Added filters for all get-all endpoints

This commit is contained in:
Nicolai Ort 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.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
@ -21,7 +22,23 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumCategory>>> GetCategory() public async Task<ActionResult<IEnumerable<ScrumCategory>>> GetCategory()
{ {
return await _context.Categories.ToListAsync(); IEnumerable<ScrumCategory> filtered = _context.Categories;
if (HttpContext.Request.Query["title"].ToString() != "")
{
filtered = filtered.Where<ScrumCategory>(c => c.title.Contains(HttpContext.Request.Query["title"].ToString()));
}
if (Convert.ToInt32(HttpContext.Request.Query["projectid"]) != 0)
{
filtered = filtered.Where<ScrumCategory>(c => c.projectid == Convert.ToInt32(HttpContext.Request.Query["projectid"]));
}
if (HttpContext.Request.Query["color"].ToString() != "")
{
filtered = filtered.Where<ScrumCategory>(c => c.color == HttpContext.Request.Query["color"].ToString());
}
return filtered.ToList();
} }
// GET: api/category/1 // GET: api/category/1

View File

@ -1,4 +1,5 @@
using System.Collections.Generic; using System;
using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
@ -21,7 +22,17 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumProject>>> GetProject() public async Task<ActionResult<IEnumerable<ScrumProject>>> GetProject()
{ {
return await _context.Projects.ToListAsync(); IEnumerable<ScrumProject> filtered = _context.Projects;
if (HttpContext.Request.Query["title"].ToString() != "")
{
filtered = filtered.Where<ScrumProject>(t => t.title.Contains(HttpContext.Request.Query["title"].ToString()));
}
if (HttpContext.Request.Query["isprivate"].ToString() != "")
{
filtered = filtered.Where<ScrumProject>(t => t.isprivate == Convert.ToBoolean(HttpContext.Request.Query["isprivate"]));
}
return filtered.ToList();
} }
// GET: api/projects/5 // GET: api/projects/5

View File

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

View File

@ -21,7 +21,13 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumStatus>>> GetStatus() public async Task<ActionResult<IEnumerable<ScrumStatus>>> GetStatus()
{ {
return await _context.Status.ToListAsync(); IEnumerable<ScrumStatus> filtered = _context.Status;
if (HttpContext.Request.Query["title"].ToString() != "")
{
filtered = filtered.Where<ScrumStatus>(s => s.title.Contains(HttpContext.Request.Query["title"].ToString()));
}
return filtered.ToList();
} }
// GET: api/status/1 // GET: api/status/1

View File

@ -1,4 +1,5 @@
using System.Collections.Generic; using System;
using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
@ -21,7 +22,40 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumTask>>> GetTasks() 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 // GET: api/tasks/5

View File

@ -21,7 +21,13 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumUser>>> GetUser() public async Task<ActionResult<IEnumerable<ScrumUser>>> GetUser()
{ {
return await _context.Users.ToListAsync(); IEnumerable<ScrumUser> filtered = _context.Users;
if (HttpContext.Request.Query["name"].ToString() != "")
{
filtered = filtered.Where<ScrumUser>(u => u.name.Contains(HttpContext.Request.Query["name"].ToString()));
}
return filtered.ToList();
} }
// GET: api/sprint/5 // GET: api/sprint/5

View File

@ -1,4 +1,5 @@
using System.Collections.Generic; using System;
using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Threading.Tasks; using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
@ -21,7 +22,40 @@ namespace ScrumTaskboard.Controllers
[HttpGet] [HttpGet]
public async Task<ActionResult<IEnumerable<ScrumUserstory>>> GetUserstory() 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 // GET: api/userstories/1