using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using TicketManager.Data; using TicketManager.Models; namespace TicketManager.Controllers { [Route("api/[controller]")] [ApiController] public class ProjectsController : ControllerBase { private readonly AppDbContext _context; public ProjectsController(AppDbContext context) { _context = context; } // GET: api/Projects [HttpGet] public async Task>> GetProjects() { return await _context.Projects .Include(p => p.Assignments) .ThenInclude(a => a.User) .Include(p => p.Tickets) .Include(p => p.Manager) .Include(p => p.Files) .AsNoTracking() .ToListAsync(); } // GET: api/Projects/5 [HttpGet("{id}")] public async Task> GetProject(int id) { var project = await _context.Projects .Include(p => p.Assignments) .Include(p => p.Tickets) .Include(p => p.Manager) .Include(p => p.Files) .AsNoTracking() .FirstOrDefaultAsync(p => p.Id == id); if (project == null) { return NotFound(); } return project; } // GET: api/Projects/5/Members [HttpGet("{id}/members")] public async Task>> GetProjectMembers(int id) { var project = await _context.Projects.FindAsync(id); if (project == null) { return NotFound(); } return project.GetMembers(); } // PUT: api/Projects/5 // To protect from overposting attacks, please enable the specific properties you want to bind to, for // more details see https://aka.ms/RazorPagesCRUD. [HttpPut("{id}")] public async Task PutProject(int id, Project project) { if (id != project.Id) { return BadRequest(); } _context.Entry(project).State = EntityState.Modified; try { await _context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { if (!ProjectExists(id)) { return NotFound(); } else { throw; } } return NoContent(); } // POST: api/Projects // To protect from overposting attacks, please enable the specific properties you want to bind to, for // more details see https://aka.ms/RazorPagesCRUD. [HttpPost] public async Task> PostProject(Project project) { _context.Projects.Add(project); await _context.SaveChangesAsync(); return CreatedAtAction("GetProject", new { id = project.Id }, project); } [HttpPost("{id}/addmembers")] public async Task> PostAssignment(int id, List usersToAdd) { var project = await _context.Projects.FindAsync(id); if (project == null) { return NotFound(); } project.AddMembers(usersToAdd); // foreach (var assignment in assignments) // { _context.Assignments.Add(assignment); } await _context.SaveChangesAsync(); // try // { // await _context.SaveChangesAsync(); // } // catch (DbUpdateException) // { // if (AssignmentExists(assignment.ProjectId)) // { // return Conflict(); // } // else // { // throw; // } // } // return CreatedAtAction("GetAssignment", new { id = assignment.ProjectId }, assignment); return project; } // DELETE: api/Projects/5 [HttpDelete("{id}")] public async Task> DeleteProject(int id) { var project = await _context.Projects.FindAsync(id); if (project == null) { return NotFound(); } _context.Projects.Remove(project); await _context.SaveChangesAsync(); return project; } private bool ProjectExists(int id) { return _context.Projects.Any(e => e.Id == id); } private bool AssignmentExists(int id) { return _context.Assignments.Any(e => e.ProjectId == id); } } }