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.
35 lines
930 B
35 lines
930 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();
|
|
}
|
|
|
|
[HttpGet]
|
|
[Authorize(Policy = "External")]
|
|
[Route("user")]
|
|
public ActionResult GetUser() {
|
|
return Ok(new {UserId = 1});
|
|
}
|
|
} |