srumboard_backend/ScrumTaskboard/Controllers/UserstoriesController.cs

146 lines
5.2 KiB
C#

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 UserstoriesController : ControllerBase
{
private readonly TaskContext _context;
public UserstoriesController(TaskContext context)
{
_context = context;
}
// GET: api/userstories
[HttpGet]
public async Task<ActionResult<IEnumerable<ScrumUserstory>>> GetUserstory()
{
IEnumerable<ScrumUserstory> filtered = _context.Userstories;
if (HttpContext.Request.Query["title"].ToString() != "")
{
filtered = filtered.Where<ScrumUserstory>(t => t.title.Contains(HttpContext.Request.Query["title"].ToString()));
}
if (Convert.ToInt32(HttpContext.Request.Query["statusid"]) != 0)
{
filtered = filtered.Where<ScrumUserstory>(t => t.statusid == Convert.ToInt32(HttpContext.Request.Query["statusid"]));
}
if (Convert.ToInt32(HttpContext.Request.Query["categoryid"]) != 0)
{
filtered = filtered.Where<ScrumUserstory>(t => t.categoryid == Convert.ToInt32(HttpContext.Request.Query["categoryid"]));
}
if (Convert.ToInt32(HttpContext.Request.Query["createdby"]) != 0)
{
filtered = filtered.Where<ScrumUserstory>(t => t.createdbyid == Convert.ToInt32(HttpContext.Request.Query["createdby"]));
}
if (Convert.ToInt32(HttpContext.Request.Query["projectid"]) != 0)
{
filtered = filtered.Where<ScrumUserstory>(t => t.projectid == Convert.ToInt32(HttpContext.Request.Query["projectid"]));
}
if (Convert.ToInt32(HttpContext.Request.Query["sprintid"]) != 0)
{
filtered = filtered.Where<ScrumUserstory>(t => t.sprintid == Convert.ToInt32(HttpContext.Request.Query["sprintid"]));
}
if (HttpContext.Request.Query["priority"].ToString() != "")
{
ScrumPrio priority;
Enum.TryParse<ScrumPrio>(HttpContext.Request.Query["priority"].ToString(), out priority);
filtered = filtered.Where<ScrumUserstory>(t => t.priority == priority);
}
return filtered.ToList();
}
// GET: api/userstories/1
[HttpGet("{id}")]
public async Task<ActionResult<ScrumUserstory>> GetUserstory(int id)
{
var userstory = await _context.Userstories.FindAsync(id);
if (userstory == null)
{
return NotFound();
}
return userstory;
}
// PUT: api/userstories/1
[HttpPut("{id}")]
public async Task<IActionResult> PutUserstory(int id, ScrumUserstory userstory)
{
// Die ID der Userstory darf nicht geändert werden
if (id != userstory.id)
{
return BadRequest();
}
// Speichere die geänderten Userstory im Context
_context.Entry(userstory).State = EntityState.Modified;
try
{
// Übernehme die Änderungen in die Datenbank
await _context.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
// Wenn die Userstory nicht existiert, gib Statuscode 404 zurück
if (!UserstoryExists(id))
{
return NotFound();
}
else
{
throw;
}
}
return NoContent();
}
// POST: api/userstories
[HttpPost]
public async Task<ActionResult<ScrumUserstory>> PostTask(ScrumUserstory userstory)
{
_context.Userstories.Add(userstory);
await _context.SaveChangesAsync();
// Die neue Userstory wurde erstellt und kann über die GetUserstory Methode abgerufen werden.
return CreatedAtAction("GetUserstory", new { id = userstory.id }, userstory);
}
// DELETE: api/userstories/1
[HttpDelete("{id}")]
public async Task<ActionResult<ScrumUserstory>> DeleteUserstory(int id)
{
var userstory = await _context.Userstories.FindAsync(id);
if (userstory == null)
{
return NotFound();
}
// Entferne die Userstory aus dem Context
_context.Userstories.Remove(userstory);
// Speichere die Änderungen in der Datenbank
await _context.SaveChangesAsync();
return userstory;
}
/// <summary>
/// Prüft, ob eine Userstory mit der angegebenen ID bereits existiert.
/// </summary>
private bool UserstoryExists(int id)
{
return _context.Userstories.Any(e => e.id == id);
}
}
}