using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; namespace ScrumTaskboard.Controllers { [Route("[controller]")] [ApiController] public class CategoriesController : ControllerBase { private readonly TaskContext _context; public CategoriesController(TaskContext context) { _context = context; } // GET: api/category [HttpGet] public async Task>> GetCategory([FromQuery]string? title, [FromQuery]int? projectid, [FromQuery] string? color) { var filtered = _context.Categories.AsQueryable(); if (title != null) { filtered = filtered.Where(c => c.title.Contains(title)); } if (projectid != null) { filtered = filtered.Where(c => c.projectid == projectid); } if (color != null) { filtered = filtered.Where(c => c.color == color); } return await filtered.ToListAsync(); } // GET: api/category/1 [HttpGet("{id}")] public async Task> GetCategory(int id) { var category = await _context.Categories.FindAsync(id); if (category == null) { return NotFound(); } return category; } // PUT: api/category/1 [HttpPut("{id}")] public async Task PutCategory(int id, ScrumCategory category) { // Die ID der Kategorie darf nicht geändert werden if (id != category.id) { return BadRequest(); } // Speichere die geänderten Kategorie im Context _context.Entry(category).State = EntityState.Modified; try { // Übernehme die Änderungen in die Datenbank await _context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { // Wenn die Kategorie nicht existiert, gib Statuscode 404 zurück if (!CategoryExists(id)) { return NotFound(); } else { throw; } } return NoContent(); } // POST: api/category [HttpPost] public async Task> PostCategory(ScrumCategory category) { _context.Categories.Add(category); await _context.SaveChangesAsync(); // Die neue Userstory wurde erstellt und kann über die GetUserstory Methode abgerufen werden. return CreatedAtAction("GetCategory", new { id = category.id }, category); } // DELETE: api/category/1 [HttpDelete("{id}")] public async Task> DeleteCategory(int id) { var category = await _context.Categories.FindAsync(id); if (category == null) { return NotFound(); } // Entferne die Kateorie aus dem Context _context.Categories.Remove(category); // Speichere die Änderungen in der Datenbank await _context.SaveChangesAsync(); return category; } /// /// Prüft, ob eine Kategorie mit der angegebenen ID bereits existiert. /// private bool CategoryExists(int id) { return _context.Categories.Any(e => e.id == id); } } }