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

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});
}
}