mirror of
https://github.com/bitwarden/server.git
synced 2025-04-05 21:18:13 -05:00
[PM-8285] add endpoint for alerting when device lost trust (#4554)
* endpoint for alerting when device lost trust * get user from current context
This commit is contained in:
parent
ce185eb3df
commit
8121f898de
@ -3,6 +3,7 @@ using Bit.Api.Auth.Models.Request;
|
|||||||
using Bit.Api.Auth.Models.Request.Accounts;
|
using Bit.Api.Auth.Models.Request.Accounts;
|
||||||
using Bit.Api.Models.Request;
|
using Bit.Api.Models.Request;
|
||||||
using Bit.Api.Models.Response;
|
using Bit.Api.Models.Response;
|
||||||
|
using Bit.Core;
|
||||||
using Bit.Core.Auth.Models.Api.Request;
|
using Bit.Core.Auth.Models.Api.Request;
|
||||||
using Bit.Core.Auth.Models.Api.Response;
|
using Bit.Core.Auth.Models.Api.Response;
|
||||||
using Bit.Core.Context;
|
using Bit.Core.Context;
|
||||||
@ -25,19 +26,22 @@ public class DevicesController : Controller
|
|||||||
private readonly IUserService _userService;
|
private readonly IUserService _userService;
|
||||||
private readonly IUserRepository _userRepository;
|
private readonly IUserRepository _userRepository;
|
||||||
private readonly ICurrentContext _currentContext;
|
private readonly ICurrentContext _currentContext;
|
||||||
|
private readonly ILogger<DevicesController> _logger;
|
||||||
|
|
||||||
public DevicesController(
|
public DevicesController(
|
||||||
IDeviceRepository deviceRepository,
|
IDeviceRepository deviceRepository,
|
||||||
IDeviceService deviceService,
|
IDeviceService deviceService,
|
||||||
IUserService userService,
|
IUserService userService,
|
||||||
IUserRepository userRepository,
|
IUserRepository userRepository,
|
||||||
ICurrentContext currentContext)
|
ICurrentContext currentContext,
|
||||||
|
ILogger<DevicesController> logger)
|
||||||
{
|
{
|
||||||
_deviceRepository = deviceRepository;
|
_deviceRepository = deviceRepository;
|
||||||
_deviceService = deviceService;
|
_deviceService = deviceService;
|
||||||
_userService = userService;
|
_userService = userService;
|
||||||
_userRepository = userRepository;
|
_userRepository = userRepository;
|
||||||
_currentContext = currentContext;
|
_currentContext = currentContext;
|
||||||
|
_logger = logger;
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpGet("{id}")]
|
[HttpGet("{id}")]
|
||||||
@ -231,4 +235,25 @@ public class DevicesController : Controller
|
|||||||
var device = await _deviceRepository.GetByIdentifierAsync(identifier, user.Id);
|
var device = await _deviceRepository.GetByIdentifierAsync(identifier, user.Id);
|
||||||
return device != null;
|
return device != null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[RequireFeature(FeatureFlagKeys.DeviceTrustLogging)]
|
||||||
|
[HttpPost("lost-trust")]
|
||||||
|
public void PostLostTrust()
|
||||||
|
{
|
||||||
|
var userId = _currentContext.UserId.GetValueOrDefault();
|
||||||
|
if (userId == default)
|
||||||
|
{
|
||||||
|
throw new UnauthorizedAccessException();
|
||||||
|
}
|
||||||
|
|
||||||
|
var deviceId = _currentContext.DeviceIdentifier;
|
||||||
|
if (deviceId == null)
|
||||||
|
{
|
||||||
|
throw new BadRequestException("Please provide a device identifier");
|
||||||
|
}
|
||||||
|
|
||||||
|
_logger.LogError("User {id} has a device key, but didn't receive decryption keys for device {device}", userId,
|
||||||
|
deviceId);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -135,6 +135,7 @@ public static class FeatureFlagKeys
|
|||||||
public const string GroupsComponentRefactor = "groups-component-refactor";
|
public const string GroupsComponentRefactor = "groups-component-refactor";
|
||||||
public const string AC2828_ProviderPortalMembersPage = "AC-2828_provider-portal-members-page";
|
public const string AC2828_ProviderPortalMembersPage = "AC-2828_provider-portal-members-page";
|
||||||
public const string ProviderClientVaultPrivacyBanner = "ac-2833-provider-client-vault-privacy-banner";
|
public const string ProviderClientVaultPrivacyBanner = "ac-2833-provider-client-vault-privacy-banner";
|
||||||
|
public const string DeviceTrustLogging = "pm-8285-device-trust-logging";
|
||||||
|
|
||||||
public static List<string> GetAllKeys()
|
public static List<string> GetAllKeys()
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user