mirror of
https://github.com/bitwarden/server.git
synced 2025-05-22 12:04:27 -05:00
Add basic opaque usage
This commit is contained in:
parent
29dc69a77b
commit
377dad6852
@ -39,4 +39,8 @@
|
||||
<PackageReference Include="Swashbuckle.AspNetCore" Version="7.2.0" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="../../../dotnet-extensions/extensions/Bitwarden.OPAQUE/src/Bitwarden.OPAQUE.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
||||
|
63
src/Api/Auth/Controllers/OpaqueKeyExchangeController.cs
Normal file
63
src/Api/Auth/Controllers/OpaqueKeyExchangeController.cs
Normal file
@ -0,0 +1,63 @@
|
||||
using Bit.Api.Auth.Models.Request.Opaque;
|
||||
using Bit.Api.Auth.Models.Response.Opaque;
|
||||
using Bit.Core.Services;
|
||||
using Bitwarden.OPAQUE;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
|
||||
namespace Bit.Api.Auth.Controllers;
|
||||
|
||||
[Route("opaque")]
|
||||
public class OpaqueKeyExchangeController : Controller
|
||||
{
|
||||
private readonly IUserService _userService;
|
||||
private readonly BitwardenOpaque _bitwardenOpaque;
|
||||
private CipherConfiguration _cipherConfiguration = new CipherConfiguration();
|
||||
|
||||
public OpaqueKeyExchangeController(
|
||||
IUserService userService
|
||||
)
|
||||
{
|
||||
_userService = userService;
|
||||
_bitwardenOpaque = new BitwardenOpaque();
|
||||
_cipherConfiguration.KeGroup = KeGroup.Ristretto255;
|
||||
_cipherConfiguration.OprfCS = OprfCS.Ristretto255;
|
||||
_cipherConfiguration.KeyExchange = KeyExchange.TripleDH;
|
||||
_cipherConfiguration.KSF = new Argon2id(3, 256 * 1024, 4);
|
||||
}
|
||||
|
||||
[HttpGet("~/opaque/start-registration")]
|
||||
public async Task<RegisterStartResponse> StartRegistration(RegisterStartRequest request)
|
||||
{
|
||||
var user = await _userService.GetUserByPrincipalAsync(User);
|
||||
var registrationRequest = _bitwardenOpaque.StartServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegistrationStartResult), user.Id.ToString());
|
||||
var message = registrationRequest.Item1;
|
||||
var serverSetup = registrationRequest.Item2;
|
||||
// persist server setup
|
||||
var sessionId = Guid.NewGuid();
|
||||
SessionStore.RegisterSessions.Add(sessionId, new RegisterSession() { SessionId = sessionId, ServerSetup = serverSetup, cipherConfiguration = _cipherConfiguration });
|
||||
return new RegisterStartResponse(sessionId, System.Convert.ToBase64String(message));
|
||||
}
|
||||
|
||||
|
||||
[HttpGet("~/opaque/finish-registration")]
|
||||
public async Task<String> FinishRegistration(RegisterFinishRequest request)
|
||||
{
|
||||
var registrationFinish = _bitwardenOpaque.FinishServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegisterFinishResult));
|
||||
Console.WriteLine("Registration Finish: " + registrationFinish);
|
||||
return "Registration Finish";
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public class RegisterSession
|
||||
{
|
||||
public Guid SessionId { get; set; }
|
||||
public byte[] ServerSetup { get; set; }
|
||||
public CipherConfiguration cipherConfiguration { get; set; }
|
||||
}
|
||||
|
||||
public class SessionStore()
|
||||
{
|
||||
public static Dictionary<Guid, RegisterSession> RegisterSessions = new Dictionary<Guid, RegisterSession>();
|
||||
public static Dictionary<Guid, byte[]> LoginSessions = new Dictionary<Guid, byte[]>();
|
||||
}
|
14
src/Api/Auth/Models/Request/Opaque/RegisterFinishRequest.cs
Normal file
14
src/Api/Auth/Models/Request/Opaque/RegisterFinishRequest.cs
Normal file
@ -0,0 +1,14 @@
|
||||
namespace Bit.Api.Auth.Models.Request.Opaque;
|
||||
|
||||
public class RegisterFinishRequest
|
||||
{
|
||||
public String ClientRegisterFinishResult { 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,9 @@
|
||||
using Bitwarden.OPAQUE;
|
||||
|
||||
namespace Bit.Api.Auth.Models.Request.Opaque;
|
||||
|
||||
public class RegisterStartRequest
|
||||
{
|
||||
public String ClientRegistrationStartResult { get; set; }
|
||||
public CipherConfiguration CipherConfiguration { get; set; }
|
||||
}
|
17
src/Api/Auth/Models/Response/Opaque/RegisterStartResponse.cs
Normal file
17
src/Api/Auth/Models/Response/Opaque/RegisterStartResponse.cs
Normal file
@ -0,0 +1,17 @@
|
||||
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