Added endpoint for registering a user locally after successful logon from Auth0

This commit is contained in:
Carl Tibule
2023-01-25 22:47:05 -06:00
parent e0b38beff6
commit 406bd9a0d1
16 changed files with 267 additions and 47 deletions

View File

@ -0,0 +1,35 @@
using Microsoft.AspNetCore.Mvc;
using System.Security.Claims;
using YABA.Common.Extensions;
using YABA.Common.Lookups;
namespace YABA.API.Extensions
{
public static class ControllerExtensions
{
public static string GetAuthProviderId(this ControllerBase controller)
{
return GetCustomClaim(controller, ClaimsLookup.AuthProviderId);
}
public static int GetUserId(this ControllerBase controller)
{
var isValidUserId = int.TryParse(GetCustomClaim(controller, ClaimsLookup.UserId), out int userId);
return isValidUserId ? userId : 0;
}
public static string GetCustomClaim(this ControllerBase controller, ClaimsLookup claim)
{
var claimsIdentity = controller.User.Identity as ClaimsIdentity;
return claimsIdentity.FindFirst(claim.GetClaimName())?.Value.ToString();
}
public static string GetIpAddress(this ControllerBase controller)
{
if (controller.Request.Headers.ContainsKey("X-Forwarded-For"))
return controller.Request.Headers["X-Forwarded-For"];
return controller.HttpContext.Connection.RemoteIpAddress.MapToIPv4().ToString();
}
}
}