You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
32 lines
791 B
32 lines
791 B
using System.Security.Claims;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
|
|
namespace OAuthServer.Controllers;
|
|
|
|
[ApiController]
|
|
[Route("")]
|
|
public class ExternalController : ControllerBase
|
|
{
|
|
private readonly ILogger<ExternalController> _logger;
|
|
|
|
public ExternalController(ILogger<ExternalController> logger)
|
|
{
|
|
_logger = logger;
|
|
}
|
|
|
|
[HttpPost]
|
|
[Authorize(Policy = "External")]
|
|
[Route("points")]
|
|
public ActionResult PostPoints(int points)
|
|
{
|
|
var id = HttpContext.User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.NameIdentifier);
|
|
if (id == null)
|
|
{
|
|
return BadRequest();
|
|
}
|
|
|
|
_logger.LogInformation("User {} got {} points", id.Value, points);
|
|
return Ok();
|
|
}
|
|
} |