Files
DiunaBI/WebAPI/Controllers/AuthController.cs

72 lines
2.6 KiB
C#
Raw Normal View History

2022-12-06 12:27:09 +01:00
using Google.Apis.Auth;
using Google.Apis.Http;
2022-12-09 00:14:05 +01:00
using Microsoft.AspNetCore.Authorization;
2022-12-06 12:27:09 +01:00
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Configuration;
using Microsoft.Identity.Client.Platforms.Features.DesktopOs.Kerberos;
using Microsoft.IdentityModel.Tokens;
using System.Configuration;
using System.IdentityModel.Tokens.Jwt;
using System.Security.Claims;
using System.Text;
using WebAPI.Models;
namespace WebAPI.Controllers
{
[ApiController]
[Route("api/[controller]")]
2022-12-09 00:14:05 +01:00
// [Authorize]
2022-12-06 12:27:09 +01:00
public class AuthController : Controller
{
private readonly AppDbContext db;
private readonly IConfiguration configuration;
public AuthController(
AppDbContext _db, IConfiguration _configuration)
{ db = _db; configuration = _configuration; }
[HttpPost]
[Route("apiToken")]
public async Task<IActionResult> apiToken([FromBody] string credential)
{
var settings = new GoogleJsonWebSignature.ValidationSettings()
{
Audience = new List<string> { configuration.GetValue<string>("GoogleClientId") }
};
var payload = await GoogleJsonWebSignature.ValidateAsync(credential, settings);
var user = db.Users.Where(x => x.Email == payload.Email).FirstOrDefault();
if (user != null)
{
return Ok(JWTGenerator(user));
}
else
{
2022-12-19 18:36:57 +01:00
return Unauthorized();
2022-12-06 12:27:09 +01:00
}
}
private dynamic JWTGenerator(User user)
{
var key = Encoding.ASCII.GetBytes(configuration.GetValue<string>("Secret"));
2023-01-12 18:14:40 +01:00
var expirationTime = DateTime.UtcNow.AddMinutes(5);
2022-12-06 12:27:09 +01:00
var tokenDescriptor = new SecurityTokenDescriptor
{
2022-12-09 00:14:05 +01:00
Subject = new ClaimsIdentity(new[]
{
new Claim("Id", Guid.NewGuid().ToString()),
2022-12-21 18:35:26 +01:00
new Claim(JwtRegisteredClaimNames.Sub, user.Id.ToString()),
2022-12-09 00:14:05 +01:00
new Claim(JwtRegisteredClaimNames.Jti,
Guid.NewGuid().ToString())
}),
2023-01-08 18:19:49 +01:00
Expires = expirationTime,
2022-12-09 00:14:05 +01:00
SigningCredentials = new SigningCredentials
(new SymmetricSecurityKey(key),
SecurityAlgorithms.HmacSha512Signature)
2022-12-06 12:27:09 +01:00
};
2022-12-09 00:14:05 +01:00
var tokenHandler = new JwtSecurityTokenHandler();
2022-12-06 12:27:09 +01:00
var token = tokenHandler.CreateToken(tokenDescriptor);
2022-12-09 00:14:05 +01:00
var jwtToken = tokenHandler.WriteToken(token);
var stringToken = tokenHandler.WriteToken(token);
2023-01-08 18:19:49 +01:00
return new { token = stringToken, id = user.Id, expirationTime };
2022-12-06 12:27:09 +01:00
}
}
}