New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@axway/amplify-auth-sdk

Package Overview
Dependencies
Maintainers
8
Versions
37
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@axway/amplify-auth-sdk - npm Package Compare versions

Comparing version 0.1.3 to 0.2.0

12

dist/endpoints.js

@@ -17,2 +17,3 @@ "use strict";

* @param {String} params.baseUrl - The base URL.
* @param {String} [params.platformUrl] - The platform URL.
* @param {String} params.realm - The authentication realm.

@@ -23,2 +24,3 @@ * @returns {Object}

baseUrl,
platformUrl,
realm

@@ -30,5 +32,9 @@ } = {}) {

if (platformUrl && typeof platformUrl !== 'string') {
throw _errors.default.INVALID_ARGUMENT('Expected platformUrl to be a non-empty string');
}
if (!realm || typeof realm !== 'string') {
throw _errors.default.INVALID_ARGUMENT('Expected realm to be a non-empty string');
} // strip the trailing slash
} // strip the trailing slashes

@@ -40,3 +46,5 @@

certs: `${baseUrl}/auth/realms/${realm}/protocol/openid-connect/certs`,
findSession: platformUrl ? `${platformUrl.replace(/\/$/, '')}/api/v1/auth/findSession` : undefined,
logout: `${baseUrl}/auth/realms/${realm}/protocol/openid-connect/logout`,
switchLoggedInOrg: platformUrl ? `${platformUrl.replace(/\/$/, '')}/api/v1/auth/switchLoggedInOrg` : undefined,
token: `${baseUrl}/auth/realms/${realm}/protocol/openid-connect/token`,

@@ -47,2 +55,2 @@ userinfo: `${baseUrl}/auth/realms/${realm}/protocol/openid-connect/userinfo`,

}
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVuZHBvaW50cy5qcyJdLCJuYW1lcyI6WyJnZXRFbmRwb2ludHMiLCJiYXNlVXJsIiwicmVhbG0iLCJFIiwiSU5WQUxJRF9BUkdVTUVOVCIsInJlcGxhY2UiLCJhdXRoIiwiY2VydHMiLCJsb2dvdXQiLCJ0b2tlbiIsInVzZXJpbmZvIiwid2VsbEtub3duIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7QUFFQTs7Ozs7Ozs7QUFRZSxTQUFTQSxZQUFULENBQXNCO0FBQUVDLEVBQUFBLE9BQUY7QUFBV0MsRUFBQUE7QUFBWCxJQUFxQixFQUEzQyxFQUErQztBQUM3RCxNQUFJLENBQUNELE9BQUQsSUFBWSxPQUFPQSxPQUFQLEtBQW1CLFFBQW5DLEVBQTZDO0FBQzVDLFVBQU1FLGdCQUFFQyxnQkFBRixDQUFtQiwyQ0FBbkIsQ0FBTjtBQUNBOztBQUVELE1BQUksQ0FBQ0YsS0FBRCxJQUFVLE9BQU9BLEtBQVAsS0FBaUIsUUFBL0IsRUFBeUM7QUFDeEMsVUFBTUMsZ0JBQUVDLGdCQUFGLENBQW1CLHlDQUFuQixDQUFOO0FBQ0EsR0FQNEQsQ0FTN0Q7OztBQUNBSCxFQUFBQSxPQUFPLEdBQUdBLE9BQU8sQ0FBQ0ksT0FBUixDQUFnQixLQUFoQixFQUF1QixFQUF2QixDQUFWO0FBRUEsU0FBTztBQUNOQyxJQUFBQSxJQUFJLEVBQVEsR0FBRUwsT0FBUSxnQkFBZUMsS0FBTSwrQkFEckM7QUFFTkssSUFBQUEsS0FBSyxFQUFPLEdBQUVOLE9BQVEsZ0JBQWVDLEtBQU0sZ0NBRnJDO0FBR05NLElBQUFBLE1BQU0sRUFBTSxHQUFFUCxPQUFRLGdCQUFlQyxLQUFNLGlDQUhyQztBQUlOTyxJQUFBQSxLQUFLLEVBQU8sR0FBRVIsT0FBUSxnQkFBZUMsS0FBTSxnQ0FKckM7QUFLTlEsSUFBQUEsUUFBUSxFQUFJLEdBQUVULE9BQVEsZ0JBQWVDLEtBQU0sbUNBTHJDO0FBTU5TLElBQUFBLFNBQVMsRUFBRyxHQUFFVixPQUFRLGdCQUFlQyxLQUFNO0FBTnJDLEdBQVA7QUFRQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBFIGZyb20gJy4vZXJyb3JzJztcblxuLyoqXG4gKiBDb25zdHJ1Y3RzIGFsbCBlbmRwb2ludHMuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IHBhcmFtcyAtIFJlcXVpcmVkIHBhcmFtZXRlcnMuXG4gKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLmJhc2VVcmwgLSBUaGUgYmFzZSBVUkwuXG4gKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLnJlYWxtIC0gVGhlIGF1dGhlbnRpY2F0aW9uIHJlYWxtLlxuICogQHJldHVybnMge09iamVjdH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZ2V0RW5kcG9pbnRzKHsgYmFzZVVybCwgcmVhbG0gfSA9IHt9KSB7XG5cdGlmICghYmFzZVVybCB8fCB0eXBlb2YgYmFzZVVybCAhPT0gJ3N0cmluZycpIHtcblx0XHR0aHJvdyBFLklOVkFMSURfQVJHVU1FTlQoJ0V4cGVjdGVkIGJhc2VVcmwgdG8gYmUgYSBub24tZW1wdHkgc3RyaW5nJyk7XG5cdH1cblxuXHRpZiAoIXJlYWxtIHx8IHR5cGVvZiByZWFsbSAhPT0gJ3N0cmluZycpIHtcblx0XHR0aHJvdyBFLklOVkFMSURfQVJHVU1FTlQoJ0V4cGVjdGVkIHJlYWxtIHRvIGJlIGEgbm9uLWVtcHR5IHN0cmluZycpO1xuXHR9XG5cblx0Ly8gc3RyaXAgdGhlIHRyYWlsaW5nIHNsYXNoXG5cdGJhc2VVcmwgPSBiYXNlVXJsLnJlcGxhY2UoL1xcLyQvLCAnJyk7XG5cblx0cmV0dXJuIHtcblx0XHRhdXRoOiAgICAgIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L2F1dGhgLFxuXHRcdGNlcnRzOiAgICAgYCR7YmFzZVVybH0vYXV0aC9yZWFsbXMvJHtyZWFsbX0vcHJvdG9jb2wvb3BlbmlkLWNvbm5lY3QvY2VydHNgLFxuXHRcdGxvZ291dDogICAgYCR7YmFzZVVybH0vYXV0aC9yZWFsbXMvJHtyZWFsbX0vcHJvdG9jb2wvb3BlbmlkLWNvbm5lY3QvbG9nb3V0YCxcblx0XHR0b2tlbjogICAgIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L3Rva2VuYCxcblx0XHR1c2VyaW5mbzogIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L3VzZXJpbmZvYCxcblx0XHR3ZWxsS25vd246IGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19Ly53ZWxsLWtub3duL29wZW5pZC1jb25maWd1cmF0aW9uYFxuXHR9O1xufVxuIl0sImZpbGUiOiJlbmRwb2ludHMuanMifQ==
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVuZHBvaW50cy5qcyJdLCJuYW1lcyI6WyJnZXRFbmRwb2ludHMiLCJiYXNlVXJsIiwicGxhdGZvcm1VcmwiLCJyZWFsbSIsIkUiLCJJTlZBTElEX0FSR1VNRU5UIiwicmVwbGFjZSIsImF1dGgiLCJjZXJ0cyIsImZpbmRTZXNzaW9uIiwidW5kZWZpbmVkIiwibG9nb3V0Iiwic3dpdGNoTG9nZ2VkSW5PcmciLCJ0b2tlbiIsInVzZXJpbmZvIiwid2VsbEtub3duIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7QUFFQTs7Ozs7Ozs7O0FBU2UsU0FBU0EsWUFBVCxDQUFzQjtBQUFFQyxFQUFBQSxPQUFGO0FBQVdDLEVBQUFBLFdBQVg7QUFBd0JDLEVBQUFBO0FBQXhCLElBQWtDLEVBQXhELEVBQTREO0FBQzFFLE1BQUksQ0FBQ0YsT0FBRCxJQUFZLE9BQU9BLE9BQVAsS0FBbUIsUUFBbkMsRUFBNkM7QUFDNUMsVUFBTUcsZ0JBQUVDLGdCQUFGLENBQW1CLDJDQUFuQixDQUFOO0FBQ0E7O0FBRUQsTUFBSUgsV0FBVyxJQUFJLE9BQU9BLFdBQVAsS0FBdUIsUUFBMUMsRUFBb0Q7QUFDbkQsVUFBTUUsZ0JBQUVDLGdCQUFGLENBQW1CLCtDQUFuQixDQUFOO0FBQ0E7O0FBRUQsTUFBSSxDQUFDRixLQUFELElBQVUsT0FBT0EsS0FBUCxLQUFpQixRQUEvQixFQUF5QztBQUN4QyxVQUFNQyxnQkFBRUMsZ0JBQUYsQ0FBbUIseUNBQW5CLENBQU47QUFDQSxHQVh5RSxDQWExRTs7O0FBQ0FKLEVBQUFBLE9BQU8sR0FBR0EsT0FBTyxDQUFDSyxPQUFSLENBQWdCLEtBQWhCLEVBQXVCLEVBQXZCLENBQVY7QUFFQSxTQUFPO0FBQ05DLElBQUFBLElBQUksRUFBZ0IsR0FBRU4sT0FBUSxnQkFBZUUsS0FBTSwrQkFEN0M7QUFFTkssSUFBQUEsS0FBSyxFQUFlLEdBQUVQLE9BQVEsZ0JBQWVFLEtBQU0sZ0NBRjdDO0FBR05NLElBQUFBLFdBQVcsRUFBUVAsV0FBVyxHQUFJLEdBQUVBLFdBQVcsQ0FBQ0ksT0FBWixDQUFvQixLQUFwQixFQUEyQixFQUEzQixDQUErQiwwQkFBckMsR0FBaUVJLFNBSHpGO0FBSU5DLElBQUFBLE1BQU0sRUFBYyxHQUFFVixPQUFRLGdCQUFlRSxLQUFNLGlDQUo3QztBQUtOUyxJQUFBQSxpQkFBaUIsRUFBRVYsV0FBVyxHQUFJLEdBQUVBLFdBQVcsQ0FBQ0ksT0FBWixDQUFvQixLQUFwQixFQUEyQixFQUEzQixDQUErQixnQ0FBckMsR0FBdUVJLFNBTC9GO0FBTU5HLElBQUFBLEtBQUssRUFBZSxHQUFFWixPQUFRLGdCQUFlRSxLQUFNLGdDQU43QztBQU9OVyxJQUFBQSxRQUFRLEVBQVksR0FBRWIsT0FBUSxnQkFBZUUsS0FBTSxtQ0FQN0M7QUFRTlksSUFBQUEsU0FBUyxFQUFXLEdBQUVkLE9BQVEsZ0JBQWVFLEtBQU07QUFSN0MsR0FBUDtBQVVBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEUgZnJvbSAnLi9lcnJvcnMnO1xuXG4vKipcbiAqIENvbnN0cnVjdHMgYWxsIGVuZHBvaW50cy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIC0gUmVxdWlyZWQgcGFyYW1ldGVycy5cbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXJhbXMuYmFzZVVybCAtIFRoZSBiYXNlIFVSTC5cbiAqIEBwYXJhbSB7U3RyaW5nfSBbcGFyYW1zLnBsYXRmb3JtVXJsXSAtIFRoZSBwbGF0Zm9ybSBVUkwuXG4gKiBAcGFyYW0ge1N0cmluZ30gcGFyYW1zLnJlYWxtIC0gVGhlIGF1dGhlbnRpY2F0aW9uIHJlYWxtLlxuICogQHJldHVybnMge09iamVjdH1cbiAqL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gZ2V0RW5kcG9pbnRzKHsgYmFzZVVybCwgcGxhdGZvcm1VcmwsIHJlYWxtIH0gPSB7fSkge1xuXHRpZiAoIWJhc2VVcmwgfHwgdHlwZW9mIGJhc2VVcmwgIT09ICdzdHJpbmcnKSB7XG5cdFx0dGhyb3cgRS5JTlZBTElEX0FSR1VNRU5UKCdFeHBlY3RlZCBiYXNlVXJsIHRvIGJlIGEgbm9uLWVtcHR5IHN0cmluZycpO1xuXHR9XG5cblx0aWYgKHBsYXRmb3JtVXJsICYmIHR5cGVvZiBwbGF0Zm9ybVVybCAhPT0gJ3N0cmluZycpIHtcblx0XHR0aHJvdyBFLklOVkFMSURfQVJHVU1FTlQoJ0V4cGVjdGVkIHBsYXRmb3JtVXJsIHRvIGJlIGEgbm9uLWVtcHR5IHN0cmluZycpO1xuXHR9XG5cblx0aWYgKCFyZWFsbSB8fCB0eXBlb2YgcmVhbG0gIT09ICdzdHJpbmcnKSB7XG5cdFx0dGhyb3cgRS5JTlZBTElEX0FSR1VNRU5UKCdFeHBlY3RlZCByZWFsbSB0byBiZSBhIG5vbi1lbXB0eSBzdHJpbmcnKTtcblx0fVxuXG5cdC8vIHN0cmlwIHRoZSB0cmFpbGluZyBzbGFzaGVzXG5cdGJhc2VVcmwgPSBiYXNlVXJsLnJlcGxhY2UoL1xcLyQvLCAnJyk7XG5cblx0cmV0dXJuIHtcblx0XHRhdXRoOiAgICAgICAgICAgICAgYCR7YmFzZVVybH0vYXV0aC9yZWFsbXMvJHtyZWFsbX0vcHJvdG9jb2wvb3BlbmlkLWNvbm5lY3QvYXV0aGAsXG5cdFx0Y2VydHM6ICAgICAgICAgICAgIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L2NlcnRzYCxcblx0XHRmaW5kU2Vzc2lvbjogICAgICAgcGxhdGZvcm1VcmwgPyBgJHtwbGF0Zm9ybVVybC5yZXBsYWNlKC9cXC8kLywgJycpfS9hcGkvdjEvYXV0aC9maW5kU2Vzc2lvbmAgOiB1bmRlZmluZWQsXG5cdFx0bG9nb3V0OiAgICAgICAgICAgIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L2xvZ291dGAsXG5cdFx0c3dpdGNoTG9nZ2VkSW5Pcmc6IHBsYXRmb3JtVXJsID8gYCR7cGxhdGZvcm1VcmwucmVwbGFjZSgvXFwvJC8sICcnKX0vYXBpL3YxL2F1dGgvc3dpdGNoTG9nZ2VkSW5PcmdgIDogdW5kZWZpbmVkLFxuXHRcdHRva2VuOiAgICAgICAgICAgICBgJHtiYXNlVXJsfS9hdXRoL3JlYWxtcy8ke3JlYWxtfS9wcm90b2NvbC9vcGVuaWQtY29ubmVjdC90b2tlbmAsXG5cdFx0dXNlcmluZm86ICAgICAgICAgIGAke2Jhc2VVcmx9L2F1dGgvcmVhbG1zLyR7cmVhbG19L3Byb3RvY29sL29wZW5pZC1jb25uZWN0L3VzZXJpbmZvYCxcblx0XHR3ZWxsS25vd246ICAgICAgICAgYCR7YmFzZVVybH0vYXV0aC9yZWFsbXMvJHtyZWFsbX0vLndlbGwta25vd24vb3BlbmlkLWNvbmZpZ3VyYXRpb25gXG5cdH07XG59XG4iXSwiZmlsZSI6ImVuZHBvaW50cy5qcyJ9

14

dist/environments.js

@@ -6,3 +6,3 @@ "use strict";

});
exports.default = void 0;
exports.default = exports.environments = void 0;

