UNPKG

@spartacus/core

Version:

Spartacus - the core framework

102 lines 12.9 kB
import { Inject, Injectable, PLATFORM_ID } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "angular-oauth2-oidc"; import * as i2 from "./auth-config.service"; import * as i3 from "../../../window/window-ref"; /** * Wrapper service on the library OAuthService. Normalizes the lib API for services. * Use this service when you want to access low level OAuth library methods. */ export class OAuthLibWrapperService { // TODO: Remove platformId dependency in 4.0 constructor(oAuthService, authConfigService, platformId, winRef) { this.oAuthService = oAuthService; this.authConfigService = authConfigService; this.platformId = platformId; this.winRef = winRef; this.events$ = this.oAuthService.events; this.initialize(); } initialize() { var _a, _b, _c, _d; const isSSR = !this.winRef.isBrowser(); this.oAuthService.configure(Object.assign({ tokenEndpoint: this.authConfigService.getTokenEndpoint(), loginUrl: this.authConfigService.getLoginUrl(), clientId: this.authConfigService.getClientId(), dummyClientSecret: this.authConfigService.getClientSecret(), revocationEndpoint: this.authConfigService.getRevokeEndpoint(), logoutUrl: this.authConfigService.getLogoutUrl(), userinfoEndpoint: this.authConfigService.getUserinfoEndpoint(), issuer: (_b = (_a = this.authConfigService.getOAuthLibConfig()) === null || _a === void 0 ? void 0 : _a.issuer) !== null && _b !== void 0 ? _b : this.authConfigService.getBaseUrl(), redirectUri: (_d = (_c = this.authConfigService.getOAuthLibConfig()) === null || _c === void 0 ? void 0 : _c.redirectUri) !== null && _d !== void 0 ? _d : (!isSSR ? // eslint-disable-next-line @typescript-eslint/no-non-null-assertion this.winRef.nativeWindow.location.origin : '') }, this.authConfigService.getOAuthLibConfig())); } /** * Authorize with ResourceOwnerPasswordFlow. * * @param userId * @param password * * @return token response from the lib */ authorizeWithPasswordFlow(userId, password) { return this.oAuthService.fetchTokenUsingPasswordFlow(userId, password); } /** * Refresh access_token. */ refreshToken() { this.oAuthService.refreshToken(); } /** * Revoke access tokens and clear tokens in lib state. */ revokeAndLogout() { return new Promise((resolve) => { this.oAuthService .revokeTokenAndLogout() .catch(() => { // when there would be some kind of error during revocation we can't do anything else, so at least we logout user. this.oAuthService.logOut(); }) .finally(() => { resolve(); }); }); } /** * Clear tokens in library state (no revocation). */ logout() { this.oAuthService.logOut(); } /** * Returns Open Id token. Might be empty, when it was not requested with the `responseType` config. * * @return id token */ getIdToken() { return this.oAuthService.getIdToken(); } /** * Initialize Implicit Flow or Authorization Code flows with the redirect to OAuth login url. */ initLoginFlow() { return this.oAuthService.initLoginFlow(); } /** * Tries to login user based on `code` or `token` present in the url. */ tryLogin() { return this.oAuthService.tryLogin({ // We don't load discovery document, because it doesn't contain revoke endpoint information disableOAuth2StateCheck: true, }); } } OAuthLibWrapperService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OAuthLibWrapperService, deps: [{ token: i1.OAuthService }, { token: i2.AuthConfigService }, { token: PLATFORM_ID }, { token: i3.WindowRef }], target: i0.ɵɵFactoryTarget.Injectable }); OAuthLibWrapperService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OAuthLibWrapperService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: OAuthLibWrapperService, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.OAuthService }, { type: i2.AuthConfigService }, { type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID] }] }, { type: i3.WindowRef }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth-lib-wrapper.service.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/auth/user-auth/services/oauth-lib-wrapper.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, PLATFORM_ID } from '@angular/core';\nimport { OAuthEvent, OAuthService, TokenResponse } from 'angular-oauth2-oidc';\nimport { Observable } from 'rxjs';\nimport { WindowRef } from '../../../window/window-ref';\nimport { AuthConfigService } from './auth-config.service';\n\n/**\n * Wrapper service on the library OAuthService. Normalizes the lib API for services.\n * Use this service when you want to access low level OAuth library methods.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class OAuthLibWrapperService {\n  events$: Observable<OAuthEvent> = this.oAuthService.events;\n\n  // TODO: Remove platformId dependency in 4.0\n  constructor(\n    protected oAuthService: OAuthService,\n    protected authConfigService: AuthConfigService,\n    @Inject(PLATFORM_ID) protected platformId: Object,\n    protected winRef: WindowRef\n  ) {\n    this.initialize();\n  }\n\n  protected initialize() {\n    const isSSR = !this.winRef.isBrowser();\n    this.oAuthService.configure({\n      tokenEndpoint: this.authConfigService.getTokenEndpoint(),\n      loginUrl: this.authConfigService.getLoginUrl(),\n      clientId: this.authConfigService.getClientId(),\n      dummyClientSecret: this.authConfigService.getClientSecret(),\n      revocationEndpoint: this.authConfigService.getRevokeEndpoint(),\n      logoutUrl: this.authConfigService.getLogoutUrl(),\n      userinfoEndpoint: this.authConfigService.getUserinfoEndpoint(),\n      issuer:\n        this.authConfigService.getOAuthLibConfig()?.issuer ??\n        this.authConfigService.getBaseUrl(),\n      redirectUri:\n        this.authConfigService.getOAuthLibConfig()?.redirectUri ??\n        (!isSSR\n          ? // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n            this.winRef.nativeWindow!.location.origin\n          : ''),\n      ...this.authConfigService.getOAuthLibConfig(),\n    });\n  }\n\n  /**\n   * Authorize with ResourceOwnerPasswordFlow.\n   *\n   * @param userId\n   * @param password\n   *\n   * @return token response from the lib\n   */\n  authorizeWithPasswordFlow(\n    userId: string,\n    password: string\n  ): Promise<TokenResponse> {\n    return this.oAuthService.fetchTokenUsingPasswordFlow(userId, password);\n  }\n\n  /**\n   * Refresh access_token.\n   */\n  refreshToken(): void {\n    this.oAuthService.refreshToken();\n  }\n\n  /**\n   * Revoke access tokens and clear tokens in lib state.\n   */\n  revokeAndLogout(): Promise<void> {\n    return new Promise((resolve) => {\n      this.oAuthService\n        .revokeTokenAndLogout()\n        .catch(() => {\n          // when there would be some kind of error during revocation we can't do anything else, so at least we logout user.\n          this.oAuthService.logOut();\n        })\n        .finally(() => {\n          resolve();\n        });\n    });\n  }\n\n  /**\n   * Clear tokens in library state (no revocation).\n   */\n  logout(): void {\n    this.oAuthService.logOut();\n  }\n\n  /**\n   * Returns Open Id token. Might be empty, when it was not requested with the `responseType` config.\n   *\n   * @return id token\n   */\n  getIdToken(): string {\n    return this.oAuthService.getIdToken();\n  }\n\n  /**\n   * Initialize Implicit Flow or Authorization Code flows with the redirect to OAuth login url.\n   */\n  initLoginFlow() {\n    return this.oAuthService.initLoginFlow();\n  }\n\n  /**\n   * Tries to login user based on `code` or `token` present in the url.\n   */\n  tryLogin() {\n    return this.oAuthService.tryLogin({\n      // We don't load discovery document, because it doesn't contain revoke endpoint information\n      disableOAuth2StateCheck: true,\n    });\n  }\n}\n"]}