UNPKG

@cause-911/core

Version:

Run `npm install @cause-911/core --save` to add this library to your project

182 lines 16.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable } from '@angular/core'; import { HttpBackend, HttpClient } from '@angular/common/http'; import { of, throwError } from 'rxjs'; import { catchError, map, switchMap } from 'rxjs/operators'; import { CoreService } from '../../core.service'; export class HttpTokenWriterInterceptor { /** * @param {?} coreService * @param {?} handler */ constructor(coreService, handler) { this.http = new HttpClient(handler); this.config = coreService.getConfig(); } /** * @param {?} request * @param {?} next * @return {?} */ intercept(request, next) { this.requestOriginal = request; request = request.clone({ headers: this.addSettings(), }); return next.handle(request).pipe(catchError((/** * @param {?} error * @return {?} */ error => { return this.checkIfWeCanManageError(error).pipe(switchMap((/** * @param {?} handleRequest * @return {?} */ handleRequest => { request = handleRequest.clone({ headers: this.addSettings(), }); return next.handle(request); })), catchError((/** * @param {?} unhandleError * @return {?} */ unhandleError => { return throwError(unhandleError); }))); }))); } /** * @private * @return {?} */ addSettings() { /** @type {?} */ let headers = this.requestOriginal.headers; /** @type {?} */ const isFormData = this.requestOriginal.body instanceof FormData; if (!headers.has('Authorization') && this.config.accessToken) { headers = headers.set('Authorization', `${this.config.authorizationType} ${this.config.accessToken}`); } if (!headers.has('X-CSRF-Token') && this.config.CSRFToken) { headers = headers.set('X-CSRF-Token', `${this.config.CSRFToken}`); } if (!headers.has('Content-Type') && !isFormData) { headers = headers.set('Content-Type', `application/json; charset=${this.config.charset}`); } if (!headers.has('Language-Code')) { headers = headers.set('Language-Code', this.config.locale); } return headers; } /** * @private * @param {?} error * @return {?} */ checkIfWeCanManageError(error) { if (error.status === 401 && this.config.accessToken && this.config.allowRefreshToken) { return this.checkRefreshToken().pipe(map((/** * @param {?} response * @return {?} */ response => { if (!response) { location.href = this.config.loginURL; } return this.requestOriginal; }))); } else if (error.status === 401 && this.config.accessToken) { location.href = this.config.loginURL; } else if (error.status === 200) { if (error.message && error.message.indexOf('Http failure during parsing for') === 0) { return of(this.resendAsHTML()); } } return throwError(error); } /** * @private * @return {?} */ checkRefreshToken() { return this.postRefreshToken().pipe(map((/** * @param {?} data * @return {?} */ data => { this.config.accessToken = data.accessToken || ''; return data.accessToken ? true : false; })), catchError((/** * @param {?} error * @return {?} */ error => { this.config.accessToken = ''; return of(false); }))); } /** * @private * @return {?} */ postRefreshToken() { /** @type {?} */ const host = this.config.refreshLoginURL; /** @type {?} */ let refreshUrl = host; if (!refreshUrl) { refreshUrl = `/api/Authentification/Refresh`; } /** @type {?} */ const token = (/** @type {?} */ ({ accessToken: this.config.accessToken, refreshToken: this.config.refreshToken, })); return this.http.post(refreshUrl, token); } /** * @private * @return {?} */ resendAsHTML() { /** @type {?} */ let headers = this.requestOriginal.headers; headers = headers.set('Content-Type', `text/html; charset=${this.config.charset}`); return this.requestOriginal.clone({ responseType: 'text', headers: headers, }); } } HttpTokenWriterInterceptor.decorators = [ { type: Injectable } ]; /** @nocollapse */ HttpTokenWriterInterceptor.ctorParameters = () => [ { type: CoreService }, { type: HttpBackend } ]; if (false) { /** * @type {?} * @private */ HttpTokenWriterInterceptor.prototype.http; /** * @type {?} * @private */ HttpTokenWriterInterceptor.prototype.config; /** * @type {?} * @private */ HttpTokenWriterInterceptor.prototype.requestOriginal; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-token-writer-interceptor.js","sourceRoot":"ng://@cause-911/core/","sources":["lib/shared/interceptor/http-token-writer-interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\nimport {HttpBackend, HttpClient, HttpEvent, HttpHandler, HttpRequest} from '@angular/common/http';\nimport {Observable, of, throwError} from 'rxjs';\nimport {catchError, map, switchMap} from 'rxjs/operators';\nimport {Configuration} from '../classes/configuration';\nimport {CoreService} from '../../core.service';\nimport {RefreshToken} from '../models/refresh-token';\n\n@Injectable()\nexport class HttpTokenWriterInterceptor {\n    private http: HttpClient;\n    private config: Configuration;\n    private requestOriginal: HttpRequest<any>;\n\n    constructor(\n        coreService: CoreService,\n        handler: HttpBackend,\n    ) {\n        this.http = new HttpClient(handler);\n        this.config = coreService.getConfig();\n    }\n\n    public intercept(\n        request: HttpRequest<any>,\n        next: HttpHandler,\n    ): Observable<HttpEvent<any>> {\n        this.requestOriginal = request;\n        request = request.clone({\n            headers: this.addSettings(),\n        });\n\n        return next.handle(request).pipe(\n            catchError(error => {\n                return this.checkIfWeCanManageError(error).pipe(\n                    switchMap(handleRequest => {\n                        request = handleRequest.clone({\n                            headers: this.addSettings(),\n                        });\n\n                        return next.handle(request);\n                    }),\n                    catchError(unhandleError => {\n                        return throwError(unhandleError);\n                    })\n                );\n            })\n        );\n    }\n\n    private addSettings() {\n        let headers = this.requestOriginal.headers;\n        const isFormData = this.requestOriginal.body instanceof FormData;\n\n        if (!headers.has('Authorization') && this.config.accessToken) {\n            headers = headers.set('Authorization', `${this.config.authorizationType} ${this.config.accessToken}`);\n        }\n        if (!headers.has('X-CSRF-Token') && this.config.CSRFToken) {\n            headers = headers.set('X-CSRF-Token', `${this.config.CSRFToken}`);\n        }\n        if (!headers.has('Content-Type') && !isFormData) {\n            headers = headers.set('Content-Type', `application/json; charset=${this.config.charset}`);\n        }\n        if (!headers.has('Language-Code')) {\n            headers = headers.set('Language-Code', this.config.locale);\n        }\n        return headers;\n    }\n\n    private checkIfWeCanManageError(error): Observable<HttpRequest<any>> {\n        if (error.status === 401 && this.config.accessToken && this.config.allowRefreshToken) {\n            return this.checkRefreshToken().pipe(\n                map(response => {\n                    if (!response) {\n                        location.href = this.config.loginURL;\n                    }\n\n                    return this.requestOriginal;\n                })\n            );\n        } else if (error.status === 401 && this.config.accessToken) {\n            location.href = this.config.loginURL;\n        } else if (error.status === 200) {\n            if (error.message && error.message.indexOf('Http failure during parsing for') === 0) {\n                return of(this.resendAsHTML());\n            }\n        }\n\n        return throwError(error);\n    }\n\n    private checkRefreshToken(): Observable<boolean> {\n        return this.postRefreshToken().pipe(\n            map(data => {\n                this.config.accessToken = data.accessToken || '';\n                return data.accessToken ? true : false;\n            }),\n            catchError(error => {\n                this.config.accessToken = '';\n                return of(false);\n            })\n        );\n    }\n\n    private postRefreshToken(): Observable<RefreshToken> {\n        const host = this.config.refreshLoginURL;\n        let refreshUrl = host;\n        if (!refreshUrl) {\n            refreshUrl = `/api/Authentification/Refresh`;\n        }\n        const token = {\n            accessToken: this.config.accessToken,\n            refreshToken: this.config.refreshToken,\n        } as RefreshToken;\n\n        return this.http.post<RefreshToken>(refreshUrl, token);\n    }\n\n    private resendAsHTML() {\n        let headers = this.requestOriginal.headers;\n        headers = headers.set('Content-Type', `text/html; charset=${this.config.charset}`);\n\n        return this.requestOriginal.clone({\n            responseType: 'text',\n            headers: headers,\n        });\n    }\n}\n"]}