@@ -16,13 +16,17 @@ /**

dev: {
baseUrl: 'https://login-dev.axway.com'
baseUrl: 'https://login-dev.axway.com',
platformUrl: ''
},
preprod: {
baseUrl: 'https://login-preprod.axway.com'
baseUrl: 'https://login-preprod.axway.com',
platformUrl: 'https://platform-preprod.axwaytest.net'
},
prod: {
baseUrl: 'https://login.axway.com'
baseUrl: 'https://login.axway.com',
platformUrl: 'https://platform.axway.com'
}
};
exports.environments = environments;
var _default = environments;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVudmlyb25tZW50cy5qcyJdLCJuYW1lcyI6WyJlbnZpcm9ubWVudHMiLCJkZXYiLCJiYXNlVXJsIiwicHJlcHJvZCIsInByb2QiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7Ozs7QUFLQSxNQUFNQSxZQUFZLEdBQUc7QUFDcEJDLEVBQUFBLEdBQUcsRUFBRTtBQUNKQyxJQUFBQSxPQUFPLEVBQUU7QUFETCxHQURlO0FBSXBCQyxFQUFBQSxPQUFPLEVBQUU7QUFDUkQsSUFBQUEsT0FBTyxFQUFFO0FBREQsR0FKVztBQU9wQkUsRUFBQUEsSUFBSSxFQUFFO0FBQ0xGLElBQUFBLE9BQU8sRUFBRTtBQURKO0FBUGMsQ0FBckI7ZUFZZUYsWSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRW52aXJvbm1lbnQgc3BlY2lmaWMgZGVmYXVsdCBzZXR0aW5ncy5cbiAqXG4gKiBAdHlwZSB7T2JqZWN0fVxuICovXG5jb25zdCBlbnZpcm9ubWVudHMgPSB7XG5cdGRldjoge1xuXHRcdGJhc2VVcmw6ICdodHRwczovL2xvZ2luLWRldi5heHdheS5jb20nXG5cdH0sXG5cdHByZXByb2Q6IHtcblx0XHRiYXNlVXJsOiAnaHR0cHM6Ly9sb2dpbi1wcmVwcm9kLmF4d2F5LmNvbSdcblx0fSxcblx0cHJvZDoge1xuXHRcdGJhc2VVcmw6ICdodHRwczovL2xvZ2luLmF4d2F5LmNvbSdcblx0fVxufTtcblxuZXhwb3J0IGRlZmF1bHQgZW52aXJvbm1lbnRzO1xuIl0sImZpbGUiOiJlbnZpcm9ubWVudHMuanMifQ==
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVudmlyb25tZW50cy5qcyJdLCJuYW1lcyI6WyJlbnZpcm9ubWVudHMiLCJkZXYiLCJiYXNlVXJsIiwicGxhdGZvcm1VcmwiLCJwcmVwcm9kIiwicHJvZCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOzs7OztBQUtPLE1BQU1BLFlBQVksR0FBRztBQUMzQkMsRUFBQUEsR0FBRyxFQUFFO0FBQ0pDLElBQUFBLE9BQU8sRUFBRSw2QkFETDtBQUVKQyxJQUFBQSxXQUFXLEVBQUU7QUFGVCxHQURzQjtBQUszQkMsRUFBQUEsT0FBTyxFQUFFO0FBQ1JGLElBQUFBLE9BQU8sRUFBRSxpQ0FERDtBQUVSQyxJQUFBQSxXQUFXLEVBQUU7QUFGTCxHQUxrQjtBQVMzQkUsRUFBQUEsSUFBSSxFQUFFO0FBQ0xILElBQUFBLE9BQU8sRUFBRSx5QkFESjtBQUVMQyxJQUFBQSxXQUFXLEVBQUU7QUFGUjtBQVRxQixDQUFyQjs7ZUFlUUgsWSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogRW52aXJvbm1lbnQgc3BlY2lmaWMgZGVmYXVsdCBzZXR0aW5ncy5cbiAqXG4gKiBAdHlwZSB7T2JqZWN0fVxuICovXG5leHBvcnQgY29uc3QgZW52aXJvbm1lbnRzID0ge1xuXHRkZXY6IHtcblx0XHRiYXNlVXJsOiAnaHR0cHM6Ly9sb2dpbi1kZXYuYXh3YXkuY29tJyxcblx0XHRwbGF0Zm9ybVVybDogJydcblx0fSxcblx0cHJlcHJvZDoge1xuXHRcdGJhc2VVcmw6ICdodHRwczovL2xvZ2luLXByZXByb2QuYXh3YXkuY29tJyxcblx0XHRwbGF0Zm9ybVVybDogJ2h0dHBzOi8vcGxhdGZvcm0tcHJlcHJvZC5heHdheXRlc3QubmV0J1xuXHR9LFxuXHRwcm9kOiB7XG5cdFx0YmFzZVVybDogJ2h0dHBzOi8vbG9naW4uYXh3YXkuY29tJyxcblx0XHRwbGF0Zm9ybVVybDogJ2h0dHBzOi8vcGxhdGZvcm0uYXh3YXkuY29tJ1xuXHR9XG59O1xuXG5leHBvcnQgZGVmYXVsdCBlbnZpcm9ubWVudHM7XG4iXSwiZmlsZSI6ImVudmlyb25tZW50cy5qcyJ9

@@ -13,3 +13,2 @@ "use strict";

createError('INVALID_ARGUMENT', TypeError, 'A function argument is undefined or the incorrect data type');
createError('INVALID_BASE_URL', Error, 'Invalid base URL');
createError('INVALID_FILE', Error, 'The file does not exist or access is denied');

@@ -24,2 +23,4 @@ createError('INVALID_PARAMETER', TypeError, 'A parameter was not a valid value or type');

createError('MISSING_REQUIRED_PARAMETER', TypeError, 'A required parameter was not specified or not a valid type');
createError('ORG_SWITCH_FAILED', Error, 'Failed to switch the current org for some reason');
createError('REQUEST_FAILED', Error, 'An HTTP request has errored or returned an invalid response');
createError('TOKEN_EXPIRED', Error, 'The access token is expired');

@@ -76,2 +77,2 @@ /**

}
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVycm9ycy5qcyJdLCJuYW1lcyI6WyJlcnJvcnMiLCJjcmVhdGVFcnJvciIsIkVycm9yIiwiVHlwZUVycm9yIiwiUmFuZ2VFcnJvciIsImNvZGUiLCJ0eXBlIiwiZGVzYyIsIm1zZyIsIm1ldGEiLCJlcnIiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0aWVzIiwiY29uZmlndXJhYmxlIiwiZW51bWVyYWJsZSIsIndyaXRhYmxlIiwidmFsdWUiLCJ1bmRlZmluZWQiLCJuYW1lIiwidG9TdHJpbmciXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE1BQU1BLE1BQU0sR0FBRyxFQUFmO2VBQ2VBLE07O0FBRWZDLFdBQVcsQ0FBQyxhQUFELEVBQStCQyxLQUEvQixFQUEyQyxzQkFBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsY0FBRCxFQUErQkMsS0FBL0IsRUFBMkMsMkRBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLGtCQUFELEVBQStCRSxTQUEvQixFQUEyQyw2REFBM0MsQ0FBWDtBQUNBRixXQUFXLENBQUMsa0JBQUQsRUFBK0JDLEtBQS9CLEVBQTJDLGtCQUEzQyxDQUFYO0FBQ0FELFdBQVcsQ0FBQyxjQUFELEVBQStCQyxLQUEvQixFQUEyQyw2Q0FBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsbUJBQUQsRUFBK0JFLFNBQS9CLEVBQTJDLDJDQUEzQyxDQUFYO0FBQ0FGLFdBQVcsQ0FBQyxlQUFELEVBQStCRyxVQUEvQixFQUEyQyxzREFBM0MsQ0FBWDtBQUNBSCxXQUFXLENBQUMsZUFBRCxFQUErQkMsS0FBL0IsRUFBMkMsZ0NBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLGVBQUQsRUFBK0JDLEtBQS9CLEVBQTJDLDBDQUEzQyxDQUFYO0FBQ0FELFdBQVcsQ0FBQyxnQkFBRCxFQUErQkMsS0FBL0IsRUFBMkMsbUJBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLGtCQUFELEVBQStCQyxLQUEvQixFQUEyQyx1Q0FBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsbUJBQUQsRUFBK0JFLFNBQS9CLEVBQTJDLG9DQUEzQyxDQUFYO0FBQ0FGLFdBQVcsQ0FBQyw0QkFBRCxFQUErQkUsU0FBL0IsRUFBMkMsNERBQTNDLENBQVg7QUFDQUYsV0FBVyxDQUFDLGVBQUQsRUFBK0JDLEtBQS9CLEVBQTJDLDZCQUEzQyxDQUFYO0FBRUE7Ozs7Ozs7O0FBT0EsU0FBU0QsV0FBVCxDQUFxQkksSUFBckIsRUFBMkJDLElBQTNCLEVBQWlDQyxJQUFqQyxFQUF1QztBQUN0Q1AsRUFBQUEsTUFBTSxDQUFDSyxJQUFELENBQU4sR0FBZSxVQUFVRyxHQUFWLEVBQWVDLElBQWYsRUFBcUI7QUFDbkMsVUFBTUMsR0FBRyxHQUFHLElBQUlKLElBQUosQ0FBU0UsR0FBVCxDQUFaOztBQUVBLFFBQUlELElBQUosRUFBVTtBQUNULFVBQUksQ0FBQ0UsSUFBTCxFQUFXO0FBQ1ZBLFFBQUFBLElBQUksR0FBRyxFQUFQO0FBQ0E7O0FBQ0RBLE1BQUFBLElBQUksQ0FBQ0YsSUFBTCxHQUFZQSxJQUFaO0FBQ0E7O0FBRUQsV0FBT0ksTUFBTSxDQUFDQyxnQkFBUCxDQUF3QkYsR0FBeEIsRUFBNkI7QUFDbkNMLE1BQUFBLElBQUksRUFBRTtBQUNMUSxRQUFBQSxZQUFZLEVBQUUsSUFEVDtBQUVMQyxRQUFBQSxVQUFVLEVBQUUsSUFGUDtBQUdMQyxRQUFBQSxRQUFRLEVBQUUsSUFITDtBQUlMQyxRQUFBQSxLQUFLLEVBQUcsT0FBTVgsSUFBSztBQUpkLE9BRDZCO0FBT25DSSxNQUFBQSxJQUFJLEVBQUU7QUFDTEksUUFBQUEsWUFBWSxFQUFFLElBRFQ7QUFFTEcsUUFBQUEsS0FBSyxFQUFFUCxJQUFJLElBQUlRLFNBRlY7QUFHTEYsUUFBQUEsUUFBUSxFQUFFO0FBSEw7QUFQNkIsS0FBN0IsQ0FBUDtBQWFBLEdBdkJEOztBQXlCQUosRUFBQUEsTUFBTSxDQUFDQyxnQkFBUCxDQUF3QlosTUFBTSxDQUFDSyxJQUFELENBQTlCLEVBQXNDO0FBQ3JDYSxJQUFBQSxJQUFJLEVBQUU7QUFDTEwsTUFBQUEsWUFBWSxFQUFFLElBRFQ7QUFFTEcsTUFBQUEsS0FBSyxFQUFFWCxJQUZGO0FBR0xVLE1BQUFBLFFBQVEsRUFBRTtBQUhMLEtBRCtCO0FBTXJDSSxJQUFBQSxRQUFRLEVBQUU7QUFDVE4sTUFBQUEsWUFBWSxFQUFFLElBREw7QUFFVEcsTUFBQUEsS0FBSyxFQUFFLFNBQVNHLFFBQVQsR0FBb0I7QUFDMUIsZUFBUSxPQUFNZCxJQUFLLEVBQW5CO0FBQ0EsT0FKUTtBQUtUVSxNQUFBQSxRQUFRLEVBQUU7QUFMRDtBQU4yQixHQUF0QztBQWNBIiwic291cmNlc0NvbnRlbnQiOlsiY29uc3QgZXJyb3JzID0ge307XG5leHBvcnQgZGVmYXVsdCBlcnJvcnM7XG5cbmNyZWF0ZUVycm9yKCdBVVRIX0ZBSUxFRCcsICAgICAgICAgICAgICAgIEVycm9yLCAgICAgICdBdXRob3JpemF0aW9uIGZhaWxlZCcpO1xuY3JlYXRlRXJyb3IoJ0FVVEhfVElNRU9VVCcsICAgICAgICAgICAgICAgRXJyb3IsICAgICAgJ0Egc3VjY2Vzc2Z1bCBsb2dpbiBkaWQgbm90IGhhcHBlbiB3aXRoaW4gdGhlIGFsbG93ZWQgdGltZScpO1xuY3JlYXRlRXJyb3IoJ0lOVkFMSURfQVJHVU1FTlQnLCAgICAgICAgICAgVHlwZUVycm9yLCAgJ0EgZnVuY3Rpb24gYXJndW1lbnQgaXMgdW5kZWZpbmVkIG9yIHRoZSBpbmNvcnJlY3QgZGF0YSB0eXBlJyk7XG5jcmVhdGVFcnJvcignSU5WQUxJRF9CQVNFX1VSTCcsICAgICAgICAgICBFcnJvciwgICAgICAnSW52YWxpZCBiYXNlIFVSTCcpO1xuY3JlYXRlRXJyb3IoJ0lOVkFMSURfRklMRScsICAgICAgICAgICAgICAgRXJyb3IsICAgICAgJ1RoZSBmaWxlIGRvZXMgbm90IGV4aXN0IG9yIGFjY2VzcyBpcyBkZW5pZWQnKTtcbmNyZWF0ZUVycm9yKCdJTlZBTElEX1BBUkFNRVRFUicsICAgICAgICAgIFR5cGVFcnJvciwgICdBIHBhcmFtZXRlciB3YXMgbm90IGEgdmFsaWQgdmFsdWUgb3IgdHlwZScpO1xuY3JlYXRlRXJyb3IoJ0lOVkFMSURfUkFOR0UnLCAgICAgICAgICAgICAgUmFuZ2VFcnJvciwgJ1RoZSB2YWx1ZSBpcyBub3Qgd2l0aGluIHRoZSBhY2NlcHRhYmxlIG1pbi9tYXggcmFuZ2UnKTtcbmNyZWF0ZUVycm9yKCdJTlZBTElEX1RPS0VOJywgICAgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgdG9rZW4gY291bGQgbm90IGJlIGRlY29kZWQnKTtcbmNyZWF0ZUVycm9yKCdJTlZBTElEX1ZBTFVFJywgICAgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgc3BlY2lmaWVkIHZhbHVlIGlzIGFuIGFjY2VwdGVkIHZhbHVlJyk7XG5jcmVhdGVFcnJvcignTE9HSU5fUkVRVUlSRUQnLCAgICAgICAgICAgICBFcnJvciwgICAgICAnTG9naW4gaXMgcmVxdWlyZWQnKTtcbmNyZWF0ZUVycm9yKCdLRVlUQVJfTk9UX0ZPVU5EJywgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgdG9rZW4gc3RvcmUgY291bGQgbm90IGZpbmQga2V5dGFyJyk7XG5jcmVhdGVFcnJvcignTUlTU0lOR19BVVRIX0NPREUnLCAgICAgICAgICBUeXBlRXJyb3IsICAnQW4gYXV0aG9yaXphdGlvbiBjb2RlIHdhcyBleHBlY3RlZCcpO1xuY3JlYXRlRXJyb3IoJ01JU1NJTkdfUkVRVUlSRURfUEFSQU1FVEVSJywgVHlwZUVycm9yLCAgJ0EgcmVxdWlyZWQgcGFyYW1ldGVyIHdhcyBub3Qgc3BlY2lmaWVkIG9yIG5vdCBhIHZhbGlkIHR5cGUnKTtcbmNyZWF0ZUVycm9yKCdUT0tFTl9FWFBJUkVEJywgICAgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgYWNjZXNzIHRva2VuIGlzIGV4cGlyZWQnKTtcblxuLyoqXG4gKiBDcmVhdGVzIGFuIHRoZSBlcnJvciBvYmplY3QgYW5kIHBvcHVsYXRlcyB0aGUgbWVzc2FnZSwgY29kZSwgYW5kIG1ldGFkYXRhLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlIC0gVGhlIGVycm9yIGNvZGUuXG4gKiBAcGFyYW0ge0Vycm9yfFJhbmdlRXJyb3J8VHlwZUVycm9yfSB0eXBlIC0gQW4gaW5zdGFudGlhYmxlIGVycm9yIG9iamVjdC5cbiAqIEBwYXJhbSB7U3RyaW5nfSBkZXNjIC0gQSBnZW5lcmljIGVycm9yIGRlc2NyaXB0aW9uLlxuICovXG5mdW5jdGlvbiBjcmVhdGVFcnJvcihjb2RlLCB0eXBlLCBkZXNjKSB7XG5cdGVycm9yc1tjb2RlXSA9IGZ1bmN0aW9uIChtc2csIG1ldGEpIHtcblx0XHRjb25zdCBlcnIgPSBuZXcgdHlwZShtc2cpO1xuXG5cdFx0aWYgKGRlc2MpIHtcblx0XHRcdGlmICghbWV0YSkge1xuXHRcdFx0XHRtZXRhID0ge307XG5cdFx0XHR9XG5cdFx0XHRtZXRhLmRlc2MgPSBkZXNjO1xuXHRcdH1cblxuXHRcdHJldHVybiBPYmplY3QuZGVmaW5lUHJvcGVydGllcyhlcnIsIHtcblx0XHRcdGNvZGU6IHtcblx0XHRcdFx0Y29uZmlndXJhYmxlOiB0cnVlLFxuXHRcdFx0XHRlbnVtZXJhYmxlOiB0cnVlLFxuXHRcdFx0XHR3cml0YWJsZTogdHJ1ZSxcblx0XHRcdFx0dmFsdWU6IGBFUlJfJHtjb2RlfWBcblx0XHRcdH0sXG5cdFx0XHRtZXRhOiB7XG5cdFx0XHRcdGNvbmZpZ3VyYWJsZTogdHJ1ZSxcblx0XHRcdFx0dmFsdWU6IG1ldGEgfHwgdW5kZWZpbmVkLFxuXHRcdFx0XHR3cml0YWJsZTogdHJ1ZVxuXHRcdFx0fVxuXHRcdH0pO1xuXHR9O1xuXG5cdE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKGVycm9yc1tjb2RlXSwge1xuXHRcdG5hbWU6IHtcblx0XHRcdGNvbmZpZ3VyYWJsZTogdHJ1ZSxcblx0XHRcdHZhbHVlOiBjb2RlLFxuXHRcdFx0d3JpdGFibGU6IHRydWVcblx0XHR9LFxuXHRcdHRvU3RyaW5nOiB7XG5cdFx0XHRjb25maWd1cmFibGU6IHRydWUsXG5cdFx0XHR2YWx1ZTogZnVuY3Rpb24gdG9TdHJpbmcoKSB7XG5cdFx0XHRcdHJldHVybiBgRVJSXyR7Y29kZX1gO1xuXHRcdFx0fSxcblx0XHRcdHdyaXRhYmxlOiB0cnVlXG5cdFx0fVxuXHR9KTtcbn1cbiJdLCJmaWxlIjoiZXJyb3JzLmpzIn0=
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVycm9ycy5qcyJdLCJuYW1lcyI6WyJlcnJvcnMiLCJjcmVhdGVFcnJvciIsIkVycm9yIiwiVHlwZUVycm9yIiwiUmFuZ2VFcnJvciIsImNvZGUiLCJ0eXBlIiwiZGVzYyIsIm1zZyIsIm1ldGEiLCJlcnIiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0aWVzIiwiY29uZmlndXJhYmxlIiwiZW51bWVyYWJsZSIsIndyaXRhYmxlIiwidmFsdWUiLCJ1bmRlZmluZWQiLCJuYW1lIiwidG9TdHJpbmciXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLE1BQU1BLE1BQU0sR0FBRyxFQUFmO2VBQ2VBLE07O0FBRWZDLFdBQVcsQ0FBQyxhQUFELEVBQStCQyxLQUEvQixFQUEyQyxzQkFBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsY0FBRCxFQUErQkMsS0FBL0IsRUFBMkMsMkRBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLGtCQUFELEVBQStCRSxTQUEvQixFQUEyQyw2REFBM0MsQ0FBWDtBQUNBRixXQUFXLENBQUMsY0FBRCxFQUErQkMsS0FBL0IsRUFBMkMsNkNBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLG1CQUFELEVBQStCRSxTQUEvQixFQUEyQywyQ0FBM0MsQ0FBWDtBQUNBRixXQUFXLENBQUMsZUFBRCxFQUErQkcsVUFBL0IsRUFBMkMsc0RBQTNDLENBQVg7QUFDQUgsV0FBVyxDQUFDLGVBQUQsRUFBK0JDLEtBQS9CLEVBQTJDLGdDQUEzQyxDQUFYO0FBQ0FELFdBQVcsQ0FBQyxlQUFELEVBQStCQyxLQUEvQixFQUEyQywwQ0FBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsZ0JBQUQsRUFBK0JDLEtBQS9CLEVBQTJDLG1CQUEzQyxDQUFYO0FBQ0FELFdBQVcsQ0FBQyxrQkFBRCxFQUErQkMsS0FBL0IsRUFBMkMsdUNBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLG1CQUFELEVBQStCRSxTQUEvQixFQUEyQyxvQ0FBM0MsQ0FBWDtBQUNBRixXQUFXLENBQUMsNEJBQUQsRUFBK0JFLFNBQS9CLEVBQTJDLDREQUEzQyxDQUFYO0FBQ0FGLFdBQVcsQ0FBQyxtQkFBRCxFQUErQkMsS0FBL0IsRUFBMkMsa0RBQTNDLENBQVg7QUFDQUQsV0FBVyxDQUFDLGdCQUFELEVBQStCQyxLQUEvQixFQUEyQyw2REFBM0MsQ0FBWDtBQUNBRCxXQUFXLENBQUMsZUFBRCxFQUErQkMsS0FBL0IsRUFBMkMsNkJBQTNDLENBQVg7QUFFQTs7Ozs7Ozs7QUFPQSxTQUFTRCxXQUFULENBQXFCSSxJQUFyQixFQUEyQkMsSUFBM0IsRUFBaUNDLElBQWpDLEVBQXVDO0FBQ3RDUCxFQUFBQSxNQUFNLENBQUNLLElBQUQsQ0FBTixHQUFlLFVBQVVHLEdBQVYsRUFBZUMsSUFBZixFQUFxQjtBQUNuQyxVQUFNQyxHQUFHLEdBQUcsSUFBSUosSUFBSixDQUFTRSxHQUFULENBQVo7O0FBRUEsUUFBSUQsSUFBSixFQUFVO0FBQ1QsVUFBSSxDQUFDRSxJQUFMLEVBQVc7QUFDVkEsUUFBQUEsSUFBSSxHQUFHLEVBQVA7QUFDQTs7QUFDREEsTUFBQUEsSUFBSSxDQUFDRixJQUFMLEdBQVlBLElBQVo7QUFDQTs7QUFFRCxXQUFPSSxNQUFNLENBQUNDLGdCQUFQLENBQXdCRixHQUF4QixFQUE2QjtBQUNuQ0wsTUFBQUEsSUFBSSxFQUFFO0FBQ0xRLFFBQUFBLFlBQVksRUFBRSxJQURUO0FBRUxDLFFBQUFBLFVBQVUsRUFBRSxJQUZQO0FBR0xDLFFBQUFBLFFBQVEsRUFBRSxJQUhMO0FBSUxDLFFBQUFBLEtBQUssRUFBRyxPQUFNWCxJQUFLO0FBSmQsT0FENkI7QUFPbkNJLE1BQUFBLElBQUksRUFBRTtBQUNMSSxRQUFBQSxZQUFZLEVBQUUsSUFEVDtBQUVMRyxRQUFBQSxLQUFLLEVBQUVQLElBQUksSUFBSVEsU0FGVjtBQUdMRixRQUFBQSxRQUFRLEVBQUU7QUFITDtBQVA2QixLQUE3QixDQUFQO0FBYUEsR0F2QkQ7O0FBeUJBSixFQUFBQSxNQUFNLENBQUNDLGdCQUFQLENBQXdCWixNQUFNLENBQUNLLElBQUQsQ0FBOUIsRUFBc0M7QUFDckNhLElBQUFBLElBQUksRUFBRTtBQUNMTCxNQUFBQSxZQUFZLEVBQUUsSUFEVDtBQUVMRyxNQUFBQSxLQUFLLEVBQUVYLElBRkY7QUFHTFUsTUFBQUEsUUFBUSxFQUFFO0FBSEwsS0FEK0I7QUFNckNJLElBQUFBLFFBQVEsRUFBRTtBQUNUTixNQUFBQSxZQUFZLEVBQUUsSUFETDtBQUVURyxNQUFBQSxLQUFLLEVBQUUsU0FBU0csUUFBVCxHQUFvQjtBQUMxQixlQUFRLE9BQU1kLElBQUssRUFBbkI7QUFDQSxPQUpRO0FBS1RVLE1BQUFBLFFBQVEsRUFBRTtBQUxEO0FBTjJCLEdBQXRDO0FBY0EiLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCBlcnJvcnMgPSB7fTtcbmV4cG9ydCBkZWZhdWx0IGVycm9ycztcblxuY3JlYXRlRXJyb3IoJ0FVVEhfRkFJTEVEJywgICAgICAgICAgICAgICAgRXJyb3IsICAgICAgJ0F1dGhvcml6YXRpb24gZmFpbGVkJyk7XG5jcmVhdGVFcnJvcignQVVUSF9USU1FT1VUJywgICAgICAgICAgICAgICBFcnJvciwgICAgICAnQSBzdWNjZXNzZnVsIGxvZ2luIGRpZCBub3QgaGFwcGVuIHdpdGhpbiB0aGUgYWxsb3dlZCB0aW1lJyk7XG5jcmVhdGVFcnJvcignSU5WQUxJRF9BUkdVTUVOVCcsICAgICAgICAgICBUeXBlRXJyb3IsICAnQSBmdW5jdGlvbiBhcmd1bWVudCBpcyB1bmRlZmluZWQgb3IgdGhlIGluY29ycmVjdCBkYXRhIHR5cGUnKTtcbmNyZWF0ZUVycm9yKCdJTlZBTElEX0ZJTEUnLCAgICAgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgZmlsZSBkb2VzIG5vdCBleGlzdCBvciBhY2Nlc3MgaXMgZGVuaWVkJyk7XG5jcmVhdGVFcnJvcignSU5WQUxJRF9QQVJBTUVURVInLCAgICAgICAgICBUeXBlRXJyb3IsICAnQSBwYXJhbWV0ZXIgd2FzIG5vdCBhIHZhbGlkIHZhbHVlIG9yIHR5cGUnKTtcbmNyZWF0ZUVycm9yKCdJTlZBTElEX1JBTkdFJywgICAgICAgICAgICAgIFJhbmdlRXJyb3IsICdUaGUgdmFsdWUgaXMgbm90IHdpdGhpbiB0aGUgYWNjZXB0YWJsZSBtaW4vbWF4IHJhbmdlJyk7XG5jcmVhdGVFcnJvcignSU5WQUxJRF9UT0tFTicsICAgICAgICAgICAgICBFcnJvciwgICAgICAnVGhlIHRva2VuIGNvdWxkIG5vdCBiZSBkZWNvZGVkJyk7XG5jcmVhdGVFcnJvcignSU5WQUxJRF9WQUxVRScsICAgICAgICAgICAgICBFcnJvciwgICAgICAnVGhlIHNwZWNpZmllZCB2YWx1ZSBpcyBhbiBhY2NlcHRlZCB2YWx1ZScpO1xuY3JlYXRlRXJyb3IoJ0xPR0lOX1JFUVVJUkVEJywgICAgICAgICAgICAgRXJyb3IsICAgICAgJ0xvZ2luIGlzIHJlcXVpcmVkJyk7XG5jcmVhdGVFcnJvcignS0VZVEFSX05PVF9GT1VORCcsICAgICAgICAgICBFcnJvciwgICAgICAnVGhlIHRva2VuIHN0b3JlIGNvdWxkIG5vdCBmaW5kIGtleXRhcicpO1xuY3JlYXRlRXJyb3IoJ01JU1NJTkdfQVVUSF9DT0RFJywgICAgICAgICAgVHlwZUVycm9yLCAgJ0FuIGF1dGhvcml6YXRpb24gY29kZSB3YXMgZXhwZWN0ZWQnKTtcbmNyZWF0ZUVycm9yKCdNSVNTSU5HX1JFUVVJUkVEX1BBUkFNRVRFUicsIFR5cGVFcnJvciwgICdBIHJlcXVpcmVkIHBhcmFtZXRlciB3YXMgbm90IHNwZWNpZmllZCBvciBub3QgYSB2YWxpZCB0eXBlJyk7XG5jcmVhdGVFcnJvcignT1JHX1NXSVRDSF9GQUlMRUQnLCAgICAgICAgICBFcnJvciwgICAgICAnRmFpbGVkIHRvIHN3aXRjaCB0aGUgY3VycmVudCBvcmcgZm9yIHNvbWUgcmVhc29uJyk7XG5jcmVhdGVFcnJvcignUkVRVUVTVF9GQUlMRUQnLCAgICAgICAgICAgICBFcnJvciwgICAgICAnQW4gSFRUUCByZXF1ZXN0IGhhcyBlcnJvcmVkIG9yIHJldHVybmVkIGFuIGludmFsaWQgcmVzcG9uc2UnKTtcbmNyZWF0ZUVycm9yKCdUT0tFTl9FWFBJUkVEJywgICAgICAgICAgICAgIEVycm9yLCAgICAgICdUaGUgYWNjZXNzIHRva2VuIGlzIGV4cGlyZWQnKTtcblxuLyoqXG4gKiBDcmVhdGVzIGFuIHRoZSBlcnJvciBvYmplY3QgYW5kIHBvcHVsYXRlcyB0aGUgbWVzc2FnZSwgY29kZSwgYW5kIG1ldGFkYXRhLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBjb2RlIC0gVGhlIGVycm9yIGNvZGUuXG4gKiBAcGFyYW0ge0Vycm9yfFJhbmdlRXJyb3J8VHlwZUVycm9yfSB0eXBlIC0gQW4gaW5zdGFudGlhYmxlIGVycm9yIG9iamVjdC5cbiAqIEBwYXJhbSB7U3RyaW5nfSBkZXNjIC0gQSBnZW5lcmljIGVycm9yIGRlc2NyaXB0aW9uLlxuICovXG5mdW5jdGlvbiBjcmVhdGVFcnJvcihjb2RlLCB0eXBlLCBkZXNjKSB7XG5cdGVycm9yc1tjb2RlXSA9IGZ1bmN0aW9uIChtc2csIG1ldGEpIHtcblx0XHRjb25zdCBlcnIgPSBuZXcgdHlwZShtc2cpO1xuXG5cdFx0aWYgKGRlc2MpIHtcblx0XHRcdGlmICghbWV0YSkge1xuXHRcdFx0XHRtZXRhID0ge307XG5cdFx0XHR9XG5cdFx0XHRtZXRhLmRlc2MgPSBkZXNjO1xuXHRcdH1cblxuXHRcdHJldHVybiBPYmplY3QuZGVmaW5lUHJvcGVydGllcyhlcnIsIHtcblx0XHRcdGNvZGU6IHtcblx0XHRcdFx0Y29uZmlndXJhYmxlOiB0cnVlLFxuXHRcdFx0XHRlbnVtZXJhYmxlOiB0cnVlLFxuXHRcdFx0XHR3cml0YWJsZTogdHJ1ZSxcblx0XHRcdFx0dmFsdWU6IGBFUlJfJHtjb2RlfWBcblx0XHRcdH0sXG5cdFx0XHRtZXRhOiB7XG5cdFx0XHRcdGNvbmZpZ3VyYWJsZTogdHJ1ZSxcblx0XHRcdFx0dmFsdWU6IG1ldGEgfHwgdW5kZWZpbmVkLFxuXHRcdFx0XHR3cml0YWJsZTogdHJ1ZVxuXHRcdFx0fVxuXHRcdH0pO1xuXHR9O1xuXG5cdE9iamVjdC5kZWZpbmVQcm9wZXJ0aWVzKGVycm9yc1tjb2RlXSwge1xuXHRcdG5hbWU6IHtcblx0XHRcdGNvbmZpZ3VyYWJsZTogdHJ1ZSxcblx0XHRcdHZhbHVlOiBjb2RlLFxuXHRcdFx0d3JpdGFibGU6IHRydWVcblx0XHR9LFxuXHRcdHRvU3RyaW5nOiB7XG5cdFx0XHRjb25maWd1cmFibGU6IHRydWUsXG5cdFx0XHR2YWx1ZTogZnVuY3Rpb24gdG9TdHJpbmcoKSB7XG5cdFx0XHRcdHJldHVybiBgRVJSXyR7Y29kZX1gO1xuXHRcdFx0fSxcblx0XHRcdHdyaXRhYmxlOiB0cnVlXG5cdFx0fVxuXHR9KTtcbn1cbiJdLCJmaWxlIjoiZXJyb3JzLmpzIn0=

@@ -153,2 +153,3 @@ "use strict";

* @param {String} [opts.password] - The password used to authenticate. Requires a `username`.
* @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.
* @param {String} [opts.realm] - The name of the realm to authenticate with.

@@ -196,2 +197,5 @@ * @param {String} [opts.secretFile] - The path to the jwt secret file.

},
platformUrl: {
value: opts.platformUrl
},
realm: {

@@ -257,2 +261,3 @@ value: opts.realm

* @param {Object} [opts] - Various options.
* @returns {Object}
* @access private

@@ -279,2 +284,3 @@ */

