1
0
mirror of https://github.com/bitwarden/server.git synced 2025-04-07 14:08:13 -05:00

Make registration work

This commit is contained in:
Bernd Schoolmann 2025-03-12 15:20:20 +01:00
parent 377dad6852
commit a713ba8040
No known key found for this signature in database
3 changed files with 16 additions and 8 deletions

View File

@ -2,11 +2,13 @@
using Bit.Api.Auth.Models.Response.Opaque; using Bit.Api.Auth.Models.Response.Opaque;
using Bit.Core.Services; using Bit.Core.Services;
using Bitwarden.OPAQUE; using Bitwarden.OPAQUE;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
namespace Bit.Api.Auth.Controllers; namespace Bit.Api.Auth.Controllers;
[Route("opaque")] [Route("opaque")]
[Authorize("Web")]
public class OpaqueKeyExchangeController : Controller public class OpaqueKeyExchangeController : Controller
{ {
private readonly IUserService _userService; private readonly IUserService _userService;
@ -25,8 +27,8 @@ public class OpaqueKeyExchangeController : Controller
_cipherConfiguration.KSF = new Argon2id(3, 256 * 1024, 4); _cipherConfiguration.KSF = new Argon2id(3, 256 * 1024, 4);
} }
[HttpGet("~/opaque/start-registration")] [HttpPost("~/opaque/start-registration")]
public async Task<RegisterStartResponse> StartRegistration(RegisterStartRequest request) public async Task<RegisterStartResponse> StartRegistration([FromBody] RegisterStartRequest request)
{ {
var user = await _userService.GetUserByPrincipalAsync(User); var user = await _userService.GetUserByPrincipalAsync(User);
var registrationRequest = _bitwardenOpaque.StartServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegistrationStartResult), user.Id.ToString()); var registrationRequest = _bitwardenOpaque.StartServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegistrationStartResult), user.Id.ToString());
@ -39,11 +41,14 @@ public class OpaqueKeyExchangeController : Controller
} }
[HttpGet("~/opaque/finish-registration")] [HttpPost("~/opaque/finish-registration")]
public async Task<String> FinishRegistration(RegisterFinishRequest request) public async Task<String> FinishRegistration([FromBody] RegisterFinishRequest request)
{ {
var registrationFinish = _bitwardenOpaque.FinishServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegisterFinishResult)); await Task.Run(() =>
Console.WriteLine("Registration Finish: " + registrationFinish); {
var registrationFinish = _bitwardenOpaque.FinishServerRegistration(_cipherConfiguration, System.Convert.FromBase64String(request.ClientRegistrationFinishResult));
Console.WriteLine("Registration Finish: " + registrationFinish);
});
return "Registration Finish"; return "Registration Finish";
} }

View File

@ -2,7 +2,7 @@
public class RegisterFinishRequest public class RegisterFinishRequest
{ {
public String ClientRegisterFinishResult { get; set; } public String ClientRegistrationFinishResult { get; set; }
public Guid SessionId { get; set; } public Guid SessionId { get; set; }
} }

View File

@ -1,9 +1,12 @@
using Bitwarden.OPAQUE; using System.ComponentModel.DataAnnotations;
using Bitwarden.OPAQUE;
namespace Bit.Api.Auth.Models.Request.Opaque; namespace Bit.Api.Auth.Models.Request.Opaque;
public class RegisterStartRequest public class RegisterStartRequest
{ {
[Required]
public String ClientRegistrationStartResult { get; set; } public String ClientRegistrationStartResult { get; set; }
[Required]
public CipherConfiguration CipherConfiguration { get; set; } public CipherConfiguration CipherConfiguration { get; set; }
} }