Swagger/Swashbuckle: OAuth2 с полномочиями владельца ресурса

Я пытаюсь использовать Swashbuckle 5.0.x с OAuth2. Я хочу использовать грант учетных данных для владельца ресурса OAuth2. В основном я хочу сначала запросить маркер и включить этот токен в каждый запрос (например, нет необходимости в обласках).

Может ли кто-нибудь помочь с этим? Как мне настроить swagger/swashbuckle?

Ответ 1

ОК, я решил это следующим образом:

Добавить обработчик завершения JavaScript для чванства:

config
    .EnableSwagger(c => {
                    //do stuff
    })
    .EnableSwaggerUi(c => {
        c.InjectJavaScript(typeof(Startup).Assembly, "MyNamespace.SwaggerExtensions.onComplete.js");
    });

Возьмите имя пользователя: пароль из текстового поля API_KEY:

$('#input_apiKey').change(function () {
    var key = $('#input_apiKey')[0].value;
    var credentials = key.split(':'); //username:password expected
    $.ajax({
        url: "myURL",
        type: "post",
        contenttype: 'x-www-form-urlencoded',
        data: "grant_type=password&username=" + credentials[0] + "&password=" + credentials[1],
        success: function (response) {
            var bearerToken = 'Bearer ' + response.access_token;
            window.authorizations.add('key', new ApiKeyAuthorization('Authorization', bearerToken, 'header'));
        },
        error: function (xhr, ajaxoptions, thrownerror) {
            alert("Login failed!");
        }
    });
});

Ответ 2

Спасибо @Dunken. Ваш ответ почти решает мою проблему, но чтобы он работал с последней версией Swashbuckle, мне пришлось немного изменить ее как

$('#explore').off();

$('#explore').click(function () {
   var key = $('#input_apiKey')[0].value;
   var credentials = key.split(':'); //username:password expected

$.ajax({
    url: "yourAuthEndpoint",
    type: "post",
    contenttype: 'x-www-form-urlencoded',
    data: "grant_type=password&username=" + credentials[0] + "&password=" + credentials[1],
    success: function (response) {
        var bearerToken = 'Bearer ' + response.access_token;

        window.swaggerUi.api.clientAuthorizations.add('Authorization', new SwaggerClient.ApiKeyAuthorization('Authorization', bearerToken, 'header'));
        window.swaggerUi.api.clientAuthorizations.remove("api_key");
        alert("Login successfull");
       },
       error: function (xhr, ajaxoptions, thrownerror) {
        alert("Login failed!");
       }
    });
});