Files
server/src/Api/AdminConsole/Controllers/EventsController.cs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

158 lines
7.1 KiB
C#
Raw Normal View History

using Bit.Api.Models.Response;
using Bit.Api.Utilities;
using Bit.Core.AdminConsole.Repositories;
using Bit.Core.Context;
2017-12-14 12:33:50 -05:00
using Bit.Core.Exceptions;
2017-12-15 15:23:57 -05:00
using Bit.Core.Models.Data;
2017-12-14 12:33:50 -05:00
using Bit.Core.Repositories;
using Bit.Core.Services;
using Bit.Core.Vault.Repositories;
2017-12-14 12:33:50 -05:00
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
namespace Bit.Api.Controllers;
2022-08-29 16:06:55 -04:00
2017-12-14 12:33:50 -05:00
[Route("events")]
2017-12-15 15:50:50 -05:00
[Authorize("Application")]
2017-12-14 12:33:50 -05:00
public class EventsController : Controller
{
private readonly IUserService _userService;
2017-12-15 15:50:50 -05:00
private readonly ICipherRepository _cipherRepository;
private readonly IOrganizationUserRepository _organizationUserRepository;
2017-12-14 12:33:50 -05:00
private readonly IProviderUserRepository _providerUserRepository;
private readonly IEventRepository _eventRepository;
private readonly ICurrentContext _currentContext;
2022-08-29 16:06:55 -04:00
2017-12-14 12:33:50 -05:00
public EventsController(
IUserService userService,
2017-12-15 15:50:50 -05:00
ICipherRepository cipherRepository,
IOrganizationUserRepository organizationUserRepository,
IProviderUserRepository providerUserRepository,
2017-12-14 12:33:50 -05:00
IEventRepository eventRepository,
ICurrentContext currentContext)
2022-08-29 16:06:55 -04:00
{
2017-12-15 15:50:50 -05:00
_userService = userService;
_cipherRepository = cipherRepository;
_organizationUserRepository = organizationUserRepository;
_providerUserRepository = providerUserRepository;
2017-12-14 12:33:50 -05:00
_eventRepository = eventRepository;
_currentContext = currentContext;
2022-08-29 16:06:55 -04:00
}
2017-12-14 13:27:52 -05:00
[HttpGet("")]
2017-12-14 12:33:50 -05:00
public async Task<ListResponseModel<EventResponseModel>> GetUser(
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
{
var dateRange = ApiHelpers.GetDateRange(start, end);
2017-12-14 12:33:50 -05:00
var userId = _userService.GetProperUserId(User).Value;
2017-12-15 15:50:50 -05:00
var result = await _eventRepository.GetManyByUserAsync(userId, dateRange.Item1, dateRange.Item2,
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
2017-12-14 12:33:50 -05:00
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
2017-12-14 12:33:50 -05:00
[HttpGet("~/ciphers/{id}/events")]
public async Task<ListResponseModel<EventResponseModel>> GetCipher(string id,
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
2022-08-29 16:06:55 -04:00
{
2017-12-15 15:50:50 -05:00
var cipher = await _cipherRepository.GetByIdAsync(new Guid(id));
if (cipher == null)
2017-12-14 12:33:50 -05:00
{
2017-12-15 15:50:50 -05:00
throw new NotFoundException();
2017-12-14 12:33:50 -05:00
}
2017-12-15 15:23:57 -05:00
var canView = false;
if (cipher.OrganizationId.HasValue)
2022-08-29 16:06:55 -04:00
{
2017-12-15 15:23:57 -05:00
canView = await _currentContext.AccessEventLogs(cipher.OrganizationId.Value);
2022-08-29 16:06:55 -04:00
}
2017-12-15 15:23:57 -05:00
else if (cipher.UserId.HasValue)
2017-12-14 12:33:50 -05:00
{
var userId = _userService.GetProperUserId(User).Value;
2017-12-15 15:23:57 -05:00
canView = userId == cipher.UserId.Value;
}
2022-08-29 16:06:55 -04:00
2017-12-15 15:23:57 -05:00
if (!canView)
{
throw new NotFoundException();
2017-12-14 12:33:50 -05:00
}
var dateRange = ApiHelpers.GetDateRange(start, end);
2017-12-15 15:50:50 -05:00
var result = await _eventRepository.GetManyByCipherAsync(cipher, dateRange.Item1, dateRange.Item2,
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
2017-12-15 15:50:50 -05:00
[HttpGet("~/organizations/{id}/events")]
public async Task<ListResponseModel<EventResponseModel>> GetOrganization(string id,
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
2022-08-29 16:06:55 -04:00
{
2017-12-14 12:33:50 -05:00
var orgId = new Guid(id);
if (!await _currentContext.AccessEventLogs(orgId))
2017-12-15 15:50:50 -05:00
{
2017-12-14 12:33:50 -05:00
throw new NotFoundException();
2017-12-15 15:50:50 -05:00
}
var dateRange = ApiHelpers.GetDateRange(start, end);
2017-12-15 15:23:57 -05:00
var result = await _eventRepository.GetManyByOrganizationAsync(orgId, dateRange.Item1, dateRange.Item2,
2017-12-15 15:50:50 -05:00
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
2017-12-14 15:04:20 -05:00
[HttpGet("~/organizations/{orgId}/users/{id}/events")]
2017-12-14 12:33:50 -05:00
public async Task<ListResponseModel<EventResponseModel>> GetOrganizationUser(string orgId, string id,
2017-12-15 15:23:57 -05:00
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
2022-08-29 16:06:55 -04:00
{
2017-12-15 15:50:50 -05:00
var organizationUser = await _organizationUserRepository.GetByIdAsync(new Guid(id));
if (organizationUser == null || !organizationUser.UserId.HasValue ||
!await _currentContext.AccessEventLogs(organizationUser.OrganizationId))
2017-12-14 12:33:50 -05:00
{
throw new NotFoundException();
2017-12-15 15:50:50 -05:00
}
var dateRange = ApiHelpers.GetDateRange(start, end);
2017-12-15 15:50:50 -05:00
var result = await _eventRepository.GetManyByOrganizationActingUserAsync(organizationUser.OrganizationId,
organizationUser.UserId.Value, dateRange.Item1, dateRange.Item2,
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
2017-12-15 15:50:50 -05:00
[HttpGet("~/providers/{providerId:guid}/events")]
public async Task<ListResponseModel<EventResponseModel>> GetProvider(Guid providerId,
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
2022-08-29 16:06:55 -04:00
{
if (!_currentContext.ProviderAccessEventLogs(providerId))
2017-12-15 15:50:50 -05:00
{
throw new NotFoundException();
}
var dateRange = ApiHelpers.GetDateRange(start, end);
var result = await _eventRepository.GetManyByProviderAsync(providerId, dateRange.Item1, dateRange.Item2,
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
[HttpGet("~/providers/{providerId:guid}/users/{id:guid}/events")]
public async Task<ListResponseModel<EventResponseModel>> GetProviderUser(Guid providerId, Guid id,
[FromQuery] DateTime? start = null, [FromQuery] DateTime? end = null, [FromQuery] string continuationToken = null)
2022-08-29 16:06:55 -04:00
{
var providerUser = await _providerUserRepository.GetByIdAsync(id);
if (providerUser == null || !providerUser.UserId.HasValue ||
!_currentContext.ProviderAccessEventLogs(providerUser.ProviderId))
{
throw new NotFoundException();
}
var dateRange = ApiHelpers.GetDateRange(start, end);
var result = await _eventRepository.GetManyByProviderActingUserAsync(providerUser.ProviderId,
providerUser.UserId.Value, dateRange.Item1, dateRange.Item2,
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2022-08-29 16:06:55 -04:00
}
2017-12-14 12:33:50 -05:00
}