UNPKG

angular-auth-oidc-client

Version:
115 lines 18.3 kB
import { Injectable, inject } from '@angular/core'; import { LoggerService } from '../logging/logger.service'; import { StoragePersistenceService } from '../storage/storage-persistence.service'; import { RandomService } from './random/random.service'; import * as i0 from "@angular/core"; export class FlowsDataService { constructor() { this.loggerService = inject(LoggerService); this.storagePersistenceService = inject(StoragePersistenceService); this.randomService = inject(RandomService); } createNonce(configuration) { const nonce = this.randomService.createRandom(40, configuration); this.loggerService.logDebug(configuration, 'Nonce created. nonce:' + nonce); this.setNonce(nonce, configuration); return nonce; } setNonce(nonce, configuration) { this.storagePersistenceService.write('authNonce', nonce, configuration); } getAuthStateControl(configuration) { if (!configuration) { return ''; } return this.storagePersistenceService.read('authStateControl', configuration); } setAuthStateControl(authStateControl, configuration) { if (!configuration) { return false; } return this.storagePersistenceService.write('authStateControl', authStateControl, configuration); } getExistingOrCreateAuthStateControl(configuration) { let state = this.storagePersistenceService.read('authStateControl', configuration); if (!state) { state = this.randomService.createRandom(40, configuration); this.storagePersistenceService.write('authStateControl', state, configuration); } return state; } setSessionState(sessionState, configuration) { this.storagePersistenceService.write('session_state', sessionState, configuration); } resetStorageFlowData(configuration) { this.storagePersistenceService.resetStorageFlowData(configuration); } getCodeVerifier(configuration) { return this.storagePersistenceService.read('codeVerifier', configuration); } createCodeVerifier(configuration) { const codeVerifier = this.randomService.createRandom(67, configuration); this.storagePersistenceService.write('codeVerifier', codeVerifier, configuration); return codeVerifier; } isCodeFlowInProgress(configuration) { return !!this.storagePersistenceService.read('storageCodeFlowInProgress', configuration); } setCodeFlowInProgress(configuration) { this.storagePersistenceService.write('storageCodeFlowInProgress', true, configuration); } resetCodeFlowInProgress(configuration) { this.storagePersistenceService.write('storageCodeFlowInProgress', false, configuration); } isSilentRenewRunning(configuration) { const { configId, silentRenewTimeoutInSeconds } = configuration; const storageObject = this.getSilentRenewRunningStorageEntry(configuration); if (!storageObject) { return false; } if (storageObject.state === 'not-running') { return false; } const timeOutInMilliseconds = (silentRenewTimeoutInSeconds ?? 0) * 1000; const dateOfLaunchedProcessUtc = Date.parse(storageObject.dateOfLaunchedProcessUtc); const currentDateUtc = Date.parse(new Date().toISOString()); const elapsedTimeInMilliseconds = Math.abs(currentDateUtc - dateOfLaunchedProcessUtc); const isProbablyStuck = elapsedTimeInMilliseconds > timeOutInMilliseconds; if (isProbablyStuck) { this.loggerService.logDebug(configuration, 'silent renew process is probably stuck, state will be reset.', configId); this.resetSilentRenewRunning(configuration); return false; } return storageObject.state === 'running'; } setSilentRenewRunning(configuration) { const storageObject = { state: 'running', dateOfLaunchedProcessUtc: new Date().toISOString(), }; this.storagePersistenceService.write('storageSilentRenewRunning', JSON.stringify(storageObject), configuration); } resetSilentRenewRunning(configuration) { if (!configuration) { return; } this.storagePersistenceService.write('storageSilentRenewRunning', '', configuration); } getSilentRenewRunningStorageEntry(configuration) { const storageEntry = this.storagePersistenceService.read('storageSilentRenewRunning', configuration); if (!storageEntry) { return { dateOfLaunchedProcessUtc: '', state: 'not-running', }; } return JSON.parse(storageEntry); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FlowsDataService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FlowsDataService, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: FlowsDataService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flows-data.service.js","sourceRoot":"","sources":["../../../../../projects/angular-auth-oidc-client/src/lib/flows/flows-data.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { OpenIdConfiguration } from '../config/openid-configuration';\nimport { LoggerService } from '../logging/logger.service';\nimport { StoragePersistenceService } from '../storage/storage-persistence.service';\nimport { SilentRenewRunning } from './flows.models';\nimport { RandomService } from './random/random.service';\n\n@Injectable({ providedIn: 'root' })\nexport class FlowsDataService {\n  private readonly loggerService = inject(LoggerService);\n\n  private readonly storagePersistenceService = inject(\n    StoragePersistenceService\n  );\n\n  private readonly randomService = inject(RandomService);\n\n  createNonce(configuration: OpenIdConfiguration): string {\n    const nonce = this.randomService.createRandom(40, configuration);\n\n    this.loggerService.logDebug(configuration, 'Nonce created. nonce:' + nonce);\n    this.setNonce(nonce, configuration);\n\n    return nonce;\n  }\n\n  setNonce(nonce: string, configuration: OpenIdConfiguration): void {\n    this.storagePersistenceService.write('authNonce', nonce, configuration);\n  }\n\n  getAuthStateControl(configuration: OpenIdConfiguration | null): string {\n    if (!configuration) {\n      return '';\n    }\n\n    return this.storagePersistenceService.read(\n      'authStateControl',\n      configuration\n    );\n  }\n\n  setAuthStateControl(\n    authStateControl: string,\n    configuration: OpenIdConfiguration | null\n  ): boolean {\n    if (!configuration) {\n      return false;\n    }\n\n    return this.storagePersistenceService.write(\n      'authStateControl',\n      authStateControl,\n      configuration\n    );\n  }\n\n  getExistingOrCreateAuthStateControl(configuration: OpenIdConfiguration): any {\n    let state = this.storagePersistenceService.read(\n      'authStateControl',\n      configuration\n    );\n\n    if (!state) {\n      state = this.randomService.createRandom(40, configuration);\n      this.storagePersistenceService.write(\n        'authStateControl',\n        state,\n        configuration\n      );\n    }\n\n    return state;\n  }\n\n  setSessionState(sessionState: any, configuration: OpenIdConfiguration): void {\n    this.storagePersistenceService.write(\n      'session_state',\n      sessionState,\n      configuration\n    );\n  }\n\n  resetStorageFlowData(configuration: OpenIdConfiguration): void {\n    this.storagePersistenceService.resetStorageFlowData(configuration);\n  }\n\n  getCodeVerifier(configuration: OpenIdConfiguration): any {\n    return this.storagePersistenceService.read('codeVerifier', configuration);\n  }\n\n  createCodeVerifier(configuration: OpenIdConfiguration): string {\n    const codeVerifier = this.randomService.createRandom(67, configuration);\n\n    this.storagePersistenceService.write(\n      'codeVerifier',\n      codeVerifier,\n      configuration\n    );\n\n    return codeVerifier;\n  }\n\n  isCodeFlowInProgress(configuration: OpenIdConfiguration): boolean {\n    return !!this.storagePersistenceService.read(\n      'storageCodeFlowInProgress',\n      configuration\n    );\n  }\n\n  setCodeFlowInProgress(configuration: OpenIdConfiguration): void {\n    this.storagePersistenceService.write(\n      'storageCodeFlowInProgress',\n      true,\n      configuration\n    );\n  }\n\n  resetCodeFlowInProgress(configuration: OpenIdConfiguration): void {\n    this.storagePersistenceService.write(\n      'storageCodeFlowInProgress',\n      false,\n      configuration\n    );\n  }\n\n  isSilentRenewRunning(configuration: OpenIdConfiguration): boolean {\n    const { configId, silentRenewTimeoutInSeconds } = configuration;\n    const storageObject = this.getSilentRenewRunningStorageEntry(configuration);\n\n    if (!storageObject) {\n      return false;\n    }\n\n    if (storageObject.state === 'not-running') {\n      return false;\n    }\n\n    const timeOutInMilliseconds = (silentRenewTimeoutInSeconds ?? 0) * 1000;\n    const dateOfLaunchedProcessUtc = Date.parse(\n      storageObject.dateOfLaunchedProcessUtc\n    );\n    const currentDateUtc = Date.parse(new Date().toISOString());\n    const elapsedTimeInMilliseconds = Math.abs(\n      currentDateUtc - dateOfLaunchedProcessUtc\n    );\n    const isProbablyStuck = elapsedTimeInMilliseconds > timeOutInMilliseconds;\n\n    if (isProbablyStuck) {\n      this.loggerService.logDebug(\n        configuration,\n        'silent renew process is probably stuck, state will be reset.',\n        configId\n      );\n      this.resetSilentRenewRunning(configuration);\n\n      return false;\n    }\n\n    return storageObject.state === 'running';\n  }\n\n  setSilentRenewRunning(configuration: OpenIdConfiguration): void {\n    const storageObject: SilentRenewRunning = {\n      state: 'running',\n      dateOfLaunchedProcessUtc: new Date().toISOString(),\n    };\n\n    this.storagePersistenceService.write(\n      'storageSilentRenewRunning',\n      JSON.stringify(storageObject),\n      configuration\n    );\n  }\n\n  resetSilentRenewRunning(configuration: OpenIdConfiguration | null): void {\n    if (!configuration) {\n      return;\n    }\n\n    this.storagePersistenceService.write(\n      'storageSilentRenewRunning',\n      '',\n      configuration\n    );\n  }\n\n  private getSilentRenewRunningStorageEntry(\n    configuration: OpenIdConfiguration\n  ): SilentRenewRunning {\n    const storageEntry = this.storagePersistenceService.read(\n      'storageSilentRenewRunning',\n      configuration\n    );\n\n    if (!storageEntry) {\n      return {\n        dateOfLaunchedProcessUtc: '',\n        state: 'not-running',\n      };\n    }\n\n    return JSON.parse(storageEntry);\n  }\n}\n"]}