@ariyana/appauth
Version:
A general purpose OAuth client.
130 lines • 19.5 kB
JavaScript
;
/*
* Copyright 2017 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing permissions and
* limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.App = void 0;
// Represents a Node application, that uses the AppAuthJS library.
var authorization_request_1 = require("../authorization_request");
var authorization_request_handler_1 = require("../authorization_request_handler");
var authorization_service_configuration_1 = require("../authorization_service_configuration");
var logger_1 = require("../logger");
var node_support_1 = require("../node_support");
var node_requestor_1 = require("../node_support/node_requestor");
var node_request_handler_1 = require("../node_support/node_request_handler");
var revoke_token_request_1 = require("../revoke_token_request");
var token_request_1 = require("../token_request");
var token_request_handler_1 = require("../token_request_handler");
var PORT = 32111;
/* the Node.js based HTTP client. */
var requestor = new node_requestor_1.NodeRequestor();
/* an example open id connect provider */
var openIdConnectUrl = 'https://accounts.google.com';
/* example client configuration */
var clientId = '511828570984-7nmej36h9j2tebiqmpqh835naet4vci4.apps.googleusercontent.com';
var redirectUri = "http://127.0.0.1:" + PORT;
var scope = 'openid';
var App = /** @class */ (function () {
function App() {
var _this = this;
this.notifier = new authorization_request_handler_1.AuthorizationNotifier();
this.authorizationHandler = new node_request_handler_1.NodeBasedHandler(PORT);
this.tokenHandler = new token_request_handler_1.BaseTokenRequestHandler(requestor);
// set notifier to deliver responses
this.authorizationHandler.setAuthorizationNotifier(this.notifier);
// set a listener to listen for authorization responses
// make refresh and access token requests.
this.notifier.setAuthorizationListener(function (request, response, error) {
logger_1.log('Authorization request complete ', request, response, error);
if (response) {
_this.makeRefreshTokenRequest(_this.configuration, request, response)
.then(function (result) { return _this.makeAccessTokenRequest(_this.configuration, result.refreshToken); })
.then(function () { return logger_1.log('All done.'); });
}
});
}
App.prototype.fetchServiceConfiguration = function () {
return authorization_service_configuration_1.AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl, requestor)
.then(function (response) {
logger_1.log('Fetched service configuration', response);
return response;
});
};
App.prototype.makeAuthorizationRequest = function (configuration) {
// create a request
var request = new authorization_request_1.AuthorizationRequest({
client_id: clientId,
redirect_uri: redirectUri,
scope: scope,
response_type: authorization_request_1.AuthorizationRequest.RESPONSE_TYPE_CODE,
state: undefined,
extras: { 'prompt': 'consent', 'access_type': 'offline' }
}, new node_support_1.NodeCrypto());
logger_1.log('Making authorization request ', configuration, request);
this.authorizationHandler.performAuthorizationRequest(configuration, request);
};
App.prototype.makeRefreshTokenRequest = function (configuration, request, response) {
var extras = undefined;
if (request && request.internal) {
extras = {};
extras['code_verifier'] = request.internal['code_verifier'];
}
var tokenRequest = new token_request_1.TokenRequest({
client_id: clientId,
redirect_uri: redirectUri,
grant_type: token_request_1.GRANT_TYPE_AUTHORIZATION_CODE,
code: response.code,
refresh_token: undefined,
extras: extras
});
return this.tokenHandler.performTokenRequest(configuration, tokenRequest).then(function (response) {
logger_1.log("Refresh Token is " + response.refreshToken);
return response;
});
};
App.prototype.makeAccessTokenRequest = function (configuration, refreshToken) {
var request = new token_request_1.TokenRequest({
client_id: clientId,
redirect_uri: redirectUri,
grant_type: token_request_1.GRANT_TYPE_REFRESH_TOKEN,
code: undefined,
refresh_token: refreshToken,
extras: undefined
});
return this.tokenHandler.performTokenRequest(configuration, request).then(function (response) {
logger_1.log("Access Token is " + response.accessToken + ", Id Token is " + response.idToken);
return response;
});
};
App.prototype.makeRevokeTokenRequest = function (configuration, refreshToken) {
var request = new revoke_token_request_1.RevokeTokenRequest({ token: refreshToken });
return this.tokenHandler.performRevokeTokenRequest(configuration, request).then(function (response) {
logger_1.log('revoked refreshToken');
return response;
});
};
return App;
}());
exports.App = App;
logger_1.log('Application is ready.');
var app = new App();
app.fetchServiceConfiguration()
.then(function (configuration) {
app.configuration = configuration;
app.makeAuthorizationRequest(configuration);
// notifier makes token requests.
})
.catch(function (error) {
logger_1.log('Something bad happened ', error);
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/node_app/index.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright 2017 Google Inc.\r\n *\r\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\r\n * in compliance with the License. You may obtain a copy of the License at\r\n *\r\n * http://www.apache.org/licenses/LICENSE-2.0\r\n *\r\n * Unless required by applicable law or agreed to in writing, software distributed under the\r\n * License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either\r\n * express or implied. See the License for the specific language governing permissions and\r\n * limitations under the License.\r\n */\r\n\r\n// Represents a Node application, that uses the AppAuthJS library.\r\n\r\nimport { AuthorizationRequest } from '../authorization_request';\r\nimport { AuthorizationNotifier, AuthorizationRequestHandler } from '../authorization_request_handler';\r\nimport { AuthorizationResponse } from '../authorization_response';\r\nimport { AuthorizationServiceConfiguration } from '../authorization_service_configuration';\r\nimport { log } from '../logger';\r\nimport { NodeCrypto } from '../node_support';\r\nimport { NodeRequestor } from '../node_support/node_requestor';\r\nimport { NodeBasedHandler } from '../node_support/node_request_handler';\r\nimport { RevokeTokenRequest } from '../revoke_token_request';\r\nimport { GRANT_TYPE_AUTHORIZATION_CODE, GRANT_TYPE_REFRESH_TOKEN, TokenRequest } from '../token_request';\r\nimport { BaseTokenRequestHandler, TokenRequestHandler } from '../token_request_handler';\r\nimport { StringMap } from '../types';\r\n\r\nconst PORT = 32111;\r\n\r\n/* the Node.js based HTTP client. */\r\nconst requestor = new NodeRequestor();\r\n\r\n/* an example open id connect provider */\r\nconst openIdConnectUrl = 'https://accounts.google.com';\r\n\r\n/* example client configuration */\r\nconst clientId = '511828570984-7nmej36h9j2tebiqmpqh835naet4vci4.apps.googleusercontent.com';\r\nconst redirectUri = `http://127.0.0.1:${PORT}`;\r\nconst scope = 'openid';\r\n\r\nexport class App {\r\n  private notifier: AuthorizationNotifier;\r\n  private authorizationHandler: AuthorizationRequestHandler;\r\n  private tokenHandler: TokenRequestHandler;\r\n\r\n  // state\r\n  configuration: AuthorizationServiceConfiguration|undefined;\r\n\r\n  constructor() {\r\n    this.notifier = new AuthorizationNotifier();\r\n    this.authorizationHandler = new NodeBasedHandler(PORT);\r\n    this.tokenHandler = new BaseTokenRequestHandler(requestor);\r\n    // set notifier to deliver responses\r\n    this.authorizationHandler.setAuthorizationNotifier(this.notifier);\r\n    // set a listener to listen for authorization responses\r\n    // make refresh and access token requests.\r\n    this.notifier.setAuthorizationListener((request, response, error) => {\r\n      log('Authorization request complete ', request, response, error);\r\n      if (response) {\r\n        this.makeRefreshTokenRequest(this.configuration!, request, response)\r\n            .then(result => this.makeAccessTokenRequest(this.configuration!, result.refreshToken!))\r\n            .then(() => log('All done.'));\r\n      }\r\n    });\r\n  }\r\n\r\n  fetchServiceConfiguration(): Promise<AuthorizationServiceConfiguration> {\r\n    return AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl, requestor)\r\n        .then(response => {\r\n          log('Fetched service configuration', response);\r\n          return response;\r\n        });\r\n  }\r\n\r\n  makeAuthorizationRequest(configuration: AuthorizationServiceConfiguration) {\r\n    // create a request\r\n    let request = new AuthorizationRequest({\r\n      client_id: clientId,\r\n      redirect_uri: redirectUri,\r\n      scope: scope,\r\n      response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,\r\n      state: undefined,\r\n      extras: {'prompt': 'consent', 'access_type': 'offline'}\r\n    }, new NodeCrypto());\r\n\r\n    log('Making authorization request ', configuration, request);\r\n    this.authorizationHandler.performAuthorizationRequest(configuration, request);\r\n  }\r\n\r\n  makeRefreshTokenRequest(\r\n      configuration: AuthorizationServiceConfiguration,\r\n      request: AuthorizationRequest,\r\n      response: AuthorizationResponse) {\r\n    \r\n    let extras: StringMap|undefined = undefined;\r\n    if (request && request.internal) {\r\n      extras = {};\r\n      extras['code_verifier'] = request.internal['code_verifier'];\r\n    }\r\n\r\n    let tokenRequest = new TokenRequest({\r\n      client_id: clientId,\r\n      redirect_uri: redirectUri,\r\n      grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\r\n      code: response.code,\r\n      refresh_token: undefined,\r\n      extras: extras\r\n    });\r\n\r\n    return this.tokenHandler.performTokenRequest(configuration, tokenRequest).then(response => {\r\n      log(`Refresh Token is ${response.refreshToken}`);\r\n      return response;\r\n    });\r\n  }\r\n\r\n  makeAccessTokenRequest(configuration: AuthorizationServiceConfiguration, refreshToken: string) {\r\n    let request = new TokenRequest({\r\n      client_id: clientId,\r\n      redirect_uri: redirectUri,\r\n      grant_type: GRANT_TYPE_REFRESH_TOKEN,\r\n      code: undefined,\r\n      refresh_token: refreshToken,\r\n      extras: undefined\r\n    });\r\n\r\n    return this.tokenHandler.performTokenRequest(configuration, request).then(response => {\r\n      log(`Access Token is ${response.accessToken}, Id Token is ${response.idToken}`);\r\n      return response;\r\n    });\r\n  }\r\n\r\n  makeRevokeTokenRequest(configuration: AuthorizationServiceConfiguration, refreshToken: string) {\r\n    let request = new RevokeTokenRequest({token: refreshToken});\r\n\r\n    return this.tokenHandler.performRevokeTokenRequest(configuration, request).then(response => {\r\n      log('revoked refreshToken');\r\n      return response;\r\n    });\r\n  }\r\n}\r\n\r\nlog('Application is ready.');\r\nconst app = new App();\r\n\r\napp.fetchServiceConfiguration()\r\n    .then(configuration => {\r\n      app.configuration = configuration;\r\n      app.makeAuthorizationRequest(configuration);\r\n      // notifier makes token requests.\r\n    })\r\n    .catch(error => {\r\n      log('Something bad happened ', error);\r\n    });\r\n"]}