Select Git revision
-
Marco Berzborn authoredMarco Berzborn authored
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
ProjectController.cs 4.12 KiB
using Coscine.Api.Project.Exceptions;
using Coscine.Api.Project.Factories;
using Coscine.Api.Project.Models;
using Coscine.Api.Project.ReturnObjects;
using Microsoft.AspNetCore.Mvc;
using System;
using System.Linq;
namespace Coscine.Api.Project.Controllers
{
public class ProjectController : Controller
{
private readonly Authenticator _authenticator;
public ProjectController()
{
_authenticator = new Authenticator(this);
}
[Route("[controller]")]
public IActionResult Index()
{
return Ok(_authenticator.ValidateAndExecute((user) =>
{
ProjectModel projectModel = new ProjectModel();
return projectModel.GetAllWhere((project) =>
{
return (from projectRole in project.ProjectRolesProjectIdIds
where projectRole.User == user
&& projectRole.Role.DisplayName == "Owner"
select projectRole).Any();
}).Select((project) =>
{
return new ProjectObject(project.Id, project.Description, project.DisplayName, project.Organization);
});
}));
}
//[Route("[controller]/greet/{username}")] would also work, but would take all commands
[HttpGet("[controller]/{id}")]
public IActionResult Get(string id)
{
return Ok(_authenticator.ValidateAndExecute((user) =>
{
ProjectModel projectModel = new ProjectModel();
var project = projectModel.GetById(Guid.Parse(id));
return new ProjectObject(project.Id, project.Description, project.DisplayName, project.Organization);
}));
}
//[Route("[controller]/greet/{username}")] would also work, but would take all commands
[HttpPost("[controller]/{id}")]
public IActionResult Update(string id)
{
return Ok(_authenticator.ValidateAndExecute((user) =>
{
ProjectObject projectObject = ObjectFactory<ProjectObject>.DeserializeFromStream(Request.Body);
ProjectModel projectModel = new ProjectModel();
var project = projectModel.GetById(Guid.Parse(id));
if(projectModel.OwnsProject(user, project))
{
return projectModel.Update(project);
}
else
{
throw new NotAuthorizedException("The user is not authorized to perform an update on the selected project!");
}
}));
}
[HttpPost("[controller]")]
public IActionResult Store()
{
return Ok(_authenticator.ValidateAndExecute((user) =>
{
ProjectObject projectObject = ObjectFactory<ProjectObject>.DeserializeFromStream(Request.Body);
ProjectModel projectModel = new ProjectModel();
var project = projectModel.StoreFromObject(projectObject, user);
return new ProjectObject(project.Id, project.Description, project.DisplayName, project.Organization);
}));
}
[HttpPost("[controller]/{id}/resource/{resource_id}")]
public IActionResult AddResource(string id, string resource_id)
{
return Ok(_authenticator.ValidateAndExecute((user) =>
{
ProjectModel projectModel = new ProjectModel();
var project = projectModel.GetById(Guid.Parse(id));
ResourceModel resourceModel = new ResourceModel();
var resource = resourceModel.GetById(Guid.Parse(resource_id));
if (projectModel.OwnsProject(user, project) && resourceModel.OwnsResource(user, resource))
{
projectModel.AddResource(project, resource);
return true;
}
else
{
throw new NotAuthorizedException("User is not authorized to add resource to project!");
}
}));
}
}
}