UNPKG

@spartacus/core

Version:

Spartacus - the core framework

80 lines 12.8 kB
import { HttpResponse, } from '@angular/common/http'; import { Injectable } from '@angular/core'; import { combineLatest } from 'rxjs'; import { switchMap, take, tap } from 'rxjs/operators'; import { ANONYMOUS_CONSENTS_HEADER, ANONYMOUS_CONSENT_STATUS, } from '../../model/index'; import * as i0 from "@angular/core"; import * as i1 from "../facade/anonymous-consents.service"; import * as i2 from "../../auth/index"; import * as i3 from "../../occ/services/occ-endpoints.service"; import * as i4 from "../config/anonymous-consents-config"; export class AnonymousConsentsInterceptor { constructor(anonymousConsentsService, authService, occEndpoints, config) { this.anonymousConsentsService = anonymousConsentsService; this.authService = authService; this.occEndpoints = occEndpoints; this.config = config; } intercept(request, next) { return combineLatest([ this.anonymousConsentsService.getConsents(), this.authService.isUserLoggedIn(), ]).pipe(take(1), switchMap(([consents, isUserLoggedIn]) => { if (!this.isOccUrl(request.url)) { return next.handle(request); } const clonedRequest = this.handleRequest(consents, request); return next.handle(clonedRequest).pipe(tap((event) => { var _a; if (event instanceof HttpResponse && ((_a = event.url) !== null && _a !== void 0 ? _a : '').startsWith(this.occEndpoints.buildUrl('anonymousConsentTemplates'))) { this.handleResponse(isUserLoggedIn, event.headers.get(ANONYMOUS_CONSENTS_HEADER), consents); } })); })); } handleResponse(isUserLoggedIn, newRawConsents, previousConsents) { if (!isUserLoggedIn && newRawConsents) { let newConsents = []; newConsents = this.anonymousConsentsService.decodeAndDeserialize(newRawConsents); newConsents = this.giveRequiredConsents(newConsents); if (this.anonymousConsentsService.consentsUpdated(newConsents, previousConsents)) { this.anonymousConsentsService.setConsents(newConsents); } } } handleRequest(consents, request) { if (!consents) { return request; } const rawConsents = this.anonymousConsentsService.serializeAndEncode(consents); return request.clone({ setHeaders: { [ANONYMOUS_CONSENTS_HEADER]: rawConsents, }, }); } isOccUrl(url) { return url.includes(this.occEndpoints.getBaseUrl()); } giveRequiredConsents(consents) { const givenConsents = [...consents]; if (Boolean(this.config.anonymousConsents) && Boolean(this.config.anonymousConsents.requiredConsents)) { for (const consent of givenConsents) { if (this.config.anonymousConsents.requiredConsents.includes(consent.templateCode)) { consent.consentState = ANONYMOUS_CONSENT_STATUS.GIVEN; } } } return givenConsents; } } AnonymousConsentsInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AnonymousConsentsInterceptor, deps: [{ token: i1.AnonymousConsentsService }, { token: i2.AuthService }, { token: i3.OccEndpointsService }, { token: i4.AnonymousConsentsConfig }], target: i0.ɵɵFactoryTarget.Injectable }); AnonymousConsentsInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AnonymousConsentsInterceptor, providedIn: 'root' }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: AnonymousConsentsInterceptor, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: function () { return [{ type: i1.AnonymousConsentsService }, { type: i2.AuthService }, { type: i3.OccEndpointsService }, { type: i4.AnonymousConsentsConfig }]; } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anonymous-consents-interceptor.js","sourceRoot":"","sources":["../../../../../../projects/core/src/anonymous-consents/http-interceptors/anonymous-consents-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  HttpEvent,\n  HttpHandler,\n  HttpInterceptor,\n  HttpRequest,\n  HttpResponse,\n} from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { combineLatest, Observable } from 'rxjs';\nimport { switchMap, take, tap } from 'rxjs/operators';\nimport { AuthService } from '../../auth/index';\nimport {\n  AnonymousConsent,\n  ANONYMOUS_CONSENTS_HEADER,\n  ANONYMOUS_CONSENT_STATUS,\n} from '../../model/index';\nimport { OccEndpointsService } from '../../occ/services/occ-endpoints.service';\nimport { AnonymousConsentsConfig } from '../config/anonymous-consents-config';\nimport { AnonymousConsentsService } from '../facade/anonymous-consents.service';\n\n@Injectable({ providedIn: 'root' })\nexport class AnonymousConsentsInterceptor implements HttpInterceptor {\n  constructor(\n    private anonymousConsentsService: AnonymousConsentsService,\n    private authService: AuthService,\n    private occEndpoints: OccEndpointsService,\n    private config: AnonymousConsentsConfig\n  ) {}\n\n  intercept(\n    request: HttpRequest<any>,\n    next: HttpHandler\n  ): Observable<HttpEvent<any>> {\n    return combineLatest([\n      this.anonymousConsentsService.getConsents(),\n      this.authService.isUserLoggedIn(),\n    ]).pipe(\n      take(1),\n      switchMap(([consents, isUserLoggedIn]) => {\n        if (!this.isOccUrl(request.url)) {\n          return next.handle(request);\n        }\n\n        const clonedRequest = this.handleRequest(consents, request);\n        return next.handle(clonedRequest).pipe(\n          tap((event) => {\n            if (\n              event instanceof HttpResponse &&\n              (event.url ?? '').startsWith(\n                this.occEndpoints.buildUrl('anonymousConsentTemplates')\n              )\n            ) {\n              this.handleResponse(\n                isUserLoggedIn,\n                event.headers.get(ANONYMOUS_CONSENTS_HEADER),\n                consents\n              );\n            }\n          })\n        );\n      })\n    );\n  }\n\n  private handleResponse(\n    isUserLoggedIn: boolean,\n    newRawConsents: string,\n    previousConsents: AnonymousConsent[]\n  ): void {\n    if (!isUserLoggedIn && newRawConsents) {\n      let newConsents: AnonymousConsent[] = [];\n      newConsents =\n        this.anonymousConsentsService.decodeAndDeserialize(newRawConsents);\n      newConsents = this.giveRequiredConsents(newConsents);\n\n      if (\n        this.anonymousConsentsService.consentsUpdated(\n          newConsents,\n          previousConsents\n        )\n      ) {\n        this.anonymousConsentsService.setConsents(newConsents);\n      }\n    }\n  }\n\n  private handleRequest(\n    consents: AnonymousConsent[],\n    request: HttpRequest<any>\n  ): HttpRequest<any> {\n    if (!consents) {\n      return request;\n    }\n\n    const rawConsents =\n      this.anonymousConsentsService.serializeAndEncode(consents);\n    return request.clone({\n      setHeaders: {\n        [ANONYMOUS_CONSENTS_HEADER]: rawConsents,\n      },\n    });\n  }\n\n  private isOccUrl(url: string): boolean {\n    return url.includes(this.occEndpoints.getBaseUrl());\n  }\n\n  private giveRequiredConsents(\n    consents: AnonymousConsent[]\n  ): AnonymousConsent[] {\n    const givenConsents = [...consents];\n\n    if (\n      Boolean(this.config.anonymousConsents) &&\n      Boolean(this.config.anonymousConsents.requiredConsents)\n    ) {\n      for (const consent of givenConsents) {\n        if (\n          this.config.anonymousConsents.requiredConsents.includes(\n            consent.templateCode\n          )\n        ) {\n          consent.consentState = ANONYMOUS_CONSENT_STATUS.GIVEN;\n        }\n      }\n    }\n    return givenConsents;\n  }\n}\n"]}