@spartacus/core
Version:
Spartacus - the core framework
102 lines • 12.9 kB
JavaScript
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"]}