Added filters for all get-all endpoints
This commit is contained in:
@@ -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<ScrumTask>>> GetTasks()
|
||||
{
|
||||
return await _context.Tasks.ToListAsync();
|
||||
IEnumerable<ScrumTask> filtered = _context.Tasks;
|
||||
if (HttpContext.Request.Query["title"].ToString() != "")
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.title.Contains(HttpContext.Request.Query["title"].ToString()));
|
||||
}
|
||||
if (Convert.ToInt32(HttpContext.Request.Query["userstoryid"]) != 0)
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.userstoryid == Convert.ToInt32(HttpContext.Request.Query["userstoryid"]));
|
||||
}
|
||||
if (Convert.ToInt32(HttpContext.Request.Query["statusid"]) != 0)
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.statusid == Convert.ToInt32(HttpContext.Request.Query["statusid"]));
|
||||
}
|
||||
if (Convert.ToInt32(HttpContext.Request.Query["categoryid"]) != 0)
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.categoryid == Convert.ToInt32(HttpContext.Request.Query["categoryid"]));
|
||||
}
|
||||
if (Convert.ToInt32(HttpContext.Request.Query["assignedtoid"]) != 0)
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.assignedtoid == Convert.ToInt32(HttpContext.Request.Query["assignedtoid"]));
|
||||
}
|
||||
if (Convert.ToInt32(HttpContext.Request.Query["projectid"]) != 0)
|
||||
{
|
||||
filtered = filtered.Where<ScrumTask>(t => t.projectid == Convert.ToInt32(HttpContext.Request.Query["projectid"]));
|
||||
}
|
||||
if (HttpContext.Request.Query["priority"].ToString() != "")
|
||||
{
|
||||
ScrumPrio priority;
|
||||
Enum.TryParse<ScrumPrio>(HttpContext.Request.Query["priority"].ToString(), out priority);
|
||||
filtered = filtered.Where<ScrumTask>(t => t.priority == priority);
|
||||
}
|
||||
|
||||
|
||||
return filtered.ToList();
|
||||
}
|
||||
|
||||
// GET: api/tasks/5
|
||||
|
||||
Reference in New Issue
Block a user