astral-api/Astral.ApiServer/Controllers/OAuthController.cs

74 lines
2.4 KiB
C#
Raw Normal View History

2024-12-11 23:12:53 +01:00
// <copyright file="OAuthController.cs" company="alveus.dev">
// Copyright (c) alveus.dev. All rights reserved. Licensed under the MIT License.
// </copyright>
2024-12-14 17:31:17 +01:00
using Astral.ApiServer.Constants;
2024-12-11 23:12:53 +01:00
using Astral.ApiServer.Models;
2024-12-14 17:31:17 +01:00
using Astral.Core.Constants;
using Astral.Services.Dtos;
using Astral.Services.Interfaces;
2024-12-11 23:12:53 +01:00
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
namespace Astral.ApiServer.Controllers;
/// <summary>
/// OAuth authentication controller.
/// </summary>
[Route("oauth")]
2024-12-14 17:31:17 +01:00
public class OAuthController : BaseApiController
2024-12-11 23:12:53 +01:00
{
2024-12-14 17:31:17 +01:00
private readonly IAuthenticationService _authenticationService;
/// <summary>
/// Initializes a new instance of the <see cref="OAuthController"/> class.
/// </summary>
/// <param name="authenticationService">Instance of <see cref="IAuthenticationService"/>.</param>
public OAuthController(IAuthenticationService authenticationService)
{
_authenticationService = authenticationService;
}
2024-12-11 23:12:53 +01:00
/// <summary>
/// Grant token request.
/// </summary>
/// <param name="tokenGrantRequest">Instance of <see cref="TokenGrantRequestModel"/>.</param>
[HttpPost("token")]
[AllowAnonymous]
2024-12-14 17:31:17 +01:00
public async Task<IActionResult> GrantToken([FromForm] TokenGrantRequestModel tokenGrantRequest)
2024-12-11 23:12:53 +01:00
{
2024-12-14 17:31:17 +01:00
if (tokenGrantRequest is null)
{
return MissingBodyResult();
}
if (!Enum.TryParse(tokenGrantRequest.GrantType, true, out OAuthGrantType grantType))
{
return FailureResult(ApiErrorCodes.UnsupportedGrantType, "Unknown grant type");
}
if (!Enum.TryParse(tokenGrantRequest.Scope, true, out TokenScope tokenScope))
{
return FailureResult(ApiErrorCodes.UnsupportedTokenScope, "Unknown token scope");
}
switch (grantType)
{
case OAuthGrantType.Password:
var request = new PasswordAuthenticateDto
{
Username = tokenGrantRequest.Username,
Password = tokenGrantRequest.Password,
Scope = tokenScope,
IpAddress = ClientIpAddress()
};
var result = await _authenticationService.AuthenticateSession(request);
return new JsonResult(new TokenGrantResultModel(result));
}
return FailureResult();
2024-12-11 23:12:53 +01:00
}
}