Skip to content
Snippets Groups Projects
Select Git revision
  • 4b5fecd5aa8a68aaf9a30dc92684ab547b67ee87
  • master default protected
  • gitkeep
  • dev protected
  • Issue/2449-GuidPidSlugToProjectSettings
  • Issue/2309-docs
  • Issue/2355-topLevelOrg
  • Issue/2328-noFailOnLog
  • Hotfix/2371-fixGitLabinRCV
  • Issue/2287-guestRole
  • Fix/xxxx-activateGitlab
  • Test/xxxx-enablingGitLab
  • Issue/2349-gitlabHttps
  • Issue/2259-updatePids
  • Issue/2101-gitLabResTypeUi
  • Hotfix/2202-fixNaNQuota
  • Issue/2246-quotaResoval
  • Issue/2221-projectDateCreated
  • Hotfix/2224-quotaSizeAnalytics
  • Fix/xxxx-resourceVisibility
  • Issue/2000-gitlabResourcesAPI
  • v4.4.3
  • v4.4.2
  • v4.4.1
  • v4.4.0
  • v4.3.4
  • v4.3.3
  • v4.3.2
  • v4.3.1
  • v4.3.0
  • v4.2.8
  • v4.2.7
  • v4.2.6
  • v4.2.5
  • v4.2.4
  • v4.2.3
  • v4.2.2
  • v4.2.1
  • v4.2.0
  • v4.1.1
  • v4.1.0
41 results

ResourceController.cs

Blame
  • L. Ellenbeck's avatar
    L. Ellenbeck authored and Marcel Nellesen committed
    4b5fecd5
    History
    Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    ResourceController.cs 4.62 KiB
    using Coscine.Api.Project.Models;
    using Coscine.Api.Project.ReturnObjects;
    using Coscine.ApiCommons;
    using Coscine.ApiCommons.Exceptions;
    using Coscine.ApiCommons.Factories;
    using Microsoft.AspNetCore.Mvc;
    using System;
    using System.Linq;
    using Newtonsoft.Json.Linq;
    
    namespace Coscine.Api.Project.Controllers
    {
        public class ResourceController : Controller
        {
            private readonly Authenticator _authenticator;
            private readonly ResourceModel _resourceModel;
    
            public ResourceController()
            {
                _authenticator = new Authenticator(this, Program.Configuration);
                _resourceModel = new ResourceModel();
            }
            
            [Route("[controller]")]
            public IActionResult Index()
            {
                return Ok(_authenticator.ValidateAndExecute((user) =>
                {
                    return _resourceModel.GetAllWhere((resource) =>                
                        (from projectResource in resource.ProjectResourceResourceIdIds
                                where (from projectRole in projectResource.Project.ProjectRolesProjectIdIds
                                       where projectRole.User == user
                                       && projectRole.Role.DisplayName == "Owner"
                                       select projectRole).Any()
                                select projectResource).Any()
                    ).Select((resource) => _resourceModel.CreateReturnObjectFromDatabaseObject(resource));
                }));
            }
    
    
            [HttpGet("[controller]/{id}")]
            public IActionResult Get(string id)
            {
                return Ok(_authenticator.ValidateAndExecute((user) =>
                {
                    var resource = _resourceModel.GetById(Guid.Parse(id));
                    if (_resourceModel.OwnsResource(user, resource))
                    {
                        _resourceModel.SetType(resource);
                        return _resourceModel.CreateReturnObjectFromDatabaseObject(resource);
                    }
                    else
                    {
                        throw new NotAuthorizedException("User does not own resource!");
                    }
                }));
            }
    
            [HttpPost("[controller]/{id}")]
            public IActionResult Update(string id)
            {
                return Ok(_authenticator.ValidateAndExecute((user) =>
                {
                    ResourceObject resourceObject = ObjectFactory<ResourceObject>.DeserializeFromStream(Request.Body);
                    var resource = _resourceModel.GetById(Guid.Parse(id));
                    if (_resourceModel.OwnsResource(user, resource))
                    {
                        return _resourceModel.UpdateByObject(resource, resourceObject);
                    }
                    else
                    {
                        throw new NotAuthorizedException("The user is not authorized to perform an update on the selected resource!");
                    }
                }));
            }
    
            [HttpDelete("[controller]/{id}")]
            public IActionResult Delete(string id)
            {
                return Ok(_authenticator.ValidateAndExecute((user) =>
                {
                    var resource = _resourceModel.GetById(Guid.Parse(id));
                    if (_resourceModel.OwnsResource(user, resource))
                    {
                        var returnObject = _resourceModel.CreateReturnObjectFromDatabaseObject(resource);
                        _resourceModel.DeleteResource(resource);
                        return returnObject;
                    }
                    else
                    {
                        throw new NotAuthorizedException("The user is not authorized to perform an update on the selected resource!");
                    }
                }));
            }
    
            [HttpPost("[controller]/project/{projectId}")]
            public IActionResult StoreToProject(string projectId)
            {
                return Ok(_authenticator.ValidateAndExecute((user) =>
                {
                    ResourceObject resourceObject = ObjectFactory<ResourceObject>.DeserializeFromStream(Request.Body);
    
                    ProjectModel projectModel = new ProjectModel();
                    var project = projectModel.GetById(Guid.Parse(projectId));
                    if (projectModel.OwnsProject(user, project))
                    {
                        var resource = _resourceModel.StoreFromObject(resourceObject);
    
                        projectModel.AddResource(project, resource);
    
                        return _resourceModel.CreateReturnObjectFromDatabaseObject(resource);
                    }
                    else
                    {
                        throw new NotAuthorizedException("The user is not authorized to add a new resource to the selected project!");
                    }                
                }));
            }
        }
    }