UNPKG

angular-auth-oidc-client

Version:
67 lines 12.2 kB
import { Injectable, inject } from '@angular/core'; import { AuthStateService } from '../auth-state/auth-state.service'; import { ConfigurationService } from '../config/config.service'; import { LoggerService } from '../logging/logger.service'; import { flattenArray } from '../utils/collections/collections.helper'; import { ClosestMatchingRouteService } from './closest-matching-route.service'; import * as i0 from "@angular/core"; export class AuthInterceptor { constructor() { this.authStateService = inject(AuthStateService); this.configurationService = inject(ConfigurationService); this.loggerService = inject(LoggerService); this.closestMatchingRouteService = inject(ClosestMatchingRouteService); } intercept(req, next) { return interceptRequest(req, next.handle, { configurationService: this.configurationService, authStateService: this.authStateService, closestMatchingRouteService: this.closestMatchingRouteService, loggerService: this.loggerService, }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AuthInterceptor, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AuthInterceptor }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.1", ngImport: i0, type: AuthInterceptor, decorators: [{ type: Injectable }] }); export function authInterceptor() { return (req, next) => { return interceptRequest(req, next, { configurationService: inject(ConfigurationService), authStateService: inject(AuthStateService), closestMatchingRouteService: inject(ClosestMatchingRouteService), loggerService: inject(LoggerService), }); }; } function interceptRequest(req, next, deps) { if (!deps.configurationService.hasAtLeastOneConfig()) { return next(req); } const allConfigurations = deps.configurationService.getAllConfigurations(); const allRoutesConfigured = allConfigurations.map((x) => x.secureRoutes || []); const allRoutesConfiguredFlat = flattenArray(allRoutesConfigured); if (allRoutesConfiguredFlat.length === 0) { deps.loggerService.logDebug(allConfigurations[0], `No routes to check configured`); return next(req); } const { matchingConfig, matchingRoute } = deps.closestMatchingRouteService.getConfigIdForClosestMatchingRoute(req.url, allConfigurations); if (!matchingConfig) { deps.loggerService.logDebug(allConfigurations[0], `Did not find any configured route for route ${req.url}`); return next(req); } deps.loggerService.logDebug(matchingConfig, `'${req.url}' matches configured route '${matchingRoute}'`); const token = deps.authStateService.getAccessToken(matchingConfig); if (!token) { deps.loggerService.logDebug(matchingConfig, `Wanted to add token to ${req.url} but found no token: '${token}'`); return next(req); } deps.loggerService.logDebug(matchingConfig, `'${req.url}' matches configured route '${matchingRoute}', adding token`); req = req.clone({ headers: req.headers.set('Authorization', 'Bearer ' + token), }); return next(req); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.interceptor.js","sourceRoot":"","sources":["../../../../../projects/angular-auth-oidc-client/src/lib/interceptor/auth.interceptor.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,yCAAyC,CAAC;AACvE,OAAO,EAAE,2BAA2B,EAAE,MAAM,kCAAkC,CAAC;;AAG/E,MAAM,OAAO,eAAe;IAD5B;QAEmB,qBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAE5C,yBAAoB,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAEpD,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAEtC,gCAA2B,GAAG,MAAM,CACnD,2BAA2B,CAC5B,CAAC;KAaH;IAXC,SAAS,CACP,GAAqB,EACrB,IAAiB;QAEjB,OAAO,gBAAgB,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,EAAE;YACxC,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,2BAA2B,EAAE,IAAI,CAAC,2BAA2B;YAC7D,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;IACL,CAAC;8GArBU,eAAe;kHAAf,eAAe;;2FAAf,eAAe;kBAD3B,UAAU;;AAyBX,MAAM,UAAU,eAAe;IAC7B,OAAO,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;QACnB,OAAO,gBAAgB,CAAC,GAAG,EAAE,IAAI,EAAE;YACjC,oBAAoB,EAAE,MAAM,CAAC,oBAAoB,CAAC;YAClD,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,CAAC;YAC1C,2BAA2B,EAAE,MAAM,CAAC,2BAA2B,CAAC;YAChE,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC;SACrC,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,gBAAgB,CACvB,GAAqB,EACrB,IAAmB,EACnB,IAKC;IAED,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,mBAAmB,EAAE,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,MAAM,iBAAiB,GAAG,IAAI,CAAC,oBAAoB,CAAC,oBAAoB,EAAE,CAAC;IAC3E,MAAM,mBAAmB,GAAG,iBAAiB,CAAC,GAAG,CAC/C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,IAAI,EAAE,CAC5B,CAAC;IACF,MAAM,uBAAuB,GAAG,YAAY,CAAC,mBAAmB,CAAC,CAAC;IAElE,IAAI,uBAAuB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzC,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,iBAAiB,CAAC,CAAC,CAAC,EACpB,+BAA+B,CAChC,CAAC;QAEF,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,MAAM,EAAE,cAAc,EAAE,aAAa,EAAE,GACrC,IAAI,CAAC,2BAA2B,CAAC,kCAAkC,CACjE,GAAG,CAAC,GAAG,EACP,iBAAiB,CAClB,CAAC;IAEJ,IAAI,CAAC,cAAc,EAAE,CAAC;QACpB,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,iBAAiB,CAAC,CAAC,CAAC,EACpB,+CAA+C,GAAG,CAAC,GAAG,EAAE,CACzD,CAAC;QAEF,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,cAAc,EACd,IAAI,GAAG,CAAC,GAAG,+BAA+B,aAAa,GAAG,CAC3D,CAAC;IACF,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;IAEnE,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,cAAc,EACd,0BAA0B,GAAG,CAAC,GAAG,yBAAyB,KAAK,GAAG,CACnE,CAAC;QAEF,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,IAAI,CAAC,aAAa,CAAC,QAAQ,CACzB,cAAc,EACd,IAAI,GAAG,CAAC,GAAG,+BAA+B,aAAa,iBAAiB,CACzE,CAAC;IACF,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC;QACd,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,SAAS,GAAG,KAAK,CAAC;KAC7D,CAAC,CAAC;IAEH,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;AACnB,CAAC","sourcesContent":["import {\r\n  HttpEvent,\r\n  HttpHandler,\r\n  HttpHandlerFn,\r\n  HttpInterceptor,\r\n  HttpInterceptorFn,\r\n  HttpRequest,\r\n} from '@angular/common/http';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { AuthStateService } from '../auth-state/auth-state.service';\r\nimport { ConfigurationService } from '../config/config.service';\r\nimport { LoggerService } from '../logging/logger.service';\r\nimport { flattenArray } from '../utils/collections/collections.helper';\r\nimport { ClosestMatchingRouteService } from './closest-matching-route.service';\r\n\r\n@Injectable()\r\nexport class AuthInterceptor implements HttpInterceptor {\r\n  private readonly authStateService = inject(AuthStateService);\r\n\r\n  private readonly configurationService = inject(ConfigurationService);\r\n\r\n  private readonly loggerService = inject(LoggerService);\r\n\r\n  private readonly closestMatchingRouteService = inject(\r\n    ClosestMatchingRouteService\r\n  );\r\n\r\n  intercept(\r\n    req: HttpRequest<any>,\r\n    next: HttpHandler\r\n  ): Observable<HttpEvent<any>> {\r\n    return interceptRequest(req, next.handle, {\r\n      configurationService: this.configurationService,\r\n      authStateService: this.authStateService,\r\n      closestMatchingRouteService: this.closestMatchingRouteService,\r\n      loggerService: this.loggerService,\r\n    });\r\n  }\r\n}\r\n\r\nexport function authInterceptor(): HttpInterceptorFn {\r\n  return (req, next) => {\r\n    return interceptRequest(req, next, {\r\n      configurationService: inject(ConfigurationService),\r\n      authStateService: inject(AuthStateService),\r\n      closestMatchingRouteService: inject(ClosestMatchingRouteService),\r\n      loggerService: inject(LoggerService),\r\n    });\r\n  };\r\n}\r\n\r\nfunction interceptRequest(\r\n  req: HttpRequest<any>,\r\n  next: HttpHandlerFn,\r\n  deps: {\r\n    authStateService: AuthStateService;\r\n    configurationService: ConfigurationService;\r\n    loggerService: LoggerService;\r\n    closestMatchingRouteService: ClosestMatchingRouteService;\r\n  }\r\n): Observable<HttpEvent<unknown>> {\r\n  if (!deps.configurationService.hasAtLeastOneConfig()) {\r\n    return next(req);\r\n  }\r\n\r\n  const allConfigurations = deps.configurationService.getAllConfigurations();\r\n  const allRoutesConfigured = allConfigurations.map(\r\n    (x) => x.secureRoutes || []\r\n  );\r\n  const allRoutesConfiguredFlat = flattenArray(allRoutesConfigured);\r\n\r\n  if (allRoutesConfiguredFlat.length === 0) {\r\n    deps.loggerService.logDebug(\r\n      allConfigurations[0],\r\n      `No routes to check configured`\r\n    );\r\n\r\n    return next(req);\r\n  }\r\n\r\n  const { matchingConfig, matchingRoute } =\r\n    deps.closestMatchingRouteService.getConfigIdForClosestMatchingRoute(\r\n      req.url,\r\n      allConfigurations\r\n    );\r\n\r\n  if (!matchingConfig) {\r\n    deps.loggerService.logDebug(\r\n      allConfigurations[0],\r\n      `Did not find any configured route for route ${req.url}`\r\n    );\r\n\r\n    return next(req);\r\n  }\r\n\r\n  deps.loggerService.logDebug(\r\n    matchingConfig,\r\n    `'${req.url}' matches configured route '${matchingRoute}'`\r\n  );\r\n  const token = deps.authStateService.getAccessToken(matchingConfig);\r\n\r\n  if (!token) {\r\n    deps.loggerService.logDebug(\r\n      matchingConfig,\r\n      `Wanted to add token to ${req.url} but found no token: '${token}'`\r\n    );\r\n\r\n    return next(req);\r\n  }\r\n\r\n  deps.loggerService.logDebug(\r\n    matchingConfig,\r\n    `'${req.url}' matches configured route '${matchingRoute}', adding token`\r\n  );\r\n  req = req.clone({\r\n    headers: req.headers.set('Authorization', 'Bearer ' + token),\r\n  });\r\n\r\n  return next(req);\r\n}\r\n"]}