UNPKG

@ema/js-base-library

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 7.2.0.

367 lines 30.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; export class BaseApi { constructor() { this.headers = {}; this.routes = {}; this.baseUrl = '/api'; this.idField = 'id'; this.requestCredentials = 'same-origin'; // include, same-origin, *omit (default) // include, same-origin, *omit (default) this.corsMode = 'same-origin'; // no-cors, cors, *same-origin (default) // no-cors, cors, *same-origin (default) this.cachePolicy = 'no-cache'; // *default, no-cache, reload, force-cache, only-if-cached this.entities = {}; this.hasDebugger = false; } /** * @param {?} settings * @return {?} */ init(settings) { this.settings = settings; if (this.settings.host) { this.baseUrl = settings.host; } if (this.settings.routes) { this.initApiRoutes(this.settings.routes); } if (this.settings.headers) { /** @type {?} */ const self = this; this.settings.headers.forEach((/** * @param {?} obj * @return {?} */ (obj) => { for (const k in obj) { self.headers[k] = obj[k]; } })); } if (this['httpHeaders']) { // AngularJs only Object.keys(this.headers).forEach((/** * @param {?} k * @return {?} */ (k) => { this['httpHeaders'].set(k, this.headers[k]); })); } // if ('withCredentials' in new XMLHttpRequest) { // this.cors = true; // } } ; /** * @param {?} url * @return {?} */ route(url) { /** @type {?} */ let mappedUrl; Object.keys(this.routes).forEach((/** * @param {?} k * @return {?} */ (k) => { if (k === url) { mappedUrl = this.routes[k]; } })); if (mappedUrl) { return mappedUrl; } else { return url; } } // CRUD /** * @param {?} path * @param {?} data * @return {?} */ post(path, data) { return tslib_1.__awaiter(this, void 0, void 0, function* () { /** @type {?} */ const result = yield fetch(`${this.baseUrl}${path}`, { body: JSON.stringify(data), // must match 'Content-Type' header cache: this.cachePolicy, credentials: this.requestCredentials, headers: this.headers, mode: this.corsMode, method: 'POST', }) .then((/** * @param {?} response * @return {?} */ (response) => { if (response.status >= 400) { console.log(response); console.error('Bad response from server'); return response; } return response.json(); })) .catch(this.errorHandler) .then((/** * @param {?} data * @return {?} */ (data) => { return data; })); return result; }); } /** * @param {?} path * @param {?=} params * @return {?} */ get(path, params = undefined) { return tslib_1.__awaiter(this, void 0, void 0, function* () { if (params) { path += '?'; Object.keys(params).forEach((/** * @param {?} key * @return {?} */ key => path += key + '=' + params[key] + '&')); } /** @type {?} */ const result = yield fetch(`${this.baseUrl}${path}`, { cache: this.cachePolicy, credentials: this.requestCredentials, headers: this.headers, mode: this.corsMode, method: 'GET', }).then((/** * @param {?} response * @return {?} */ (response) => { if (response.status >= 400) { console.log(response); console.log('Bad response from server'); return response; } return response.json(); })) .catch(this.errorHandler) .then((/** * @param {?} data * @return {?} */ (data) => { return data; })); return result; }); } // todo: patch /** * @param {?} path * @param {?} id * @param {?} data * @return {?} */ patch(path, id, data) { return tslib_1.__awaiter(this, void 0, void 0, function* () { yield fetch(`${this.baseUrl}${path}/` + id, { headers: this.headers, // method: 'PATCH', method: 'patch', body: JSON.stringify(data) }); }); } // fixme: causes php server error on drupal content page /** * @param {?} path * @param {?} id * @return {?} */ delete(path, id) { return tslib_1.__awaiter(this, void 0, void 0, function* () { console.log(path, id); // await fetch(`${this.baseUrl}${path}/` + id, { //     headers: this.headers, // //  method: 'DELETE' //     method: 'delete' // }); }); } /** * @param {?} username * @param {?} password * @return {?} */ login(username, password) { console.log(username, password.length); } /** * @param {?=} namespace * @param {?=} refresh * @return {?} */ logout(namespace = 'app:authData', refresh = false) { this.clearCredentials(namespace); this.settings.authenticated = false; if (refresh) { // location.href = location.origin; location.href = location.href; } } // todo: use btoa + atob /** * @param {?} credentials * @param {?=} namespace * @return {?} */ setCredentials(credentials, namespace = 'app-auth') { this.credentials = credentials; // window.localStorage.setItem(namespace, btoa(JSON.stringify(credentials))); if (typeof window !== 'undefined' && window.localStorage) { window.localStorage.setItem(namespace, JSON.stringify(credentials)); } } /** * @param {?=} namespace * @return {?} */ getCredentials(namespace = 'app:authData') { if (typeof window !== 'undefined' && window.localStorage && window.localStorage.getItem(namespace)) { // return JSON.parse(atob(window.localStorage.getItem(namespace))); return JSON.parse(window.localStorage.getItem(namespace)); } } /** * @param {?=} namespace * @return {?} */ clearCredentials(namespace = 'app:authData') { if (typeof window !== 'undefined' && window.localStorage.getItem(namespace)) { window.localStorage.removeItem(namespace); } } /** * @param {?} routes * @return {?} */ initApiRoutes(routes) { /** @type {?} */ const self = this; routes.forEach((/** * @param {?} obj * @return {?} */ (obj) => { for (let k in obj) { self.routes[k] = obj[k]; } })); if (self.settings.dev && self.settings.routes_dev) { self.settings.routes_dev.forEach((/** * @param {?} obj * @return {?} */ (obj) => { for (let k in obj) { self.routes[k] = obj[k]; } })); } } // todo /** * @param {?} error * @return {?} */ errorHandler(error) { // AppService.scope.$broadcast('formError', error); console.error(error); if (!error) { return; } // if(error.data === "token expired"){ //     toastr.warning($filter('translate')('LOGIN EXPIRED')+'.'); //     service.logOut(); //     return; // } // if (error.statusText === 'Bad Request' || error.status == 400) { //     if (error.data.message) { //         toastr.warning($filter('translate')(error.data.message)); //     } else { //         toastr.warning($filter('translate')('ERROR BAD REQUEST') + '.'); //     } // } // if(error.statusText === 'Unauthorized' || error.status == 401){ //     toastr.warning($filter('translate')('UNAUTHORIZED ERROR')+'.'); //     service.logOut(); //     return; // } // if(error.statusText === 'Not found' || error.status == 404){ //     toastr.warning($filter('translate')('ERROR NOT FOUND')+'.'); // } } // entities local storage todo: move to storage.js /** * @param {?} resource * @return {?} */ saveLocalResource(resource) { localStorage.setItem(resource[this.idField], resource); } /** * @param {?} ID * @return {?} */ loadLocalResource(ID) { if (localStorage.getItem(ID)) { localStorage.getItem(ID); } } /** * @param {?} ID * @return {?} */ flushLocalResource(ID) { if (localStorage.getItem(ID)) { localStorage.removeItem(ID); } } } if (false) { /** @type {?} */ BaseApi.prototype.headers; /** @type {?} */ BaseApi.prototype.settings; /** @type {?} */ BaseApi.prototype.routes; /** @type {?} */ BaseApi.prototype.baseUrl; /** @type {?} */ BaseApi.prototype.idField; /** @type {?} */ BaseApi.prototype.requestCredentials; /** @type {?} */ BaseApi.prototype.corsMode; /** @type {?} */ BaseApi.prototype.cachePolicy; /** @type {?} */ BaseApi.prototype.credentials; /** @type {?} */ BaseApi.prototype.entities; /** @type {?} */ BaseApi.prototype.hasDebugger; /* Skipping unhandled member: ;*/ } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-api.js","sourceRoot":"ng://@ema/js-base-library/","sources":["lib/base/base-api.ts"],"names":[],"mappings":"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","sourcesContent":["declare var fetch: any;\r\n\r\nexport class BaseApi {\r\n\r\n    public headers: any = {};\r\n    public settings: any;\r\n    public routes = {};\r\n    public baseUrl = '/api';\r\n    public idField = 'id';\r\n    public requestCredentials = 'same-origin'; // include, same-origin, *omit (default)\r\n    public corsMode = 'same-origin'; // no-cors, cors, *same-origin (default)\r\n    public cachePolicy = 'no-cache'; // *default, no-cache, reload, force-cache, only-if-cached\r\n    public credentials: any;\r\n    public entities: any = {};\r\n    public hasDebugger = false;\r\n\r\n    constructor() { }\r\n\r\n    public init(settings) {\r\n        this.settings = settings;\r\n        if (this.settings.host) {\r\n            this.baseUrl = settings.host;\r\n        }\r\n        if (this.settings.routes) {\r\n            this.initApiRoutes(this.settings.routes);\r\n        }\r\n        if (this.settings.headers) {\r\n            const self = this;\r\n            this.settings.headers.forEach((obj) => {\r\n                for (const k in obj) {\r\n                    self.headers[k] = obj[k];\r\n                }\r\n            });\r\n        }\r\n        if(this['httpHeaders']) {\r\n            // AngularJs only\r\n            Object.keys(this.headers).forEach((k) => {\r\n                this['httpHeaders'].set(k, this.headers[k]);\r\n            });\r\n        }\r\n        // if ('withCredentials' in new XMLHttpRequest) {\r\n        //     this.cors = true;\r\n        // }\r\n    };\r\n\r\n    public route(url: string) {\r\n        let mappedUrl: string;\r\n        Object.keys(this.routes).forEach((k) => {\r\n            if(k === url) {\r\n                mappedUrl = this.routes[k]\r\n            }\r\n        });\r\n        if (mappedUrl) {\r\n            return mappedUrl;\r\n        }else{\r\n            return url;\r\n        }\r\n    }\r\n\r\n    // CRUD\r\n    public async post(path, data: any) {\r\n        const result: any = await fetch(`${this.baseUrl}${path}`, {\r\n            body: JSON.stringify(data), // must match 'Content-Type' header\r\n            cache: this.cachePolicy,\r\n            credentials: this.requestCredentials,\r\n            headers: this.headers,\r\n            mode: this.corsMode,\r\n            method: 'POST',\r\n            // redirect: 'follow', // manual, *follow, error\r\n            // referrer: 'no-referrer', // *client, no-referrer\r\n        })\r\n            .then((response) => {\r\n                if (response.status >= 400) {\r\n                    console.log(response);\r\n                    console.error('Bad response from server');\r\n                    return response;\r\n                }\r\n                return response.json();\r\n            })\r\n            .catch(this.errorHandler)\r\n            .then((data) => {\r\n                return data;\r\n            });\r\n        return result;\r\n    }\r\n\r\n    public async get(path: string, params: any = undefined) {\r\n        if (params) {\r\n            path += '?';\r\n            Object.keys(params).forEach(key => path += key + '=' + params[key] + '&');\r\n        }\r\n        const result: any = await fetch(`${this.baseUrl}${path}`, {\r\n            cache: this.cachePolicy,\r\n            credentials: this.requestCredentials,\r\n            headers: this.headers,\r\n            mode: this.corsMode,\r\n            method: 'GET',\r\n            // redirect: 'follow', // manual, *follow, error\r\n            // referrer: 'no-referrer', // *client, no-referrer\r\n        }).then((response) => {\r\n                if (response.status >= 400) {\r\n                    console.log(response);\r\n                    console.log('Bad response from server');\r\n                    return response;\r\n                }\r\n                return response.json();\r\n            })\r\n            .catch(this.errorHandler)\r\n            .then((data) => {\r\n                return data;\r\n            });\r\n        return result;\r\n    }\r\n\r\n    // todo: patch\r\n    public async patch(path, id, data) {\r\n        await fetch(`${this.baseUrl}${path}/`+id, {\r\n            headers: this.headers,\r\n            // method: 'PATCH',\r\n            method: 'patch',\r\n            body: JSON.stringify( data )\r\n        })\r\n    }\r\n\r\n\r\n    // fixme: causes php server error on drupal content page\r\n    public async delete(path, id) {\r\n        console.log(path,id);\r\n        // await fetch(`${this.baseUrl}${path}/` + id, {\r\n        //     headers: this.headers,\r\n        // //  method: 'DELETE'\r\n        //     method: 'delete'\r\n        // });\r\n    }\r\n\r\n\r\n    login(username: string, password: string) {\r\n        console.log(username,password.length);\r\n    }\r\n\r\n    logout(namespace: string = 'app:authData', refresh: boolean = false) {\r\n        this.clearCredentials(namespace);\r\n        this.settings.authenticated = false;\r\n        if (refresh) {\r\n            // location.href = location.origin;\r\n            location.href = location.href;\r\n        }\r\n    }\r\n\r\n    // todo: use btoa + atob\r\n    setCredentials(credentials: any, namespace: string = 'app-auth') {\r\n        this.credentials = credentials;\r\n        // window.localStorage.setItem(namespace, btoa(JSON.stringify(credentials)));\r\n        if (typeof window !== 'undefined' && window.localStorage) {\r\n            window.localStorage.setItem(namespace, JSON.stringify(credentials));\r\n        }\r\n    }\r\n\r\n    getCredentials(namespace: string = 'app:authData') {\r\n        if (typeof window !== 'undefined' && window.localStorage && window.localStorage.getItem(namespace)) {\r\n            // return JSON.parse(atob(window.localStorage.getItem(namespace)));\r\n            return JSON.parse(window.localStorage.getItem(namespace));\r\n        }\r\n    }\r\n\r\n    clearCredentials(namespace: string = 'app:authData') {\r\n        if (typeof window !== 'undefined' && window.localStorage.getItem(namespace)) {\r\n            window.localStorage.removeItem(namespace);\r\n        }\r\n    }\r\n\r\n    initApiRoutes(routes) {\r\n        const self = this;\r\n        routes.forEach((obj) => {\r\n            for (let k in obj) {\r\n                self.routes[k] = obj[k];\r\n            }\r\n        });\r\n        if (self.settings.dev && self.settings.routes_dev) {\r\n            self.settings.routes_dev.forEach((obj) => {\r\n                for (let k in obj) {\r\n                    self.routes[k] = obj[k];\r\n                }\r\n            });\r\n        }\r\n    }\r\n\r\n    // todo\r\n    errorHandler(error) {\r\n        // AppService.scope.$broadcast('formError', error);\r\n        console.error(error);\r\n        if (!error) {\r\n            return;\r\n        }\r\n        // if(error.data === \"token expired\"){\r\n        //     toastr.warning($filter('translate')('LOGIN EXPIRED')+'.');\r\n        //     service.logOut();\r\n        //     return;\r\n        // }\r\n        // if (error.statusText === 'Bad Request' || error.status == 400) {\r\n        //     if (error.data.message) {\r\n        //         toastr.warning($filter('translate')(error.data.message));\r\n        //     } else {\r\n        //         toastr.warning($filter('translate')('ERROR BAD REQUEST') + '.');\r\n        //     }\r\n        // }\r\n        // if(error.statusText === 'Unauthorized' || error.status == 401){\r\n        //     toastr.warning($filter('translate')('UNAUTHORIZED ERROR')+'.');\r\n        //     service.logOut();\r\n        //     return;\r\n        // }\r\n        // if(error.statusText === 'Not found' || error.status == 404){\r\n        //     toastr.warning($filter('translate')('ERROR NOT FOUND')+'.');\r\n        // }\r\n    }\r\n\r\n    // entities local storage todo: move to storage.js\r\n    saveLocalResource(resource) {\r\n        localStorage.setItem(resource[this.idField], resource);\r\n    }\r\n\r\n    loadLocalResource(ID) {\r\n        if (localStorage.getItem(ID)) {\r\n            localStorage.getItem(ID);\r\n        }\r\n    }\r\n\r\n    flushLocalResource(ID) {\r\n        if (localStorage.getItem(ID)) {\r\n            localStorage.removeItem(ID);\r\n        }\r\n    }\r\n}"]}