This commit is contained in:
@@ -168,16 +168,16 @@ namespace AyaNova.Api.Controllers
|
||||
string hashed = Hasher.hash(u.Salt, creds.Password);
|
||||
if (hashed == u.Password)
|
||||
{
|
||||
//TWO FACTOR ENABLED??
|
||||
//TWO FACTOR ENABLED??
|
||||
//if 2fa enabled then need to validate it before sending token, so we're halfway there and need to send a 2fa prompt
|
||||
if (u.TwoFactorEnabled)
|
||||
{
|
||||
//Generate a temporary token to identify and verify this is the same user
|
||||
u.TempToken = Hasher.GenerateSalt().Replace("=", "").Replace("+", "");
|
||||
await ct.SaveChangesAsync();
|
||||
var UOpt=await ct.UserOptions.AsNoTracking().FirstAsync(z=>z.UserId==u.Id);
|
||||
var UOpt = await ct.UserOptions.AsNoTracking().FirstAsync(z => z.UserId == u.Id);
|
||||
|
||||
List<string> TranslationKeysToFetch = new List<string> { "AuthTwoFactor", "AuthEnterPin", "AuthVerifyCode", "Cancel","AuthPinInvalid" };
|
||||
List<string> TranslationKeysToFetch = new List<string> { "AuthTwoFactor", "AuthEnterPin", "AuthVerifyCode", "Cancel", "AuthPinInvalid" };
|
||||
var LT = await TranslationBiz.GetSubsetStaticAsync(TranslationKeysToFetch, UOpt.TranslationId);
|
||||
|
||||
return Ok(ApiOkResponse.Response(new
|
||||
@@ -185,7 +185,7 @@ namespace AyaNova.Api.Controllers
|
||||
AuthTwoFactor = LT["AuthTwoFactor"],
|
||||
AuthEnterPin = LT["AuthEnterPin"],
|
||||
AuthVerifyCode = LT["AuthVerifyCode"],
|
||||
AuthPinInvalid=LT["AuthPinInvalid"],
|
||||
AuthPinInvalid = LT["AuthPinInvalid"],
|
||||
Cancel = LT["Cancel"],
|
||||
tfa = true,
|
||||
tt = u.TempToken
|
||||
@@ -195,7 +195,7 @@ namespace AyaNova.Api.Controllers
|
||||
//Not 2fa, Valid password, user is authorized
|
||||
return await ReturnUserCredsOnSuccessfulAuthentication(u);
|
||||
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@@ -530,6 +530,9 @@ namespace AyaNova.Api.Controllers
|
||||
}));
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Generate TOTP secret and return for use in auth app
|
||||
///
|
||||
@@ -639,13 +642,14 @@ namespace AyaNova.Api.Controllers
|
||||
|
||||
|
||||
/// <summary>
|
||||
/// Disable (turn off) 2fa for current user account
|
||||
///
|
||||
/// </summary>
|
||||
/// Disable (turn off) 2fa for user account
|
||||
/// (For other user id requires full privileges)
|
||||
/// </summary>
|
||||
/// <param name="id">Optional User id otherwise current user account</param>
|
||||
/// <param name="apiVersion">From route path</param>
|
||||
/// <returns>OK on success</returns>
|
||||
[HttpPost("totp-disable")]
|
||||
public async Task<IActionResult> DisableTOTP(ApiVersion apiVersion)
|
||||
[HttpPost("totp-disable/{id}")]
|
||||
public async Task<IActionResult> DisableTOTP([FromRoute] long? id, ApiVersion apiVersion)
|
||||
{
|
||||
if (!serverState.IsOpen)
|
||||
return StatusCode(503, new ApiErrorResponse(serverState.ApiErrorCode, null, serverState.Reason));
|
||||
@@ -653,14 +657,21 @@ namespace AyaNova.Api.Controllers
|
||||
if (!ModelState.IsValid)
|
||||
return BadRequest(new ApiErrorResponse(ModelState));
|
||||
|
||||
if (id != null)
|
||||
{
|
||||
if (!Authorized.HasModifyRole(HttpContext.Items, AyaType.User))
|
||||
return StatusCode(403, new ApiNotAuthorizedResponse());
|
||||
}
|
||||
|
||||
//get user
|
||||
var UserId = UserIdFromContext.Id(HttpContext.Items);
|
||||
var UserId = id ?? UserIdFromContext.Id(HttpContext.Items);
|
||||
|
||||
var u = await ct.User.FirstOrDefaultAsync(z => z.Id == UserId);
|
||||
if (u == null)//should never happen but ?
|
||||
return StatusCode(403, new ApiNotAuthorizedResponse());
|
||||
|
||||
u.TotpSecret = null;
|
||||
u.TempToken = null;
|
||||
u.TwoFactorEnabled = false;
|
||||
await ct.SaveChangesAsync();
|
||||
return NoContent();
|
||||
|
||||
@@ -495,6 +495,7 @@ namespace AyaNova.Biz
|
||||
}
|
||||
|
||||
var ResetCode = Hasher.GetRandomAlphanumericString(32);
|
||||
|
||||
dbObject.PasswordResetCode = ResetCode;
|
||||
dbObject.PasswordResetCodeExpire = DateTime.UtcNow.AddHours(48);//This is not enough time to issue a reset code on a friday at 5pm and use it Monday before noon, but it is more understandable and clear
|
||||
await ct.SaveChangesAsync();
|
||||
|
||||
Reference in New Issue
Block a user