mirror of
https://github.com/bitwarden/server.git
synced 2025-04-22 21:45:15 -05:00
Update api models
This commit is contained in:
parent
e5e5b3c1ca
commit
b7673cd450
@ -13,7 +13,6 @@ public class OpaqueKeyExchangeController : Controller
|
|||||||
{
|
{
|
||||||
private readonly IUserService _userService;
|
private readonly IUserService _userService;
|
||||||
private readonly BitwardenOpaqueServer _bitwardenOpaque;
|
private readonly BitwardenOpaqueServer _bitwardenOpaque;
|
||||||
private CipherConfiguration _cipherConfiguration = new CipherConfiguration();
|
|
||||||
|
|
||||||
public OpaqueKeyExchangeController(
|
public OpaqueKeyExchangeController(
|
||||||
IUserService userService
|
IUserService userService
|
||||||
@ -21,35 +20,32 @@ public class OpaqueKeyExchangeController : Controller
|
|||||||
{
|
{
|
||||||
_userService = userService;
|
_userService = userService;
|
||||||
_bitwardenOpaque = new BitwardenOpaqueServer();
|
_bitwardenOpaque = new BitwardenOpaqueServer();
|
||||||
_cipherConfiguration.KeGroup = KeGroup.Ristretto255;
|
|
||||||
_cipherConfiguration.OprfCS = OprfCS.Ristretto255;
|
|
||||||
_cipherConfiguration.KeyExchange = KeyExchange.TripleDH;
|
|
||||||
_cipherConfiguration.KSF = new Argon2id(3, 256 * 1024, 4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
[HttpPost("~/opaque/start-registration")]
|
[HttpPost("~/opaque/start-registration")]
|
||||||
public async Task<RegisterStartResponse> StartRegistration([FromBody] RegisterStartRequest request)
|
public async Task<OpaqueRegistrationStartResponse> StartRegistration([FromBody] OpaqueRegistrationStartRequest request)
|
||||||
{
|
{
|
||||||
var user = await _userService.GetUserByPrincipalAsync(User);
|
var user = await _userService.GetUserByPrincipalAsync(User);
|
||||||
var registrationRequest = _bitwardenOpaque.StartRegistration(_cipherConfiguration, null, System.Convert.FromBase64String(request.ClientRegistrationStartResult), user.Id.ToString());
|
var registrationRequest = _bitwardenOpaque.StartRegistration(request.CipherConfiguration, null, System.Convert.FromBase64String(request.RegistrationRequest), user.Id.ToString());
|
||||||
var message = registrationRequest.registrationResponse;
|
var message = registrationRequest.registrationResponse;
|
||||||
var serverSetup = registrationRequest.serverSetup;
|
var serverSetup = registrationRequest.serverSetup;
|
||||||
// persist server setup
|
// persist server setup
|
||||||
var sessionId = Guid.NewGuid();
|
var sessionId = Guid.NewGuid();
|
||||||
SessionStore.RegisterSessions.Add(sessionId, new RegisterSession() { SessionId = sessionId, ServerSetup = serverSetup, cipherConfiguration = _cipherConfiguration });
|
SessionStore.RegisterSessions.Add(sessionId, new RegisterSession() { SessionId = sessionId, ServerSetup = serverSetup, cipherConfiguration = request.CipherConfiguration });
|
||||||
return new RegisterStartResponse(sessionId, System.Convert.ToBase64String(message));
|
return new OpaqueRegistrationStartResponse(sessionId, System.Convert.ToBase64String(message));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
[HttpPost("~/opaque/finish-registration")]
|
[HttpPost("~/opaque/finish-registration")]
|
||||||
public async Task<String> FinishRegistration([FromBody] RegisterFinishRequest request)
|
public async Task<String> FinishRegistration([FromBody] OpaqueRegistrationFinishRequest request)
|
||||||
{
|
{
|
||||||
await Task.Run(() =>
|
await Task.Run(() =>
|
||||||
{
|
{
|
||||||
var registrationFinish = _bitwardenOpaque.FinishRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegistrationFinishResult));
|
var registerSession = SessionStore.RegisterSessions[request.SessionId];
|
||||||
|
var registrationFinish = _bitwardenOpaque.FinishRegistration(registerSession.cipherConfiguration, System.Convert.FromBase64String(request.RegistrationUpload));
|
||||||
Console.WriteLine("Registration Finish: " + registrationFinish);
|
Console.WriteLine("Registration Finish: " + registrationFinish);
|
||||||
});
|
});
|
||||||
return "Registration Finish";
|
return "";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,23 @@
|
|||||||
|
using System.ComponentModel.DataAnnotations;
|
||||||
|
|
||||||
|
namespace Bit.Api.Auth.Models.Request.Opaque;
|
||||||
|
|
||||||
|
public class OpaqueRegistrationFinishRequest
|
||||||
|
{
|
||||||
|
[Required]
|
||||||
|
public String RegistrationUpload { get; set; }
|
||||||
|
[Required]
|
||||||
|
public Guid SessionId { get; set; }
|
||||||
|
|
||||||
|
public RotateableKeyset KeySet { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class RotateableKeyset
|
||||||
|
{
|
||||||
|
[Required]
|
||||||
|
public String EncryptedUserKey { get; set; }
|
||||||
|
[Required]
|
||||||
|
public String EncryptedPublicKey { get; set; }
|
||||||
|
[Required]
|
||||||
|
public String EncryptedPrivateKey { get; set; }
|
||||||
|
}
|
@ -3,10 +3,10 @@ using Bitwarden.OPAQUE;
|
|||||||
|
|
||||||
namespace Bit.Api.Auth.Models.Request.Opaque;
|
namespace Bit.Api.Auth.Models.Request.Opaque;
|
||||||
|
|
||||||
public class RegisterStartRequest
|
public class OpaqueRegistrationStartRequest
|
||||||
{
|
{
|
||||||
[Required]
|
[Required]
|
||||||
public String ClientRegistrationStartResult { get; set; }
|
public String RegistrationRequest { get; set; }
|
||||||
[Required]
|
[Required]
|
||||||
public CipherConfiguration CipherConfiguration { get; set; }
|
public CipherConfiguration CipherConfiguration { get; set; }
|
||||||
}
|
}
|
@ -1,14 +0,0 @@
|
|||||||
namespace Bit.Api.Auth.Models.Request.Opaque;
|
|
||||||
|
|
||||||
public class RegisterFinishRequest
|
|
||||||
{
|
|
||||||
public String ClientRegistrationFinishResult { get; set; }
|
|
||||||
public Guid SessionId { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
public class RotateableKeyset
|
|
||||||
{
|
|
||||||
public String EncryptedUserKey { get; set; }
|
|
||||||
public String EncryptedPublicKey { get; set; }
|
|
||||||
public String EncryptedPrivateKey { get; set; }
|
|
||||||
}
|
|
@ -0,0 +1,17 @@
|
|||||||
|
using Bit.Core.Models.Api;
|
||||||
|
|
||||||
|
namespace Bit.Api.Auth.Models.Response.Opaque;
|
||||||
|
|
||||||
|
public class OpaqueRegistrationStartResponse : ResponseModel
|
||||||
|
{
|
||||||
|
public OpaqueRegistrationStartResponse(Guid sessionId, string registrationResponse, string obj = "register-start-response")
|
||||||
|
: base(obj)
|
||||||
|
{
|
||||||
|
RegistrationResponse = registrationResponse;
|
||||||
|
SessionId = sessionId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String RegistrationResponse { get; set; }
|
||||||
|
public Guid SessionId { get; set; }
|
||||||
|
}
|
||||||
|
|
@ -1,17 +0,0 @@
|
|||||||
using Bit.Core.Models.Api;
|
|
||||||
|
|
||||||
namespace Bit.Api.Auth.Models.Response.Opaque;
|
|
||||||
|
|
||||||
public class RegisterStartResponse : ResponseModel
|
|
||||||
{
|
|
||||||
public RegisterStartResponse(Guid sessionId, string serverRegistrationStartResult, string obj = "register-start-response")
|
|
||||||
: base(obj)
|
|
||||||
{
|
|
||||||
ServerRegistrationStartResult = serverRegistrationStartResult;
|
|
||||||
SessionId = sessionId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String ServerRegistrationStartResult { get; set; }
|
|
||||||
public Guid SessionId { get; set; }
|
|
||||||
}
|
|
||||||
|
|
Loading…
x
Reference in New Issue
Block a user