@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
JavaScript
/**
* @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}"]}