Я пытаюсь реализовать 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 для правильного получения токенов с кодом авторизации?