Added filters for all get-all endpoints

This commit is contained in:
2020-06-18 15:10:42 +02:00
parent 48d5622c0f
commit 8a26b957aa
7 changed files with 219 additions and 92 deletions

View File

@@ -1,4 +1,5 @@
using System.Collections.Generic;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
@@ -21,92 +22,110 @@ namespace ScrumTaskboard.Controllers
[HttpGet]
public async Task<ActionResult<IEnumerable<ScrumSprint>>> GetSprint()
{
return await _context.Sprints.ToListAsync();
}
// GET: api/sprint/5
[HttpGet("{id}")]
public async Task<ActionResult<ScrumSprint>> GetSprint(int id)
{
var Sprint = await _context.Sprints.FindAsync(id);
if (Sprint == null)
IEnumerable<ScrumSprint> filtered = _context.Sprints;
if (HttpContext.Request.Query["title"].ToString() != "")
{
return NotFound();
filtered = filtered.Where<ScrumSprint>(s => s.title.Contains(HttpContext.Request.Query["title"].ToString()));
}
if (Convert.ToInt32(HttpContext.Request.Query["projectid"]) != 0)
{
filtered = filtered.Where<ScrumSprint>(s => s.projectid == Convert.ToInt32(HttpContext.Request.Query["projectid"]));
}
if (HttpContext.Request.Query["startDate"].ToString() != "")
{
filtered = filtered.Where<ScrumSprint>(s => s.startDate == DateTime.Parse(HttpContext.Request.Query["startDate"].ToString()));
}
if (HttpContext.Request.Query["endDate"].ToString() != "")
{
filtered = filtered.Where<ScrumSprint>(s => s.endDate == DateTime.Parse(HttpContext.Request.Query["startDate"].ToString()));
}
return Sprint;
}
// PUT: api/sprint/5
[HttpPut("{id}")]
public async Task<IActionResult> PutSprint(int id, ScrumSprint sprint)
{
// Die ID des Sprints darf nicht geändert werden
if (id != sprint.id)
{
return BadRequest();
}
// Speichere den geänderten Sprint im Context
_context.Entry(sprint).State = EntityState.Modified;
try
{
// Übernehme die Änderungen in die Datenbank
await _context.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
// Wenn der Sprint nicht existiert, gib Statuscode 404 zurück
if (!SprintExists(id))
{
return NotFound();
}
else
{
throw;
}
}
return NoContent();
}
// POST: api/Sprint
[HttpPost]
public async Task<ActionResult<ScrumSprint>> PostSprint(ScrumSprint sprint)
{
_context.Sprints.Add(sprint);
await _context.SaveChangesAsync();
// Der neue Sprint wurde erstellt und kann über die GetSprint Methode abgerufen werden.
return CreatedAtAction("GetSprint", new { id = sprint.id }, sprint);
}
// DELETE: api/Sprint/5
[HttpDelete("{id}")]
public async Task<ActionResult<ScrumSprint>> DeleteSprint(int id)
{
var scrumSprint = await _context.Sprints.FindAsync(id);
if (scrumSprint == null)
{
return NotFound();
}
// Entferne den Sprint aus dem Context
_context.Sprints.Remove(scrumSprint);
// Speichere die Änderungen in der Datenbank
await _context.SaveChangesAsync();
return scrumSprint;
}
return filtered.ToList();
}
// GET: api/sprint/5
[HttpGet("{id}")]
public async Task<ActionResult<ScrumSprint>> GetSprint(int id)
{
var Sprint = await _context.Sprints.FindAsync(id);
if (Sprint == null)
{
return NotFound();
}
return Sprint;
}
// PUT: api/sprint/5
[HttpPut("{id}")]
public async Task<IActionResult> PutSprint(int id, ScrumSprint sprint)
{
// Die ID des Sprints darf nicht geändert werden
if (id != sprint.id)
{
return BadRequest();
}
// Speichere den geänderten Sprint im Context
_context.Entry(sprint).State = EntityState.Modified;
try
{
// Übernehme die Änderungen in die Datenbank
await _context.SaveChangesAsync();
}
catch (DbUpdateConcurrencyException)
{
// Wenn der Sprint nicht existiert, gib Statuscode 404 zurück
if (!SprintExists(id))
{
return NotFound();
}
else
{
throw;
}
}
return NoContent();
}
// POST: api/Sprint
[HttpPost]
public async Task<ActionResult<ScrumSprint>> PostSprint(ScrumSprint sprint)
{
_context.Sprints.Add(sprint);
await _context.SaveChangesAsync();
// Der neue Sprint wurde erstellt und kann über die GetSprint Methode abgerufen werden.
return CreatedAtAction("GetSprint", new { id = sprint.id }, sprint);
}
// DELETE: api/Sprint/5
[HttpDelete("{id}")]
public async Task<ActionResult<ScrumSprint>> DeleteSprint(int id)
{
var scrumSprint = await _context.Sprints.FindAsync(id);
if (scrumSprint == null)
{
return NotFound();
}
// Entferne den Sprint aus dem Context
_context.Sprints.Remove(scrumSprint);
// Speichere die Änderungen in der Datenbank
await _context.SaveChangesAsync();
return scrumSprint;
}
/// <summary>
/// Prüft, ob ein Sprint mit der angegebenen ID bereits existiert.
/// </summary>
private bool SprintExists(int id)
{
return _context.Sprints.Any(e => e.id == id);
}
private bool SprintExists(int id)
{
return _context.Sprints.Any(e => e.id == id);
}
}
}