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