Skip to content
Snippets Groups Projects
Select Git revision
  • d8d0c3bd4844432e7af0b08fd49b1c97b71c8694
  • master default protected
  • gitkeep
  • dev protected
  • Issue/2583-treeBug
  • Hotfix/2504-formGen
  • Issue/2309-docs
  • Issue/2462-removeTraces
  • Hotfix/2459-EncodingPath
  • Hotfix/2452-linkedDeletion
  • Issue/1792-newMetadataStructure
  • Hotfix/2384-guestsAndLinked
  • v2.8.14-Hotfix2365
  • Hotfix/2365-targetClassWorks
  • Hotfix/2371-fixGitLabinRCV
  • Fix/xxxx-activateGitlab
  • Test/xxxx-enablingGitLab
  • Issue/2349-gitlabHttps
  • Issue/2287-guestRole
  • Hotfix/2296-selectedValuesNotReturned
  • Issue/2102-gitLabResTypeRCV
  • v2.11.5
  • v2.11.4
  • v2.11.3
  • v2.11.2
  • v2.11.1
  • v2.11.0
  • v2.10.3
  • v2.10.2
  • v2.10.1
  • v2.10.0
  • v2.9.4
  • v2.9.3
  • v2.9.2
  • v2.9.1
  • v2.9.0
  • v2.8.16
  • v2.8.15
  • v2.8.14
  • v2.8.13
  • v2.8.12
41 results

TreeController.cs

Blame
  • 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!");
                    }
                }));
            }
        }
    }