UNPKG

@spartacus/core

Version:

Spartacus - the core framework

132 lines 13.2 kB
import { Injectable } from '@angular/core'; import { OAuthFlow } from '../models/oauth-flow'; import * as i0 from "@angular/core"; import * as i1 from "../config/auth-config"; import * as i2 from "../../../occ/config/occ-config"; /** * Utility service on top of the authorization config. * Provides handy defaults, when not everything is set in the configuration. * Use this service instead of direct configuration. */ export class AuthConfigService { constructor(authConfig, occConfig) { this.authConfig = authConfig; this.occConfig = occConfig; } /** * Utility to make access to authentication config easier. */ get config() { var _a, _b; return (_b = (_a = this.authConfig) === null || _a === void 0 ? void 0 : _a.authentication) !== null && _b !== void 0 ? _b : {}; } /** * Get client_id * * @return client_id */ getClientId() { var _a; return (_a = this.config.client_id) !== null && _a !== void 0 ? _a : ''; } /** * Get client_secret. OAuth server shouldn't require it from web apps (but Hybris OAuth server requires). * * @return client_secret */ getClientSecret() { var _a; return (_a = this.config.client_secret) !== null && _a !== void 0 ? _a : ''; } /** * Returns base url of the authorization server */ getBaseUrl() { var _a, _b, _c, _d, _e; return ((_a = this.config.baseUrl) !== null && _a !== void 0 ? _a : ((_e = (_d = (_c = (_b = this.occConfig) === null || _b === void 0 ? void 0 : _b.backend) === null || _c === void 0 ? void 0 : _c.occ) === null || _d === void 0 ? void 0 : _d.baseUrl) !== null && _e !== void 0 ? _e : '') + '/authorizationserver'); } /** * Returns endpoint for getting the auth token */ getTokenEndpoint() { var _a; const tokenEndpoint = (_a = this.config.tokenEndpoint) !== null && _a !== void 0 ? _a : ''; return this.prefixEndpoint(tokenEndpoint); } /** * Returns url for redirect to the authorization server to get token/code */ getLoginUrl() { var _a; const loginUrl = (_a = this.config.loginUrl) !== null && _a !== void 0 ? _a : ''; return this.prefixEndpoint(loginUrl); } /** * Returns endpoint for token revocation (both access and refresh token). */ getRevokeEndpoint() { var _a; const revokeEndpoint = (_a = this.config.revokeEndpoint) !== null && _a !== void 0 ? _a : ''; return this.prefixEndpoint(revokeEndpoint); } /** * Returns logout url to redirect to on logout. */ getLogoutUrl() { var _a; const logoutUrl = (_a = this.config.logoutUrl) !== null && _a !== void 0 ? _a : ''; return this.prefixEndpoint(logoutUrl); } /** * Returns userinfo endpoint of the OAuth server. */ getUserinfoEndpoint() { var _a; const userinfoEndpoint = (_a = this.config.userinfoEndpoint) !== null && _a !== void 0 ? _a : ''; return this.prefixEndpoint(userinfoEndpoint); } /** * Returns configuration specific for the angular-oauth2-oidc library. */ getOAuthLibConfig() { var _a; return (_a = this.config.OAuthLibConfig) !== null && _a !== void 0 ? _a : {}; } prefixEndpoint(endpoint) { let url = endpoint; if (!url.startsWith('/')) { url = '/' + url; } return `${this.getBaseUrl()}${url}`; } /** * Returns the type of the OAuth flow based on auth config. * Use when you have to perform particular action only in some of the OAuth flow scenarios. */ getOAuthFlow() { var _a; const responseType = (_a = this.config.OAuthLibConfig) === null || _a === void 0 ? void 0 : _a.responseType; if (responseType) { const types = responseType.split(' '); if (types.includes('code')) { return OAuthFlow.AuthorizationCode; } else if (types.includes('token')) { return OAuthFlow.ImplicitFlow; } else { return OAuthFlow.ResourceOwnerPasswordFlow; } } return OAuthFlow.ResourceOwnerPasswordFlow; } } AuthConfigService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AuthConfigService, deps: [{ token: i1.AuthConfig }, { token: i2.OccConfig }], target: i0.ɵɵFactoryTarget.Injectable }); AuthConfigService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AuthConfigService, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AuthConfigService, decorators: [{ type: Injectable, args: [{ providedIn: 'root', }] }], ctorParameters: function () { return [{ type: i1.AuthConfig }, { type: i2.OccConfig }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-config.service.js","sourceRoot":"","sources":["../../../../../../../projects/core/src/auth/user-auth/services/auth-config.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { OccConfig } from '../../../occ/config/occ-config';\nimport { AuthConfig, AuthLibConfig } from '../config/auth-config';\nimport { OAuthFlow } from '../models/oauth-flow';\n\n/**\n * Utility service on top of the authorization config.\n * Provides handy defaults, when not everything is set in the configuration.\n * Use this service instead of direct configuration.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class AuthConfigService {\n  constructor(\n    protected authConfig: AuthConfig,\n    protected occConfig: OccConfig\n  ) {}\n\n  /**\n   * Utility to make access to authentication config easier.\n   */\n  private get config(): AuthConfig['authentication'] {\n    return this.authConfig?.authentication ?? {};\n  }\n\n  /**\n   * Get client_id\n   *\n   * @return client_id\n   */\n  public getClientId(): string {\n    return this.config.client_id ?? '';\n  }\n\n  /**\n   * Get client_secret. OAuth server shouldn't require it from web apps (but Hybris OAuth server requires).\n   *\n   * @return client_secret\n   */\n  public getClientSecret(): string {\n    return this.config.client_secret ?? '';\n  }\n\n  /**\n   * Returns base url of the authorization server\n   */\n  public getBaseUrl(): string {\n    return (\n      this.config.baseUrl ??\n      (this.occConfig?.backend?.occ?.baseUrl ?? '') + '/authorizationserver'\n    );\n  }\n\n  /**\n   * Returns endpoint for getting the auth token\n   */\n  public getTokenEndpoint(): string {\n    const tokenEndpoint = this.config.tokenEndpoint ?? '';\n    return this.prefixEndpoint(tokenEndpoint);\n  }\n\n  /**\n   * Returns url for redirect to the authorization server to get token/code\n   */\n  public getLoginUrl(): string {\n    const loginUrl = this.config.loginUrl ?? '';\n    return this.prefixEndpoint(loginUrl);\n  }\n\n  /**\n   * Returns endpoint for token revocation (both access and refresh token).\n   */\n  public getRevokeEndpoint(): string {\n    const revokeEndpoint = this.config.revokeEndpoint ?? '';\n    return this.prefixEndpoint(revokeEndpoint);\n  }\n\n  /**\n   * Returns logout url to redirect to on logout.\n   */\n  public getLogoutUrl(): string {\n    const logoutUrl = this.config.logoutUrl ?? '';\n    return this.prefixEndpoint(logoutUrl);\n  }\n\n  /**\n   * Returns userinfo endpoint of the OAuth server.\n   */\n  public getUserinfoEndpoint(): string {\n    const userinfoEndpoint = this.config.userinfoEndpoint ?? '';\n    return this.prefixEndpoint(userinfoEndpoint);\n  }\n\n  /**\n   * Returns configuration specific for the angular-oauth2-oidc library.\n   */\n  public getOAuthLibConfig(): AuthLibConfig {\n    return this.config.OAuthLibConfig ?? {};\n  }\n\n  protected prefixEndpoint(endpoint: string): string {\n    let url = endpoint;\n    if (!url.startsWith('/')) {\n      url = '/' + url;\n    }\n    return `${this.getBaseUrl()}${url}`;\n  }\n\n  /**\n   * Returns the type of the OAuth flow based on auth config.\n   * Use when you have to perform particular action only in some of the OAuth flow scenarios.\n   */\n  public getOAuthFlow(): OAuthFlow {\n    const responseType = this.config.OAuthLibConfig?.responseType;\n    if (responseType) {\n      const types = responseType.split(' ');\n      if (types.includes('code')) {\n        return OAuthFlow.AuthorizationCode;\n      } else if (types.includes('token')) {\n        return OAuthFlow.ImplicitFlow;\n      } else {\n        return OAuthFlow.ResourceOwnerPasswordFlow;\n      }\n    }\n    return OAuthFlow.ResourceOwnerPasswordFlow;\n  }\n}\n"]}