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,7 +22,40 @@ namespace ScrumTaskboard.Controllers
[HttpGet]
public async Task<ActionResult<IEnumerable<ScrumUserstory>>> GetUserstory()
{
return await _context.Userstories.ToListAsync();
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