public async Task UpdateCloudProviderService(Guid organizationId, Guid organizationCPSId, OrganizationCPSPutRp resource) { string loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return; } PipelineRole role = user.GetRoleInOrganization(organizationId); if (role != PipelineRole.OrganizationAdmin) { await _domainManagerService.AddForbidden($"You are not authorized to update settings in this organization."); return; } OrganizationCPS organizationCPS = organization.GetCloudProviderServiceById(organizationCPSId); if (organizationCPS == null) { await _domainManagerService.AddConflict($"The cloud provider service with id {organizationCPSId} does not exists."); return; } bool validCredentials = await _cpsCredentialService(resource.Type).ValidateCredentials(resource.AccessId, resource.AccessName, resource.AccessSecret, resource.AccessAppId, resource.AccessAppSecret, resource.AccessDirectory, resource.AccessRegion); if (!validCredentials) { await _domainManagerService.AddConflict($"The credentials are not valid or there are some permissions problems"); return; } user.UpdateCloudProviderService(organizationId, organizationCPSId, _dataProtectorService.Protect(resource.AccessId), _dataProtectorService.Protect(resource.AccessName), _dataProtectorService.Protect(resource.AccessSecret), _dataProtectorService.Protect(resource.AccessAppId), _dataProtectorService.Protect(resource.AccessAppSecret), _dataProtectorService.Protect(resource.AccessDirectory), _dataProtectorService.Protect(resource.AccessRegion)); _userRepository.Update(user); await _userRepository.SaveChanges(); }
public async Task DeleteCloudProviderService(Guid organizationId, Guid organizationCPSId) { string loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return; } PipelineRole role = user.GetRoleInOrganization(organizationId); if (role != PipelineRole.OrganizationAdmin) { await _domainManagerService.AddForbidden($"You are not authorized to delete settings in this organization."); return; } OrganizationCPS organizationCPS = organization.GetCloudProviderServiceById(organizationCPSId); if (organizationCPS == null) { await _domainManagerService.AddConflict($"The cloud provider service with id {organizationCPSId} does not exists."); return; } List <Project> relatedProjects = organization.GetProjectsByCPSId(organizationCPSId); if (relatedProjects.Any()) { await _domainManagerService.AddConflict($"There are projects already configured with the cloud provider service {organizationCPS.Name}."); return; } user.DeleteCloudProviderService(organizationId, organizationCPSId); _userRepository.Update(user); await _userRepository.SaveChanges(); }
public async Task <OrganizationCPSGetRp> GetOrganizationCloudProviderServiceById(Guid organizationId, Guid organizationCPSId) { var loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return(null); } OrganizationCPS cloudProvider = organization.GetCloudProviderServiceById(organizationCPSId); if (cloudProvider == null) { return(null); } PipelineRole role = user.GetRoleInOrganization(organizationId); OrganizationCPSGetRp organizationCPSRp = new OrganizationCPSGetRp() { OrganizationCPSId = cloudProvider.OrganizationCPSId, Name = cloudProvider.Name, Type = cloudProvider.Type, AccessId = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessId) : DomainConstants.Obfuscator.Default, AccessName = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessName) : DomainConstants.Obfuscator.Default, AccessSecret = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessSecret) : DomainConstants.Obfuscator.Default, AccessRegion = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessRegion) : DomainConstants.Obfuscator.Default, AccessAppId = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessAppId) : DomainConstants.Obfuscator.Default, AccessAppSecret = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessAppSecret) : DomainConstants.Obfuscator.Default, AccessDirectory = role == PipelineRole.OrganizationAdmin ? _dataProtectorService.Unprotect(cloudProvider.AccessDirectory) : DomainConstants.Obfuscator.Default }; return(organizationCPSRp); }
public async Task CreateCloudProviderService(Guid organizationId, OrganizationCPSPostRp resource) { string loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return; } PipelineRole role = user.GetRoleInOrganization(organizationId); if (role != PipelineRole.OrganizationAdmin) { await _domainManagerService.AddForbidden($"You are not authorized to create settings in this organization."); return; } //OrganizationCPS organizationCPS = organization.GetCloudProviderServiceByType(resource.Type); //if (organizationCPS != null) //{ // await _domainManagerService.AddConflict($"The cloud provider service with type {resource.Type} already exists."); // return; //} OrganizationCPS existingCSP = organization.GetCloudProviderServiceByName(resource.Name); if (existingCSP != null) { await _domainManagerService.AddConflict($"The cloud provider service {resource.Name} has already been taken."); return; } bool validCredentials = await _cpsCredentialService(resource.Type).ValidateCredentials(resource.AccessId, resource.AccessName, resource.AccessSecret, resource.AccessAppId, resource.AccessAppSecret, resource.AccessDirectory, resource.AccessRegion); if (!validCredentials) { if (resource.Type == CloudProviderService.AWS) { await _domainManagerService.AddConflict($"The credentials are not valid"); } else { await _domainManagerService.AddConflict($"The credentials are not valid or the client does not have enough privileges"); } return; } user.AddCloudProviderService(organizationId, resource.Name, resource.Type, _dataProtectorService.Protect(resource.AccessId), _dataProtectorService.Protect(resource.AccessName), _dataProtectorService.Protect(resource.AccessSecret), _dataProtectorService.Protect(resource.AccessAppId), _dataProtectorService.Protect(resource.AccessAppSecret), _dataProtectorService.Protect(resource.AccessDirectory), _dataProtectorService.Protect(resource.AccessRegion)); _userRepository.Update(user); await _userRepository.SaveChanges(); }
public async Task CreateProject(Guid organizationId, ProjectPostRp resource) { string loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return; } OrganizationCMS organizationCMS = organization.GetConfigurationManagementServiceById(resource.OrganizationCMSId); if (organizationCMS == null) { await _domainManagerService.AddNotFound($"The configuration management service with id {resource.OrganizationCMSId} does not exists."); return; } if (organizationCMS.Type == ConfigurationManagementService.VSTS && resource.projectVisibility == ProjectVisibility.None) { await _domainManagerService.AddConflict($"The project visibility should be Private or Public."); return; } OrganizationCPS organizationCPS = null; if (resource.OrganizationCPSId.HasValue) { organizationCPS = organization.GetCloudProviderServiceById(resource.OrganizationCPSId.Value); if (organizationCPS == null) { await _domainManagerService.AddNotFound($"The cloud provider service with id {resource.OrganizationCPSId} does not exists."); return; } } else { organizationCPS = new OrganizationCPS { Type = CloudProviderService.None }; } ProjectTemplate projectTemplate = null; if (resource.ProjectTemplateId.HasValue) { projectTemplate = await _projectTemplateRepository.GetProjectTemplateById(resource.ProjectTemplateId.Value); if (projectTemplate == null) { await _domainManagerService.AddNotFound($"The project template with id {resource.ProjectTemplateId.Value} does not exists."); return; } } Project existingProject = organization.GetProjectByName(resource.Name); if (existingProject != null) { await _domainManagerService.AddConflict($"The project name {resource.Name} has already been taken."); return; } //Auth CMSAuthCredentialModel cmsAuthCredential = this._cmsCredentialService(organizationCMS.Type).GetToken( _dataProtectorService.Unprotect(organizationCMS.AccountId), _dataProtectorService.Unprotect(organizationCMS.AccountName), _dataProtectorService.Unprotect(organizationCMS.AccessSecret), _dataProtectorService.Unprotect(organizationCMS.AccessToken)); CMSProjectAvailabilityResultModel cmsProjectAvailability = await _cmsService(organizationCMS.Type).ValidateProjectAvailability(cmsAuthCredential, resource.TeamId, resource.Name); if (!cmsProjectAvailability.Success) { await _domainManagerService.AddConflict($"The CMS data is not valid. {cmsProjectAvailability.GetReasonForNoSuccess()}"); return; } Project newProject = user.CreateProject(organizationId, resource.TeamId, resource.Name, resource.Description, resource.ProjectType, resource.OrganizationCMSId, resource.OrganizationCPSId, resource.ProjectTemplateId, resource.AgentPoolId, resource.projectVisibility, organizationCPS.Type, organizationCMS.Type); //SaveChanges in CSM CMSProjectCreateModel projectCreateModel = CMSProjectCreateModel.Factory.Create(organization.Name, resource.Name, resource.Description, resource.projectVisibility); projectCreateModel.TeamId = resource.TeamId; CMSProjectCreateResultModel cmsProjectCreate = await _cmsService(organizationCMS.Type).CreateProject(cmsAuthCredential, projectCreateModel); if (!cmsProjectCreate.Success) { await _domainManagerService.AddConflict($"The CMS data is not valid. {cmsProjectCreate.GetReasonForNoSuccess()}"); return; } newProject.UpdateExternalInformation(cmsProjectCreate.ProjectExternalId, resource.Name); _userRepository.Update(user); await _userRepository.SaveChanges(); await _domainManagerService.AddResult("ProjectId", newProject.ProjectId); //send event var @event = new ProjectCreatedEvent(_correlationId) { OrganizationId = organization.OrganizationId, ProjectId = newProject.ProjectId, ProjectName = newProject.Name, InternalProjectName = newProject.InternalName, ProjectVSTSFake = this._slugService.GetSlug($"{organization.Owner.Email} {organization.Name} {newProject.Name}"), AgentPoolId = newProject.AgentPoolId, CMSType = organizationCMS.Type, CMSAccountId = _dataProtectorService.Unprotect(organizationCMS.AccountId), CMSAccountName = _dataProtectorService.Unprotect(organizationCMS.AccountName), CMSAccessId = _dataProtectorService.Unprotect(organizationCMS.AccessId), CMSAccessSecret = _dataProtectorService.Unprotect(organizationCMS.AccessSecret), CMSAccessToken = _dataProtectorService.Unprotect(organizationCMS.AccessToken), CPSType = organizationCPS.Type, CPSAccessId = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessId) : string.Empty, CPSAccessName = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessName) : string.Empty, CPSAccessSecret = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessSecret) : string.Empty, CPSAccessAppId = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessAppId) : string.Empty, CPSAccessAppSecret = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessAppSecret) : string.Empty, CPSAccessDirectory = organizationCPS.Type != CloudProviderService.None ? _dataProtectorService.Unprotect(organizationCPS.AccessDirectory) : string.Empty, UserId = loggedUserId }; if (resource.ProjectTemplateId.HasValue) { @event.ProjectTemplate = new ProjectTemplateCreatedEvent(); @event.ProjectTemplate.Services = projectTemplate.Services.Select(x => new ProjectTemplateServiceCreatedEvent() { Name = x.Name, ProjectServiceTemplateId = x.ProjectServiceTemplateId }).ToList(); } await _eventBusService.Publish(queueName : "ProjectCreatedEvent", @event : @event); }
public async Task ImportProject(Guid organizationId, ProjectImportPostRp resource) { string loggedUserId = _identityService.GetUserId(); User user = await _userRepository.GetUser(loggedUserId); Organization organization = user.FindOrganizationById(organizationId); if (organization == null) { await _domainManagerService.AddNotFound($"The organzation with id {organizationId} does not exists."); return; } OrganizationCMS organizationCMS = organization.GetConfigurationManagementServiceById(resource.OrganizationCMSId); if (organizationCMS == null) { await _domainManagerService.AddNotFound($"The configuration management service with id {resource.OrganizationCMSId} does not exists."); return; } if (organizationCMS.Type == ConfigurationManagementService.VSTS && resource.projectVisibility == ProjectVisibility.None) { await _domainManagerService.AddConflict($"The project visibility should be Private or Public."); return; } OrganizationCPS organizationCPS = null; if (resource.OrganizationCPSId.HasValue) { organizationCPS = organization.GetCloudProviderServiceById(resource.OrganizationCPSId.Value); if (organizationCPS == null) { await _domainManagerService.AddNotFound($"The cloud provider service with id {resource.OrganizationCPSId} does not exists."); return; } } else { organizationCPS = new OrganizationCPS { Type = CloudProviderService.None }; } Project existingProject = organization.GetProjectByName(resource.Name); if (existingProject != null) { await _domainManagerService.AddConflict($"The project name {resource.Name} has already been taken."); return; } //Auth CMSAuthCredentialModel cmsAuthCredential = this._cmsCredentialService(organizationCMS.Type).GetToken( _dataProtectorService.Unprotect(organizationCMS.AccountId), _dataProtectorService.Unprotect(organizationCMS.AccountName), _dataProtectorService.Unprotect(organizationCMS.AccessSecret), _dataProtectorService.Unprotect(organizationCMS.AccessToken)); Project newProject = user.ImportProject(organizationId, string.Empty, resource.Name, resource.Description, resource.ProjectType, resource.OrganizationCMSId, resource.OrganizationCPSId, null, resource.AgentPoolId, resource.projectVisibility, organizationCPS.Type, organizationCMS.Type); //SaveChanges in CSM CMSProjectCreateModel projectCreateModel = CMSProjectCreateModel.Factory.Create(organization.Name, resource.Name, resource.Description, resource.projectVisibility); newProject.UpdateExternalInformation(resource.ProjectExternalId, resource.ProjectExternalName); _userRepository.Update(user); await _userRepository.SaveChanges(); await _domainManagerService.AddResult("ProjectId", newProject.ProjectId); //send event var @event = new ProjectImportedEvent(_correlationId) { OrganizationId = organization.OrganizationId, OrganizationCMSId = resource.OrganizationCMSId, ProjectId = newProject.ProjectId, ProjectName = resource.Name, InternalProjectName = newProject.InternalName, ProjectExternalId = resource.ProjectExternalId, ProjectExternalName = resource.ProjectExternalName, BuildDefinitionYML = resource.BuildDefinitionYML, ProjectServiceTemplateId = resource.ProjectServiceTemplateId, ProjectVSTSFake = this._slugService.GetSlug($"{organization.Owner.Email} {organization.Name} {newProject.Name}"), AgentPoolId = newProject.AgentPoolId, CMSType = organizationCMS.Type, CMSAccountId = _dataProtectorService.Unprotect(organizationCMS.AccountId), CMSAccountName = _dataProtectorService.Unprotect(organizationCMS.AccountName), CMSAccessId = _dataProtectorService.Unprotect(organizationCMS.AccessId), CMSAccessSecret = _dataProtectorService.Unprotect(organizationCMS.AccessSecret), CMSAccessToken = _dataProtectorService.Unprotect(organizationCMS.AccessToken), CPSType = organizationCPS.Type, CPSAccessId = _dataProtectorService.Unprotect(organizationCPS.AccessId), CPSAccessName = _dataProtectorService.Unprotect(organizationCPS.AccessName), CPSAccessSecret = _dataProtectorService.Unprotect(organizationCPS.AccessSecret), CPSAccessAppId = _dataProtectorService.Unprotect(organizationCPS.AccessAppId), CPSAccessAppSecret = _dataProtectorService.Unprotect(organizationCPS.AccessAppSecret), CPSAccessDirectory = _dataProtectorService.Unprotect(organizationCPS.AccessDirectory), UserId = loggedUserId, ProjectRepository = new ProjectRepositoryCreatedEvent { Repositories = resource.Repositories.Select(c => new ProjectRepositoryServiceCreatedEvent { Id = c.Id, Name = c.Name, Link = c.Link, BranchName = c.BranchName, ExternalName = c.ExternalName }).ToList(), } }; await _eventBusService.Publish(queueName : "ProjectImportedEvent", @event : @event); }