data-and-reporting-sdk
Version:
Data And Reporting product consists of API's which provides details of transaction and invoice informations about shell cards. The Shell Card Transaction and Invoice API is REST-based and employs Basic authentication in Version 1 and Oauth authentication
34 lines • 1.54 kB
JavaScript
;
/**
* Shell Data & Reporting APIsLib
*
* This file was automatically generated by APIMATIC v3.0 ( https://www.apimatic.io ).
*/
exports.__esModule = true;
exports.createAuthProviderFromConfig = void 0;
var authentication_1 = require("./authentication");
function createAuthProviderFromConfig(config, bearerToken) {
var authConfig = {
basicAuth: config.basicAuthCredentials &&
(0, authentication_1.basicAuthenticationProvider)(config.basicAuthCredentials.username, config.basicAuthCredentials.password),
bearerToken: config.bearerTokenCredentials &&
(0, authentication_1.requestAuthenticationProvider)(config.bearerTokenCredentials.oAuthToken, bearerTokenTokenProvider(bearerToken, config.bearerTokenCredentials.oAuthTokenProvider), config.bearerTokenCredentials.oAuthOnTokenUpdate, {
clockSkew: config.bearerTokenCredentials.oAuthClockSkew
})
};
return (0, authentication_1.compositeAuthenticationProvider)(authConfig);
}
exports.createAuthProviderFromConfig = createAuthProviderFromConfig;
function bearerTokenTokenProvider(bearerToken, defaultProvider) {
return function (token) {
var manager = bearerToken();
if (manager === undefined) {
throw Error('Unable to find the OAuthManager instance');
}
if (defaultProvider === undefined) {
return manager.updateToken(token);
}
return defaultProvider(token, manager);
};
}
//# sourceMappingURL=authProvider.js.map