Skip to content
Snippets Groups Projects
Select Git revision
  • 6a3dd5c786dba40418861aab4831702c4d69d5b1
  • 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

SubProjectController.cs

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    SubProjectController.cs 3.88 KiB
    using Coscine.Api.Project.Models;
    using Coscine.ApiCommons;
    using Microsoft.AspNetCore.Authorization;
    using Microsoft.AspNetCore.Mvc;
    using Newtonsoft.Json.Linq;
    using System;
    using System.Linq;
    
    namespace Coscine.Api.Project.Controllers
    {
        [Authorize]
        public class SubProjectController : Controller
        {
            private readonly Authenticator _authenticator;
            private readonly SubProjectModel _subProjectModel;
    
            public SubProjectController()
            {
                _authenticator = new Authenticator(this, Program.Configuration);
                _subProjectModel = new SubProjectModel();
            }
    
            [HttpGet("[controller]/{parentId}")]
            public IActionResult Get(string parentId)
            {
                var parentGuid = new Guid(parentId);
                var projectModel = new ProjectModel();
                var projectRoleModel = new ProjectRoleModel();
                var user = _authenticator.GetUser();
                string[] allowedRoles = { UserRoles.Owner, UserRoles.Member };
                allowedRoles = allowedRoles.Select(x => x.ToLower().Trim()).ToArray();
                if (projectModel.HasAccess(user, projectModel.GetById(parentGuid), allowedRoles))
                {
                    var subProjects = _subProjectModel.GetAllWhere((subProjectM) => (subProjectM.ProjectId == parentGuid 
                                                                                     // select only subprojects to which the user has access
                                                                                     && (from projectRole in subProjectM.SubProject_FK.ProjectRolesProjectIdIds
                                                                                         where projectRole.User.Id == user.Id 
                                                                                         && allowedRoles.Contains(projectRole.Role.DisplayName.ToLower())
                                                                                         select projectRole).Any())
                                                                                     )
                                                        .Select((subProject) => projectModel.GetById(subProject.SubProjectId))
                                                        .Select((project) => projectModel.CreateReturnObjectFromDatabaseObject(project, parentGuid))
                                                        .OrderBy(element => element.DisplayName);
                    return Json(subProjects);
                }
                else
                {
                    return Unauthorized("User is not allowed to create a subproject for the given project id!");
                }
            }
    
            [HttpGet("[controller]/{childId}/accessibleParent")]
            public IActionResult GetAccessibleParent(string childId)
            {
                var childGuid = new Guid(childId);
                var projectModel = new ProjectModel();
                var projectRoleModel = new ProjectRoleModel();
                var user = _authenticator.GetUser();
                string[] allowedRoles = { UserRoles.Owner, UserRoles.Member };
                allowedRoles = allowedRoles.Select(x => x.ToLower().Trim()).ToArray();
                if (projectModel.HasAccess(user, projectModel.GetById(childGuid), allowedRoles))
                {
                    var subProjects = _subProjectModel.GetAllWhere((subProjectM) => (subProjectM.SubProjectId == childGuid)).ToArray();
                    var json = new JObject();
                    json["id"] = "00000000-0000-0000-0000-000000000000";
                    if (subProjects.Count() == 1 && projectModel.HasAccess(user, projectModel.GetById(subProjects[0].ProjectId), allowedRoles))
                    {
                        json["id"] = subProjects[0].ProjectId;
                    }
                    return Json(json);