@delewis13/appauth
Version:
A general purpose OAuth client. Vendored awaiting PR merge
130 lines • 19.1 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) {
(0, 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 (0, logger_1.log)('All done.'); });
}
});
}
App.prototype.fetchServiceConfiguration = function () {
return authorization_service_configuration_1.AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl, requestor)
.then(function (response) {
(0, 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());
(0, 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) {
(0, 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) {
(0, 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) {
(0, logger_1.log)('revoked refreshToken');
return response;
});
};
return App;
}());
exports.App = App;
(0, 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) {
(0, 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":";AAAA;;;;;;;;;;;;GAYG;;;AAEH,kEAAkE;AAElE,kEAAgE;AAChE,kFAAsG;AAEtG,8FAA2F;AAC3F,oCAAgC;AAChC,gDAA6C;AAC7C,iEAA+D;AAC/D,6EAAwE;AACxE,gEAA6D;AAC7D,kDAAyG;AACzG,kEAAwF;AAGxF,IAAM,IAAI,GAAG,KAAK,CAAC;AAEnB,oCAAoC;AACpC,IAAM,SAAS,GAAG,IAAI,8BAAa,EAAE,CAAC;AAEtC,yCAAyC;AACzC,IAAM,gBAAgB,GAAG,6BAA6B,CAAC;AAEvD,kCAAkC;AAClC,IAAM,QAAQ,GAAG,0EAA0E,CAAC;AAC5F,IAAM,WAAW,GAAG,sBAAoB,IAAM,CAAC;AAC/C,IAAM,KAAK,GAAG,QAAQ,CAAC;AAEvB;IAQE;QAAA,iBAgBC;QAfC,IAAI,CAAC,QAAQ,GAAG,IAAI,qDAAqB,EAAE,CAAC;QAC5C,IAAI,CAAC,oBAAoB,GAAG,IAAI,uCAAgB,CAAC,IAAI,CAAC,CAAC;QACvD,IAAI,CAAC,YAAY,GAAG,IAAI,+CAAuB,CAAC,SAAS,CAAC,CAAC;QAC3D,oCAAoC;QACpC,IAAI,CAAC,oBAAoB,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClE,uDAAuD;QACvD,0CAA0C;QAC1C,IAAI,CAAC,QAAQ,CAAC,wBAAwB,CAAC,UAAC,OAAO,EAAE,QAAQ,EAAE,KAAK;YAC9D,IAAA,YAAG,EAAC,iCAAiC,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;YACjE,IAAI,QAAQ,EAAE;gBACZ,KAAI,CAAC,uBAAuB,CAAC,KAAI,CAAC,aAAc,EAAE,OAAO,EAAE,QAAQ,CAAC;qBAC/D,IAAI,CAAC,UAAA,MAAM,IAAI,OAAA,KAAI,CAAC,sBAAsB,CAAC,KAAI,CAAC,aAAc,EAAE,MAAM,CAAC,YAAa,CAAC,EAAtE,CAAsE,CAAC;qBACtF,IAAI,CAAC,cAAM,OAAA,IAAA,YAAG,EAAC,WAAW,CAAC,EAAhB,CAAgB,CAAC,CAAC;aACnC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,uCAAyB,GAAzB;QACE,OAAO,uEAAiC,CAAC,eAAe,CAAC,gBAAgB,EAAE,SAAS,CAAC;aAChF,IAAI,CAAC,UAAA,QAAQ;YACZ,IAAA,YAAG,EAAC,+BAA+B,EAAE,QAAQ,CAAC,CAAC;YAC/C,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IACT,CAAC;IAED,sCAAwB,GAAxB,UAAyB,aAAgD;QACvE,mBAAmB;QACnB,IAAI,OAAO,GAAG,IAAI,4CAAoB,CAAC;YACrC,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,WAAW;YACzB,KAAK,EAAE,KAAK;YACZ,aAAa,EAAE,4CAAoB,CAAC,kBAAkB;YACtD,KAAK,EAAE,SAAS;YAChB,MAAM,EAAE,EAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,SAAS,EAAC;SACxD,EAAE,IAAI,yBAAU,EAAE,CAAC,CAAC;QAErB,IAAA,YAAG,EAAC,+BAA+B,EAAE,aAAa,EAAE,OAAO,CAAC,CAAC;QAC7D,IAAI,CAAC,oBAAoB,CAAC,2BAA2B,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAChF,CAAC;IAED,qCAAuB,GAAvB,UACI,aAAgD,EAChD,OAA6B,EAC7B,QAA+B;QAEjC,IAAI,MAAM,GAAwB,SAAS,CAAC;QAC5C,IAAI,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE;YAC/B,MAAM,GAAG,EAAE,CAAC;YACZ,MAAM,CAAC,eAAe,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC;SAC7D;QAED,IAAI,YAAY,GAAG,IAAI,4BAAY,CAAC;YAClC,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,WAAW;YACzB,UAAU,EAAE,6CAA6B;YACzC,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,aAAa,EAAE,SAAS;YACxB,MAAM,EAAE,MAAM;SACf,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,UAAA,QAAQ;YACrF,IAAA,YAAG,EAAC,sBAAoB,QAAQ,CAAC,YAAc,CAAC,CAAC;YACjD,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oCAAsB,GAAtB,UAAuB,aAAgD,EAAE,YAAoB;QAC3F,IAAI,OAAO,GAAG,IAAI,4BAAY,CAAC;YAC7B,SAAS,EAAE,QAAQ;YACnB,YAAY,EAAE,WAAW;YACzB,UAAU,EAAE,wCAAwB;YACpC,IAAI,EAAE,SAAS;YACf,aAAa,EAAE,YAAY;YAC3B,MAAM,EAAE,SAAS;SAClB,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,UAAA,QAAQ;YAChF,IAAA,YAAG,EAAC,qBAAmB,QAAQ,CAAC,WAAW,sBAAiB,QAAQ,CAAC,OAAS,CAAC,CAAC;YAChF,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,oCAAsB,GAAtB,UAAuB,aAAgD,EAAE,YAAoB;QAC3F,IAAI,OAAO,GAAG,IAAI,yCAAkB,CAAC,EAAC,KAAK,EAAE,YAAY,EAAC,CAAC,CAAC;QAE5D,OAAO,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC,UAAA,QAAQ;YACtF,IAAA,YAAG,EAAC,sBAAsB,CAAC,CAAC;YAC5B,OAAO,QAAQ,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC;IACH,UAAC;AAAD,CAAC,AAnGD,IAmGC;AAnGY,kBAAG;AAqGhB,IAAA,YAAG,EAAC,uBAAuB,CAAC,CAAC;AAC7B,IAAM,GAAG,GAAG,IAAI,GAAG,EAAE,CAAC;AAEtB,GAAG,CAAC,yBAAyB,EAAE;KAC1B,IAAI,CAAC,UAAA,aAAa;IACjB,GAAG,CAAC,aAAa,GAAG,aAAa,CAAC;IAClC,GAAG,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAC;IAC5C,iCAAiC;AACnC,CAAC,CAAC;KACD,KAAK,CAAC,UAAA,KAAK;IACV,IAAA,YAAG,EAAC,yBAAyB,EAAE,KAAK,CAAC,CAAC;AACxC,CAAC,CAAC,CAAC","sourcesContent":["/*\n * Copyright 2017 Google Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use this file except\n * in compliance with the License. You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software distributed under the\n * License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either\n * express or implied. See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// Represents a Node application, that uses the AppAuthJS library.\n\nimport { AuthorizationRequest } from '../authorization_request';\nimport { AuthorizationNotifier, AuthorizationRequestHandler } from '../authorization_request_handler';\nimport { AuthorizationResponse } from '../authorization_response';\nimport { AuthorizationServiceConfiguration } from '../authorization_service_configuration';\nimport { log } from '../logger';\nimport { NodeCrypto } from '../node_support';\nimport { NodeRequestor } from '../node_support/node_requestor';\nimport { NodeBasedHandler } from '../node_support/node_request_handler';\nimport { RevokeTokenRequest } from '../revoke_token_request';\nimport { GRANT_TYPE_AUTHORIZATION_CODE, GRANT_TYPE_REFRESH_TOKEN, TokenRequest } from '../token_request';\nimport { BaseTokenRequestHandler, TokenRequestHandler } from '../token_request_handler';\nimport { StringMap } from '../types';\n\nconst PORT = 32111;\n\n/* the Node.js based HTTP client. */\nconst requestor = new NodeRequestor();\n\n/* an example open id connect provider */\nconst openIdConnectUrl = 'https://accounts.google.com';\n\n/* example client configuration */\nconst clientId = '511828570984-7nmej36h9j2tebiqmpqh835naet4vci4.apps.googleusercontent.com';\nconst redirectUri = `http://127.0.0.1:${PORT}`;\nconst scope = 'openid';\n\nexport class App {\n  private notifier: AuthorizationNotifier;\n  private authorizationHandler: AuthorizationRequestHandler;\n  private tokenHandler: TokenRequestHandler;\n\n  // state\n  configuration: AuthorizationServiceConfiguration|undefined;\n\n  constructor() {\n    this.notifier = new AuthorizationNotifier();\n    this.authorizationHandler = new NodeBasedHandler(PORT);\n    this.tokenHandler = new BaseTokenRequestHandler(requestor);\n    // set notifier to deliver responses\n    this.authorizationHandler.setAuthorizationNotifier(this.notifier);\n    // set a listener to listen for authorization responses\n    // make refresh and access token requests.\n    this.notifier.setAuthorizationListener((request, response, error) => {\n      log('Authorization request complete ', request, response, error);\n      if (response) {\n        this.makeRefreshTokenRequest(this.configuration!, request, response)\n            .then(result => this.makeAccessTokenRequest(this.configuration!, result.refreshToken!))\n            .then(() => log('All done.'));\n      }\n    });\n  }\n\n  fetchServiceConfiguration(): Promise<AuthorizationServiceConfiguration> {\n    return AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl, requestor)\n        .then(response => {\n          log('Fetched service configuration', response);\n          return response;\n        });\n  }\n\n  makeAuthorizationRequest(configuration: AuthorizationServiceConfiguration) {\n    // create a request\n    let request = new AuthorizationRequest({\n      client_id: clientId,\n      redirect_uri: redirectUri,\n      scope: scope,\n      response_type: AuthorizationRequest.RESPONSE_TYPE_CODE,\n      state: undefined,\n      extras: {'prompt': 'consent', 'access_type': 'offline'}\n    }, new NodeCrypto());\n\n    log('Making authorization request ', configuration, request);\n    this.authorizationHandler.performAuthorizationRequest(configuration, request);\n  }\n\n  makeRefreshTokenRequest(\n      configuration: AuthorizationServiceConfiguration,\n      request: AuthorizationRequest,\n      response: AuthorizationResponse) {\n    \n    let extras: StringMap|undefined = undefined;\n    if (request && request.internal) {\n      extras = {};\n      extras['code_verifier'] = request.internal['code_verifier'];\n    }\n\n    let tokenRequest = new TokenRequest({\n      client_id: clientId,\n      redirect_uri: redirectUri,\n      grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\n      code: response.code,\n      refresh_token: undefined,\n      extras: extras\n    });\n\n    return this.tokenHandler.performTokenRequest(configuration, tokenRequest).then(response => {\n      log(`Refresh Token is ${response.refreshToken}`);\n      return response;\n    });\n  }\n\n  makeAccessTokenRequest(configuration: AuthorizationServiceConfiguration, refreshToken: string) {\n    let request = new TokenRequest({\n      client_id: clientId,\n      redirect_uri: redirectUri,\n      grant_type: GRANT_TYPE_REFRESH_TOKEN,\n      code: undefined,\n      refresh_token: refreshToken,\n      extras: undefined\n    });\n\n    return this.tokenHandler.performTokenRequest(configuration, request).then(response => {\n      log(`Access Token is ${response.accessToken}, Id Token is ${response.idToken}`);\n      return response;\n    });\n  }\n\n  makeRevokeTokenRequest(configuration: AuthorizationServiceConfiguration, refreshToken: string) {\n    let request = new RevokeTokenRequest({token: refreshToken});\n\n    return this.tokenHandler.performRevokeTokenRequest(configuration, request).then(response => {\n      log('revoked refreshToken');\n      return response;\n    });\n  }\n}\n\nlog('Application is ready.');\nconst app = new App();\n\napp.fetchServiceConfiguration()\n    .then(configuration => {\n      app.configuration = configuration;\n      app.makeAuthorizationRequest(configuration);\n      // notifier makes token requests.\n    })\n    .catch(error => {\n      log('Something bad happened ', error);\n    });\n"]}