using Bit.Api.Models.Response; using Bit.Core.Context; using Bit.Core.Entities; using Bit.Core.Services; using Bit.Core.Settings; using Core.Models.Data; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; namespace Bit.Api.Controllers; [Route("organizations/{organizationId}")] [Authorize("Application")] public class OrganizationExportController : Controller { private readonly ICurrentContext _currentContext; private readonly IUserService _userService; private readonly ICollectionService _collectionService; private readonly ICipherService _cipherService; private readonly GlobalSettings _globalSettings; public OrganizationExportController( ICurrentContext currentContext, ICipherService cipherService, ICollectionService collectionService, IUserService userService, GlobalSettings globalSettings) { _currentContext = currentContext; _cipherService = cipherService; _collectionService = collectionService; _userService = userService; _globalSettings = globalSettings; } [HttpGet("export")] public async Task Export(Guid organizationId) { var userId = _userService.GetProperUserId(User).Value; IEnumerable orgCollections = await _collectionService.GetOrganizationCollections(organizationId); (IEnumerable orgCiphers, Dictionary> collectionCiphersGroupDict) = await _cipherService.GetOrganizationCiphers(userId, organizationId); // Backward compatibility with versions before 2022.11.0 that use ListResponseModel if (_currentContext.ClientVersion < new Version("2022.11.0")) { var organizationExportListResponseModel = new OrganizationExportListResponseModel { Collections = GetOrganizationCollectionsResponse(orgCollections), Ciphers = GetOrganizationCiphersResponse(orgCiphers, collectionCiphersGroupDict) }; return Ok(organizationExportListResponseModel); } var organizationExportResponseModel = new OrganizationExportResponseModel { Collections = orgCollections.Select(c => new CollectionResponseModel(c)), Ciphers = orgCiphers.Select(c => new CipherMiniDetailsResponseModel(c, _globalSettings, collectionCiphersGroupDict, c.OrganizationUseTotp)) }; return Ok(organizationExportResponseModel); } private ListResponseModel GetOrganizationCollectionsResponse(IEnumerable orgCollections) { var collections = orgCollections.Select(c => new CollectionResponseModel(c)); return new ListResponseModel(collections); } private ListResponseModel GetOrganizationCiphersResponse(IEnumerable orgCiphers, Dictionary> collectionCiphersGroupDict) { var responses = orgCiphers.Select(c => new CipherMiniDetailsResponseModel(c, _globalSettings, collectionCiphersGroupDict, c.OrganizationUseTotp)); return new ListResponseModel(responses); } }