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.
45 lines
1.8 KiB
45 lines
1.8 KiB
using System;
|
|
using System.Net.Http;
|
|
using System.Net.Http.Headers;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Authentication;
|
|
using Microsoft.AspNetCore.Authentication.Cookies;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.IdentityModel.Protocols.OpenIdConnect;
|
|
|
|
namespace Mvc.Client.Controllers
|
|
{
|
|
public class HomeController : Controller
|
|
{
|
|
private readonly IHttpClientFactory _httpClientFactory;
|
|
|
|
public HomeController(IHttpClientFactory httpClientFactory)
|
|
=> _httpClientFactory = httpClientFactory;
|
|
|
|
[HttpGet("~/")]
|
|
public ActionResult Index() => View("Home");
|
|
|
|
[Authorize, HttpPost("~/")]
|
|
public async Task<ActionResult> Index(CancellationToken cancellationToken)
|
|
{
|
|
var token = await HttpContext.GetTokenAsync(CookieAuthenticationDefaults.AuthenticationScheme, OpenIdConnectParameterNames.AccessToken);
|
|
if (string.IsNullOrEmpty(token))
|
|
{
|
|
throw new InvalidOperationException("The access token cannot be found in the authentication ticket. " +
|
|
"Make sure that SaveTokens is set to true in the OIDC options.");
|
|
}
|
|
|
|
using var client = _httpClientFactory.CreateClient();
|
|
|
|
using var request = new HttpRequestMessage(HttpMethod.Get, "https://localhost:44395/api/message");
|
|
request.Headers.Authorization = new AuthenticationHeaderValue("Bearer", token);
|
|
|
|
using var response = await client.SendAsync(request, cancellationToken);
|
|
response.EnsureSuccessStatusCode();
|
|
|
|
return View("Home", model: await response.Content.ReadAsStringAsync(cancellationToken));
|
|
}
|
|
}
|
|
}
|