2023-10-19 01:27:56 +10:00
|
|
|
|
using Bit.Api.AdminConsole.Models.Request.Providers;
|
|
|
|
|
|
using Bit.Api.AdminConsole.Models.Response.Providers;
|
2021-12-14 15:05:07 +00:00
|
|
|
|
using Bit.Api.Models.Response;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
using Bit.Core.AdminConsole.Providers.Interfaces;
|
2023-10-27 03:38:29 +10:00
|
|
|
|
using Bit.Core.AdminConsole.Repositories;
|
|
|
|
|
|
using Bit.Core.AdminConsole.Services;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
using Bit.Core.Context;
|
|
|
|
|
|
using Bit.Core.Exceptions;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
using Bit.Core.Repositories;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
using Bit.Core.Services;
|
2021-07-08 17:05:32 +02:00
|
|
|
|
using Bit.Core.Utilities;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
using Microsoft.AspNetCore.Authorization;
|
|
|
|
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
|
|
|
2023-10-19 01:27:56 +10:00
|
|
|
|
namespace Bit.Api.AdminConsole.Controllers;
|
2022-08-29 16:06:55 -04:00
|
|
|
|
|
2021-06-30 09:35:26 +02:00
|
|
|
|
[Route("providers/{providerId:guid}/organizations")]
|
|
|
|
|
|
[Authorize("Application")]
|
|
|
|
|
|
public class ProviderOrganizationsController : Controller
|
|
|
|
|
|
{
|
2024-01-12 10:38:47 -05:00
|
|
|
|
private readonly ICurrentContext _currentContext;
|
|
|
|
|
|
private readonly IOrganizationRepository _organizationRepository;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
private readonly IProviderOrganizationRepository _providerOrganizationRepository;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
private readonly IProviderRepository _providerRepository;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
private readonly IProviderService _providerService;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
private readonly IRemoveOrganizationFromProviderCommand _removeOrganizationFromProviderCommand;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
private readonly IUserService _userService;
|
2022-08-29 16:06:55 -04:00
|
|
|
|
|
2021-06-30 09:35:26 +02:00
|
|
|
|
public ProviderOrganizationsController(
|
2024-01-12 10:38:47 -05:00
|
|
|
|
ICurrentContext currentContext,
|
|
|
|
|
|
IOrganizationRepository organizationRepository,
|
2021-06-30 09:35:26 +02:00
|
|
|
|
IProviderOrganizationRepository providerOrganizationRepository,
|
2024-01-12 10:38:47 -05:00
|
|
|
|
IProviderRepository providerRepository,
|
2021-06-30 09:35:26 +02:00
|
|
|
|
IProviderService providerService,
|
2024-01-12 10:38:47 -05:00
|
|
|
|
IRemoveOrganizationFromProviderCommand removeOrganizationFromProviderCommand,
|
|
|
|
|
|
IUserService userService)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2024-01-12 10:38:47 -05:00
|
|
|
|
_currentContext = currentContext;
|
|
|
|
|
|
_organizationRepository = organizationRepository;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
_providerOrganizationRepository = providerOrganizationRepository;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
_providerRepository = providerRepository;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
_providerService = providerService;
|
2024-01-12 10:38:47 -05:00
|
|
|
|
_removeOrganizationFromProviderCommand = removeOrganizationFromProviderCommand;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
_userService = userService;
|
2022-08-29 16:06:55 -04:00
|
|
|
|
}
|
2022-08-29 15:53:48 -04:00
|
|
|
|
|
2021-06-30 09:35:26 +02:00
|
|
|
|
[HttpGet("")]
|
|
|
|
|
|
public async Task<ListResponseModel<ProviderOrganizationOrganizationDetailsResponseModel>> Get(Guid providerId)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-06-30 09:35:26 +02:00
|
|
|
|
if (!_currentContext.AccessProviderOrganizations(providerId))
|
|
|
|
|
|
{
|
|
|
|
|
|
throw new NotFoundException();
|
|
|
|
|
|
}
|
2021-12-16 15:35:09 +01:00
|
|
|
|
|
2021-06-30 09:35:26 +02:00
|
|
|
|
var providerOrganizations = await _providerOrganizationRepository.GetManyDetailsByProviderAsync(providerId);
|
|
|
|
|
|
var responses = providerOrganizations.Select(o => new ProviderOrganizationOrganizationDetailsResponseModel(o));
|
|
|
|
|
|
return new ListResponseModel<ProviderOrganizationOrganizationDetailsResponseModel>(responses);
|
2022-08-29 15:53:48 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-06-30 09:35:26 +02:00
|
|
|
|
[HttpPost("add")]
|
|
|
|
|
|
public async Task Add(Guid providerId, [FromBody] ProviderOrganizationAddRequestModel model)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-06-30 09:35:26 +02:00
|
|
|
|
if (!_currentContext.ManageProviderOrganizations(providerId))
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-06-30 09:35:26 +02:00
|
|
|
|
throw new NotFoundException();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-04-14 11:13:16 +01:00
|
|
|
|
await _providerService.AddOrganization(providerId, model.OrganizationId, model.Key);
|
2022-08-29 16:06:55 -04:00
|
|
|
|
}
|
2021-06-30 09:35:26 +02:00
|
|
|
|
|
2021-07-08 17:05:32 +02:00
|
|
|
|
[HttpPost("")]
|
2021-06-30 09:35:26 +02:00
|
|
|
|
[SelfHosted(NotSelfHostedOnly = true)]
|
|
|
|
|
|
public async Task<ProviderOrganizationResponseModel> Post(Guid providerId, [FromBody] ProviderOrganizationCreateRequestModel model)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-06-30 09:35:26 +02:00
|
|
|
|
var user = await _userService.GetUserByPrincipalAsync(User);
|
2021-07-08 17:05:32 +02:00
|
|
|
|
if (user == null)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-06-30 09:35:26 +02:00
|
|
|
|
throw new UnauthorizedAccessException();
|
|
|
|
|
|
}
|
2021-07-08 17:05:32 +02:00
|
|
|
|
|
2021-07-30 08:10:58 -05:00
|
|
|
|
if (!_currentContext.ManageProviderOrganizations(providerId))
|
2021-07-08 17:05:32 +02:00
|
|
|
|
{
|
2021-07-15 16:37:27 +02:00
|
|
|
|
throw new NotFoundException();
|
|
|
|
|
|
}
|
2022-08-29 14:53:16 -04:00
|
|
|
|
|
2021-08-05 08:50:41 -04:00
|
|
|
|
var organizationSignup = model.OrganizationCreateRequest.ToOrganizationSignup(user);
|
2024-09-11 09:04:15 -04:00
|
|
|
|
organizationSignup.IsFromProvider = true;
|
2021-06-30 09:35:26 +02:00
|
|
|
|
var result = await _providerService.CreateOrganizationAsync(providerId, organizationSignup, model.ClientOwnerEmail, user);
|
|
|
|
|
|
return new ProviderOrganizationResponseModel(result);
|
2022-08-29 15:53:48 -04:00
|
|
|
|
}
|
|
|
|
|
|
|
2021-07-15 16:37:27 +02:00
|
|
|
|
[HttpDelete("{id:guid}")]
|
|
|
|
|
|
[HttpPost("{id:guid}/delete")]
|
2021-07-30 08:10:58 -05:00
|
|
|
|
public async Task Delete(Guid providerId, Guid id)
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-07-30 08:10:58 -05:00
|
|
|
|
if (!_currentContext.ManageProviderOrganizations(providerId))
|
2022-08-29 16:06:55 -04:00
|
|
|
|
{
|
2021-07-30 08:10:58 -05:00
|
|
|
|
throw new NotFoundException();
|
2022-08-29 15:53:48 -04:00
|
|
|
|
}
|
2022-08-29 16:06:55 -04:00
|
|
|
|
|
2024-01-12 10:38:47 -05:00
|
|
|
|
var provider = await _providerRepository.GetByIdAsync(providerId);
|
|
|
|
|
|
|
|
|
|
|
|
var providerOrganization = await _providerOrganizationRepository.GetByIdAsync(id);
|
|
|
|
|
|
|
|
|
|
|
|
var organization = await _organizationRepository.GetByIdAsync(providerOrganization.OrganizationId);
|
|
|
|
|
|
|
|
|
|
|
|
await _removeOrganizationFromProviderCommand.RemoveOrganizationFromProvider(
|
|
|
|
|
|
provider,
|
|
|
|
|
|
providerOrganization,
|
|
|
|
|
|
organization);
|
2021-06-30 09:35:26 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|