Мне нужно реализовать разную логику в зависимости от того, какая схема аутентификации использовалась для аутентификации пользователей. В настоящее время я использую функцию IAuthenticateResultFeature в HttpContext, но мне очень сложно ее модульное тестирование. Кроме того, мне это не очень нравится, поскольку весь код для его получения:
Код: Выделить всё
CurrentAuthScheme = context.HttpContext
.Features.Get()?
.AuthenticateResult?
.Ticket?.AuthenticationScheme;
И на самом деле это работает не так уж хорошо, потому что просто возвращает то, что передается в атрибут авторизации, а не фактическую схему, которая использовалась. Итак, если я использую, например:
Код: Выделить всё
[Authorize(AuthenticationSchemes = "Scheme1,Scheme2")]
Этот код вернет Scheme1, Scheme2, что совершенно не идеально, если мне когда-нибудь понадобится иметь несколько схем на конечной точке.
Есть ли какой-нибудь способ проверить, какая схема аутентификации использовалась для запроса? Разрешены любые изменения в ClaimsPrincipal или что-то еще, просто чтобы знать, какая схема фактически использовалась.
Подробнее здесь:
https://stackoverflow.com/questions/784 ... nt-request