Changed the method for all the filters to stomething more standardized and .net compliant (also easier built into openapi v3)

This commit is contained in:
2020-06-18 16:38:14 +02:00
parent 00d5cea156
commit ec7f4c940c
7 changed files with 55 additions and 59 deletions

View File

@@ -20,38 +20,36 @@ namespace ScrumTaskboard.Controllers
// GET: api/userstories
[HttpGet]
public async Task<ActionResult<IEnumerable<ScrumUserstory>>> GetUserstory()
public async Task<ActionResult<IEnumerable<ScrumUserstory>>> GetUserstory([FromQuery]string? title, [FromQuery]int? statusid, [FromQuery]int? categoryid, [FromQuery]int? createdbyid, [FromQuery]int? projectid, [FromQuery]int? sprintid, [FromQuery]ScrumPrio? priority)
{
var filtered = _context.Userstories.AsQueryable();
if (HttpContext.Request.Query["title"].ToString() != "")
if (title != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.title.Contains(HttpContext.Request.Query["title"].ToString()));
filtered = filtered.Where<ScrumUserstory>(t => t.title.Contains(title));
}
if (Convert.ToInt32(HttpContext.Request.Query["statusid"]) != 0)
if (statusid != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.statusid == Convert.ToInt32(HttpContext.Request.Query["statusid"]));
filtered = filtered.Where<ScrumUserstory>(t => t.statusid == statusid);
}
if (Convert.ToInt32(HttpContext.Request.Query["categoryid"]) != 0)
if (categoryid != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.categoryid == Convert.ToInt32(HttpContext.Request.Query["categoryid"]));
filtered = filtered.Where<ScrumUserstory>(t => t.categoryid == categoryid);
}
if (Convert.ToInt32(HttpContext.Request.Query["createdby"]) != 0)
if (createdbyid != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.createdbyid == Convert.ToInt32(HttpContext.Request.Query["createdby"]));
filtered = filtered.Where<ScrumUserstory>(t => t.createdbyid == createdbyid);
}
if (Convert.ToInt32(HttpContext.Request.Query["projectid"]) != 0)
if (projectid != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.projectid == Convert.ToInt32(HttpContext.Request.Query["projectid"]));
filtered = filtered.Where<ScrumUserstory>(t => t.projectid == projectid);
}
if (Convert.ToInt32(HttpContext.Request.Query["sprintid"]) != 0)
if (sprintid != null)
{
filtered = filtered.Where<ScrumUserstory>(t => t.sprintid == Convert.ToInt32(HttpContext.Request.Query["sprintid"]));
filtered = filtered.Where<ScrumUserstory>(t => t.sprintid == sprintid);
}
if (HttpContext.Request.Query["priority"].ToString() != "")
if (priority != null)
{
ScrumPrio priority;
Enum.TryParse<ScrumPrio>(HttpContext.Request.Query["priority"].ToString(), out priority);
filtered = filtered.Where<ScrumUserstory>(t => t.priority == priority);
}