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

143 lines
6.1 KiB
C#
Raw Normal View History

2017-12-14 12:33:50 -05:00
using System;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Bit.Core.Repositories;
using Microsoft.AspNetCore.Authorization;
using Bit.Core.Exceptions;
using Bit.Core.Models.Api;
using Bit.Core.Services;
using Bit.Core.Context;
2017-12-15 15:23:57 -05:00
using Bit.Core.Models.Data;
2017-12-14 12:33:50 -05:00
namespace Bit.Api.Controllers
{
[Route("events")]
[Authorize("Application")]
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 IEventRepository _eventRepository;
private readonly ICurrentContext _currentContext;
2017-12-14 12:33:50 -05:00
public EventsController(
IUserService userService,
2017-12-15 15:50:50 -05:00
ICipherRepository cipherRepository,
IOrganizationUserRepository organizationUserRepository,
2017-12-14 12:33:50 -05:00
IEventRepository eventRepository,
ICurrentContext currentContext)
2017-12-14 12:33:50 -05:00
{
_userService = userService;
2017-12-15 15:50:50 -05:00
_cipherRepository = cipherRepository;
_organizationUserRepository = organizationUserRepository;
2017-12-14 12:33:50 -05:00
_eventRepository = eventRepository;
_currentContext = currentContext;
}
2017-12-14 13:27:52 -05:00
[HttpGet("")]
2017-12-14 12:33:50 -05:00
public async Task<ListResponseModel<EventResponseModel>> GetUser(
2017-12-15 15:23:57 -05:00
[FromQuery]DateTime? start = null, [FromQuery]DateTime? end = null, [FromQuery]string continuationToken = null)
2017-12-14 12:33:50 -05:00
{
var dateRange = GetDateRange(start, end);
var userId = _userService.GetProperUserId(User).Value;
2017-12-15 15:23:57 -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));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2017-12-14 12:33:50 -05:00
}
2017-12-15 15:50: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)
{
var cipher = await _cipherRepository.GetByIdAsync(new Guid(id));
if (cipher == null)
{
throw new NotFoundException();
}
var canView = false;
if (cipher.OrganizationId.HasValue)
{
canView = await _currentContext.AccessEventLogs(cipher.OrganizationId.Value);
}
else if (cipher.UserId.HasValue)
{
var userId = _userService.GetProperUserId(User).Value;
canView = userId == cipher.UserId.Value;
}
if (!canView)
2017-12-15 15:50:50 -05:00
{
throw new NotFoundException();
}
var dateRange = GetDateRange(start, end);
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);
}
2017-12-14 15:04:20 -05:00
[HttpGet("~/organizations/{id}/events")]
2017-12-14 12:33:50 -05:00
public async Task<ListResponseModel<EventResponseModel>> GetOrganization(string id,
2017-12-15 15:23:57 -05:00
[FromQuery]DateTime? start = null, [FromQuery]DateTime? end = null, [FromQuery]string continuationToken = null)
2017-12-14 12:33:50 -05:00
{
var orgId = new Guid(id);
if (!await _currentContext.AccessEventLogs(orgId))
2017-12-14 12:33:50 -05:00
{
throw new NotFoundException();
}
var dateRange = 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);
}
[HttpGet("~/organizations/{orgId}/users/{id}/events")]
public async Task<ListResponseModel<EventResponseModel>> GetOrganizationUser(string orgId, string id,
[FromQuery]DateTime? start = null, [FromQuery]DateTime? end = null, [FromQuery]string continuationToken = null)
{
var organizationUser = await _organizationUserRepository.GetByIdAsync(new Guid(id));
if (organizationUser == null || !organizationUser.UserId.HasValue ||
!await _currentContext.AccessEventLogs(organizationUser.OrganizationId))
2017-12-15 15:50:50 -05:00
{
throw new NotFoundException();
}
var dateRange = GetDateRange(start, end);
var result = await _eventRepository.GetManyByOrganizationActingUserAsync(organizationUser.OrganizationId,
organizationUser.UserId.Value, dateRange.Item1, dateRange.Item2,
2017-12-15 15:23:57 -05:00
new PageOptions { ContinuationToken = continuationToken });
var responses = result.Data.Select(e => new EventResponseModel(e));
return new ListResponseModel<EventResponseModel>(responses, result.ContinuationToken);
2017-12-14 12:33:50 -05:00
}
private Tuple<DateTime, DateTime> GetDateRange(DateTime? start, DateTime? end)
{
if (!end.HasValue || !start.HasValue)
2017-12-14 12:33:50 -05:00
{
end = DateTime.UtcNow.Date.AddDays(1).AddMilliseconds(-1);
2017-12-15 12:24:32 -05:00
start = DateTime.UtcNow.Date.AddDays(-30);
2017-12-14 12:33:50 -05:00
}
else if (start.Value > end.Value)
2017-12-14 12:33:50 -05:00
{
2017-12-14 13:24:26 -05:00
var newEnd = start;
start = end;
end = newEnd;
}
if ((end.Value - start.Value) > TimeSpan.FromDays(367))
2017-12-14 13:24:26 -05:00
{
throw new BadRequestException("Range too large.");
2017-12-14 12:33:50 -05:00
}
return new Tuple<DateTime, DateTime>(start.Value, end.Value);
}
}
}