.Net Core OAuth возвращает 302 при перенаправлении кода авторизации - PullRequest
3 голосов
/ 04 мая 2019

Я пытаюсь реализовать OAuth для StripeConnect, используя .Net-Core 2.1.Я настроил свой запуск следующим образом:

services.AddAuthentication(options =>
{
    options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
    options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
})
.AddJwtBearer(cfg =>
{
    cfg.RequireHttpsMetadata = false;
    cfg.SaveToken = true;
    cfg.TokenValidationParameters = tokenValidationParameters;
})
.AddGoogle(options =>
{
    options.SaveTokens = true;
    options.ClientId = Configuration["Google:ClientId"];
    options.ClientSecret = Configuration["Google:ClientSecret"];
})
.AddOAuth(StripeConnectDefaults.AuthenticationScheme, options => {
    options.SaveTokens = true;
    options.ClientId = Configuration["Stripe:ClientId"];
    options.ClientSecret = Configuration["Stripe:ClientSecret"];
    options.TokenEndpoint = StripeConnectDefaults.TokenEndpoint;
    options.AuthorizationEndpoint = StripeConnectDefaults.AuthorizationEndpoint;
    options.CallbackPath = new PathString("/signin-stripeconnect");
    options.ClaimActions.MapJsonKey(ClaimTypes.NameIdentifier, "stripe_user_id");
});

Я могу получить OAuthTokenResponse Просто отлично с токенами, однако, когда он попадает в ExternalLoginCallback, токены не предоставляются

[HttpPost("ExternalLogin")]
[AllowAnonymous]
public IActionResult ExternalLogin(string provider, string returnUrl = null)
{
    var redirectUrl = Url.Action(nameof(ExternalLoginCallback), "Account", new { returnUrl });
    var properties = _signInManager.ConfigureExternalAuthenticationProperties(provider, redirectUrl);
    return Challenge(properties, provider);
}

[HttpGet("ExternalLoginCallback")]
[AllowAnonymous]
public async Task<IActionResult> ExternalLoginCallback(string returnUrl = null, string remoteError = null)
{
    if (remoteError != null)
    {
        throw new Exception($"Error from external provider: {remoteError}");
    }
    var info = await _signInManager.GetExternalLoginInfoAsync();
    if (info == null)
    {
        //It throws here, since there are no tokens 
        throw new Exception("Error: could not find user tokens");
    }

    //Handle the rest of authentication
}

Обновление

Я создал расследование Dummy Handler. Похоже, что я получаю OAuthTokenResponse Fine, но по какой-то причине менеджер подписи не находит токены:

public class DummyOAuthHandler<T> : OAuthHandler<T>
    where T: OAuthOptions, new()
{
    public DummyOAuthHandler(IOptionsMonitor<T> options, 
        ILoggerFactory logger, UrlEncoder encoder, ISystemClock clock) : base(options, logger, encoder, clock)
    {
    }

    protected override async Task<OAuthTokenResponse> ExchangeCodeAsync(string code, string redirectUri)
    {
        var result = await base.ExchangeCodeAsync(code, redirectUri);
        return result;
    }
}

Как получить .Net-core для правильного получения токенов с кодом авторизации?

...