UNPKG

@delewis13/appauth

Version:

A general purpose OAuth client. Vendored awaiting PR merge

164 lines 22.4 kB
"use strict"; /* * 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 the test web app 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 redirect_based_handler_1 = require("../redirect_based_handler"); var token_request_1 = require("../token_request"); var token_request_handler_1 = require("../token_request_handler"); /* an example open id connect provider */ var openIdConnectUrl = 'https://accounts.google.com'; /* example client configuration */ var clientId = '674027045299-a31g2q39v6qgngqvh8psi99km931rn8f.apps.googleusercontent.com'; var clientSecret = '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'; var redirectUri = 'http://localhost:8000/app/redirect.html'; var scope = 'openid profile email'; /** * The Test application. */ var App = /** @class */ (function () { function App(snackbar) { var _this = this; this.snackbar = snackbar; this.notifier = new authorization_request_handler_1.AuthorizationNotifier(); this.authorizationHandler = new redirect_based_handler_1.RedirectRequestHandler(); this.tokenHandler = new token_request_handler_1.BaseTokenRequestHandler(); // set notifier to deliver responses this.authorizationHandler.setAuthorizationNotifier(this.notifier); // set a listener to listen for authorization responses this.notifier.setAuthorizationListener(function (request, response, error) { (0, logger_1.log)('Authorization request complete ', request, response, error); if (response) { _this.request = request; _this.response = response; _this.code = response.code; _this.showMessage("Authorization Code " + response.code); } }); } App.prototype.showMessage = function (message) { var snackbar = this.snackbar['MaterialSnackbar']; snackbar.showSnackbar({ message: message }); }; App.prototype.fetchServiceConfiguration = function () { var _this = this; authorization_service_configuration_1.AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl) .then(function (response) { (0, logger_1.log)('Fetched service configuration', response); _this.configuration = response; _this.showMessage('Completed fetching configuration'); }) .catch(function (error) { (0, logger_1.log)('Something bad happened', error); _this.showMessage("Something bad happened " + error); }); }; App.prototype.makeAuthorizationRequest = function () { // 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' } }); if (this.configuration) { this.authorizationHandler.performAuthorizationRequest(this.configuration, request); } else { this.showMessage('Fetch Authorization Service configuration, before you make the authorization request.'); } }; App.prototype.makeTokenRequest = function () { var _this = this; if (!this.configuration) { this.showMessage('Please fetch service configuration.'); return; } var request = null; if (this.code) { var extras = undefined; if (this.request && this.request.internal) { extras = {}; extras['code_verifier'] = this.request.internal['code_verifier']; } // use the code to make the token request. request = new token_request_1.TokenRequest({ client_id: clientId, client_secret: clientSecret, redirect_uri: redirectUri, grant_type: token_request_1.GRANT_TYPE_AUTHORIZATION_CODE, code: this.code, refresh_token: undefined, extras: extras }); } else if (this.tokenResponse) { // use the token response to make a request for an access token request = new token_request_1.TokenRequest({ client_id: clientId, client_secret: clientSecret, redirect_uri: redirectUri, grant_type: token_request_1.GRANT_TYPE_REFRESH_TOKEN, code: undefined, refresh_token: this.tokenResponse.refreshToken, extras: undefined }); } if (request) { this.tokenHandler.performTokenRequest(this.configuration, request) .then(function (response) { var isFirstRequest = false; if (_this.tokenResponse) { // copy over new fields _this.tokenResponse.accessToken = response.accessToken; _this.tokenResponse.issuedAt = response.issuedAt; _this.tokenResponse.expiresIn = response.expiresIn; _this.tokenResponse.tokenType = response.tokenType; _this.tokenResponse.scope = response.scope; } else { isFirstRequest = true; _this.tokenResponse = response; } // unset code, so we can do refresh token exchanges subsequently _this.code = undefined; if (isFirstRequest) { _this.showMessage("Obtained a refresh token " + response.refreshToken); } else { _this.showMessage("Obtained an access token " + response.accessToken + "."); } }) .catch(function (error) { (0, logger_1.log)('Something bad happened', error); _this.showMessage("Something bad happened " + error); }); } }; App.prototype.checkForAuthorizationResponse = function () { this.authorizationHandler.completeAuthorizationRequestIfPossible(); }; return App; }()); exports.App = App; // export App window['App'] = App; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/app/index.ts"],"names":[],"mappings":"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","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 the test web app that uses the AppAuthJS library.\n\nimport {AuthorizationRequest} from '../authorization_request';\nimport {AuthorizationNotifier, AuthorizationRequestHandler} from '../authorization_request_handler';\nimport {AuthorizationServiceConfiguration} from '../authorization_service_configuration';\nimport {log} from '../logger';\nimport {RedirectRequestHandler} from '../redirect_based_handler';\nimport {GRANT_TYPE_AUTHORIZATION_CODE, GRANT_TYPE_REFRESH_TOKEN, TokenRequest} from '../token_request';\nimport {BaseTokenRequestHandler, TokenRequestHandler} from '../token_request_handler';\nimport {TokenResponse} from '../token_response';\nimport { AuthorizationResponse } from '../authorization_response';\nimport { StringMap } from '../types';\n\n/* Some interface declarations for Material design lite. */\n\n/**\n * Snackbar options.\n */\ndeclare interface SnackBarOptions {\n  message: string;\n  timeout?: number;\n}\n\n/**\n * Interface that defines the MDL Material Snack Bar API.\n */\ndeclare interface MaterialSnackBar {\n  showSnackbar: (options: SnackBarOptions) => void;\n}\n\n/* an example open id connect provider */\nconst openIdConnectUrl = 'https://accounts.google.com';\n\n/* example client configuration */\nconst clientId = '674027045299-a31g2q39v6qgngqvh8psi99km931rn8f.apps.googleusercontent.com';\nconst clientSecret = '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';\nconst redirectUri = 'http://localhost:8000/app/redirect.html';\nconst scope = 'openid profile email';\n\n/**\n * The Test application.\n */\nexport class App {\n  private notifier: AuthorizationNotifier;\n  private authorizationHandler: AuthorizationRequestHandler;\n  private tokenHandler: TokenRequestHandler;\n\n  // state\n  private configuration: AuthorizationServiceConfiguration|undefined;\n  private request: AuthorizationRequest|undefined;\n  private response: AuthorizationResponse|undefined;\n  private code: string|undefined;\n  private tokenResponse: TokenResponse|undefined;\n\n  constructor(public snackbar: Element) {\n    this.notifier = new AuthorizationNotifier();\n    this.authorizationHandler = new RedirectRequestHandler();\n    this.tokenHandler = new BaseTokenRequestHandler();\n    // set notifier to deliver responses\n    this.authorizationHandler.setAuthorizationNotifier(this.notifier);\n    // set a listener to listen for authorization responses\n    this.notifier.setAuthorizationListener((request, response, error) => {\n      log('Authorization request complete ', request, response, error);\n      if (response) {\n        this.request = request;\n        this.response = response;\n        this.code = response.code;\n        this.showMessage(`Authorization Code ${response.code}`);\n      }\n    });\n  }\n\n  showMessage(message: string) {\n    const snackbar = (this.snackbar as any)['MaterialSnackbar'] as MaterialSnackBar;\n    snackbar.showSnackbar({message: message});\n  }\n\n  fetchServiceConfiguration() {\n    AuthorizationServiceConfiguration.fetchFromIssuer(openIdConnectUrl)\n        .then(response => {\n          log('Fetched service configuration', response);\n          this.configuration = response;\n          this.showMessage('Completed fetching configuration');\n        })\n        .catch(error => {\n          log('Something bad happened', error);\n          this.showMessage(`Something bad happened ${error}`)\n        });\n  }\n\n  makeAuthorizationRequest() {\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    });\n\n    if (this.configuration) {\n      this.authorizationHandler.performAuthorizationRequest(this.configuration, request);\n    } else {\n      this.showMessage(\n          'Fetch Authorization Service configuration, before you make the authorization request.');\n    }\n  }\n\n  makeTokenRequest() {\n    if (!this.configuration) {\n      this.showMessage('Please fetch service configuration.');\n      return;\n    }\n\n    let request: TokenRequest|null = null;\n    if (this.code) {\n      let extras: StringMap|undefined = undefined;\n      if (this.request && this.request.internal) {\n        extras = {};\n        extras['code_verifier'] = this.request.internal['code_verifier'];\n      }\n      // use the code to make the token request.\n      request = new TokenRequest({\n        client_id: clientId,\n        client_secret: clientSecret,\n        redirect_uri: redirectUri,\n        grant_type: GRANT_TYPE_AUTHORIZATION_CODE,\n        code: this.code,\n        refresh_token: undefined,\n        extras: extras\n      });\n    } else if (this.tokenResponse) {\n      // use the token response to make a request for an access token\n      request = new TokenRequest({\n        client_id: clientId,\n        client_secret: clientSecret,\n        redirect_uri: redirectUri,\n        grant_type: GRANT_TYPE_REFRESH_TOKEN,\n        code: undefined,\n        refresh_token: this.tokenResponse.refreshToken,\n        extras: undefined\n      });\n    }\n\n    if (request) {\n      this.tokenHandler.performTokenRequest(this.configuration, request)\n          .then(response => {\n            let isFirstRequest = false;\n            if (this.tokenResponse) {\n              // copy over new fields\n              this.tokenResponse.accessToken = response.accessToken;\n              this.tokenResponse.issuedAt = response.issuedAt;\n              this.tokenResponse.expiresIn = response.expiresIn;\n              this.tokenResponse.tokenType = response.tokenType;\n              this.tokenResponse.scope = response.scope;\n            } else {\n              isFirstRequest = true;\n              this.tokenResponse = response;\n            }\n\n            // unset code, so we can do refresh token exchanges subsequently\n            this.code = undefined;\n            if (isFirstRequest) {\n              this.showMessage(`Obtained a refresh token ${response.refreshToken}`);\n            } else {\n              this.showMessage(`Obtained an access token ${response.accessToken}.`);\n            }\n          })\n          .catch(error => {\n            log('Something bad happened', error);\n            this.showMessage(`Something bad happened ${error}`)\n          });\n    }\n  }\n\n  checkForAuthorizationResponse() {\n    this.authorizationHandler.completeAuthorizationRequestIfPossible();\n  }\n}\n\n// export App\n(window as any)['App'] = App;\n"]}