@pepperi/lib
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 10.0.1.
95 lines • 12.7 kB
JavaScript
import { Injectable } from '@angular/core';
import { throwError } from 'rxjs';
import { catchError } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "../../common/services/session.service";
import * as i2 from "@angular/common/http";
export class HttpService {
constructor(sessionService, http) {
this.sessionService = sessionService;
this.http = http;
}
getTextFile(filename) {
// The Observable returned by get() is of type Observable<string>
// because a text response was specified.
// There's no need to pass a <string> type parameter to get().
// return this.http.get(filename, {responseType: 'text'})
// .pipe(
// tap( // Log the result or error
// data => this.log(filename, data),
// error => this.logError(filename, error)
// )
// );
}
getHttpCall(url, httpOptions = {}) {
return this.http.get(url, httpOptions)
.pipe(catchError(this.handleError.bind(this)));
// .subscribe(
// (res) => console.log(''),
// (error) => console.log(''),
// () => {}
// );
}
postHttpCall(url, body = {}, httpOptions = {}) {
return this.http.post(url, body, httpOptions)
.pipe(catchError(this.handleError.bind(this)));
// .subscribe(
// (res) => console.log(''),
// (error) => console.log(''),
// () => {}
// );
}
getWapiApiCall(url, httpOptions = {}) {
const wapiBaseUrl = this.sessionService.getWapiBaseUrl();
return this.getHttpCall(`${wapiBaseUrl}${url}`, httpOptions);
}
postWapiApiCall(url, body = {}, httpOptions = {}) {
const wapiBaseUrl = this.sessionService.getWapiBaseUrl();
return this.postHttpCall(`${wapiBaseUrl}${url}`, body, httpOptions);
}
getPapiApiCall(url, httpOptions = {}) {
const papiBaseUrl = this.sessionService.getPapiBaseUrl();
return this.getHttpCall(`${papiBaseUrl}${url}`, httpOptions);
}
postPapiApiCall(url, body = {}, httpOptions = {}) {
const papiBaseUrl = this.sessionService.getPapiBaseUrl();
return this.postHttpCall(`${papiBaseUrl}${url}`, body, httpOptions);
}
handleError(error) {
let errorMessage = 'Unknown error!';
if (error.error instanceof ErrorEvent) {
// Client-side errors
errorMessage = `Error: ${error.error.message}`;
}
else {
// Server-side errors
errorMessage = this.getServerErrorMessage(error);
}
return throwError(errorMessage);
}
getServerErrorMessage(error) {
switch (error.status) {
case 404: {
return `Not Found: ${error.message}`;
}
case 403: {
return `Access Denied: ${error.message}`;
}
case 500: {
return `Internal Server Error: ${error.message}`;
}
default: {
return `Unknown Server Error\nError Code: ${error.status}\nMessage: ${error.message}`;
}
}
}
}
HttpService.ɵfac = function HttpService_Factory(t) { return new (t || HttpService)(i0.ɵɵinject(i1.SessionService), i0.ɵɵinject(i2.HttpClient)); };
HttpService.ɵprov = i0.ɵɵdefineInjectable({ token: HttpService, factory: HttpService.ɵfac, providedIn: 'root' });
/*@__PURE__*/ (function () { i0.ɵsetClassMetadata(HttpService, [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}], function () { return [{ type: i1.SessionService }, { type: i2.HttpClient }]; }, null); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http.service.js","sourceRoot":"","sources":["../../../../../../projects/pepperi-lib/src/core/http/services/http.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable} from '@angular/core';\r\nimport {HttpClient, HttpErrorResponse, HttpParams, HttpHeaders } from '@angular/common/http';\r\nimport { throwError, Observable } from 'rxjs';\r\nimport { retry, catchError, tap } from 'rxjs/operators';\r\nimport { SessionService } from '../../common/services/session.service';\r\n\r\n@Injectable({\r\n    providedIn: 'root',\r\n})\r\nexport class HttpService {\r\n    constructor(\r\n        private sessionService: SessionService,\r\n        private http: HttpClient) {\r\n    }\r\n\r\n    getTextFile(filename: string) {\r\n        // The Observable returned by get() is of type Observable<string>\r\n        // because a text response was specified.\r\n        // There's no need to pass a <string> type parameter to get().\r\n        // return this.http.get(filename, {responseType: 'text'})\r\n        //     .pipe(\r\n        //         tap( // Log the result or error\r\n        //         data => this.log(filename, data),\r\n        //         error => this.logError(filename, error)\r\n        //         )\r\n        // );\r\n    }\r\n\r\n    getHttpCall(url: string, httpOptions = {}): Observable<any> {\r\n        return this.http.get(url, httpOptions)\r\n            .pipe(catchError(this.handleError.bind(this)));\r\n        //     .subscribe(\r\n        //         (res) => console.log(''),\r\n        //         (error) => console.log(''),\r\n        //         () => {}\r\n        // );\r\n    }\r\n\r\n    postHttpCall(url: string, body = {}, httpOptions = {}): Observable<any> {\r\n        return this.http.post(url, body, httpOptions)\r\n            .pipe(catchError(this.handleError.bind(this)));\r\n        //     .subscribe(\r\n        //         (res) => console.log(''),\r\n        //         (error) => console.log(''),\r\n        //         () => {}\r\n        // );\r\n    }\r\n\r\n    getWapiApiCall(url: string, httpOptions = {}): Observable<any> {\r\n        const wapiBaseUrl = this.sessionService.getWapiBaseUrl();\r\n        return this.getHttpCall(`${wapiBaseUrl}${url}`, httpOptions);\r\n    }\r\n\r\n    postWapiApiCall(url: string, body = {}, httpOptions = {}): Observable<any> {\r\n        const wapiBaseUrl = this.sessionService.getWapiBaseUrl();\r\n        return this.postHttpCall(`${wapiBaseUrl}${url}`, body, httpOptions);\r\n    }\r\n\r\n    getPapiApiCall(url: string, httpOptions = {}): Observable<any> {\r\n        const papiBaseUrl = this.sessionService.getPapiBaseUrl();\r\n        return this.getHttpCall(`${papiBaseUrl}${url}`, httpOptions);\r\n    }\r\n\r\n    postPapiApiCall(url: string, body = {}, httpOptions = {}): Observable<any> {\r\n        const papiBaseUrl = this.sessionService.getPapiBaseUrl();\r\n        return this.postHttpCall(`${papiBaseUrl}${url}`, body, httpOptions);\r\n    }\r\n\r\n    private handleError(error: HttpErrorResponse): Observable<never> {\r\n        let errorMessage = 'Unknown error!';\r\n        if (error.error instanceof ErrorEvent) {\r\n            // Client-side errors\r\n            errorMessage = `Error: ${error.error.message}`;\r\n        } else {\r\n            // Server-side errors\r\n            errorMessage = this.getServerErrorMessage(error);\r\n        }\r\n\r\n        return throwError(errorMessage);\r\n    }\r\n\r\n    private getServerErrorMessage(error: HttpErrorResponse): string {\r\n        switch (error.status) {\r\n            case 404: {\r\n                return `Not Found: ${error.message}`;\r\n            }\r\n            case 403: {\r\n                return `Access Denied: ${error.message}`;\r\n            }\r\n            case 500: {\r\n                return `Internal Server Error: ${error.message}`;\r\n            }\r\n            default: {\r\n                return `Unknown Server Error\\nError Code: ${error.status}\\nMessage: ${error.message}`;\r\n            }\r\n        }\r\n    }\r\n}\r\n"]}