mirror of
https://github.com/bitwarden/server.git
synced 2025-04-07 05:58:13 -05:00
Make registration work
This commit is contained in:
parent
377dad6852
commit
a713ba8040
@ -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";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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; }
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user