@c8y/ngx-components
Version:
Angular modules for Cumulocity IoT applications
75 lines • 12.4 kB
JavaScript
import { Injectable } from '@angular/core';
import { UserAgent, isBasic, isOauthInternal } from './basic-settings.model';
import { defaults, isEmpty, omitBy, omit } from 'lodash-es';
import * as i0 from "@angular/core";
export class TenantLoginOptionMapper {
mapTo(tenantLoginOption) {
const loginOption = omit(this.prapareTenantLoginOption(tenantLoginOption), 'authenticationRestrictions');
if (isBasic(loginOption)) {
loginOption.authenticationRestrictions = this.mapAuthenticationRestrictionsTo(tenantLoginOption.authenticationRestrictions);
}
return loginOption;
}
mapFrom(originalLoginOption, newLoginOption) {
if (isBasic(originalLoginOption)) {
return this.mapBasicLoginOption(originalLoginOption, newLoginOption);
}
if (isOauthInternal(originalLoginOption)) {
return this.mapOauthInternalLoginOption(originalLoginOption, newLoginOption);
}
throw new Error(`TenantLoginOptionMapper: The tenant login option cannot be mapped. Login option with type: ${originalLoginOption.type} is not supported.`);
}
mapAuthenticationRestrictionsTo(authenticationRestrictions) {
const restrictions = defaults({}, omitBy(authenticationRestrictions, isEmpty), {
forbiddenUserAgents: [''],
trustedUserAgents: [''],
forbiddenClients: []
});
restrictions.forbiddenUserAgents = restrictions.forbiddenUserAgents.map(val => new UserAgent(val));
restrictions.trustedUserAgents = restrictions.trustedUserAgents.map(val => new UserAgent(val));
return restrictions;
}
mapBasicLoginOption(originalLoginOption, newLoginOption) {
const loginOption = omit(originalLoginOption, ['sessionConfiguration']);
loginOption.authenticationRestrictions = this.mapAuthenticationRestrictionsFrom(newLoginOption.authenticationRestrictions);
return loginOption;
}
mapOauthInternalLoginOption(originalLoginOption, newLoginOption) {
const loginOption = omit(originalLoginOption, ['authenticationRestrictions']);
newLoginOption.sessionConfiguration !== null
? (loginOption.sessionConfiguration = newLoginOption.sessionConfiguration)
: delete loginOption.sessionConfiguration;
return loginOption;
}
mapAuthenticationRestrictionsFrom(authenticationRestrictions) {
return {
trustedUserAgents: authenticationRestrictions.trustedUserAgents
.filter(({ value }) => value)
.map(({ value }) => value),
forbiddenUserAgents: authenticationRestrictions.forbiddenUserAgents
.filter(({ value }) => value)
.map(({ value }) => value),
forbiddenClients: authenticationRestrictions.forbiddenClients.filter(value => value)
};
}
prapareTenantLoginOption(tenantLoginOption) {
return omit(tenantLoginOption, [
'self',
'strengthValidity',
'tfaStrategy',
'greenMinLength',
'enforceStrength',
'strengthValidity',
'_type'
]);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TenantLoginOptionMapper, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TenantLoginOptionMapper, providedIn: 'root' }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TenantLoginOptionMapper, decorators: [{
type: Injectable,
args: [{
providedIn: 'root'
}]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tenant-login-option.mapper.js","sourceRoot":"","sources":["../../../../auth-configuration/basic-settings/tenant-login-option.mapper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  UserAgent,\n  AuthenticationRestrictions,\n  TenantLoginOption,\n  isBasic,\n  isOauthInternal\n} from './basic-settings.model';\nimport { ITenantLoginOption, IAuthenticationRestrictions } from '@c8y/client';\nimport { defaults, isEmpty, omitBy, omit } from 'lodash-es';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class TenantLoginOptionMapper {\n  mapTo(tenantLoginOption: ITenantLoginOption): TenantLoginOption {\n    const loginOption: TenantLoginOption = omit(\n      this.prapareTenantLoginOption(tenantLoginOption),\n      'authenticationRestrictions'\n    );\n    if (isBasic(loginOption)) {\n      loginOption.authenticationRestrictions = this.mapAuthenticationRestrictionsTo(\n        tenantLoginOption.authenticationRestrictions\n      );\n    }\n    return loginOption;\n  }\n\n  mapFrom(\n    originalLoginOption: TenantLoginOption,\n    newLoginOption: TenantLoginOption\n  ): ITenantLoginOption {\n    if (isBasic(originalLoginOption)) {\n      return this.mapBasicLoginOption(originalLoginOption, newLoginOption);\n    }\n    if (isOauthInternal(originalLoginOption)) {\n      return this.mapOauthInternalLoginOption(originalLoginOption, newLoginOption);\n    }\n    throw new Error(\n      `TenantLoginOptionMapper: The tenant login option cannot be mapped. Login option with type: ${originalLoginOption.type} is not supported.`\n    );\n  }\n\n  private mapAuthenticationRestrictionsTo(\n    authenticationRestrictions: IAuthenticationRestrictions\n  ): AuthenticationRestrictions {\n    const restrictions = defaults({}, omitBy(authenticationRestrictions, isEmpty), {\n      forbiddenUserAgents: [''],\n      trustedUserAgents: [''],\n      forbiddenClients: []\n    });\n    restrictions.forbiddenUserAgents = restrictions.forbiddenUserAgents.map(\n      val => new UserAgent(val)\n    );\n    restrictions.trustedUserAgents = restrictions.trustedUserAgents.map(val => new UserAgent(val));\n    return restrictions;\n  }\n\n  private mapBasicLoginOption(\n    originalLoginOption: TenantLoginOption,\n    newLoginOption: TenantLoginOption\n  ) {\n    const loginOption = omit(originalLoginOption, ['sessionConfiguration']);\n    loginOption.authenticationRestrictions = this.mapAuthenticationRestrictionsFrom(\n      newLoginOption.authenticationRestrictions\n    );\n    return loginOption;\n  }\n\n  private mapOauthInternalLoginOption(\n    originalLoginOption: TenantLoginOption,\n    newLoginOption: TenantLoginOption\n  ) {\n    const loginOption = omit(originalLoginOption, ['authenticationRestrictions']);\n    newLoginOption.sessionConfiguration !== null\n      ? (loginOption.sessionConfiguration = newLoginOption.sessionConfiguration)\n      : delete loginOption.sessionConfiguration;\n    return loginOption;\n  }\n\n  private mapAuthenticationRestrictionsFrom(\n    authenticationRestrictions: AuthenticationRestrictions\n  ): IAuthenticationRestrictions {\n    return {\n      trustedUserAgents: authenticationRestrictions.trustedUserAgents\n        .filter(({ value }) => value)\n        .map(({ value }) => value),\n      forbiddenUserAgents: authenticationRestrictions.forbiddenUserAgents\n        .filter(({ value }) => value)\n        .map(({ value }) => value),\n      forbiddenClients: authenticationRestrictions.forbiddenClients.filter(value => value)\n    };\n  }\n\n  private prapareTenantLoginOption(tenantLoginOption: ITenantLoginOption): TenantLoginOption {\n    return omit(tenantLoginOption, [\n      'self',\n      'strengthValidity',\n      'tfaStrategy',\n      'greenMinLength',\n      'enforceStrength',\n      'strengthValidity',\n      '_type'\n    ]);\n  }\n}\n"]}