@delewis13/appauth
Version:
A general purpose OAuth client. Vendored awaiting PR merge
164 lines • 22.4 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 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"]}