opts.password = opts.password || this.password;
opts.platformUrl = opts.platformUrl || this.platformUrl || _environments.default[env].platformUrl;
opts.realm = opts.realm || this.realm;

@@ -285,2 +291,3 @@ opts.secretFile = opts.secretFile || this.secretFile;

opts.username = opts.username || this.username;
return opts;
}

@@ -331,3 +338,3 @@ /**

*
* @param {Object} opts - Required options.
* @param {Object|String} opts - Required options or a string containing the hash.
* @param {String} opts.accountName - The account name to retrieve.

@@ -337,2 +344,3 @@ * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not

* @param {String} [opts.baseUrl] - The base URL to filter by.
* @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.
* @returns {Promise<?Object>}

@@ -349,6 +357,23 @@ * @access public

this.applyDefaults(opts);
const authenticator = this.createAuthenticator(opts);
opts.hash = authenticator.hash;
return await this.tokenStore.get(opts);
let authenticator;
if (typeof opts === 'string') {
opts = this.applyDefaults({
hash: opts
});
} else {
this.applyDefaults(opts);
authenticator = this.createAuthenticator(opts);
opts.hash = authenticator.hash;
}
const account = await this.tokenStore.get(opts);
if (account && !account.expired) {
if (!authenticator) {
authenticator = this.createAuthenticator(opts);
}
return await authenticator.getInfo(account);
}
}

@@ -385,2 +410,3 @@ /**

* launching the auth URL in the default browser.
* @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.
* @param {String} [opts.realm] - The name of the realm to authenticate with.

@@ -486,6 +512,90 @@ * @param {Number} [opts.timeout] - The number of milliseconds to wait before timing out.

}
/**
* Switches the current organization.
*
* @param {Object} opts - Various options.
* @param {String} opts.accessToken - The access token.
* @param {Object} [opts.account] - The account object.
* @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.
* @param {String} opts.orgId - The org id.
* @param {String} [opts.platformUrl] - The Axway Platform URL.
* @param {String} [opts.realm] - The name of the realm to authenticate with.
* @returns {Promise<Object>} Resolves the selected organization info.
* @access public
*/
async switchOrg(opts) {
if (!opts || typeof opts !== 'object') {
throw _errors.default.INVALID_ARGUMENT('Expected options to be an object');
}
this.applyDefaults(opts);
const {
accessToken,
orgId
} = opts;
log(`Switching org to ${orgId}`);
const {
body,
error,
status,
statusCode
} = await (0, _amplifyRequest.default)({
formData: {
org_id: orgId
},
headers: {
Accept: 'application/json',
Authorization: `Bearer ${accessToken}`
},
method: 'POST',
url: `${(0, _endpoints.default)(opts).switchLoggedInOrg}`,
validateJSON: true
});
if (statusCode >= 200 && statusCode < 300) {
if (!body) {
throw _errors.default.REQUEST_FAILED(`Switch org failed: Response has no body (${status})`);
}
if (!body.success) {
throw _errors.default.REQUEST_FAILED(`Switch org failed: Request was not successful (${status})`);
}
if (!body.result) {
throw _errors.default.REQUEST_FAILED(`Switch org failed: Response did not contain a result (${status})`);
}
const org = {
name: body.result.org_name,
org_id: body.result.org_id
};
if (opts.account && typeof opts.account === 'object' && this.tokenStore) {
opts.account.org = org;
await this.tokenStore.set(opts.account);
}
return org;
}
let msg = error;
try {
const obj = JSON.parse(msg);
msg = `${obj.error}: ${obj.error_description}`;
} catch (e) {// squelch
}
msg = `Failed to switch org: ${msg.trim() || `server returned ${statusCode}`}`;
error(`${msg} ${note(`(${status})`)}`);
throw _errors.default.ORG_SWITCH_FAILED(msg, {
status
});
}
}
exports.Auth = exports.default = Auth;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.js"],"names":["Error","prepareStackTrace","require","log","alert","highlight","magenta","note","snooplogg","styles","Auth","constructor","opts","E","INVALID_ARGUMENT","Object","defineProperties","baseUrl","value","clientId","clientSecret","env","messages","password","realm","secretFile","serviceAccount","username","tokenStore","TokenStore","INVALID_PARAMETER","tokenStoreType","undefined","SecureStore","e","FileStore","code","MemoryStore","applyDefaults","environments","INVALID_VALUE","createAuthenticator","authenticator","Authenticator","INVALID_ARUGMENT","OwnerPassword","ClientSecret","SignedJWT","PKCE","getAccount","hash","get","list","login","revoke","accounts","all","Array","isArray","length","revoked","clear","delete","entry","url","logout","tokens","id_token","status","validateJSON","name","err","serverInfo","wellKnown"],"mappings":"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","sourcesContent":["/* istanbul ignore if */\nif (!Error.prepareStackTrace) {\n\trequire('source-map-support/register');\n}\n\nimport E from './errors';\n\nimport Authenticator from './authenticators/authenticator';\nimport ClientSecret from './authenticators/client-secret';\nimport OwnerPassword from './authenticators/owner-password';\nimport PKCE from './authenticators/pkce';\nimport SignedJWT from './authenticators/signed-jwt';\n\nimport FileStore from './stores/file-store';\nimport MemoryStore from './stores/memory-store';\nimport SecureStore from './stores/secure-store';\nimport TokenStore from './stores/token-store';\n\nimport environments from './environments';\nimport getEndpoints from './endpoints';\nimport snooplogg from 'snooplogg';\nimport * as server from './server';\n\nimport request from '@axway/amplify-request';\nimport { getServerInfo } from './util';\n\nconst { log } = snooplogg('amplify-auth');\nconst { alert, highlight, magenta, note } = snooplogg.styles;\n\n/**\n * Authenticates the machine and retreives the auth token.\n */\nexport default class Auth {\n\t/**\n\t * The store to persist the token.\n\t *\n\t * @type {TokenStore}\n\t * @access private\n\t */\n\ttokenStore = null;\n\n\t/**\n\t * Initializes the authentication instance by setting the default settings and creating the\n\t * token store.\n\t *\n\t * @param {Object} opts - Various options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.clientId] - The client id to specify when authenticating.\n\t * @param {String} [opts.clientSecret] - The secret token to use to authenticate.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {String} [opts.secureServiceName=\"Axway AMPLIFY Auth\"] - The name of the consumer\n\t * using this library when using the \"secure\" token store.\n\t * @param {String} [opts.password] - The password used to authenticate. Requires a `username`.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {String} [opts.secretFile] - The path to the jwt secret file.\n\t * @param {Boolean} [opts.serviceAccount=false] - When `true`, indicates authentication is being\n\t * requested by a service instead of a user.\n\t * @param {Boolean} [opts.tokenRefreshThreshold=0] - The number of seconds before the access\n\t * token expires and should be refreshed.\n\t * @param {TokenStore} [opts.tokenStore] - A token store instance for persisting the tokens.\n\t * @param {String} [opts.tokenStoreDir] - The directory where the token store is saved. Required\n\t * when the `tokenStoreType` is `secure` or `file`.\n\t * @param {String} [opts.tokenStoreType=auto] - The type of store to persist the access token.\n\t * Possible values include: `auto`, `secure`, `file`, or `memory`. If value is `auto`, it will\n\t * attempt to use `secure`, then `file`, then `memory`. If set to `null`, then it will not\n\t * persist the access token.\n\t * @param {String} [opts.username] - The username used to authenticate. Requires a `password`.\n\t * @access public\n\t */\n\tconstructor(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tObject.defineProperties(this, {\n\t\t\tbaseUrl:        { value: opts.baseUrl },\n\t\t\tclientId:       { value: opts.clientId },\n\t\t\tclientSecret:   { value: opts.clientSecret },\n\t\t\tenv:            { value: opts.env },\n\t\t\tmessages:       { value: opts.messages },\n\t\t\tpassword:       { value: opts.password },\n\t\t\trealm:          { value: opts.realm },\n\t\t\tsecretFile:     { value: opts.secretFile },\n\t\t\tserviceAccount: { value: opts.serviceAccount },\n\t\t\tusername:       { value: opts.username }\n\t\t});\n\n\t\tif (opts.tokenStore) {\n\t\t\tif (!(opts.tokenStore instanceof TokenStore)) {\n\t\t\t\tthrow E.INVALID_PARAMETER('Expected the token store to be a \"TokenStore\" instance');\n\t\t\t}\n\t\t\tthis.tokenStore = opts.tokenStore;\n\t\t} else {\n\t\t\tconst tokenStoreType = opts.tokenStoreType === undefined ? 'auto' : opts.tokenStoreType;\n\t\t\tswitch (tokenStoreType) {\n\t\t\t\tcase 'auto':\n\t\t\t\tcase 'secure':\n\t\t\t\t\ttry {\n\t\t\t\t\t\tthis.tokenStore = new SecureStore(opts);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t/* istanbul ignore if */\n\t\t\t\t\t\tif (tokenStoreType === 'auto') {\n\t\t\t\t\t\t\t// let 'auto' fall through\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\tcase 'file':\n\t\t\t\t\ttry {\n\t\t\t\t\t\tthis.tokenStore = new FileStore(opts);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t/* istanbul ignore if */\n\t\t\t\t\t\tif (tokenStoreType === 'auto' && e.code === 'ERR_MISSING_REQUIRED_PARAMETER') {\n\t\t\t\t\t\t\t// let 'auto' fall through\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\tcase 'memory':\n\t\t\t\t\tthis.tokenStore = new MemoryStore(opts);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Ensures the options contains the configurable settings. Validation is handled by the code\n\t * requiring the values.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @access private\n\t */\n\tapplyDefaults(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tconst env = opts.env || this.env || 'prod';\n\t\tif (!environments[env]) {\n\t\t\tthrow E.INVALID_VALUE(`Invalid environment: ${opts.env || this.env}`);\n\t\t}\n\n\t\topts.baseUrl        = opts.baseUrl || this.baseUrl || environments[env].baseUrl;\n\t\topts.clientId       = opts.clientId || this.clientId;\n\t\topts.clientSecret   = opts.clientSecret || this.clientSecret;\n\t\topts.env            = env;\n\t\topts.messages       = opts.messages || this.messages;\n\t\topts.password       = opts.password || this.password;\n\t\topts.realm          = opts.realm || this.realm;\n\t\topts.secretFile     = opts.secretFile || this.secretFile;\n\t\topts.serviceAccount = opts.serviceAccount || this.serviceAccount;\n\t\topts.tokenStore     = this.tokenStore;\n\t\topts.username       = opts.username || this.username;\n\t}\n\n\t/**\n\t * Creates an authetnicator based on the supplied options.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.clientSecret] - The secret token to use to authenticate.\n\t * @param {String} [opts.password] - The password used to authenticate. Requires a `username`.\n\t * @param {String} [opts.secretFile] - The path to the jwt secret file.\n\t * @param {Boolean} [opts.serviceAccount=false] - When `true`, indicates authentication is being\n\t * requested by a service instead of a user.\n\t * @param {String} [opts.username] - The username used to authenticate. Requires a `password`.\n\t * @returns {Authenticator}\n\t * @access public\n\t */\n\tcreateAuthenticator(opts = {}) {\n\t\tif (opts.authenticator) {\n\t\t\tif (!(opts.authenticator instanceof Authenticator)) {\n\t\t\t\tthrow E.INVALID_ARUGMENT('Expected authenticator to be an Authenticator instance.');\n\t\t\t}\n\t\t\treturn opts.authenticator;\n\t\t}\n\n\t\tif (typeof opts.username === 'string' && opts.username && typeof opts.password === 'string') {\n\t\t\treturn new OwnerPassword(opts);\n\t\t}\n\n\t\tif (typeof opts.clientSecret === 'string' && opts.clientSecret) {\n\t\t\treturn new ClientSecret(opts);\n\t\t}\n\n\t\tif (typeof opts.secretFile === 'string' && opts.secretFile) {\n\t\t\treturn new SignedJWT(opts);\n\t\t}\n\n\t\treturn new PKCE(opts);\n\t}\n\n\t/**\n\t * Retrieves the access token. If the authenticator is interactive and the authenticator has not\n\t * yet authenticated with the server, an error is thrown.\n\t *\n\t * @param {Object} opts - Required options.\n\t * @param {String} opts.accountName - The account name to retrieve.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.baseUrl] - The base URL to filter by.\n\t * @returns {Promise<?Object>}\n\t * @access public\n\t */\n\tasync getAccount(opts = {}) {\n\t\tif (!this.tokenStore) {\n\t\t\tlog('Cannot get account, no token store');\n\t\t\treturn null;\n\t\t}\n\n\t\tthis.applyDefaults(opts);\n\n\t\tconst authenticator = this.createAuthenticator(opts);\n\t\topts.hash = authenticator.hash;\n\t\treturn await this.tokenStore.get(opts);\n\t}\n\n\t/**\n\t * Returns a list of all valid access tokens.\n\t *\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync list() {\n\t\tif (this.tokenStore) {\n\t\t\treturn await this.tokenStore.list();\n\t\t}\n\t\treturn [];\n\t}\n\n\t/**\n\t * Authenticates using the configured authenticator.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {String|Array.<String>} [opt.app] - Specify the app to open the `target` with, or an\n\t * array with the app and app arguments.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.clientId] - The client id to specify when authenticating.\n\t * @param {String} [opts.code] - The authentication code from a successful interactive login.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {Boolean} [opts.manual=false] - When `true`, it will return the auth URL instead of\n\t * launching the auth URL in the default browser.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {Number} [opts.timeout] - The number of milliseconds to wait before timing out.\n\t * Defaults to the `interactiveLoginTimeout` property.\n\t * @param {Boolean} [opts.wait=false] - Wait for the opened app to exit before fulfilling the\n\t * promise. If `false` it's fulfilled immediately when opening the app.\n\t * @returns {Promise<Object>} Resolves an object containing the access token, account name, and\n\t * user info.\n\t * @access public\n\t */\n\tasync login(opts = {}) {\n\t\tthis.applyDefaults(opts);\n\t\tconst authenticator = this.createAuthenticator(opts);\n\t\treturn await authenticator.login(opts);\n\t}\n\n\t/**\n\t * Revokes all or specific authenticated accounts.\n\t *\n\t * @param {Object} opts - Required options.\n\t * @param {Array.<String>|String} opts.accounts - A list of accounts names.\n\t * @param {Boolean} opts.all - When `true`, revokes all accounts.\n\t * @param {String} [opts.baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>} Returns a list of revoked credentials.\n\t * @access public\n\t */\n\tasync revoke({ accounts, all, baseUrl } = {}) {\n\t\tif (!this.tokenStore) {\n\t\t\tlog('No token store, returning empty array');\n\t\t\treturn [];\n\t\t}\n\n\t\tif (!all && typeof accounts !== 'string' && !Array.isArray(accounts)) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected accounts to be \"all\" or a list of accounts');\n\t\t}\n\n\t\tif (!all && !accounts.length) {\n\t\t\treturn [];\n\t\t}\n\n\t\tlet revoked;\n\t\tif (all) {\n\t\t\trevoked = await this.tokenStore.clear(baseUrl);\n\t\t} else {\n\t\t\trevoked = await this.tokenStore.delete(accounts, baseUrl);\n\t\t}\n\n\t\tif (Array.isArray(revoked)) {\n\t\t\tfor (const entry of revoked) {\n\t\t\t\tconst url = `${getEndpoints(entry).logout}?id_token_hint=${entry.tokens.id_token}`;\n\t\t\t\ttry {\n\t\t\t\t\tconst { status } = await request({ url, validateJSON: true });\n\t\t\t\t\tlog(`Successfully logged out ${highlight(entry.name)} ${magenta(status)} ${note(`(${entry.baseUrl}, ${entry.realm})`)}`);\n\t\t\t\t} catch (err) {\n\t\t\t\t\tlog(`Failed to log out ${highlight(entry.name)} ${alert(err.status)} ${note(`(${entry.baseUrl}, ${entry.realm})`)}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn revoked;\n\t}\n\n\t/**\n\t * Discovers available endpoints based on the authentication server's OpenID configuration.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {String} [opts.url] - An optional URL to discover the available endpoints.\n\t * @returns {Promise<Object>}\n\t * @access public\n\t */\n\tasync serverInfo(opts = {}) {\n\t\tthis.applyDefaults(opts);\n\n\t\tlet { url } = opts;\n\n\t\tif (!url) {\n\t\t\turl = getEndpoints(opts).wellKnown;\n\t\t}\n\n\t\treturn await getServerInfo(url);\n\t}\n}\n\nexport {\n\tAuth,\n\n\tAuthenticator,\n\tClientSecret,\n\tOwnerPassword,\n\tPKCE,\n\tSignedJWT,\n\n\tFileStore,\n\tMemoryStore,\n\tSecureStore,\n\tTokenStore,\n\n\tenvironments,\n\tgetEndpoints,\n\tserver\n};\n"],"file":"index.js"}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["index.js"],"names":["Error","prepareStackTrace","require","log","alert","highlight","magenta","note","snooplogg","styles","Auth","constructor","opts","E","INVALID_ARGUMENT","Object","defineProperties","baseUrl","value","clientId","clientSecret","env","messages","password","platformUrl","realm","secretFile","serviceAccount","username","tokenStore","TokenStore","INVALID_PARAMETER","tokenStoreType","undefined","SecureStore","e","FileStore","code","MemoryStore","applyDefaults","environments","INVALID_VALUE","createAuthenticator","authenticator","Authenticator","INVALID_ARUGMENT","OwnerPassword","ClientSecret","SignedJWT","PKCE","getAccount","hash","account","get","expired","getInfo","list","login","revoke","accounts","all","Array","isArray","length","revoked","clear","delete","entry","url","logout","tokens","id_token","status","validateJSON","name","err","serverInfo","wellKnown","switchOrg","accessToken","orgId","body","error","statusCode","formData","org_id","headers","Accept","Authorization","method","switchLoggedInOrg","REQUEST_FAILED","success","result","org","org_name","set","msg","obj","JSON","parse","error_description","trim","ORG_SWITCH_FAILED"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA;;AAEA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;;;AAEA;;AACA;;;;;;;;AAxBA;AACA,IAAI,CAACA,KAAK,CAACC,iBAAX,EAA8B;AAC7BC,EAAAA,OAAO,CAAC,6BAAD,CAAP;AACA;;AAuBD,MAAM;AAAEC,EAAAA;AAAF,IAAU,wBAAU,cAAV,CAAhB;AACA,MAAM;AAAEC,EAAAA,KAAF;AAASC,EAAAA,SAAT;AAAoBC,EAAAA,OAApB;AAA6BC,EAAAA;AAA7B,IAAsCC,mBAAUC,MAAtD;AAEA;;;;AAGe,MAAMC,IAAN,CAAW;AACzB;;;;;;;AAQA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BAC,EAAAA,WAAW,CAACC,IAAI,GAAG,EAAR,EAAY;AAAA,wCAhCV,IAgCU;;AACtB,QAAI,CAACA,IAAD,IAAS,OAAOA,IAAP,KAAgB,QAA7B,EAAuC;AACtC,YAAMC,gBAAEC,gBAAF,CAAmB,kCAAnB,CAAN;AACA;;AAEDC,IAAAA,MAAM,CAACC,gBAAP,CAAwB,IAAxB,EAA8B;AAC7BC,MAAAA,OAAO,EAAS;AAAEC,QAAAA,KAAK,EAAEN,IAAI,CAACK;AAAd,OADa;AAE7BE,MAAAA,QAAQ,EAAQ;AAAED,QAAAA,KAAK,EAAEN,IAAI,CAACO;AAAd,OAFa;AAG7BC,MAAAA,YAAY,EAAI;AAAEF,QAAAA,KAAK,EAAEN,IAAI,CAACQ;AAAd,OAHa;AAI7BC,MAAAA,GAAG,EAAa;AAAEH,QAAAA,KAAK,EAAEN,IAAI,CAACS;AAAd,OAJa;AAK7BC,MAAAA,QAAQ,EAAQ;AAAEJ,QAAAA,KAAK,EAAEN,IAAI,CAACU;AAAd,OALa;AAM7BC,MAAAA,QAAQ,EAAQ;AAAEL,QAAAA,KAAK,EAAEN,IAAI,CAACW;AAAd,OANa;AAO7BC,MAAAA,WAAW,EAAK;AAAEN,QAAAA,KAAK,EAAEN,IAAI,CAACY;AAAd,OAPa;AAQ7BC,MAAAA,KAAK,EAAW;AAAEP,QAAAA,KAAK,EAAEN,IAAI,CAACa;AAAd,OARa;AAS7BC,MAAAA,UAAU,EAAM;AAAER,QAAAA,KAAK,EAAEN,IAAI,CAACc;AAAd,OATa;AAU7BC,MAAAA,cAAc,EAAE;AAAET,QAAAA,KAAK,EAAEN,IAAI,CAACe;AAAd,OAVa;AAW7BC,MAAAA,QAAQ,EAAQ;AAAEV,QAAAA,KAAK,EAAEN,IAAI,CAACgB;AAAd;AAXa,KAA9B;;AAcA,QAAIhB,IAAI,CAACiB,UAAT,EAAqB;AACpB,UAAI,EAAEjB,IAAI,CAACiB,UAAL,YAA2BC,mBAA7B,CAAJ,EAA8C;AAC7C,cAAMjB,gBAAEkB,iBAAF,CAAoB,wDAApB,CAAN;AACA;;AACD,WAAKF,UAAL,GAAkBjB,IAAI,CAACiB,UAAvB;AACA,KALD,MAKO;AACN,YAAMG,cAAc,GAAGpB,IAAI,CAACoB,cAAL,KAAwBC,SAAxB,GAAoC,MAApC,GAA6CrB,IAAI,CAACoB,cAAzE;;AACA,cAAQA,cAAR;AACC,aAAK,MAAL;AACA,aAAK,QAAL;AACC,cAAI;AACH,iBAAKH,UAAL,GAAkB,IAAIK,oBAAJ,CAAgBtB,IAAhB,CAAlB;AACA;AACA,WAHD,CAGE,OAAOuB,CAAP,EAAU;AACX;AACA,gBAAIH,cAAc,KAAK,MAAvB,EAA+B,CAC9B;AACA,aAFD,MAEO;AACN,oBAAMG,CAAN;AACA;AACD;;AAEF,aAAK,MAAL;AACC,cAAI;AACH,iBAAKN,UAAL,GAAkB,IAAIO,kBAAJ,CAAcxB,IAAd,CAAlB;AACA;AACA,WAHD,CAGE,OAAOuB,CAAP,EAAU;AACX;AACA,gBAAIH,cAAc,KAAK,MAAnB,IAA6BG,CAAC,CAACE,IAAF,KAAW,gCAA5C,EAA8E,CAC7E;AACA,aAFD,MAEO;AACN,oBAAMF,CAAN;AACA;AACD;;AAEF,aAAK,QAAL;AACC,eAAKN,UAAL,GAAkB,IAAIS,oBAAJ,CAAgB1B,IAAhB,CAAlB;AACA;AA9BF;AAgCA;AACD;AAED;;;;;;;;;;AAQA2B,EAAAA,aAAa,CAAC3B,IAAI,GAAG,EAAR,EAAY;AACxB,QAAI,CAACA,IAAD,IAAS,OAAOA,IAAP,KAAgB,QAA7B,EAAuC;AACtC,YAAMC,gBAAEC,gBAAF,CAAmB,kCAAnB,CAAN;AACA;;AAED,UAAMO,GAAG,GAAGT,IAAI,CAACS,GAAL,IAAY,KAAKA,GAAjB,IAAwB,MAApC;;AACA,QAAI,CAACmB,sBAAanB,GAAb,CAAL,EAAwB;AACvB,YAAMR,gBAAE4B,aAAF,CAAiB,wBAAuB7B,IAAI,CAACS,GAAL,IAAY,KAAKA,GAAI,EAA7D,CAAN;AACA;;AAEDT,IAAAA,IAAI,CAACK,OAAL,GAAsBL,IAAI,CAACK,OAAL,IAAgB,KAAKA,OAArB,IAAgCuB,sBAAanB,GAAb,EAAkBJ,OAAxE;AACAL,IAAAA,IAAI,CAACO,QAAL,GAAsBP,IAAI,CAACO,QAAL,IAAiB,KAAKA,QAA5C;AACAP,IAAAA,IAAI,CAACQ,YAAL,GAAsBR,IAAI,CAACQ,YAAL,IAAqB,KAAKA,YAAhD;AACAR,IAAAA,IAAI,CAACS,GAAL,GAAsBA,GAAtB;AACAT,IAAAA,IAAI,CAACU,QAAL,GAAsBV,IAAI,CAACU,QAAL,IAAiB,KAAKA,QAA5C;AACAV,IAAAA,IAAI,CAACW,QAAL,GAAsBX,IAAI,CAACW,QAAL,IAAiB,KAAKA,QAA5C;AACAX,IAAAA,IAAI,CAACY,WAAL,GAAsBZ,IAAI,CAACY,WAAL,IAAoB,KAAKA,WAAzB,IAAwCgB,sBAAanB,GAAb,EAAkBG,WAAhF;AACAZ,IAAAA,IAAI,CAACa,KAAL,GAAsBb,IAAI,CAACa,KAAL,IAAc,KAAKA,KAAzC;AACAb,IAAAA,IAAI,CAACc,UAAL,GAAsBd,IAAI,CAACc,UAAL,IAAmB,KAAKA,UAA9C;AACAd,IAAAA,IAAI,CAACe,cAAL,GAAsBf,IAAI,CAACe,cAAL,IAAuB,KAAKA,cAAlD;AACAf,IAAAA,IAAI,CAACiB,UAAL,GAAsB,KAAKA,UAA3B;AACAjB,IAAAA,IAAI,CAACgB,QAAL,GAAsBhB,IAAI,CAACgB,QAAL,IAAiB,KAAKA,QAA5C;AAEA,WAAOhB,IAAP;AACA;AAED;;;;;;;;;;;;;;;;;AAeA8B,EAAAA,mBAAmB,CAAC9B,IAAI,GAAG,EAAR,EAAY;AAC9B,QAAIA,IAAI,CAAC+B,aAAT,EAAwB;AACvB,UAAI,EAAE/B,IAAI,CAAC+B,aAAL,YAA8BC,sBAAhC,CAAJ,EAAoD;AACnD,cAAM/B,gBAAEgC,gBAAF,CAAmB,yDAAnB,CAAN;AACA;;AACD,aAAOjC,IAAI,CAAC+B,aAAZ;AACA;;AAED,QAAI,OAAO/B,IAAI,CAACgB,QAAZ,KAAyB,QAAzB,IAAqChB,IAAI,CAACgB,QAA1C,IAAsD,OAAOhB,IAAI,CAACW,QAAZ,KAAyB,QAAnF,EAA6F;AAC5F,aAAO,IAAIuB,sBAAJ,CAAkBlC,IAAlB,CAAP;AACA;;AAED,QAAI,OAAOA,IAAI,CAACQ,YAAZ,KAA6B,QAA7B,IAAyCR,IAAI,CAACQ,YAAlD,EAAgE;AAC/D,aAAO,IAAI2B,qBAAJ,CAAiBnC,IAAjB,CAAP;AACA;;AAED,QAAI,OAAOA,IAAI,CAACc,UAAZ,KAA2B,QAA3B,IAAuCd,IAAI,CAACc,UAAhD,EAA4D;AAC3D,aAAO,IAAIsB,kBAAJ,CAAcpC,IAAd,CAAP;AACA;;AAED,WAAO,IAAIqC,aAAJ,CAASrC,IAAT,CAAP;AACA;AAED;;;;;;;;;;;;;;;AAaA,QAAMsC,UAAN,CAAiBtC,IAAI,GAAG,EAAxB,EAA4B;AAC3B,QAAI,CAAC,KAAKiB,UAAV,EAAsB;AACrB1B,MAAAA,GAAG,CAAC,oCAAD,CAAH;AACA,aAAO,IAAP;AACA;;AAED,QAAIwC,aAAJ;;AAEA,QAAI,OAAO/B,IAAP,KAAgB,QAApB,EAA8B;AAC7BA,MAAAA,IAAI,GAAG,KAAK2B,aAAL,CAAmB;AAAEY,QAAAA,IAAI,EAAEvC;AAAR,OAAnB,CAAP;AACA,KAFD,MAEO;AACN,WAAK2B,aAAL,CAAmB3B,IAAnB;AACA+B,MAAAA,aAAa,GAAG,KAAKD,mBAAL,CAAyB9B,IAAzB,CAAhB;AACAA,MAAAA,IAAI,CAACuC,IAAL,GAAYR,aAAa,CAACQ,IAA1B;AACA;;AAED,UAAMC,OAAO,GAAG,MAAM,KAAKvB,UAAL,CAAgBwB,GAAhB,CAAoBzC,IAApB,CAAtB;;AACA,QAAIwC,OAAO,IAAI,CAACA,OAAO,CAACE,OAAxB,EAAiC;AAChC,UAAI,CAACX,aAAL,EAAoB;AACnBA,QAAAA,aAAa,GAAG,KAAKD,mBAAL,CAAyB9B,IAAzB,CAAhB;AACA;;AACD,aAAO,MAAM+B,aAAa,CAACY,OAAd,CAAsBH,OAAtB,CAAb;AACA;AACD;AAED;;;;;;;;AAMA,QAAMI,IAAN,GAAa;AACZ,QAAI,KAAK3B,UAAT,EAAqB;AACpB,aAAO,MAAM,KAAKA,UAAL,CAAgB2B,IAAhB,EAAb;AACA;;AACD,WAAO,EAAP;AACA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyBA,QAAMC,KAAN,CAAY7C,IAAI,GAAG,EAAnB,EAAuB;AACtB,SAAK2B,aAAL,CAAmB3B,IAAnB;AACA,UAAM+B,aAAa,GAAG,KAAKD,mBAAL,CAAyB9B,IAAzB,CAAtB;AACA,WAAO,MAAM+B,aAAa,CAACc,KAAd,CAAoB7C,IAApB,CAAb;AACA;AAED;;;;;;;;;;;;AAUA,QAAM8C,MAAN,CAAa;AAAEC,IAAAA,QAAF;AAAYC,IAAAA,GAAZ;AAAiB3C,IAAAA;AAAjB,MAA6B,EAA1C,EAA8C;AAC7C,QAAI,CAAC,KAAKY,UAAV,EAAsB;AACrB1B,MAAAA,GAAG,CAAC,uCAAD,CAAH;AACA,aAAO,EAAP;AACA;;AAED,QAAI,CAACyD,GAAD,IAAQ,OAAOD,QAAP,KAAoB,QAA5B,IAAwC,CAACE,KAAK,CAACC,OAAN,CAAcH,QAAd,CAA7C,EAAsE;AACrE,YAAM9C,gBAAEC,gBAAF,CAAmB,qDAAnB,CAAN;AACA;;AAED,QAAI,CAAC8C,GAAD,IAAQ,CAACD,QAAQ,CAACI,MAAtB,EAA8B;AAC7B,aAAO,EAAP;AACA;;AAED,QAAIC,OAAJ;;AACA,QAAIJ,GAAJ,EAAS;AACRI,MAAAA,OAAO,GAAG,MAAM,KAAKnC,UAAL,CAAgBoC,KAAhB,CAAsBhD,OAAtB,CAAhB;AACA,KAFD,MAEO;AACN+C,MAAAA,OAAO,GAAG,MAAM,KAAKnC,UAAL,CAAgBqC,MAAhB,CAAuBP,QAAvB,EAAiC1C,OAAjC,CAAhB;AACA;;AAED,QAAI4C,KAAK,CAACC,OAAN,CAAcE,OAAd,CAAJ,EAA4B;AAC3B,WAAK,MAAMG,KAAX,IAAoBH,OAApB,EAA6B;AAC5B,cAAMI,GAAG,GAAI,GAAE,wBAAaD,KAAb,EAAoBE,MAAO,kBAAiBF,KAAK,CAACG,MAAN,CAAaC,QAAS,EAAjF;;AACA,YAAI;AACH,gBAAM;AAAEC,YAAAA;AAAF,cAAa,MAAM,6BAAQ;AAAEJ,YAAAA,GAAF;AAAOK,YAAAA,YAAY,EAAE;AAArB,WAAR,CAAzB;AACAtE,UAAAA,GAAG,CAAE,2BAA0BE,SAAS,CAAC8D,KAAK,CAACO,IAAP,CAAa,IAAGpE,OAAO,CAACkE,MAAD,CAAS,IAAGjE,IAAI,CAAE,IAAG4D,KAAK,CAAClD,OAAQ,KAAIkD,KAAK,CAAC1C,KAAM,GAAnC,CAAuC,EAAnH,CAAH;AACA,SAHD,CAGE,OAAOkD,GAAP,EAAY;AACbxE,UAAAA,GAAG,CAAE,qBAAoBE,SAAS,CAAC8D,KAAK,CAACO,IAAP,CAAa,IAAGtE,KAAK,CAACuE,GAAG,CAACH,MAAL,CAAa,IAAGjE,IAAI,CAAE,IAAG4D,KAAK,CAAClD,OAAQ,KAAIkD,KAAK,CAAC1C,KAAM,GAAnC,CAAuC,EAA/G,CAAH;AACA;AACD;AACD;;AAED,WAAOuC,OAAP;AACA;AAED;;;;;;;;;;;;;;AAYA,QAAMY,UAAN,CAAiBhE,IAAI,GAAG,EAAxB,EAA4B;AAC3B,SAAK2B,aAAL,CAAmB3B,IAAnB;AAEA,QAAI;AAAEwD,MAAAA;AAAF,QAAUxD,IAAd;;AAEA,QAAI,CAACwD,GAAL,EAAU;AACTA,MAAAA,GAAG,GAAG,wBAAaxD,IAAb,EAAmBiE,SAAzB;AACA;;AAED,WAAO,MAAM,yBAAcT,GAAd,CAAb;AACA;AAED;;;;;;;;;;;;;;;AAaA,QAAMU,SAAN,CAAgBlE,IAAhB,EAAsB;AACrB,QAAI,CAACA,IAAD,IAAS,OAAOA,IAAP,KAAgB,QAA7B,EAAuC;AACtC,YAAMC,gBAAEC,gBAAF,CAAmB,kCAAnB,CAAN;AACA;;AAED,SAAKyB,aAAL,CAAmB3B,IAAnB;AAEA,UAAM;AAAEmE,MAAAA,WAAF;AAAeC,MAAAA;AAAf,QAAyBpE,IAA/B;AACAT,IAAAA,GAAG,CAAE,oBAAmB6E,KAAM,EAA3B,CAAH;AAEA,UAAM;AAAEC,MAAAA,IAAF;AAAQC,MAAAA,KAAR;AAAeV,MAAAA,MAAf;AAAuBW,MAAAA;AAAvB,QAAsC,MAAM,6BAAQ;AACzDC,MAAAA,QAAQ,EAAE;AAAEC,QAAAA,MAAM,EAAEL;AAAV,OAD+C;AAEzDM,MAAAA,OAAO,EAAE;AACRC,QAAAA,MAAM,EAAE,kBADA;AAERC,QAAAA,aAAa,EAAG,UAAST,WAAY;AAF7B,OAFgD;AAMzDU,MAAAA,MAAM,EAAE,MANiD;AAOzDrB,MAAAA,GAAG,EAAG,GAAE,wBAAaxD,IAAb,EAAmB8E,iBAAkB,EAPY;AAQzDjB,MAAAA,YAAY,EAAE;AAR2C,KAAR,CAAlD;;AAWA,QAAIU,UAAU,IAAI,GAAd,IAAqBA,UAAU,GAAG,GAAtC,EAA2C;AAC1C,UAAI,CAACF,IAAL,EAAW;AACV,cAAMpE,gBAAE8E,cAAF,CAAkB,4CAA2CnB,MAAO,GAApE,CAAN;AACA;;AAED,UAAI,CAACS,IAAI,CAACW,OAAV,EAAmB;AAClB,cAAM/E,gBAAE8E,cAAF,CAAkB,kDAAiDnB,MAAO,GAA1E,CAAN;AACA;;AAED,UAAI,CAACS,IAAI,CAACY,MAAV,EAAkB;AACjB,cAAMhF,gBAAE8E,cAAF,CAAkB,yDAAwDnB,MAAO,GAAjF,CAAN;AACA;;AAED,YAAMsB,GAAG,GAAG;AACXpB,QAAAA,IAAI,EAAIO,IAAI,CAACY,MAAL,CAAYE,QADT;AAEXV,QAAAA,MAAM,EAAEJ,IAAI,CAACY,MAAL,CAAYR;AAFT,OAAZ;;AAKA,UAAIzE,IAAI,CAACwC,OAAL,IAAgB,OAAOxC,IAAI,CAACwC,OAAZ,KAAwB,QAAxC,IAAoD,KAAKvB,UAA7D,EAAyE;AACxEjB,QAAAA,IAAI,CAACwC,OAAL,CAAa0C,GAAb,GAAmBA,GAAnB;AACA,cAAM,KAAKjE,UAAL,CAAgBmE,GAAhB,CAAoBpF,IAAI,CAACwC,OAAzB,CAAN;AACA;;AAED,aAAO0C,GAAP;AACA;;AAED,QAAIG,GAAG,GAAGf,KAAV;;AACA,QAAI;AACH,YAAMgB,GAAG,GAAGC,IAAI,CAACC,KAAL,CAAWH,GAAX,CAAZ;AACAA,MAAAA,GAAG,GAAI,GAAEC,GAAG,CAAChB,KAAM,KAAIgB,GAAG,CAACG,iBAAkB,EAA7C;AACA,KAHD,CAGE,OAAOlE,CAAP,EAAU,CACX;AACA;;AAED8D,IAAAA,GAAG,GAAI,yBAAwBA,GAAG,CAACK,IAAJ,MAAe,mBAAkBnB,UAAW,EAAE,EAA7E;AACAD,IAAAA,KAAK,CAAE,GAAEe,GAAI,IAAG1F,IAAI,CAAE,IAAGiE,MAAO,GAAZ,CAAgB,EAA/B,CAAL;AACA,UAAM3D,gBAAE0F,iBAAF,CAAoBN,GAApB,EAAyB;AAAEzB,MAAAA;AAAF,KAAzB,CAAN;AACA;;AA3YwB","sourcesContent":["/* istanbul ignore if */\nif (!Error.prepareStackTrace) {\n\trequire('source-map-support/register');\n}\n\nimport E from './errors';\n\nimport Authenticator from './authenticators/authenticator';\nimport ClientSecret from './authenticators/client-secret';\nimport OwnerPassword from './authenticators/owner-password';\nimport PKCE from './authenticators/pkce';\nimport SignedJWT from './authenticators/signed-jwt';\n\nimport FileStore from './stores/file-store';\nimport MemoryStore from './stores/memory-store';\nimport SecureStore from './stores/secure-store';\nimport TokenStore from './stores/token-store';\n\nimport environments from './environments';\nimport getEndpoints from './endpoints';\nimport snooplogg from 'snooplogg';\nimport * as server from './server';\n\nimport request from '@axway/amplify-request';\nimport { getServerInfo } from './util';\n\nconst { log } = snooplogg('amplify-auth');\nconst { alert, highlight, magenta, note } = snooplogg.styles;\n\n/**\n * Authenticates the machine and retreives the auth token.\n */\nexport default class Auth {\n\t/**\n\t * The store to persist the token.\n\t *\n\t * @type {TokenStore}\n\t * @access private\n\t */\n\ttokenStore = null;\n\n\t/**\n\t * Initializes the authentication instance by setting the default settings and creating the\n\t * token store.\n\t *\n\t * @param {Object} opts - Various options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.clientId] - The client id to specify when authenticating.\n\t * @param {String} [opts.clientSecret] - The secret token to use to authenticate.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {String} [opts.secureServiceName=\"Axway AMPLIFY Auth\"] - The name of the consumer\n\t * using this library when using the \"secure\" token store.\n\t * @param {String} [opts.password] - The password used to authenticate. Requires a `username`.\n\t * @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {String} [opts.secretFile] - The path to the jwt secret file.\n\t * @param {Boolean} [opts.serviceAccount=false] - When `true`, indicates authentication is being\n\t * requested by a service instead of a user.\n\t * @param {Boolean} [opts.tokenRefreshThreshold=0] - The number of seconds before the access\n\t * token expires and should be refreshed.\n\t * @param {TokenStore} [opts.tokenStore] - A token store instance for persisting the tokens.\n\t * @param {String} [opts.tokenStoreDir] - The directory where the token store is saved. Required\n\t * when the `tokenStoreType` is `secure` or `file`.\n\t * @param {String} [opts.tokenStoreType=auto] - The type of store to persist the access token.\n\t * Possible values include: `auto`, `secure`, `file`, or `memory`. If value is `auto`, it will\n\t * attempt to use `secure`, then `file`, then `memory`. If set to `null`, then it will not\n\t * persist the access token.\n\t * @param {String} [opts.username] - The username used to authenticate. Requires a `password`.\n\t * @access public\n\t */\n\tconstructor(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tObject.defineProperties(this, {\n\t\t\tbaseUrl:        { value: opts.baseUrl },\n\t\t\tclientId:       { value: opts.clientId },\n\t\t\tclientSecret:   { value: opts.clientSecret },\n\t\t\tenv:            { value: opts.env },\n\t\t\tmessages:       { value: opts.messages },\n\t\t\tpassword:       { value: opts.password },\n\t\t\tplatformUrl:    { value: opts.platformUrl },\n\t\t\trealm:          { value: opts.realm },\n\t\t\tsecretFile:     { value: opts.secretFile },\n\t\t\tserviceAccount: { value: opts.serviceAccount },\n\t\t\tusername:       { value: opts.username }\n\t\t});\n\n\t\tif (opts.tokenStore) {\n\t\t\tif (!(opts.tokenStore instanceof TokenStore)) {\n\t\t\t\tthrow E.INVALID_PARAMETER('Expected the token store to be a \"TokenStore\" instance');\n\t\t\t}\n\t\t\tthis.tokenStore = opts.tokenStore;\n\t\t} else {\n\t\t\tconst tokenStoreType = opts.tokenStoreType === undefined ? 'auto' : opts.tokenStoreType;\n\t\t\tswitch (tokenStoreType) {\n\t\t\t\tcase 'auto':\n\t\t\t\tcase 'secure':\n\t\t\t\t\ttry {\n\t\t\t\t\t\tthis.tokenStore = new SecureStore(opts);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t/* istanbul ignore if */\n\t\t\t\t\t\tif (tokenStoreType === 'auto') {\n\t\t\t\t\t\t\t// let 'auto' fall through\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\tcase 'file':\n\t\t\t\t\ttry {\n\t\t\t\t\t\tthis.tokenStore = new FileStore(opts);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t} catch (e) {\n\t\t\t\t\t\t/* istanbul ignore if */\n\t\t\t\t\t\tif (tokenStoreType === 'auto' && e.code === 'ERR_MISSING_REQUIRED_PARAMETER') {\n\t\t\t\t\t\t\t// let 'auto' fall through\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tthrow e;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\tcase 'memory':\n\t\t\t\t\tthis.tokenStore = new MemoryStore(opts);\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Ensures the options contains the configurable settings. Validation is handled by the code\n\t * requiring the values.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @returns {Object}\n\t * @access private\n\t */\n\tapplyDefaults(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tconst env = opts.env || this.env || 'prod';\n\t\tif (!environments[env]) {\n\t\t\tthrow E.INVALID_VALUE(`Invalid environment: ${opts.env || this.env}`);\n\t\t}\n\n\t\topts.baseUrl        = opts.baseUrl || this.baseUrl || environments[env].baseUrl;\n\t\topts.clientId       = opts.clientId || this.clientId;\n\t\topts.clientSecret   = opts.clientSecret || this.clientSecret;\n\t\topts.env            = env;\n\t\topts.messages       = opts.messages || this.messages;\n\t\topts.password       = opts.password || this.password;\n\t\topts.platformUrl    = opts.platformUrl || this.platformUrl || environments[env].platformUrl;\n\t\topts.realm          = opts.realm || this.realm;\n\t\topts.secretFile     = opts.secretFile || this.secretFile;\n\t\topts.serviceAccount = opts.serviceAccount || this.serviceAccount;\n\t\topts.tokenStore     = this.tokenStore;\n\t\topts.username       = opts.username || this.username;\n\n\t\treturn opts;\n\t}\n\n\t/**\n\t * Creates an authetnicator based on the supplied options.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.clientSecret] - The secret token to use to authenticate.\n\t * @param {String} [opts.password] - The password used to authenticate. Requires a `username`.\n\t * @param {String} [opts.secretFile] - The path to the jwt secret file.\n\t * @param {Boolean} [opts.serviceAccount=false] - When `true`, indicates authentication is being\n\t * requested by a service instead of a user.\n\t * @param {String} [opts.username] - The username used to authenticate. Requires a `password`.\n\t * @returns {Authenticator}\n\t * @access public\n\t */\n\tcreateAuthenticator(opts = {}) {\n\t\tif (opts.authenticator) {\n\t\t\tif (!(opts.authenticator instanceof Authenticator)) {\n\t\t\t\tthrow E.INVALID_ARUGMENT('Expected authenticator to be an Authenticator instance.');\n\t\t\t}\n\t\t\treturn opts.authenticator;\n\t\t}\n\n\t\tif (typeof opts.username === 'string' && opts.username && typeof opts.password === 'string') {\n\t\t\treturn new OwnerPassword(opts);\n\t\t}\n\n\t\tif (typeof opts.clientSecret === 'string' && opts.clientSecret) {\n\t\t\treturn new ClientSecret(opts);\n\t\t}\n\n\t\tif (typeof opts.secretFile === 'string' && opts.secretFile) {\n\t\t\treturn new SignedJWT(opts);\n\t\t}\n\n\t\treturn new PKCE(opts);\n\t}\n\n\t/**\n\t * Retrieves the access token. If the authenticator is interactive and the authenticator has not\n\t * yet authenticated with the server, an error is thrown.\n\t *\n\t * @param {Object|String} opts - Required options or a string containing the hash.\n\t * @param {String} opts.accountName - The account name to retrieve.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.baseUrl] - The base URL to filter by.\n\t * @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.\n\t * @returns {Promise<?Object>}\n\t * @access public\n\t */\n\tasync getAccount(opts = {}) {\n\t\tif (!this.tokenStore) {\n\t\t\tlog('Cannot get account, no token store');\n\t\t\treturn null;\n\t\t}\n\n\t\tlet authenticator;\n\n\t\tif (typeof opts === 'string') {\n\t\t\topts = this.applyDefaults({ hash: opts });\n\t\t} else {\n\t\t\tthis.applyDefaults(opts);\n\t\t\tauthenticator = this.createAuthenticator(opts);\n\t\t\topts.hash = authenticator.hash;\n\t\t}\n\n\t\tconst account = await this.tokenStore.get(opts);\n\t\tif (account && !account.expired) {\n\t\t\tif (!authenticator) {\n\t\t\t\tauthenticator = this.createAuthenticator(opts);\n\t\t\t}\n\t\t\treturn await authenticator.getInfo(account);\n\t\t}\n\t}\n\n\t/**\n\t * Returns a list of all valid access tokens.\n\t *\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync list() {\n\t\tif (this.tokenStore) {\n\t\t\treturn await this.tokenStore.list();\n\t\t}\n\t\treturn [];\n\t}\n\n\t/**\n\t * Authenticates using the configured authenticator.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {String|Array.<String>} [opt.app] - Specify the app to open the `target` with, or an\n\t * array with the app and app arguments.\n\t * @param {Authenticator} [opts.authenticator] - An authenticator instance to use. If not\n\t * specified, one will be auto-selected based on the options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.clientId] - The client id to specify when authenticating.\n\t * @param {String} [opts.code] - The authentication code from a successful interactive login.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {Boolean} [opts.manual=false] - When `true`, it will return the auth URL instead of\n\t * launching the auth URL in the default browser.\n\t * @param {String} [opts.platformUrl] - The platform URL used to get user info and orgs.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {Number} [opts.timeout] - The number of milliseconds to wait before timing out.\n\t * Defaults to the `interactiveLoginTimeout` property.\n\t * @param {Boolean} [opts.wait=false] - Wait for the opened app to exit before fulfilling the\n\t * promise. If `false` it's fulfilled immediately when opening the app.\n\t * @returns {Promise<Object>} Resolves an object containing the access token, account name, and\n\t * user info.\n\t * @access public\n\t */\n\tasync login(opts = {}) {\n\t\tthis.applyDefaults(opts);\n\t\tconst authenticator = this.createAuthenticator(opts);\n\t\treturn await authenticator.login(opts);\n\t}\n\n\t/**\n\t * Revokes all or specific authenticated accounts.\n\t *\n\t * @param {Object} opts - Required options.\n\t * @param {Array.<String>|String} opts.accounts - A list of accounts names.\n\t * @param {Boolean} opts.all - When `true`, revokes all accounts.\n\t * @param {String} [opts.baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>} Returns a list of revoked credentials.\n\t * @access public\n\t */\n\tasync revoke({ accounts, all, baseUrl } = {}) {\n\t\tif (!this.tokenStore) {\n\t\t\tlog('No token store, returning empty array');\n\t\t\treturn [];\n\t\t}\n\n\t\tif (!all && typeof accounts !== 'string' && !Array.isArray(accounts)) {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected accounts to be \"all\" or a list of accounts');\n\t\t}\n\n\t\tif (!all && !accounts.length) {\n\t\t\treturn [];\n\t\t}\n\n\t\tlet revoked;\n\t\tif (all) {\n\t\t\trevoked = await this.tokenStore.clear(baseUrl);\n\t\t} else {\n\t\t\trevoked = await this.tokenStore.delete(accounts, baseUrl);\n\t\t}\n\n\t\tif (Array.isArray(revoked)) {\n\t\t\tfor (const entry of revoked) {\n\t\t\t\tconst url = `${getEndpoints(entry).logout}?id_token_hint=${entry.tokens.id_token}`;\n\t\t\t\ttry {\n\t\t\t\t\tconst { status } = await request({ url, validateJSON: true });\n\t\t\t\t\tlog(`Successfully logged out ${highlight(entry.name)} ${magenta(status)} ${note(`(${entry.baseUrl}, ${entry.realm})`)}`);\n\t\t\t\t} catch (err) {\n\t\t\t\t\tlog(`Failed to log out ${highlight(entry.name)} ${alert(err.status)} ${note(`(${entry.baseUrl}, ${entry.realm})`)}`);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn revoked;\n\t}\n\n\t/**\n\t * Discovers available endpoints based on the authentication server's OpenID configuration.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} [opts.env=prod] - The environment name. Must be `dev`, `preprod`, or `prod`.\n\t * The environment is a shorthand way of specifying a Axway default base URL.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @param {String} [opts.url] - An optional URL to discover the available endpoints.\n\t * @returns {Promise<Object>}\n\t * @access public\n\t */\n\tasync serverInfo(opts = {}) {\n\t\tthis.applyDefaults(opts);\n\n\t\tlet { url } = opts;\n\n\t\tif (!url) {\n\t\t\turl = getEndpoints(opts).wellKnown;\n\t\t}\n\n\t\treturn await getServerInfo(url);\n\t}\n\n\t/**\n\t * Switches the current organization.\n\t *\n\t * @param {Object} opts - Various options.\n\t * @param {String} opts.accessToken - The access token.\n\t * @param {Object} [opts.account] - The account object.\n\t * @param {String} [opts.baseUrl] - The base URL to use for all outgoing requests.\n\t * @param {String} opts.orgId - The org id.\n\t * @param {String} [opts.platformUrl] - The Axway Platform URL.\n\t * @param {String} [opts.realm] - The name of the realm to authenticate with.\n\t * @returns {Promise<Object>} Resolves the selected organization info.\n\t * @access public\n\t */\n\tasync switchOrg(opts) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tthis.applyDefaults(opts);\n\n\t\tconst { accessToken, orgId } = opts;\n\t\tlog(`Switching org to ${orgId}`);\n\n\t\tconst { body, error, status, statusCode } = await request({\n\t\t\tformData: { org_id: orgId },\n\t\t\theaders: {\n\t\t\t\tAccept: 'application/json',\n\t\t\t\tAuthorization: `Bearer ${accessToken}`\n\t\t\t},\n\t\t\tmethod: 'POST',\n\t\t\turl: `${getEndpoints(opts).switchLoggedInOrg}`,\n\t\t\tvalidateJSON: true\n\t\t});\n\n\t\tif (statusCode >= 200 && statusCode < 300) {\n\t\t\tif (!body) {\n\t\t\t\tthrow E.REQUEST_FAILED(`Switch org failed: Response has no body (${status})`);\n\t\t\t}\n\n\t\t\tif (!body.success) {\n\t\t\t\tthrow E.REQUEST_FAILED(`Switch org failed: Request was not successful (${status})`);\n\t\t\t}\n\n\t\t\tif (!body.result) {\n\t\t\t\tthrow E.REQUEST_FAILED(`Switch org failed: Response did not contain a result (${status})`);\n\t\t\t}\n\n\t\t\tconst org = {\n\t\t\t\tname:   body.result.org_name,\n\t\t\t\torg_id: body.result.org_id\n\t\t\t};\n\n\t\t\tif (opts.account && typeof opts.account === 'object' && this.tokenStore) {\n\t\t\t\topts.account.org = org;\n\t\t\t\tawait this.tokenStore.set(opts.account);\n\t\t\t}\n\n\t\t\treturn org;\n\t\t}\n\n\t\tlet msg = error;\n\t\ttry {\n\t\t\tconst obj = JSON.parse(msg);\n\t\t\tmsg = `${obj.error}: ${obj.error_description}`;\n\t\t} catch (e) {\n\t\t\t// squelch\n\t\t}\n\n\t\tmsg = `Failed to switch org: ${msg.trim() || `server returned ${statusCode}`}`;\n\t\terror(`${msg} ${note(`(${status})`)}`);\n\t\tthrow E.ORG_SWITCH_FAILED(msg, { status });\n\t}\n}\n\nexport {\n\tAuth,\n\n\tAuthenticator,\n\tClientSecret,\n\tOwnerPassword,\n\tPKCE,\n\tSignedJWT,\n\n\tFileStore,\n\tMemoryStore,\n\tSecureStore,\n\tTokenStore,\n\n\tenvironments,\n\tgetEndpoints,\n\tserver\n};\n"],"file":"index.js"}

@@ -36,3 +36,3 @@ "use strict";

} = await super._clear(baseUrl);
this.store = entries.length ? entries : [];
this.store = entries;
return removed;

@@ -55,3 +55,3 @@ }

} = await super._delete(accounts, baseUrl);
this.store = entries.length ? entries : [];
this.store = entries;
return removed;

@@ -80,4 +80,3 @@ }

async set(data) {
const entries = await super._set(data);
this.store = entries.length ? entries : [];
this.store = await super._set(data);
}

@@ -88,2 +87,2 @@

exports.default = MemoryStore;
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0b3Jlcy9tZW1vcnktc3RvcmUuanMiXSwibmFtZXMiOlsiTWVtb3J5U3RvcmUiLCJUb2tlblN0b3JlIiwiY2xlYXIiLCJiYXNlVXJsIiwiZW50cmllcyIsInJlbW92ZWQiLCJfY2xlYXIiLCJzdG9yZSIsImxlbmd0aCIsImRlbGV0ZSIsImFjY291bnRzIiwiX2RlbGV0ZSIsImxpc3QiLCJwdXJnZSIsInNldCIsImRhdGEiLCJfc2V0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7OztBQUVBOzs7QUFHZSxNQUFNQSxXQUFOLFNBQTBCQyxtQkFBMUIsQ0FBcUM7QUFBQTtBQUFBOztBQUFBLG1DQU0zQyxFQU4yQztBQUFBOztBQVFuRDs7Ozs7OztBQU9BLFFBQU1DLEtBQU4sQ0FBWUMsT0FBWixFQUFxQjtBQUNwQixVQUFNO0FBQUVDLE1BQUFBLE9BQUY7QUFBV0MsTUFBQUE7QUFBWCxRQUF1QixNQUFNLE1BQU1DLE1BQU4sQ0FBYUgsT0FBYixDQUFuQztBQUNBLFNBQUtJLEtBQUwsR0FBYUgsT0FBTyxDQUFDSSxNQUFSLEdBQWlCSixPQUFqQixHQUEyQixFQUF4QztBQUNBLFdBQU9DLE9BQVA7QUFDQTtBQUVEOzs7Ozs7Ozs7O0FBUUEsUUFBTUksTUFBTixDQUFhQyxRQUFiLEVBQXVCUCxPQUF2QixFQUFnQztBQUMvQixVQUFNO0FBQUVDLE1BQUFBLE9BQUY7QUFBV0MsTUFBQUE7QUFBWCxRQUF1QixNQUFNLE1BQU1NLE9BQU4sQ0FBY0QsUUFBZCxFQUF3QlAsT0FBeEIsQ0FBbkM7QUFDQSxTQUFLSSxLQUFMLEdBQWFILE9BQU8sQ0FBQ0ksTUFBUixHQUFpQkosT0FBakIsR0FBMkIsRUFBeEM7QUFDQSxXQUFPQyxPQUFQO0FBQ0E7QUFFRDs7Ozs7Ozs7QUFNQSxRQUFNTyxJQUFOLEdBQWE7QUFDWixXQUFPLEtBQUtDLEtBQUwsQ0FBVyxLQUFLTixLQUFoQixDQUFQO0FBQ0E7QUFFRDs7Ozs7Ozs7O0FBT0EsUUFBTU8sR0FBTixDQUFVQyxJQUFWLEVBQWdCO0FBQ2YsVUFBTVgsT0FBTyxHQUFHLE1BQU0sTUFBTVksSUFBTixDQUFXRCxJQUFYLENBQXRCO0FBQ0EsU0FBS1IsS0FBTCxHQUFhSCxPQUFPLENBQUNJLE1BQVIsR0FBaUJKLE9BQWpCLEdBQTJCLEVBQXhDO0FBQ0E7O0FBdkRrRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUb2tlblN0b3JlIGZyb20gJy4vdG9rZW4tc3RvcmUnO1xuXG4vKipcbiAqIEEgb3BlcmF0aW5nLXNwZWNpZmljIHNlY3VyZSB0b2tlbiBzdG9yZS5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWVtb3J5U3RvcmUgZXh0ZW5kcyBUb2tlblN0b3JlIHtcblx0LyoqXG5cdCAqIFRoZSBpbi1tZW1vcnkgc3RvcmUuXG5cdCAqXG5cdCAqIEB0eXBlIHtBcnJheS48T2JqZWN0Pn1cblx0ICovXG5cdHN0b3JlID0gW107XG5cblx0LyoqXG5cdCAqIFJlbW92ZXMgYWxsIHRva2Vucy5cblx0ICpcblx0ICogQHBhcmFtIHtTdHJpbmd9IFtiYXNlVXJsXSAtIFRoZSBiYXNlIFVSTCB1c2VkIHRvIGZpbHRlciBhY2NvdW50cy5cblx0ICogQHJldHVybnMge1Byb21pc2U8QXJyYXk+fVxuXHQgKiBAYWNjZXNzIHB1YmxpY1xuXHQgKi9cblx0YXN5bmMgY2xlYXIoYmFzZVVybCkge1xuXHRcdGNvbnN0IHsgZW50cmllcywgcmVtb3ZlZCB9ID0gYXdhaXQgc3VwZXIuX2NsZWFyKGJhc2VVcmwpO1xuXHRcdHRoaXMuc3RvcmUgPSBlbnRyaWVzLmxlbmd0aCA/IGVudHJpZXMgOiBbXTtcblx0XHRyZXR1cm4gcmVtb3ZlZDtcblx0fVxuXG5cdC8qKlxuXHQgKiBEZWxldGVzIGEgdG9rZW4gZnJvbSB0aGUgc3RvcmUuXG5cdCAqXG5cdCAqIEBwYXJhbSB7U3RyaW5nfEFycmF5LjxTdHJpbmc+fSBhY2NvdW50cyAtIFRoZSBhY2NvdW50IG5hbWUocykgdG8gZGVsZXRlLlxuXHQgKiBAcGFyYW0ge1N0cmluZ30gW2Jhc2VVcmxdIC0gVGhlIGJhc2UgVVJMIHVzZWQgdG8gZmlsdGVyIGFjY291bnRzLlxuXHQgKiBAcmV0dXJucyB7UHJvbWlzZTxBcnJheT59XG5cdCAqIEBhY2Nlc3MgcHVibGljXG5cdCAqL1xuXHRhc3luYyBkZWxldGUoYWNjb3VudHMsIGJhc2VVcmwpIHtcblx0XHRjb25zdCB7IGVudHJpZXMsIHJlbW92ZWQgfSA9IGF3YWl0IHN1cGVyLl9kZWxldGUoYWNjb3VudHMsIGJhc2VVcmwpO1xuXHRcdHRoaXMuc3RvcmUgPSBlbnRyaWVzLmxlbmd0aCA/IGVudHJpZXMgOiBbXTtcblx0XHRyZXR1cm4gcmVtb3ZlZDtcblx0fVxuXG5cdC8qKlxuXHQgKiBSZXRyZWl2ZXMgYWxsIHRva2VucyBmcm9tIHRoZSBzdG9yZS5cblx0ICpcblx0ICogQHJldHVybnMge1Byb21pc2U8QXJyYXk+fSBSZXNvbHZlcyBhbiBhcnJheSBvZiB0b2tlbnMuXG5cdCAqIEBhY2Nlc3MgcHVibGljXG5cdCAqL1xuXHRhc3luYyBsaXN0KCkge1xuXHRcdHJldHVybiB0aGlzLnB1cmdlKHRoaXMuc3RvcmUpO1xuXHR9XG5cblx0LyoqXG5cdCAqIFNhdmVzIGFjY291bnQgY3JlZGVudGlhbHMuIElmIGV4aXN0cywgdGhlIG9sZCBvbmUgaXMgZGVsZXRlZC5cblx0ICpcblx0ICogQHBhcmFtIHtPYmplY3R9IGRhdGEgLSBUaGUgdG9rZW4gZGF0YS5cblx0ICogQHJldHVybnMge1Byb21pc2V9XG5cdCAqIEBhY2Nlc3MgcHVibGljXG5cdCAqL1xuXHRhc3luYyBzZXQoZGF0YSkge1xuXHRcdGNvbnN0IGVudHJpZXMgPSBhd2FpdCBzdXBlci5fc2V0KGRhdGEpO1xuXHRcdHRoaXMuc3RvcmUgPSBlbnRyaWVzLmxlbmd0aCA/IGVudHJpZXMgOiBbXTtcblx0fVxufVxuIl0sImZpbGUiOiJzdG9yZXMvbWVtb3J5LXN0b3JlLmpzIn0=
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInN0b3Jlcy9tZW1vcnktc3RvcmUuanMiXSwibmFtZXMiOlsiTWVtb3J5U3RvcmUiLCJUb2tlblN0b3JlIiwiY2xlYXIiLCJiYXNlVXJsIiwiZW50cmllcyIsInJlbW92ZWQiLCJfY2xlYXIiLCJzdG9yZSIsImRlbGV0ZSIsImFjY291bnRzIiwiX2RlbGV0ZSIsImxpc3QiLCJwdXJnZSIsInNldCIsImRhdGEiLCJfc2V0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7OztBQUVBOzs7QUFHZSxNQUFNQSxXQUFOLFNBQTBCQyxtQkFBMUIsQ0FBcUM7QUFBQTtBQUFBOztBQUFBLG1DQU0zQyxFQU4yQztBQUFBOztBQVFuRDs7Ozs7OztBQU9BLFFBQU1DLEtBQU4sQ0FBWUMsT0FBWixFQUFxQjtBQUNwQixVQUFNO0FBQUVDLE1BQUFBLE9BQUY7QUFBV0MsTUFBQUE7QUFBWCxRQUF1QixNQUFNLE1BQU1DLE1BQU4sQ0FBYUgsT0FBYixDQUFuQztBQUNBLFNBQUtJLEtBQUwsR0FBYUgsT0FBYjtBQUNBLFdBQU9DLE9BQVA7QUFDQTtBQUVEOzs7Ozs7Ozs7O0FBUUEsUUFBTUcsTUFBTixDQUFhQyxRQUFiLEVBQXVCTixPQUF2QixFQUFnQztBQUMvQixVQUFNO0FBQUVDLE1BQUFBLE9BQUY7QUFBV0MsTUFBQUE7QUFBWCxRQUF1QixNQUFNLE1BQU1LLE9BQU4sQ0FBY0QsUUFBZCxFQUF3Qk4sT0FBeEIsQ0FBbkM7QUFDQSxTQUFLSSxLQUFMLEdBQWFILE9BQWI7QUFDQSxXQUFPQyxPQUFQO0FBQ0E7QUFFRDs7Ozs7Ozs7QUFNQSxRQUFNTSxJQUFOLEdBQWE7QUFDWixXQUFPLEtBQUtDLEtBQUwsQ0FBVyxLQUFLTCxLQUFoQixDQUFQO0FBQ0E7QUFFRDs7Ozs7Ozs7O0FBT0EsUUFBTU0sR0FBTixDQUFVQyxJQUFWLEVBQWdCO0FBQ2YsU0FBS1AsS0FBTCxHQUFhLE1BQU0sTUFBTVEsSUFBTixDQUFXRCxJQUFYLENBQW5CO0FBQ0E7O0FBdERrRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBUb2tlblN0b3JlIGZyb20gJy4vdG9rZW4tc3RvcmUnO1xuXG4vKipcbiAqIEEgb3BlcmF0aW5nLXNwZWNpZmljIHNlY3VyZSB0b2tlbiBzdG9yZS5cbiAqL1xuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWVtb3J5U3RvcmUgZXh0ZW5kcyBUb2tlblN0b3JlIHtcblx0LyoqXG5cdCAqIFRoZSBpbi1tZW1vcnkgc3RvcmUuXG5cdCAqXG5cdCAqIEB0eXBlIHtBcnJheS48T2JqZWN0Pn1cblx0ICovXG5cdHN0b3JlID0gW107XG5cblx0LyoqXG5cdCAqIFJlbW92ZXMgYWxsIHRva2Vucy5cblx0ICpcblx0ICogQHBhcmFtIHtTdHJpbmd9IFtiYXNlVXJsXSAtIFRoZSBiYXNlIFVSTCB1c2VkIHRvIGZpbHRlciBhY2NvdW50cy5cblx0ICogQHJldHVybnMge1Byb21pc2U8QXJyYXk+fVxuXHQgKiBAYWNjZXNzIHB1YmxpY1xuXHQgKi9cblx0YXN5bmMgY2xlYXIoYmFzZVVybCkge1xuXHRcdGNvbnN0IHsgZW50cmllcywgcmVtb3ZlZCB9ID0gYXdhaXQgc3VwZXIuX2NsZWFyKGJhc2VVcmwpO1xuXHRcdHRoaXMuc3RvcmUgPSBlbnRyaWVzO1xuXHRcdHJldHVybiByZW1vdmVkO1xuXHR9XG5cblx0LyoqXG5cdCAqIERlbGV0ZXMgYSB0b2tlbiBmcm9tIHRoZSBzdG9yZS5cblx0ICpcblx0ICogQHBhcmFtIHtTdHJpbmd8QXJyYXkuPFN0cmluZz59IGFjY291bnRzIC0gVGhlIGFjY291bnQgbmFtZShzKSB0byBkZWxldGUuXG5cdCAqIEBwYXJhbSB7U3RyaW5nfSBbYmFzZVVybF0gLSBUaGUgYmFzZSBVUkwgdXNlZCB0byBmaWx0ZXIgYWNjb3VudHMuXG5cdCAqIEByZXR1cm5zIHtQcm9taXNlPEFycmF5Pn1cblx0ICogQGFjY2VzcyBwdWJsaWNcblx0ICovXG5cdGFzeW5jIGRlbGV0ZShhY2NvdW50cywgYmFzZVVybCkge1xuXHRcdGNvbnN0IHsgZW50cmllcywgcmVtb3ZlZCB9ID0gYXdhaXQgc3VwZXIuX2RlbGV0ZShhY2NvdW50cywgYmFzZVVybCk7XG5cdFx0dGhpcy5zdG9yZSA9IGVudHJpZXM7XG5cdFx0cmV0dXJuIHJlbW92ZWQ7XG5cdH1cblxuXHQvKipcblx0ICogUmV0cmVpdmVzIGFsbCB0b2tlbnMgZnJvbSB0aGUgc3RvcmUuXG5cdCAqXG5cdCAqIEByZXR1cm5zIHtQcm9taXNlPEFycmF5Pn0gUmVzb2x2ZXMgYW4gYXJyYXkgb2YgdG9rZW5zLlxuXHQgKiBAYWNjZXNzIHB1YmxpY1xuXHQgKi9cblx0YXN5bmMgbGlzdCgpIHtcblx0XHRyZXR1cm4gdGhpcy5wdXJnZSh0aGlzLnN0b3JlKTtcblx0fVxuXG5cdC8qKlxuXHQgKiBTYXZlcyBhY2NvdW50IGNyZWRlbnRpYWxzLiBJZiBleGlzdHMsIHRoZSBvbGQgb25lIGlzIGRlbGV0ZWQuXG5cdCAqXG5cdCAqIEBwYXJhbSB7T2JqZWN0fSBkYXRhIC0gVGhlIHRva2VuIGRhdGEuXG5cdCAqIEByZXR1cm5zIHtQcm9taXNlfVxuXHQgKiBAYWNjZXNzIHB1YmxpY1xuXHQgKi9cblx0YXN5bmMgc2V0KGRhdGEpIHtcblx0XHR0aGlzLnN0b3JlID0gYXdhaXQgc3VwZXIuX3NldChkYXRhKTtcblx0fVxufVxuIl0sImZpbGUiOiJzdG9yZXMvbWVtb3J5LXN0b3JlLmpzIn0=

@@ -203,3 +203,3 @@ "use strict";

if (baseUrl) {
baseUrl = baseUrl.replace(protoRegExp, '');
baseUrl = baseUrl.replace(protoRegExp, '').replace(/\/$/, '');
}

@@ -215,3 +215,3 @@

for (let i = 0; i < len; i++) {
if ((accountName && entries[i].name === accountName || hash && entries[i].hash === hash) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '') === baseUrl)) {
if ((accountName && entries[i].name === accountName || hash && entries[i].hash === hash) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '').replace(/\/$/, '') === baseUrl)) {
log(`Found account tokens: ${highlight(entries[i].name)}`);

@@ -260,3 +260,3 @@ return entries[i];

if (expires.access > now + this.tokenRefreshThreshold || expires.refresh > now) {
if (expires && (expires.access > now + this.tokenRefreshThreshold || expires.refresh > now)) {
// not expired

@@ -323,2 +323,2 @@ if (!Object.getOwnPropertyDescriptor(entries[i], 'expired')) {

exports.default = TokenStore;
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["stores/token-store.js"],"names":["pluralize","snooplogg","log","highlight","styles","protoRegExp","TokenStore","constructor","opts","E","INVALID_ARGUMENT","tokenRefreshThreshold","undefined","threshold","parseInt","isNaN","INVALID_PARAMETER","INVALID_RANGE","clear","baseUrl","entries","removed","_clear","list","entry","Object","defineProperty","value","replace","i","length","splice","push","delete","accounts","_delete","Array","isArray","includes","name","get","accountName","hash","MISSING_REQUIRED_PARAMETER","len","purge","count","expires","tokens","now","Date","access","refresh","getOwnPropertyDescriptor","configurable","set","data","_set"],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars */\n\nimport E from '../errors';\nimport snooplogg from 'snooplogg';\n\nconst { pluralize } = snooplogg;\nconst { log } = snooplogg('amplify-auth:token-store');\nconst { highlight } = snooplogg.styles;\n\n/**\n * A regex to match a URL protocol.\n * @type {RegExp}\n */\nconst protoRegExp = /^.*\\/\\//;\n\n/**\n * Base class for token storage backends.\n */\nexport default class TokenStore {\n\t/**\n\t * The age in milliseconds before the access token expires and should be refreshed.\n\t *\n\t * @type {Number}\n\t * @access private\n\t */\n\ttokenRefreshThreshold = 0;\n\n\t/**\n\t * Initializes the file store.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {Boolean} [opts.tokenRefreshThreshold=0] - The number of seconds before the access\n\t * token expires and should be refreshed.\n\t * @access public\n\t */\n\tconstructor(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tif (opts.tokenRefreshThreshold !== undefined) {\n\t\t\tconst threshold = parseInt(opts.tokenRefreshThreshold, 10);\n\t\t\tif (isNaN(threshold)) {\n\t\t\t\tthrow E.INVALID_PARAMETER('Expected token refresh threshold to be a number of seconds');\n\t\t\t}\n\n\t\t\tif (threshold < 0) {\n\t\t\t\tthrow E.INVALID_RANGE('Token refresh threshold must be greater than or equal to zero');\n\t\t\t}\n\n\t\t\tthis.tokenRefreshThreshold = threshold * 1000;\n\t\t}\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Removes all tokens. This method is intended to be overwritten.\n\t *\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync clear(baseUrl) {\n\t\treturn { entries: [], removed: [] };\n\t}\n\n\t/**\n\t * Removes all tokens.\n\t *\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync _clear(baseUrl) {\n\t\tconst entries = await this.list();\n\n\t\tif (!baseUrl) {\n\t\t\tfor (const entry of entries) {\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t}\n\t\t\treturn { entries: [], removed: entries };\n\t\t}\n\n\t\tconst removed = [];\n\t\tbaseUrl = baseUrl.replace(/^.*\\/\\//, '');\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tif (entries[i].baseUrl.replace(protoRegExp, '') === baseUrl) {\n\t\t\t\tconst entry = entries.splice(i--, 1)[0];\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t\tremoved.push(entry);\n\t\t\t}\n\t\t}\n\n\t\treturn { entries, removed };\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Deletes a token from the store. This method is intended to be overwritten.\n\t *\n\t * @param {String|Array.<String>} accounts - The account name(s) to delete.\n \t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync delete(accounts, baseUrl) {\n\t\treturn [];\n\t}\n\n\t/**\n\t * Deletes a token from the store.\n\t *\n\t * @param {String|Array.<String>} accounts - The account name(s) to delete.\n \t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync _delete(accounts, baseUrl) {\n\t\tconst entries = await this.list();\n\t\tconst removed = [];\n\n\t\tif (baseUrl) {\n\t\t\tbaseUrl = baseUrl.replace(/^.*\\/\\//, '');\n\t\t}\n\n\t\tif (!Array.isArray(accounts)) {\n\t\t\taccounts = [ accounts ];\n\t\t}\n\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tif (accounts.includes(entries[i].name) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '') === baseUrl)) {\n\t\t\t\tconst entry = entries.splice(i--, 1)[0];\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t\tremoved.push(entry);\n\t\t\t}\n\t\t}\n\n\t\treturn { entries, removed };\n\t}\n\n\t/**\n\t * Retreives a token from the store.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {String} params.accountName - The account name to get.\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise} Resolves the token or `undefined` if not set.\n\t * @access public\n\t */\n\tasync get({ accountName, baseUrl, hash } = {}) {\n\t\tconst entries = await this.list();\n\n\t\tif (baseUrl) {\n\t\t\tbaseUrl = baseUrl.replace(protoRegExp, '');\n\t\t}\n\n\t\tif (!accountName && !hash) {\n\t\t\tthrow E.MISSING_REQUIRED_PARAMETER('Must specify either the account name or authenticator hash');\n\t\t}\n\n\t\tconst len = entries.length;\n\t\tlog(`Scanning ${highlight(len)} ${pluralize('token', len)} for accountName=${highlight(accountName)} hash=${highlight(hash)} baseUrl=${highlight(baseUrl)}`);\n\n\t\tfor (let i = 0; i < len; i++) {\n\t\t\tif (((accountName && entries[i].name === accountName) || (hash && entries[i].hash === hash)) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '') === baseUrl)) {\n\t\t\t\tlog(`Found account tokens: ${highlight(entries[i].name)}`);\n\t\t\t\treturn entries[i];\n\t\t\t}\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t/**\n\t * Retreives all tokens from the store. This method is intended to be overwritten.\n\t *\n\t * @returns {Promise<Array>} Resolves an array of tokens.\n\t * @access public\n\t */\n\tasync list() {\n\t\treturn [];\n\t}\n\n\t/**\n\t * Ensures list of tokens is valid and does not contain any expired tokens.\n\t *\n\t * @param {Array.<Object>} entries - An array of tokens.\n\t * @returns {Array.<Object>}\n\t * @access private\n\t */\n\tpurge(entries) {\n\t\tif (!entries) {\n\t\t\treturn [];\n\t\t}\n\n\t\tlet count = 0;\n\n\t\t// loop over each entry and remove any expired tokens\n\t\t// NOTE: this code intentionally checkes `entries.length` each loop instead of caching the\n\t\t// length since splice() shrinks the array length\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tconst { expires, tokens } = entries[i];\n\t\t\tconst now = Date.now();\n\t\t\tif ((expires.access > (now + this.tokenRefreshThreshold)) || (expires.refresh > now)) {\n\t\t\t\t// not expired\n\t\t\t\tif (!Object.getOwnPropertyDescriptor(entries[i], 'expired')) {\n\t\t\t\t\tObject.defineProperty(entries[i], 'expired', {\n\t\t\t\t\t\tconfigurable: true,\n\t\t\t\t\t\tget() {\n\t\t\t\t\t\t\treturn this.expires.access < Date.now();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcount++;\n\t\t\tentries.splice(i--, 1);\n\t\t}\n\n\t\tlog(`Purged ${highlight(count)} ${pluralize('entry', count)}`);\n\n\t\treturn entries;\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Saves account credentials. This method is intended to be overwritten.\n\t *\n\t * @param {Object} data - The token data.\n\t * @returns {Promise}\n\t * @access private\n\t */\n\tasync set(data) {\n\t\t// noop\n\t}\n\n\t/**\n\t * Saves account credentials. If exists, the old one is deleted.\n\t *\n\t * @param {Object} data - The token data.\n\t * @returns {Promise}\n\t * @access private\n\t */\n\tasync _set(data) {\n\t\tconst entries = await this.list();\n\n\t\tfor (let i = 0, len = entries.length; i < len; i++) {\n\t\t\tif (entries[i].baseUrl === data.baseUrl && entries[i].name === data.name) {\n\t\t\t\tentries.splice(i, 1);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tentries.push(data);\n\t\treturn entries;\n\t}\n}\n"],"file":"stores/token-store.js"}
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["stores/token-store.js"],"names":["pluralize","snooplogg","log","highlight","styles","protoRegExp","TokenStore","constructor","opts","E","INVALID_ARGUMENT","tokenRefreshThreshold","undefined","threshold","parseInt","isNaN","INVALID_PARAMETER","INVALID_RANGE","clear","baseUrl","entries","removed","_clear","list","entry","Object","defineProperty","value","replace","i","length","splice","push","delete","accounts","_delete","Array","isArray","includes","name","get","accountName","hash","MISSING_REQUIRED_PARAMETER","len","purge","count","expires","tokens","now","Date","access","refresh","getOwnPropertyDescriptor","configurable","set","data","_set"],"mappings":"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","sourcesContent":["/* eslint-disable no-unused-vars */\n\nimport E from '../errors';\nimport snooplogg from 'snooplogg';\n\nconst { pluralize } = snooplogg;\nconst { log } = snooplogg('amplify-auth:token-store');\nconst { highlight } = snooplogg.styles;\n\n/**\n * A regex to match a URL protocol.\n * @type {RegExp}\n */\nconst protoRegExp = /^.*\\/\\//;\n\n/**\n * Base class for token storage backends.\n */\nexport default class TokenStore {\n\t/**\n\t * The age in milliseconds before the access token expires and should be refreshed.\n\t *\n\t * @type {Number}\n\t * @access private\n\t */\n\ttokenRefreshThreshold = 0;\n\n\t/**\n\t * Initializes the file store.\n\t *\n\t * @param {Object} [opts] - Various options.\n\t * @param {Boolean} [opts.tokenRefreshThreshold=0] - The number of seconds before the access\n\t * token expires and should be refreshed.\n\t * @access public\n\t */\n\tconstructor(opts = {}) {\n\t\tif (!opts || typeof opts !== 'object') {\n\t\t\tthrow E.INVALID_ARGUMENT('Expected options to be an object');\n\t\t}\n\n\t\tif (opts.tokenRefreshThreshold !== undefined) {\n\t\t\tconst threshold = parseInt(opts.tokenRefreshThreshold, 10);\n\t\t\tif (isNaN(threshold)) {\n\t\t\t\tthrow E.INVALID_PARAMETER('Expected token refresh threshold to be a number of seconds');\n\t\t\t}\n\n\t\t\tif (threshold < 0) {\n\t\t\t\tthrow E.INVALID_RANGE('Token refresh threshold must be greater than or equal to zero');\n\t\t\t}\n\n\t\t\tthis.tokenRefreshThreshold = threshold * 1000;\n\t\t}\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Removes all tokens. This method is intended to be overwritten.\n\t *\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync clear(baseUrl) {\n\t\treturn { entries: [], removed: [] };\n\t}\n\n\t/**\n\t * Removes all tokens.\n\t *\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise<Array>}\n\t * @access public\n\t */\n\tasync _clear(baseUrl) {\n\t\tconst entries = await this.list();\n\n\t\tif (!baseUrl) {\n\t\t\tfor (const entry of entries) {\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t}\n\t\t\treturn { entries: [], removed: entries };\n\t\t}\n\n\t\tconst removed = [];\n\t\tbaseUrl = baseUrl.replace(/^.*\\/\\//, '');\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tif (entries[i].baseUrl.replace(protoRegExp, '') === baseUrl) {\n\t\t\t\tconst entry = entries.splice(i--, 1)[0];\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t\tremoved.push(entry);\n\t\t\t}\n\t\t}\n\n\t\treturn { entries, removed };\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Deletes a token from the store. This method is intended to be overwritten.\n\t *\n\t * @param {String|Array.<String>} accounts - The account name(s) to delete.\n \t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync delete(accounts, baseUrl) {\n\t\treturn [];\n\t}\n\n\t/**\n\t * Deletes a token from the store.\n\t *\n\t * @param {String|Array.<String>} accounts - The account name(s) to delete.\n \t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise}\n\t * @access public\n\t */\n\tasync _delete(accounts, baseUrl) {\n\t\tconst entries = await this.list();\n\t\tconst removed = [];\n\n\t\tif (baseUrl) {\n\t\t\tbaseUrl = baseUrl.replace(/^.*\\/\\//, '');\n\t\t}\n\n\t\tif (!Array.isArray(accounts)) {\n\t\t\taccounts = [ accounts ];\n\t\t}\n\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tif (accounts.includes(entries[i].name) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '') === baseUrl)) {\n\t\t\t\tconst entry = entries.splice(i--, 1)[0];\n\t\t\t\tObject.defineProperty(entry, 'expired', { value: true });\n\t\t\t\tremoved.push(entry);\n\t\t\t}\n\t\t}\n\n\t\treturn { entries, removed };\n\t}\n\n\t/**\n\t * Retreives a token from the store.\n\t *\n\t * @param {Object} params - Various parameters.\n\t * @param {String} params.accountName - The account name to get.\n\t * @param {String} [baseUrl] - The base URL used to filter accounts.\n\t * @returns {Promise} Resolves the token or `undefined` if not set.\n\t * @access public\n\t */\n\tasync get({ accountName, baseUrl, hash } = {}) {\n\t\tconst entries = await this.list();\n\n\t\tif (baseUrl) {\n\t\t\tbaseUrl = baseUrl.replace(protoRegExp, '').replace(/\\/$/, '');\n\t\t}\n\n\t\tif (!accountName && !hash) {\n\t\t\tthrow E.MISSING_REQUIRED_PARAMETER('Must specify either the account name or authenticator hash');\n\t\t}\n\n\t\tconst len = entries.length;\n\t\tlog(`Scanning ${highlight(len)} ${pluralize('token', len)} for accountName=${highlight(accountName)} hash=${highlight(hash)} baseUrl=${highlight(baseUrl)}`);\n\n\t\tfor (let i = 0; i < len; i++) {\n\t\t\tif (((accountName && entries[i].name === accountName) || (hash && entries[i].hash === hash)) && (!baseUrl || entries[i].baseUrl.replace(protoRegExp, '').replace(/\\/$/, '') === baseUrl)) {\n\t\t\t\tlog(`Found account tokens: ${highlight(entries[i].name)}`);\n\t\t\t\treturn entries[i];\n\t\t\t}\n\t\t}\n\n\t\treturn null;\n\t}\n\n\t/**\n\t * Retreives all tokens from the store. This method is intended to be overwritten.\n\t *\n\t * @returns {Promise<Array>} Resolves an array of tokens.\n\t * @access public\n\t */\n\tasync list() {\n\t\treturn [];\n\t}\n\n\t/**\n\t * Ensures list of tokens is valid and does not contain any expired tokens.\n\t *\n\t * @param {Array.<Object>} entries - An array of tokens.\n\t * @returns {Array.<Object>}\n\t * @access private\n\t */\n\tpurge(entries) {\n\t\tif (!entries) {\n\t\t\treturn [];\n\t\t}\n\n\t\tlet count = 0;\n\n\t\t// loop over each entry and remove any expired tokens\n\t\t// NOTE: this code intentionally checkes `entries.length` each loop instead of caching the\n\t\t// length since splice() shrinks the array length\n\t\tfor (let i = 0; i < entries.length; i++) {\n\t\t\tconst { expires, tokens } = entries[i];\n\t\t\tconst now = Date.now();\n\t\t\tif (expires && ((expires.access > (now + this.tokenRefreshThreshold)) || (expires.refresh > now))) {\n\t\t\t\t// not expired\n\t\t\t\tif (!Object.getOwnPropertyDescriptor(entries[i], 'expired')) {\n\t\t\t\t\tObject.defineProperty(entries[i], 'expired', {\n\t\t\t\t\t\tconfigurable: true,\n\t\t\t\t\t\tget() {\n\t\t\t\t\t\t\treturn this.expires.access < Date.now();\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t\tcontinue;\n\t\t\t}\n\t\t\tcount++;\n\t\t\tentries.splice(i--, 1);\n\t\t}\n\n\t\tlog(`Purged ${highlight(count)} ${pluralize('entry', count)}`);\n\n\t\treturn entries;\n\t}\n\n\t/* istanbul ignore next */\n\t/**\n\t * Saves account credentials. This method is intended to be overwritten.\n\t *\n\t * @param {Object} data - The token data.\n\t * @returns {Promise}\n\t * @access private\n\t */\n\tasync set(data) {\n\t\t// noop\n\t}\n\n\t/**\n\t * Saves account credentials. If exists, the old one is deleted.\n\t *\n\t * @param {Object} data - The token data.\n\t * @returns {Promise}\n\t * @access private\n\t */\n\tasync _set(data) {\n\t\tconst entries = await this.list();\n\n\t\tfor (let i = 0, len = entries.length; i < len; i++) {\n\t\t\tif (entries[i].baseUrl === data.baseUrl && entries[i].name === data.name) {\n\t\t\t\tentries.splice(i, 1);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tentries.push(data);\n\t\treturn entries;\n\t}\n}\n"],"file":"stores/token-store.js"}

@@ -49,4 +49,2 @@ "use strict";

} catch (err) {
console.log(err);
if (err.code === 'INVALID_JSON') {

@@ -150,2 +148,2 @@ throw err;

}
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInV0aWwuanMiXSwibmFtZXMiOlsibG9nIiwiZ2V0U2VydmVySW5mbyIsInVybCIsIkUiLCJJTlZBTElEX0FSR1VNRU5UIiwiYm9keSIsInZhbGlkYXRlSlNPTiIsImVyciIsImNvbnNvbGUiLCJjb2RlIiwiRXJyb3IiLCJzdGF0dXNDb2RlIiwibWQ1IiwiaXQiLCJjcnlwdG8iLCJjcmVhdGVIYXNoIiwidXBkYXRlIiwiSlNPTiIsInN0cmluZ2lmeSIsImRpZ2VzdCIsInJlbmRlckhUTUwiLCJjbHMiLCJtZXNzYWdlIiwidGl0bGUiLCJTdHJpbmciLCJyZXBsYWNlIiwic3RyaW5naWZ5UXVlcnlTdHJpbmciLCJwYXJhbXMiLCJxdWVyeVBhcmFtcyIsIlVSTFNlYXJjaFBhcmFtcyIsInByb3AiLCJPYmplY3QiLCJrZXlzIiwic29ydCIsIm5hbWUiLCJtIiwiaSIsInRvTG93ZXJDYXNlIiwiYXBwZW5kIiwidG9TdHJpbmciXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7QUFFQTs7QUFDQTs7OztBQUVBLE1BQU07QUFBRUEsRUFBQUE7QUFBRixJQUFVLHdCQUFVLG1CQUFWLENBQWhCO0FBRUE7Ozs7Ozs7QUFNTyxlQUFlQyxhQUFmLENBQTZCQyxHQUE3QixFQUFrQztBQUN4QyxNQUFJLENBQUNBLEdBQUQsSUFBUSxPQUFPQSxHQUFQLEtBQWUsUUFBM0IsRUFBcUM7QUFDcEMsVUFBTUMsZ0JBQUVDLGdCQUFGLENBQW1CLHVDQUFuQixDQUFOO0FBQ0E7O0FBRURKLEVBQUFBLEdBQUcsQ0FBRSx5QkFBd0JFLEdBQUksS0FBOUIsQ0FBSDs7QUFDQSxNQUFJO0FBQ0gsVUFBTTtBQUFFRyxNQUFBQTtBQUFGLFFBQVcsTUFBTSw2QkFBUTtBQUFFSCxNQUFBQSxHQUFGO0FBQU9JLE1BQUFBLFlBQVksRUFBRTtBQUFyQixLQUFSLENBQXZCO0FBQ0EsV0FBT0QsSUFBUDtBQUNBLEdBSEQsQ0FHRSxPQUFPRSxHQUFQLEVBQVk7QUFDYkMsSUFBQUEsT0FBTyxDQUFDUixHQUFSLENBQVlPLEdBQVo7O0FBQ0EsUUFBSUEsR0FBRyxDQUFDRSxJQUFKLEtBQWEsY0FBakIsRUFBaUM7QUFDaEMsWUFBTUYsR0FBTjtBQUNBOztBQUNELFVBQU0sSUFBSUcsS0FBSixDQUFXLHFDQUFvQ0gsR0FBRyxDQUFDSSxVQUFXLEdBQTlELENBQU47QUFDQTtBQUVEO0FBRUQ7Ozs7Ozs7O0FBTU8sU0FBU0MsR0FBVCxDQUFhQyxFQUFiLEVBQWlCO0FBQ3ZCLFNBQU9DLGdCQUFPQyxVQUFQLENBQWtCLEtBQWxCLEVBQXlCQyxNQUF6QixDQUFnQyxPQUFPSCxFQUFQLEtBQWMsUUFBZCxHQUF5QkEsRUFBekIsR0FBOEJJLElBQUksQ0FBQ0MsU0FBTCxDQUFlTCxFQUFmLENBQTlELEVBQWtGTSxNQUFsRixDQUF5RixLQUF6RixDQUFQO0FBQ0E7QUFFRDs7Ozs7Ozs7O0FBT08sU0FBU0MsVUFBVCxDQUFvQjtBQUFFQyxFQUFBQSxHQUFGO0FBQU9DLEVBQUFBLE9BQVA7QUFBZ0JDLEVBQUFBO0FBQWhCLENBQXBCLEVBQTZDO0FBQ25ELFNBQVE7OztVQUdDQSxLQUFNOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7ZUFvQ0RGLEdBQUcsSUFBSSxFQUFHOztRQUVqQkUsS0FBTTtPQUNQQyxNQUFNLENBQUNGLE9BQUQsQ0FBTixDQUFnQkcsT0FBaEIsQ0FBd0IsSUFBeEIsRUFBOEIsT0FBOUIsRUFBdUNBLE9BQXZDLENBQStDLElBQS9DLEVBQXFELE1BQXJELEVBQTZEQSxPQUE3RCxDQUFxRSxJQUFyRSxFQUEyRSxNQUEzRSxDQUFtRjs7O1FBMUN6RjtBQThDQTtBQUVEOzs7Ozs7Ozs7QUFPTyxTQUFTQyxvQkFBVCxDQUE4QkMsTUFBOUIsRUFBc0M7QUFDNUMsUUFBTUMsV0FBVyxHQUFHLElBQUlDLG9CQUFKLEVBQXBCOztBQUNBLE9BQUssTUFBTUMsSUFBWCxJQUFtQkMsTUFBTSxDQUFDQyxJQUFQLENBQVlMLE1BQVosRUFBb0JNLElBQXBCLEVBQW5CLEVBQStDO0FBQzlDLFVBQU1DLElBQUksR0FBR0osSUFBSSxDQUFDTCxPQUFMLENBQWEsUUFBYixFQUF1QixDQUFDVSxDQUFELEVBQUlDLENBQUosS0FBVyxHQUFFQSxDQUFDLEdBQUcsR0FBSCxHQUFTLEVBQUcsR0FBRUQsQ0FBQyxDQUFDRSxXQUFGLEVBQWdCLEVBQW5FLENBQWI7QUFDQVQsSUFBQUEsV0FBVyxDQUFDVSxNQUFaLENBQW1CSixJQUFuQixFQUF5QlAsTUFBTSxDQUFDRyxJQUFELENBQS9CO0FBQ0E7O0FBQ0QsU0FBT0YsV0FBVyxDQUFDVyxRQUFaLEVBQVA7QUFDQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBjcnlwdG8gZnJvbSAnY3J5cHRvJztcbmltcG9ydCBFIGZyb20gJy4vZXJyb3JzJztcbmltcG9ydCBzbm9vcGxvZ2cgZnJvbSAnc25vb3Bsb2dnJztcblxuaW1wb3J0IHJlcXVlc3QgZnJvbSAnQGF4d2F5L2FtcGxpZnktcmVxdWVzdCc7XG5pbXBvcnQgeyBVUkxTZWFyY2hQYXJhbXMgfSBmcm9tICd1cmwnO1xuXG5jb25zdCB7IGxvZyB9ID0gc25vb3Bsb2dnKCdhbXBsaWZ5LWF1dGg6dXRpbCcpO1xuXG4vKipcbiAqIERpc2NvdmVycyBhdmFpbGFibGUgZW5kcG9pbnRzIGJhc2VkIG9uIHRoZSByZW1vdGUgc2VydmVyJ3MgT3BlbklEIGNvbmZpZ3VyYXRpb24uXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IFt1cmxdIC0gQW4gb3B0aW9uYWwgVVJMIHRvIGRpc2NvdmVyIHRoZSBhdmFpbGFibGUgZW5kcG9pbnRzLlxuICogQHJldHVybnMge1Byb21pc2U8T2JqZWN0Pn1cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGdldFNlcnZlckluZm8odXJsKSB7XG5cdGlmICghdXJsIHx8IHR5cGVvZiB1cmwgIT09ICdzdHJpbmcnKSB7XG5cdFx0dGhyb3cgRS5JTlZBTElEX0FSR1VNRU5UKCdFeHBlY3RlZCBVUkwgdG8gYmUgYSBub24tZW1wdHkgc3RyaW5nJyk7XG5cdH1cblxuXHRsb2coYEZldGNoaW5nIHNlcnZlciBpbmZvOiAke3VybH0uLi5gKTtcblx0dHJ5IHtcblx0XHRjb25zdCB7IGJvZHkgfSA9IGF3YWl0IHJlcXVlc3QoeyB1cmwsIHZhbGlkYXRlSlNPTjogdHJ1ZSB9KTtcblx0XHRyZXR1cm4gYm9keTtcblx0fSBjYXRjaCAoZXJyKSB7XG5cdFx0Y29uc29sZS5sb2coZXJyKTtcblx0XHRpZiAoZXJyLmNvZGUgPT09ICdJTlZBTElEX0pTT04nKSB7XG5cdFx0XHR0aHJvdyBlcnI7XG5cdFx0fVxuXHRcdHRocm93IG5ldyBFcnJvcihgRmFpbGVkIHRvIGdldCBzZXJ2ZXIgaW5mbyAoc3RhdHVzICR7ZXJyLnN0YXR1c0NvZGV9KWApO1xuXHR9XG5cbn1cblxuLyoqXG4gKiBSZXR1cm5zIGEgaGV4IGVuY29kZWQgbWQ1IGhhc2ggb2YgYSBzdHJpbmcgb3Igb2JqZWN0LlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfE9iamVjdH0gaXQgLSBUaGUgb2JqZWN0IHRvIHNlcmlhbGl6ZSBhbmQgaGFzaC5cbiAqIEByZXR1cm5zIHtTdHJpbmd9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBtZDUoaXQpIHtcblx0cmV0dXJuIGNyeXB0by5jcmVhdGVIYXNoKCdtZDUnKS51cGRhdGUodHlwZW9mIGl0ID09PSAnc3RyaW5nJyA/IGl0IDogSlNPTi5zdHJpbmdpZnkoaXQpKS5kaWdlc3QoJ2hleCcpO1xufVxuXG4vKipcbiAqIEdlbmVyYXRlcyBhbiBIVE1MIHBhZ2Ugd2l0aCBhIHBhbmVsIGNvbnRhaW5pbmcgYSB0aXRsZSBhbmQgYSBtZXNzYWdlLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSB0aXRsZSAtIFRoZSB0aXRsZSB0byBkaXNwbGF5LlxuICogQHBhcmFtIHtTdHJpbmd9IG1lc3NhZ2UgLSBUaGUgbWVzc2FnZSB0byBpbmplY3QgaW50byB0aGUgcGFnZS5cbiAqIEByZXR1cm5zIHtTdHJpbmd9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZW5kZXJIVE1MKHsgY2xzLCBtZXNzYWdlLCB0aXRsZSB9KSB7XG5cdHJldHVybiBgPCFkb2N0eXBlIGh0bWw+XG48aHRtbD5cbjxoZWFkPlxuXHQ8dGl0bGU+JHt0aXRsZX08L3RpdGxlPlxuXHQ8c3R5bGU+XG5cdGJvZHkge1xuXHRcdGJhY2tncm91bmQtY29sb3I6ICNmZmY7XG5cdFx0Y29sb3I6ICMzMzM7XG5cdFx0Zm9udC1mYW1pbHk6IFwiT3BlbiBTYW5zXCIsXCJIZWx2ZXRpY2EgTmV1ZVwiLFwiQXJpYWxcIixzYW5zLXNlcmlmO1xuXHRcdGZvbnQtc2l6ZTogMTVweDtcblx0fVxuXG5cdGJvZHkgPiBkaXYge1xuXHRcdGJhY2tncm91bmQtY29sb3I6ICNmN2Y3Zjc7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgI2NiY2JjYjtcblx0XHRib3JkZXItcmFkaXVzOiA0cHg7XG5cdFx0bWFyZ2luOiAzMHB4IGF1dG87XG5cdFx0cGFkZGluZzogMjBweCAzMHB4O1xuXHRcdHdpZHRoOiAzNjBweDtcblx0fVxuXG5cdC5zdWNjZXNzID4gZGl2IHtcblx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAjZGFmZmRiO1xuXHRcdGJvcmRlcjogMXB4IHNvbGlkICMwMGNiMDY7XG5cdFx0Y29sb3I6ICMwMGNiMDY7XG5cdH1cblxuXHQuZXJyb3IgPiBkaXYge1xuXHRcdGJhY2tncm91bmQtY29sb3I6ICNmZmRhZGE7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgI2NiMDAwMDtcblx0XHRjb2xvcjogI2NiMDAwMDtcblx0fVxuXG5cdGgxIHtcblx0XHRmb250LXNpemU6IDI0cHg7XG5cdFx0Zm9udC13ZWlnaHQ6IGJvbGQ7XG5cdH1cblx0PC9zdHlsZT5cbjwvaGVhZD5cbjxib2R5IGNsYXNzPVwiJHtjbHMgfHwgJyd9XCI+XG5cdDxkaXY+XG5cdFx0PGgxPiR7dGl0bGV9PC9oMT5cblx0XHQ8cD4ke1N0cmluZyhtZXNzYWdlKS5yZXBsYWNlKC8mL2csICcmYW1wOycpLnJlcGxhY2UoLzwvZywgJyZsdDsnKS5yZXBsYWNlKC8+L2csICcmZ3Q7Jyl9PC9wPlxuXHQ8L2Rpdj5cbjwvYm9keT5cbjwvaHRtbD5gO1xufVxuXG4vKipcbiAqIENvcGllcyBhbGwgcGFyYW1zIGludG8gYSBuZXcgb2JqZWN0IGFuZCBjb252ZXJ0cyBjYW1lbGNhc2UgcHJvcGVydHkgbmFtZXMgdG8gdW5kZXJzY29yZSBjYXNlLFxuICogdGhlbiByZXR1cm5zIHRoZSBzdHJpbmdpZmllZCBxdWVyeSBzdHJpbmcuXG4gKlxuICogQHBhcmFtIHtPYmplY3R9IHBhcmFtcyAtIFRoZSBxdWVyeSBzdHJpbmcgcGFyYW1ldGVycyB0byBzdHJpbmdpZnkuXG4gKiBAcmV0dXJucyB7U3RyaW5nfVxuICovXG5leHBvcnQgZnVuY3Rpb24gc3RyaW5naWZ5UXVlcnlTdHJpbmcocGFyYW1zKSB7XG5cdGNvbnN0IHF1ZXJ5UGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcygpO1xuXHRmb3IgKGNvbnN0IHByb3Agb2YgT2JqZWN0LmtleXMocGFyYW1zKS5zb3J0KCkpIHtcblx0XHRjb25zdCBuYW1lID0gcHJvcC5yZXBsYWNlKC9bQS1aXS9nLCAobSwgaSkgPT4gYCR7aSA/ICdfJyA6ICcnfSR7bS50b0xvd2VyQ2FzZSgpfWApO1xuXHRcdHF1ZXJ5UGFyYW1zLmFwcGVuZChuYW1lLCBwYXJhbXNbcHJvcF0pO1xuXHR9XG5cdHJldHVybiBxdWVyeVBhcmFtcy50b1N0cmluZygpO1xufVxuIl0sImZpbGUiOiJ1dGlsLmpzIn0=
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInV0aWwuanMiXSwibmFtZXMiOlsibG9nIiwiZ2V0U2VydmVySW5mbyIsInVybCIsIkUiLCJJTlZBTElEX0FSR1VNRU5UIiwiYm9keSIsInZhbGlkYXRlSlNPTiIsImVyciIsImNvZGUiLCJFcnJvciIsInN0YXR1c0NvZGUiLCJtZDUiLCJpdCIsImNyeXB0byIsImNyZWF0ZUhhc2giLCJ1cGRhdGUiLCJKU09OIiwic3RyaW5naWZ5IiwiZGlnZXN0IiwicmVuZGVySFRNTCIsImNscyIsIm1lc3NhZ2UiLCJ0aXRsZSIsIlN0cmluZyIsInJlcGxhY2UiLCJzdHJpbmdpZnlRdWVyeVN0cmluZyIsInBhcmFtcyIsInF1ZXJ5UGFyYW1zIiwiVVJMU2VhcmNoUGFyYW1zIiwicHJvcCIsIk9iamVjdCIsImtleXMiLCJzb3J0IiwibmFtZSIsIm0iLCJpIiwidG9Mb3dlckNhc2UiLCJhcHBlbmQiLCJ0b1N0cmluZyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUVBOztBQUNBOzs7O0FBRUEsTUFBTTtBQUFFQSxFQUFBQTtBQUFGLElBQVUsd0JBQVUsbUJBQVYsQ0FBaEI7QUFFQTs7Ozs7OztBQU1PLGVBQWVDLGFBQWYsQ0FBNkJDLEdBQTdCLEVBQWtDO0FBQ3hDLE1BQUksQ0FBQ0EsR0FBRCxJQUFRLE9BQU9BLEdBQVAsS0FBZSxRQUEzQixFQUFxQztBQUNwQyxVQUFNQyxnQkFBRUMsZ0JBQUYsQ0FBbUIsdUNBQW5CLENBQU47QUFDQTs7QUFFREosRUFBQUEsR0FBRyxDQUFFLHlCQUF3QkUsR0FBSSxLQUE5QixDQUFIOztBQUNBLE1BQUk7QUFDSCxVQUFNO0FBQUVHLE1BQUFBO0FBQUYsUUFBVyxNQUFNLDZCQUFRO0FBQUVILE1BQUFBLEdBQUY7QUFBT0ksTUFBQUEsWUFBWSxFQUFFO0FBQXJCLEtBQVIsQ0FBdkI7QUFDQSxXQUFPRCxJQUFQO0FBQ0EsR0FIRCxDQUdFLE9BQU9FLEdBQVAsRUFBWTtBQUNiLFFBQUlBLEdBQUcsQ0FBQ0MsSUFBSixLQUFhLGNBQWpCLEVBQWlDO0FBQ2hDLFlBQU1ELEdBQU47QUFDQTs7QUFDRCxVQUFNLElBQUlFLEtBQUosQ0FBVyxxQ0FBb0NGLEdBQUcsQ0FBQ0csVUFBVyxHQUE5RCxDQUFOO0FBQ0E7QUFFRDtBQUVEOzs7Ozs7OztBQU1PLFNBQVNDLEdBQVQsQ0FBYUMsRUFBYixFQUFpQjtBQUN2QixTQUFPQyxnQkFBT0MsVUFBUCxDQUFrQixLQUFsQixFQUF5QkMsTUFBekIsQ0FBZ0MsT0FBT0gsRUFBUCxLQUFjLFFBQWQsR0FBeUJBLEVBQXpCLEdBQThCSSxJQUFJLENBQUNDLFNBQUwsQ0FBZUwsRUFBZixDQUE5RCxFQUFrRk0sTUFBbEYsQ0FBeUYsS0FBekYsQ0FBUDtBQUNBO0FBRUQ7Ozs7Ozs7OztBQU9PLFNBQVNDLFVBQVQsQ0FBb0I7QUFBRUMsRUFBQUEsR0FBRjtBQUFPQyxFQUFBQSxPQUFQO0FBQWdCQyxFQUFBQTtBQUFoQixDQUFwQixFQUE2QztBQUNuRCxTQUFROzs7VUFHQ0EsS0FBTTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O2VBb0NERixHQUFHLElBQUksRUFBRzs7UUFFakJFLEtBQU07T0FDUEMsTUFBTSxDQUFDRixPQUFELENBQU4sQ0FBZ0JHLE9BQWhCLENBQXdCLElBQXhCLEVBQThCLE9BQTlCLEVBQXVDQSxPQUF2QyxDQUErQyxJQUEvQyxFQUFxRCxNQUFyRCxFQUE2REEsT0FBN0QsQ0FBcUUsSUFBckUsRUFBMkUsTUFBM0UsQ0FBbUY7OztRQTFDekY7QUE4Q0E7QUFFRDs7Ozs7Ozs7O0FBT08sU0FBU0Msb0JBQVQsQ0FBOEJDLE1BQTlCLEVBQXNDO0FBQzVDLFFBQU1DLFdBQVcsR0FBRyxJQUFJQyxvQkFBSixFQUFwQjs7QUFDQSxPQUFLLE1BQU1DLElBQVgsSUFBbUJDLE1BQU0sQ0FBQ0MsSUFBUCxDQUFZTCxNQUFaLEVBQW9CTSxJQUFwQixFQUFuQixFQUErQztBQUM5QyxVQUFNQyxJQUFJLEdBQUdKLElBQUksQ0FBQ0wsT0FBTCxDQUFhLFFBQWIsRUFBdUIsQ0FBQ1UsQ0FBRCxFQUFJQyxDQUFKLEtBQVcsR0FBRUEsQ0FBQyxHQUFHLEdBQUgsR0FBUyxFQUFHLEdBQUVELENBQUMsQ0FBQ0UsV0FBRixFQUFnQixFQUFuRSxDQUFiO0FBQ0FULElBQUFBLFdBQVcsQ0FBQ1UsTUFBWixDQUFtQkosSUFBbkIsRUFBeUJQLE1BQU0sQ0FBQ0csSUFBRCxDQUEvQjtBQUNBOztBQUNELFNBQU9GLFdBQVcsQ0FBQ1csUUFBWixFQUFQO0FBQ0EiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgY3J5cHRvIGZyb20gJ2NyeXB0byc7XG5pbXBvcnQgRSBmcm9tICcuL2Vycm9ycyc7XG5pbXBvcnQgc25vb3Bsb2dnIGZyb20gJ3Nub29wbG9nZyc7XG5cbmltcG9ydCByZXF1ZXN0IGZyb20gJ0BheHdheS9hbXBsaWZ5LXJlcXVlc3QnO1xuaW1wb3J0IHsgVVJMU2VhcmNoUGFyYW1zIH0gZnJvbSAndXJsJztcblxuY29uc3QgeyBsb2cgfSA9IHNub29wbG9nZygnYW1wbGlmeS1hdXRoOnV0aWwnKTtcblxuLyoqXG4gKiBEaXNjb3ZlcnMgYXZhaWxhYmxlIGVuZHBvaW50cyBiYXNlZCBvbiB0aGUgcmVtb3RlIHNlcnZlcidzIE9wZW5JRCBjb25maWd1cmF0aW9uLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSBbdXJsXSAtIEFuIG9wdGlvbmFsIFVSTCB0byBkaXNjb3ZlciB0aGUgYXZhaWxhYmxlIGVuZHBvaW50cy5cbiAqIEByZXR1cm5zIHtQcm9taXNlPE9iamVjdD59XG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBnZXRTZXJ2ZXJJbmZvKHVybCkge1xuXHRpZiAoIXVybCB8fCB0eXBlb2YgdXJsICE9PSAnc3RyaW5nJykge1xuXHRcdHRocm93IEUuSU5WQUxJRF9BUkdVTUVOVCgnRXhwZWN0ZWQgVVJMIHRvIGJlIGEgbm9uLWVtcHR5IHN0cmluZycpO1xuXHR9XG5cblx0bG9nKGBGZXRjaGluZyBzZXJ2ZXIgaW5mbzogJHt1cmx9Li4uYCk7XG5cdHRyeSB7XG5cdFx0Y29uc3QgeyBib2R5IH0gPSBhd2FpdCByZXF1ZXN0KHsgdXJsLCB2YWxpZGF0ZUpTT046IHRydWUgfSk7XG5cdFx0cmV0dXJuIGJvZHk7XG5cdH0gY2F0Y2ggKGVycikge1xuXHRcdGlmIChlcnIuY29kZSA9PT0gJ0lOVkFMSURfSlNPTicpIHtcblx0XHRcdHRocm93IGVycjtcblx0XHR9XG5cdFx0dGhyb3cgbmV3IEVycm9yKGBGYWlsZWQgdG8gZ2V0IHNlcnZlciBpbmZvIChzdGF0dXMgJHtlcnIuc3RhdHVzQ29kZX0pYCk7XG5cdH1cblxufVxuXG4vKipcbiAqIFJldHVybnMgYSBoZXggZW5jb2RlZCBtZDUgaGFzaCBvZiBhIHN0cmluZyBvciBvYmplY3QuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd8T2JqZWN0fSBpdCAtIFRoZSBvYmplY3QgdG8gc2VyaWFsaXplIGFuZCBoYXNoLlxuICogQHJldHVybnMge1N0cmluZ31cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG1kNShpdCkge1xuXHRyZXR1cm4gY3J5cHRvLmNyZWF0ZUhhc2goJ21kNScpLnVwZGF0ZSh0eXBlb2YgaXQgPT09ICdzdHJpbmcnID8gaXQgOiBKU09OLnN0cmluZ2lmeShpdCkpLmRpZ2VzdCgnaGV4Jyk7XG59XG5cbi8qKlxuICogR2VuZXJhdGVzIGFuIEhUTUwgcGFnZSB3aXRoIGEgcGFuZWwgY29udGFpbmluZyBhIHRpdGxlIGFuZCBhIG1lc3NhZ2UuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9IHRpdGxlIC0gVGhlIHRpdGxlIHRvIGRpc3BsYXkuXG4gKiBAcGFyYW0ge1N0cmluZ30gbWVzc2FnZSAtIFRoZSBtZXNzYWdlIHRvIGluamVjdCBpbnRvIHRoZSBwYWdlLlxuICogQHJldHVybnMge1N0cmluZ31cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHJlbmRlckhUTUwoeyBjbHMsIG1lc3NhZ2UsIHRpdGxlIH0pIHtcblx0cmV0dXJuIGA8IWRvY3R5cGUgaHRtbD5cbjxodG1sPlxuPGhlYWQ+XG5cdDx0aXRsZT4ke3RpdGxlfTwvdGl0bGU+XG5cdDxzdHlsZT5cblx0Ym9keSB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogI2ZmZjtcblx0XHRjb2xvcjogIzMzMztcblx0XHRmb250LWZhbWlseTogXCJPcGVuIFNhbnNcIixcIkhlbHZldGljYSBOZXVlXCIsXCJBcmlhbFwiLHNhbnMtc2VyaWY7XG5cdFx0Zm9udC1zaXplOiAxNXB4O1xuXHR9XG5cblx0Ym9keSA+IGRpdiB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogI2Y3ZjdmNztcblx0XHRib3JkZXI6IDFweCBzb2xpZCAjY2JjYmNiO1xuXHRcdGJvcmRlci1yYWRpdXM6IDRweDtcblx0XHRtYXJnaW46IDMwcHggYXV0bztcblx0XHRwYWRkaW5nOiAyMHB4IDMwcHg7XG5cdFx0d2lkdGg6IDM2MHB4O1xuXHR9XG5cblx0LnN1Y2Nlc3MgPiBkaXYge1xuXHRcdGJhY2tncm91bmQtY29sb3I6ICNkYWZmZGI7XG5cdFx0Ym9yZGVyOiAxcHggc29saWQgIzAwY2IwNjtcblx0XHRjb2xvcjogIzAwY2IwNjtcblx0fVxuXG5cdC5lcnJvciA+IGRpdiB7XG5cdFx0YmFja2dyb3VuZC1jb2xvcjogI2ZmZGFkYTtcblx0XHRib3JkZXI6IDFweCBzb2xpZCAjY2IwMDAwO1xuXHRcdGNvbG9yOiAjY2IwMDAwO1xuXHR9XG5cblx0aDEge1xuXHRcdGZvbnQtc2l6ZTogMjRweDtcblx0XHRmb250LXdlaWdodDogYm9sZDtcblx0fVxuXHQ8L3N0eWxlPlxuPC9oZWFkPlxuPGJvZHkgY2xhc3M9XCIke2NscyB8fCAnJ31cIj5cblx0PGRpdj5cblx0XHQ8aDE+JHt0aXRsZX08L2gxPlxuXHRcdDxwPiR7U3RyaW5nKG1lc3NhZ2UpLnJlcGxhY2UoLyYvZywgJyZhbXA7JykucmVwbGFjZSgvPC9nLCAnJmx0OycpLnJlcGxhY2UoLz4vZywgJyZndDsnKX08L3A+XG5cdDwvZGl2PlxuPC9ib2R5PlxuPC9odG1sPmA7XG59XG5cbi8qKlxuICogQ29waWVzIGFsbCBwYXJhbXMgaW50byBhIG5ldyBvYmplY3QgYW5kIGNvbnZlcnRzIGNhbWVsY2FzZSBwcm9wZXJ0eSBuYW1lcyB0byB1bmRlcnNjb3JlIGNhc2UsXG4gKiB0aGVuIHJldHVybnMgdGhlIHN0cmluZ2lmaWVkIHF1ZXJ5IHN0cmluZy5cbiAqXG4gKiBAcGFyYW0ge09iamVjdH0gcGFyYW1zIC0gVGhlIHF1ZXJ5IHN0cmluZyBwYXJhbWV0ZXJzIHRvIHN0cmluZ2lmeS5cbiAqIEByZXR1cm5zIHtTdHJpbmd9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzdHJpbmdpZnlRdWVyeVN0cmluZyhwYXJhbXMpIHtcblx0Y29uc3QgcXVlcnlQYXJhbXMgPSBuZXcgVVJMU2VhcmNoUGFyYW1zKCk7XG5cdGZvciAoY29uc3QgcHJvcCBvZiBPYmplY3Qua2V5cyhwYXJhbXMpLnNvcnQoKSkge1xuXHRcdGNvbnN0IG5hbWUgPSBwcm9wLnJlcGxhY2UoL1tBLVpdL2csIChtLCBpKSA9PiBgJHtpID8gJ18nIDogJyd9JHttLnRvTG93ZXJDYXNlKCl9YCk7XG5cdFx0cXVlcnlQYXJhbXMuYXBwZW5kKG5hbWUsIHBhcmFtc1twcm9wXSk7XG5cdH1cblx0cmV0dXJuIHF1ZXJ5UGFyYW1zLnRvU3RyaW5nKCk7XG59XG4iXSwiZmlsZSI6InV0aWwuanMifQ==
{
"name": "@axway/amplify-auth-sdk",
"version": "0.1.3",
"version": "0.2.0",
"description": "Axway AMPLIFY authentication SDK for Node.js",

@@ -8,3 +8,3 @@ "author": "Axway, Inc. <npmjs@appcelerator.com>",

"Chris Barber <cbarber@axway.com>",
"Feon Sua <fmiao@axway.com>"
"Ewan Harris <eharris@axway.com>"
],

@@ -23,7 +23,6 @@ "license": "Apache-2.0",

"dependencies": {
"@axway/amplify-request": "^0.1.3",
"@axway/amplify-request": "^0.2.0",
"accepts": "^1.3.5",
"fs-extra": "^7.0.0",
"fs-extra": "^7.0.1",
"jws": "^3.1.5",
"keytar": "^4.2.1",
"opn": "^5.4.0",

@@ -34,6 +33,9 @@ "snooplogg": "^1.13.2",

"devDependencies": {
"appcd-gulp": "^1.2.0",
"appcd-gulp": "^1.2.1",
"gulp": "^3.9.1",
"tmp": "^0.0.33"
},
"optionalDependencies": {
"keytar": "^4.3.0"
},
"homepage": "https://github.com/appcelerator/amplify-tooling#readme",

@@ -44,4 +46,3 @@ "bugs": "https://github.com/appcelerator/amplify-tooling/issues",

"node": ">=8.0.0"
},
"gitHead": "c521dc6a436085fb559e18fb5aff2a28662fc650"
}
}

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc