@forlabs/api-bridge
Advanced tools
Comparing version 0.0.10 to 0.0.11
@@ -9,2 +9,3 @@ export class NormalizerMetadata { | ||
const parseDate = (str) => str !== null ? new Date(str) : null; | ||
const ɵ0 = parseDate; | ||
const objectToUri = (entityClass) => (unNormalized) => { | ||
@@ -16,2 +17,3 @@ if (typeof unNormalized === 'string') { | ||
}; | ||
const ɵ1 = objectToUri; | ||
export const NORMALIZERS = { | ||
@@ -42,2 +44,3 @@ parseDate, | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplci5kZWNvcmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9hYnN0cmFjdC1lbnRpdHkvbm9ybWFsaXplci5kZWNvcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUNTLE1BQWlCLEVBQ2pCLFlBQW9CLEVBQ3BCLFVBQXNDO1FBRnRDLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsaUJBQVksR0FBWixZQUFZLENBQVE7UUFDcEIsZUFBVSxHQUFWLFVBQVUsQ0FBNEI7SUFFL0MsQ0FBQztDQUNGO0FBRUQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxHQUFrQixFQUFpQixFQUFFLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztBQUM3RixNQUFNLFdBQVcsR0FBRyxDQUFDLFdBQWdGLEVBQU8sRUFBRSxDQUM1RyxDQUFDLFlBQThDLEVBQUUsRUFBRTtJQUNqRCxJQUFJLE9BQU8sWUFBWSxLQUFLLFFBQVEsRUFBRTtRQUNwQyxPQUFPLFlBQVksQ0FBQztLQUNyQjtJQUNELE9BQU8sV0FBVyxDQUFDLFVBQVUsQ0FBQyxZQUFZLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ3ZELENBQUMsQ0FDRjtBQUVELE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FFcEI7SUFDRixTQUFTO0lBQ1QsV0FBVztDQUNaLENBQUM7QUFFRixNQUFNLE9BQU8seUJBQXlCO0lBQXRDO1FBQ0UsbUNBQW1DO1FBQ3pCLHdCQUFtQixHQUF5QixFQUFFLENBQUM7SUFtQjNELENBQUM7SUFqQkMsa0NBQWtDO0lBQzNCLHFCQUFxQixDQUFDLFFBQTRCO1FBQ3ZELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELGtDQUFrQztJQUMzQixzQkFBc0IsQ0FBQyxNQUFpQixFQUFFLFlBQW9CO1FBQ25FLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUM5RCxJQUFJLENBQUMsTUFBTSxLQUFLLE1BQU0sSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLFlBQVksQ0FDN0QsQ0FBQztRQUVGLE1BQU0sb0JBQW9CLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUNoRSxNQUFNLENBQUMsU0FBUyxZQUFZLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFlBQVksS0FBSyxZQUFZLENBQzlFLENBQUM7UUFFRixPQUFPLGtCQUFrQixJQUFJLG9CQUFvQixDQUFDO0lBQ3BELENBQUM7Q0FDRjtBQUVELE1BQU0sQ0FBQyxNQUFNLGdDQUFnQyxHQUFHLElBQUkseUJBQXlCLEVBQUUsQ0FBQztBQUVoRixNQUFNLENBQUMsTUFBTSxVQUFVLEdBQUcsQ0FBUyxVQUFvQyxFQUFFLEVBQUUsQ0FDekUsQ0FBQyxNQUFpQixFQUFFLEdBQVcsRUFBUSxFQUFFO0lBQ3ZDLE1BQU0sUUFBUSxHQUFHLElBQUksa0JBQWtCLENBQUMsTUFBTSxDQUFDLHdCQUF3QixFQUFFLEdBQUcsRUFBRSxVQUFVLENBQUMsQ0FBQztJQUMxRixnQ0FBZ0MsQ0FBQyxxQkFBcUIsQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUNuRSxDQUFDLENBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1R5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5cbmV4cG9ydCBjbGFzcyBOb3JtYWxpemVyTWV0YWRhdGEge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgdGFyZ2V0OiBUeXBlPGFueT4sXG4gICAgcHVibGljIHByb3BlcnR5TmFtZTogc3RyaW5nLFxuICAgIHB1YmxpYyBub3JtYWxpemVyOiAodW5Ob3JtYWxpemVkOiBhbnkpID0+IGFueSxcbiAgKSB7XG4gIH1cbn1cblxuY29uc3QgcGFyc2VEYXRlID0gKHN0cjogc3RyaW5nIHwgbnVsbCk6IChEYXRlIHwgbnVsbCkgPT4gc3RyICE9PSBudWxsID8gbmV3IERhdGUoc3RyKSA6IG51bGw7XG5jb25zdCBvYmplY3RUb1VyaSA9IChlbnRpdHlDbGFzczogeyBnZXRVcmlCeUlkOiAoaWQ6IG51bWJlciB8IHN0cmluZywgZnVsbFBhdGg/OiBib29sZWFuKSA9PiBzdHJpbmcgfSk6IGFueSA9PlxuICAodW5Ob3JtYWxpemVkOiBzdHJpbmcgfCB7IGlkOiBudW1iZXIgfCBzdHJpbmcgfSkgPT4ge1xuICAgIGlmICh0eXBlb2YgdW5Ob3JtYWxpemVkID09PSAnc3RyaW5nJykge1xuICAgICAgcmV0dXJuIHVuTm9ybWFsaXplZDtcbiAgICB9XG4gICAgcmV0dXJuIGVudGl0eUNsYXNzLmdldFVyaUJ5SWQodW5Ob3JtYWxpemVkLmlkLCB0cnVlKTtcbiAgfVxuO1xuXG5leHBvcnQgY29uc3QgTk9STUFMSVpFUlM6IHtcbiAgW25vcm1hbGl6ZXJOYW1lOiBzdHJpbmddOiAoKHVuTm9ybWFsaXplZDogYW55KSA9PiBhbnkpIHwgKCguLi5hcmdzOiBhbnlbXSkgPT4gKCh1bk5vcm1hbGl6ZWQ6IGFueSkgPT4gYW55KSk7XG59ID0ge1xuICBwYXJzZURhdGUsXG4gIG9iamVjdFRvVXJpLFxufTtcblxuZXhwb3J0IGNsYXNzIE5vcm1hbGl6ZXJNZXRhZGF0YVN0b3JhZ2Uge1xuICAvKiogQWxsIHRoZSBub3JtYWxpemVyIG1ldGFkYXRhLiAqL1xuICBwcm90ZWN0ZWQgbm9ybWFsaXplck1ldGFkYXRhczogTm9ybWFsaXplck1ldGFkYXRhW10gPSBbXTtcblxuICAvKiogQXBwZW5kIG5vcm1hbGl6ZXIgbWV0YWRhdGEuICovXG4gIHB1YmxpYyBhZGROb3JtYWxpemVyTWV0YWRhdGEobWV0YWRhdGE6IE5vcm1hbGl6ZXJNZXRhZGF0YSk6IHZvaWQge1xuICAgIHRoaXMubm9ybWFsaXplck1ldGFkYXRhcy5wdXNoKG1ldGFkYXRhKTtcbiAgfVxuXG4gIC8qKiBGaW5kIGEgbm9ybWFsaXplciBtZXRhZGF0YS4gKi9cbiAgcHVibGljIGZpbmROb3JtYWxpemVyTWV0YWRhdGEodGFyZ2V0OiBUeXBlPGFueT4sIHByb3BlcnR5TmFtZTogc3RyaW5nKTogTm9ybWFsaXplck1ldGFkYXRhIHtcbiAgICBjb25zdCBtZXRhZGF0YUZyb21UYXJnZXQgPSB0aGlzLm5vcm1hbGl6ZXJNZXRhZGF0YXMuZmluZChtZXRhID0+XG4gICAgICBtZXRhLnRhcmdldCA9PT0gdGFyZ2V0ICYmIG1ldGEucHJvcGVydHlOYW1lID09PSBwcm9wZXJ0eU5hbWUsXG4gICAgKTtcblxuICAgIGNvbnN0IG1ldGFkYXRhRnJvbUNoaWxkcmVuID0gdGhpcy5ub3JtYWxpemVyTWV0YWRhdGFzLmZpbmQobWV0YSA9PlxuICAgICAgdGFyZ2V0LnByb3RvdHlwZSBpbnN0YW5jZW9mIG1ldGEudGFyZ2V0ICYmIG1ldGEucHJvcGVydHlOYW1lID09PSBwcm9wZXJ0eU5hbWUsXG4gICAgKTtcblxuICAgIHJldHVybiBtZXRhZGF0YUZyb21UYXJnZXQgfHwgbWV0YWRhdGFGcm9tQ2hpbGRyZW47XG4gIH1cbn1cblxuZXhwb3J0IGNvbnN0IGRlZmF1bHROb3JtYWxpemVyTWV0YWRhdGFTdG9yYWdlID0gbmV3IE5vcm1hbGl6ZXJNZXRhZGF0YVN0b3JhZ2UoKTtcblxuZXhwb3J0IGNvbnN0IE5vcm1hbGl6ZXIgPSA8VDEsIFQyPihub3JtYWxpemVyOiAoaW5pdGlhbFZhbHVlOiBUMSkgPT4gVDIpID0+XG4gICh0YXJnZXQ6IFR5cGU8YW55Piwga2V5OiBzdHJpbmcpOiB2b2lkID0+IHtcbiAgICBjb25zdCBtZXRhZGF0YSA9IG5ldyBOb3JtYWxpemVyTWV0YWRhdGEodGFyZ2V0IC8qIHRhcmdldC5jb25zdHJ1Y3RvciAqLywga2V5LCBub3JtYWxpemVyKTtcbiAgICBkZWZhdWx0Tm9ybWFsaXplck1ldGFkYXRhU3RvcmFnZS5hZGROb3JtYWxpemVyTWV0YWRhdGEobWV0YWRhdGEpO1xuICB9XG47XG4iXX0= | ||
export { ɵ0, ɵ1 }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9ybWFsaXplci5kZWNvcmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9hYnN0cmFjdC1lbnRpdHkvbm9ybWFsaXplci5kZWNvcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUNTLE1BQWlCLEVBQ2pCLFlBQW9CLEVBQ3BCLFVBQXNDO1FBRnRDLFdBQU0sR0FBTixNQUFNLENBQVc7UUFDakIsaUJBQVksR0FBWixZQUFZLENBQVE7UUFDcEIsZUFBVSxHQUFWLFVBQVUsQ0FBNEI7SUFFL0MsQ0FBQztDQUNGO0FBRUQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxHQUFrQixFQUFpQixFQUFFLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQzs7QUFDN0YsTUFBTSxXQUFXLEdBQUcsQ0FBQyxXQUFnRixFQUFPLEVBQUUsQ0FDNUcsQ0FBQyxZQUE4QyxFQUFFLEVBQUU7SUFDakQsSUFBSSxPQUFPLFlBQVksS0FBSyxRQUFRLEVBQUU7UUFDcEMsT0FBTyxZQUFZLENBQUM7S0FDckI7SUFDRCxPQUFPLFdBQVcsQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUN2RCxDQUFDLENBQ0Y7O0FBRUQsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUVwQjtJQUNGLFNBQVM7SUFDVCxXQUFXO0NBQ1osQ0FBQztBQUVGLE1BQU0sT0FBTyx5QkFBeUI7SUFBdEM7UUFDRSxtQ0FBbUM7UUFDekIsd0JBQW1CLEdBQXlCLEVBQUUsQ0FBQztJQW1CM0QsQ0FBQztJQWpCQyxrQ0FBa0M7SUFDM0IscUJBQXFCLENBQUMsUUFBNEI7UUFDdkQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRUQsa0NBQWtDO0lBQzNCLHNCQUFzQixDQUFDLE1BQWlCLEVBQUUsWUFBb0I7UUFDbkUsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQzlELElBQUksQ0FBQyxNQUFNLEtBQUssTUFBTSxJQUFJLElBQUksQ0FBQyxZQUFZLEtBQUssWUFBWSxDQUM3RCxDQUFDO1FBRUYsTUFBTSxvQkFBb0IsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQ2hFLE1BQU0sQ0FBQyxTQUFTLFlBQVksSUFBSSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsWUFBWSxLQUFLLFlBQVksQ0FDOUUsQ0FBQztRQUVGLE9BQU8sa0JBQWtCLElBQUksb0JBQW9CLENBQUM7SUFDcEQsQ0FBQztDQUNGO0FBRUQsTUFBTSxDQUFDLE1BQU0sZ0NBQWdDLEdBQUcsSUFBSSx5QkFBeUIsRUFBRSxDQUFDO0FBRWhGLE1BQU0sQ0FBQyxNQUFNLFVBQVUsR0FBRyxDQUFTLFVBQW9DLEVBQUUsRUFBRSxDQUN6RSxDQUFDLE1BQWlCLEVBQUUsR0FBVyxFQUFRLEVBQUU7SUFDdkMsTUFBTSxRQUFRLEdBQUcsSUFBSSxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsd0JBQXdCLEVBQUUsR0FBRyxFQUFFLFVBQVUsQ0FBQyxDQUFDO0lBQzFGLGdDQUFnQyxDQUFDLHFCQUFxQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQ25FLENBQUMsQ0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7VHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cblxuZXhwb3J0IGNsYXNzIE5vcm1hbGl6ZXJNZXRhZGF0YSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyB0YXJnZXQ6IFR5cGU8YW55PixcbiAgICBwdWJsaWMgcHJvcGVydHlOYW1lOiBzdHJpbmcsXG4gICAgcHVibGljIG5vcm1hbGl6ZXI6ICh1bk5vcm1hbGl6ZWQ6IGFueSkgPT4gYW55LFxuICApIHtcbiAgfVxufVxuXG5jb25zdCBwYXJzZURhdGUgPSAoc3RyOiBzdHJpbmcgfCBudWxsKTogKERhdGUgfCBudWxsKSA9PiBzdHIgIT09IG51bGwgPyBuZXcgRGF0ZShzdHIpIDogbnVsbDtcbmNvbnN0IG9iamVjdFRvVXJpID0gKGVudGl0eUNsYXNzOiB7IGdldFVyaUJ5SWQ6IChpZDogbnVtYmVyIHwgc3RyaW5nLCBmdWxsUGF0aD86IGJvb2xlYW4pID0+IHN0cmluZyB9KTogYW55ID0+XG4gICh1bk5vcm1hbGl6ZWQ6IHN0cmluZyB8IHsgaWQ6IG51bWJlciB8IHN0cmluZyB9KSA9PiB7XG4gICAgaWYgKHR5cGVvZiB1bk5vcm1hbGl6ZWQgPT09ICdzdHJpbmcnKSB7XG4gICAgICByZXR1cm4gdW5Ob3JtYWxpemVkO1xuICAgIH1cbiAgICByZXR1cm4gZW50aXR5Q2xhc3MuZ2V0VXJpQnlJZCh1bk5vcm1hbGl6ZWQuaWQsIHRydWUpO1xuICB9XG47XG5cbmV4cG9ydCBjb25zdCBOT1JNQUxJWkVSUzoge1xuICBbbm9ybWFsaXplck5hbWU6IHN0cmluZ106ICgodW5Ob3JtYWxpemVkOiBhbnkpID0+IGFueSkgfCAoKC4uLmFyZ3M6IGFueVtdKSA9PiAoKHVuTm9ybWFsaXplZDogYW55KSA9PiBhbnkpKTtcbn0gPSB7XG4gIHBhcnNlRGF0ZSxcbiAgb2JqZWN0VG9VcmksXG59O1xuXG5leHBvcnQgY2xhc3MgTm9ybWFsaXplck1ldGFkYXRhU3RvcmFnZSB7XG4gIC8qKiBBbGwgdGhlIG5vcm1hbGl6ZXIgbWV0YWRhdGEuICovXG4gIHByb3RlY3RlZCBub3JtYWxpemVyTWV0YWRhdGFzOiBOb3JtYWxpemVyTWV0YWRhdGFbXSA9IFtdO1xuXG4gIC8qKiBBcHBlbmQgbm9ybWFsaXplciBtZXRhZGF0YS4gKi9cbiAgcHVibGljIGFkZE5vcm1hbGl6ZXJNZXRhZGF0YShtZXRhZGF0YTogTm9ybWFsaXplck1ldGFkYXRhKTogdm9pZCB7XG4gICAgdGhpcy5ub3JtYWxpemVyTWV0YWRhdGFzLnB1c2gobWV0YWRhdGEpO1xuICB9XG5cbiAgLyoqIEZpbmQgYSBub3JtYWxpemVyIG1ldGFkYXRhLiAqL1xuICBwdWJsaWMgZmluZE5vcm1hbGl6ZXJNZXRhZGF0YSh0YXJnZXQ6IFR5cGU8YW55PiwgcHJvcGVydHlOYW1lOiBzdHJpbmcpOiBOb3JtYWxpemVyTWV0YWRhdGEge1xuICAgIGNvbnN0IG1ldGFkYXRhRnJvbVRhcmdldCA9IHRoaXMubm9ybWFsaXplck1ldGFkYXRhcy5maW5kKG1ldGEgPT5cbiAgICAgIG1ldGEudGFyZ2V0ID09PSB0YXJnZXQgJiYgbWV0YS5wcm9wZXJ0eU5hbWUgPT09IHByb3BlcnR5TmFtZSxcbiAgICApO1xuXG4gICAgY29uc3QgbWV0YWRhdGFGcm9tQ2hpbGRyZW4gPSB0aGlzLm5vcm1hbGl6ZXJNZXRhZGF0YXMuZmluZChtZXRhID0+XG4gICAgICB0YXJnZXQucHJvdG90eXBlIGluc3RhbmNlb2YgbWV0YS50YXJnZXQgJiYgbWV0YS5wcm9wZXJ0eU5hbWUgPT09IHByb3BlcnR5TmFtZSxcbiAgICApO1xuXG4gICAgcmV0dXJuIG1ldGFkYXRhRnJvbVRhcmdldCB8fCBtZXRhZGF0YUZyb21DaGlsZHJlbjtcbiAgfVxufVxuXG5leHBvcnQgY29uc3QgZGVmYXVsdE5vcm1hbGl6ZXJNZXRhZGF0YVN0b3JhZ2UgPSBuZXcgTm9ybWFsaXplck1ldGFkYXRhU3RvcmFnZSgpO1xuXG5leHBvcnQgY29uc3QgTm9ybWFsaXplciA9IDxUMSwgVDI+KG5vcm1hbGl6ZXI6IChpbml0aWFsVmFsdWU6IFQxKSA9PiBUMikgPT5cbiAgKHRhcmdldDogVHlwZTxhbnk+LCBrZXk6IHN0cmluZyk6IHZvaWQgPT4ge1xuICAgIGNvbnN0IG1ldGFkYXRhID0gbmV3IE5vcm1hbGl6ZXJNZXRhZGF0YSh0YXJnZXQgLyogdGFyZ2V0LmNvbnN0cnVjdG9yICovLCBrZXksIG5vcm1hbGl6ZXIpO1xuICAgIGRlZmF1bHROb3JtYWxpemVyTWV0YWRhdGFTdG9yYWdlLmFkZE5vcm1hbGl6ZXJNZXRhZGF0YShtZXRhZGF0YSk7XG4gIH1cbjtcbiJdfQ== |
@@ -6,29 +6,18 @@ import { NgModule } from '@angular/core'; | ||
import { HeadersService } from './interceptor/headers.service'; | ||
import * as i0 from "@angular/core"; | ||
export class ApiBridgeModule { | ||
} | ||
/** @nocollapse */ ApiBridgeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
/** @nocollapse */ ApiBridgeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, imports: [CommonModule] }); | ||
/** @nocollapse */ ApiBridgeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
], imports: [[ | ||
CommonModule, | ||
]] }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, decorators: [{ | ||
type: NgModule, | ||
args: [{ | ||
imports: [ | ||
CommonModule, | ||
], | ||
exports: [], | ||
declarations: [], | ||
providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
] | ||
}] | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJyaWRnZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9hcGktYnJpZGdlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDMUQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLCtCQUErQixDQUFDOztBQWU3RCxNQUFNLE9BQU8sZUFBZTs7K0hBQWYsZUFBZTtnSUFBZixlQUFlLFlBVnhCLFlBQVk7Z0lBVUgsZUFBZSxhQU5mO1FBQ1QsWUFBWTtRQUNaLGtCQUFrQjtRQUNsQixjQUFjO0tBQ2YsWUFUUTtZQUNQLFlBQVk7U0FDYjsyRkFTVSxlQUFlO2tCQVozQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3FCQUNiO29CQUNELE9BQU8sRUFBRSxFQUFFO29CQUNYLFlBQVksRUFBRSxFQUFFO29CQUNoQixTQUFTLEVBQUU7d0JBQ1QsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLGNBQWM7cUJBQ2Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtUb2tlblNlcnZpY2V9IGZyb20gJy4vY3VycmVudC11c2VyL3Rva2VuLnNlcnZpY2UnO1xuaW1wb3J0IHtFcnJvckV2ZW50c1NlcnZpY2V9IGZyb20gJy4vZXJyb3ItZXZlbnRzL2Vycm9yLWV2ZW50cy5zZXJ2aWNlJztcbmltcG9ydCB7SGVhZGVyc1NlcnZpY2V9IGZyb20gJy4vaW50ZXJjZXB0b3IvaGVhZGVycy5zZXJ2aWNlJztcblxuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbXSxcbiAgZGVjbGFyYXRpb25zOiBbXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgVG9rZW5TZXJ2aWNlLFxuICAgIEVycm9yRXZlbnRzU2VydmljZSxcbiAgICBIZWFkZXJzU2VydmljZSxcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBBcGlCcmlkZ2VNb2R1bGUge31cbiJdfQ== | ||
ApiBridgeModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [ | ||
CommonModule, | ||
], | ||
exports: [], | ||
declarations: [], | ||
providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
] | ||
},] } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWJyaWRnZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9hcGktYnJpZGdlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDMUQsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0scUNBQXFDLENBQUM7QUFDdkUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBZTdELE1BQU0sT0FBTyxlQUFlOzs7WUFaM0IsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO2lCQUNiO2dCQUNELE9BQU8sRUFBRSxFQUFFO2dCQUNYLFlBQVksRUFBRSxFQUFFO2dCQUNoQixTQUFTLEVBQUU7b0JBQ1QsWUFBWTtvQkFDWixrQkFBa0I7b0JBQ2xCLGNBQWM7aUJBQ2Y7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1Rva2VuU2VydmljZX0gZnJvbSAnLi9jdXJyZW50LXVzZXIvdG9rZW4uc2VydmljZSc7XG5pbXBvcnQge0Vycm9yRXZlbnRzU2VydmljZX0gZnJvbSAnLi9lcnJvci1ldmVudHMvZXJyb3ItZXZlbnRzLnNlcnZpY2UnO1xuaW1wb3J0IHtIZWFkZXJzU2VydmljZX0gZnJvbSAnLi9pbnRlcmNlcHRvci9oZWFkZXJzLnNlcnZpY2UnO1xuXG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtdLFxuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBwcm92aWRlcnM6IFtcbiAgICBUb2tlblNlcnZpY2UsXG4gICAgRXJyb3JFdmVudHNTZXJ2aWNlLFxuICAgIEhlYWRlcnNTZXJ2aWNlLFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEFwaUJyaWRnZU1vZHVsZSB7fVxuIl19 |
@@ -70,5 +70,5 @@ import { BehaviorSubject, of } from 'rxjs'; | ||
} | ||
login(username, password) { | ||
login(username, password, errorPassthrough = false) { | ||
const data = { username, password }; | ||
return this.apiClient.post(this.apiLoginUrl, data, { errorPassthrough: false }).pipe(concatMap(({ token, refresh_token }) => { | ||
return this.apiClient.post(this.apiLoginUrl, data, { errorPassthrough }).pipe(concatMap(({ token, refresh_token }) => { | ||
this.tokenService.setUserTokens(token, refresh_token); | ||
@@ -120,2 +120,2 @@ return this.loadCurrentUser(true).pipe(filter(user => user !== null), first()); | ||
export const CURRENT_USER_SERVICE = new InjectionToken('CURRENT_USER_SERVICE'); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-current-user.service.js","sourceRoot":"","sources":["../../../../../../projects/forlabs/api-bridge/src/lib/current-user/abstract-current-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {BehaviorSubject, Observable, of} from 'rxjs';\nimport {concatMap, filter, first, map, shareReplay} from 'rxjs/operators';\nimport {AbstractUser} from '../abstract-entity/abstract-user.model';\nimport {API_CLIENT, ApiClientInterface} from '../api-client/abstract.api.client';\nimport {CACHE_STATUS_OLD, LOAD_TYPE_FULL} from '../data-services/abstract.data.service';\nimport {AbstractEntitydataService} from '../data-services/abstract.entitydata.service';\nimport {TokenService} from './token.service';\nimport {InjectionToken, Injector} from '@angular/core';\n\n\nexport interface CurrentUserServiceInterface<GenericUser extends AbstractUser> {\n  loadCurrentUser(forceRefresh: boolean): Observable<GenericUser | null>;\n  getCurrentUser(): Observable<GenericUser | null>;\n  hasCurrentUser(): Observable<boolean>;\n  refreshUserToken(): Observable<boolean>;\n  login(username: string, password: string): Observable<GenericUser>;\n  logout(): Observable<void>;\n  getRoles(): Observable<string[]>;\n  isGranted(role: string): Observable<boolean>;\n}\n\n\nexport abstract class AbstractCurrentUserService<GenericUser extends AbstractUser> extends AbstractEntitydataService<GenericUser> {\n  // Observer that emits undefined once, then the current user (every time it is updated),\n  // which might be null if user is not logged in.\n  protected user$: BehaviorSubject<GenericUser | null | undefined>;\n  // public currentUserId$: Subject<number | string | null> = new Subject<number | null>();\n\n  protected isRefreshing: boolean = false;\n  protected lastRefreshTimestamp: number;\n\n  protected abstract apiLoginUrl: string;\n  protected apiClient: ApiClientInterface;\n\n  public constructor(\n    protected tokenService: TokenService,\n    protected injector: Injector,\n  ) {\n    super();\n\n    this.apiClient = this.injector.get<ApiClientInterface>(API_CLIENT);\n    this.user$ = new BehaviorSubject<GenericUser | null | undefined>(undefined);\n    if (this.tokenService.hasUserToken()) {\n      // If there was a token in local storage, use it to recover current user information from API.\n      // Once it has been obtained, the currentUserInterceptor will emit it through our user$ subject.\n      this.loadCurrentUser(true).subscribe();\n    } else {\n      // this.currentUserId$.next(null);\n      this.user$.next(null);\n    }\n  }\n\n  public loadCurrentUser(forceRefresh: boolean = false): Observable<GenericUser | null> {\n    const parameters = 'currentUser';\n    const cacheStatus = this.cacheExpirationTracker.getCacheStatus(LOAD_TYPE_FULL, 'load', parameters) === CACHE_STATUS_OLD;\n    if (cacheStatus || forceRefresh) {\n      const innerObservable =\n        this.apiClient.getCurrentUser().pipe(map(\n          (currentUser: GenericUser) => {\n            this.user$.next(currentUser);\n            return ({collection: [currentUser], passthrough: currentUser});\n          }\n        ));\n      this.wrapObservable<GenericUser>(\n        innerObservable,\n        LOAD_TYPE_FULL,\n        'load',\n        parameters,\n      ).subscribe();\n    }\n    return this.getCurrentUser();\n  }\n\n  public getCurrentUser(): Observable<GenericUser | null> {\n    // const observable = combineLatest([\n    //   this.currentUserId$.pipe(filter((id: number | null | undefined) => id !== undefined)),\n    //   this.dataStore$,\n    // ]).pipe(\n    //   map(([currentUserId, users]: [number | null, DataStore<GenericUser>]) => {\n    //     if (users && currentUserId) {\n    //       this.user$.next(users[currentUserId]);\n    //       return users[currentUserId];\n    //     }\n    //     return null;\n    //   }),\n    // );\n\n    return this.user$.pipe(\n      shareReplay(1),\n    );\n  }\n\n  public hasCurrentUser(): Observable<boolean> {\n    return this.getCurrentUser().pipe(\n      filter((user: GenericUser | null | undefined) => user !== undefined),\n      map((user: GenericUser | null) => user !== null),\n      shareReplay(1),\n    );\n  }\n\n  public refreshUserToken(): Observable<boolean> {\n    // FIXME: check that refresh token exists\n    const data = {\n      refresh_token: this.tokenService.getRefreshToken(),\n    };\n    return this.postRefreshToken(data).pipe(\n      map(({token, refresh_token}) => {\n        this.tokenService.setUserTokens(token, refresh_token);\n        // FIXME: If all went well, return true, otherwise return false\n        return true;\n      }),\n    );\n  }\n\n  public postRefreshToken(data: {refresh_token: string}): Observable<any> {\n    return this.apiClient.post<any>('/token/refresh', data);\n  }\n\n  public login(username: string, password: string): Observable<GenericUser> {\n    const data = {username, password};\n\n    return this.apiClient.post<{ token: string; refresh_token: string; id: string | number }>(\n      this.apiLoginUrl,\n      data,\n      {errorPassthrough: false}\n    ).pipe(\n      concatMap(\n        ({token, refresh_token}) => {\n          this.tokenService.setUserTokens(token, refresh_token);\n          return this.loadCurrentUser(true).pipe(\n            filter(user => user !== null),\n            first(),\n          );\n        }\n      ),\n      // catchError(\n      //   (e) => {\n      //     this.alertService.push('Erreur d\\'authentification', this.alertService.ALERT_DANGER);\n      //     return throwError(e);\n      //   }\n      // ),\n    );\n  }\n\n  public logout(): Observable<void> {\n    return of(null).pipe(\n      map(() => {\n        this.tokenService.removeUserTokens();\n        this.user$.next(null);\n      }),\n    );\n    // return new Observable(\n    //   () => {\n    //     this.removeUserTokens();\n    //     this.user$.next(null);\n    //   }\n    // );\n  }\n\n  public patch(guest: GenericUser, patchedFields?: string[]): void {\n    console.log('todo');\n  }\n\n  //   return this.apiService.patch('/guest/' + guest.id, guest, undefined, patchedFields).pipe(\n  //     map((data: Guest | {token: string, refresh_token: string}) => {\n  //       if ('token' in data) {\n  //         // this.setUserTokens(data.token, data?.refresh_token);\n  //         // current user was already emitted by current user interceptor if we are here.\n  //         return;\n  //       }\n  //       this.user$.next(data);\n  //     }),\n  //   );\n  // }\n  public getRolesCurrentUser(): Observable<string[]> {\n    return this.user$.pipe(map((user: AbstractUser) => {\n        if (user) {\n          return user.getRoles();\n        }\n      }\n    ));\n  }\n\n  public isGranted(role: string): Observable<boolean> {\n    return this.getRolesCurrentUser().pipe(\n      map((roles: string[]) => {\n          if (roles) {\n            return roles.includes(role);\n          }\n        }\n      )\n    );\n  }\n}\n\n\nexport const CURRENT_USER_SERVICE = new InjectionToken<CurrentUserServiceInterface<AbstractUser>>('CURRENT_USER_SERVICE');\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-current-user.service.js","sourceRoot":"","sources":["../../../../../../projects/forlabs/api-bridge/src/lib/current-user/abstract-current-user.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {BehaviorSubject, Observable, of} from 'rxjs';\nimport {concatMap, filter, first, map, shareReplay} from 'rxjs/operators';\nimport {AbstractUser} from '../abstract-entity/abstract-user.model';\nimport {API_CLIENT, ApiClientInterface} from '../api-client/abstract.api.client';\nimport {CACHE_STATUS_OLD, LOAD_TYPE_FULL} from '../data-services/abstract.data.service';\nimport {AbstractEntitydataService} from '../data-services/abstract.entitydata.service';\nimport {TokenService} from './token.service';\nimport {InjectionToken, Injector} from '@angular/core';\n\n\nexport interface CurrentUserServiceInterface<GenericUser extends AbstractUser> {\n  loadCurrentUser(forceRefresh: boolean): Observable<GenericUser | null>;\n  getCurrentUser(): Observable<GenericUser | null>;\n  hasCurrentUser(): Observable<boolean>;\n  refreshUserToken(): Observable<boolean>;\n  login(username: string, password: string): Observable<GenericUser>;\n  logout(): Observable<void>;\n  getRoles(): Observable<string[]>;\n  isGranted(role: string): Observable<boolean>;\n}\n\n\nexport abstract class AbstractCurrentUserService<GenericUser extends AbstractUser> extends AbstractEntitydataService<GenericUser> {\n  // Observer that emits undefined once, then the current user (every time it is updated),\n  // which might be null if user is not logged in.\n  protected user$: BehaviorSubject<GenericUser | null | undefined>;\n  // public currentUserId$: Subject<number | string | null> = new Subject<number | null>();\n\n  protected isRefreshing: boolean = false;\n  protected lastRefreshTimestamp: number;\n\n  protected abstract apiLoginUrl: string;\n  protected apiClient: ApiClientInterface;\n\n  public constructor(\n    protected tokenService: TokenService,\n    protected injector: Injector,\n  ) {\n    super();\n\n    this.apiClient = this.injector.get<ApiClientInterface>(API_CLIENT);\n    this.user$ = new BehaviorSubject<GenericUser | null | undefined>(undefined);\n    if (this.tokenService.hasUserToken()) {\n      // If there was a token in local storage, use it to recover current user information from API.\n      // Once it has been obtained, the currentUserInterceptor will emit it through our user$ subject.\n      this.loadCurrentUser(true).subscribe();\n    } else {\n      // this.currentUserId$.next(null);\n      this.user$.next(null);\n    }\n  }\n\n  public loadCurrentUser(forceRefresh: boolean = false): Observable<GenericUser | null> {\n    const parameters = 'currentUser';\n    const cacheStatus = this.cacheExpirationTracker.getCacheStatus(LOAD_TYPE_FULL, 'load', parameters) === CACHE_STATUS_OLD;\n    if (cacheStatus || forceRefresh) {\n      const innerObservable =\n        this.apiClient.getCurrentUser().pipe(map(\n          (currentUser: GenericUser) => {\n            this.user$.next(currentUser);\n            return ({collection: [currentUser], passthrough: currentUser});\n          }\n        ));\n      this.wrapObservable<GenericUser>(\n        innerObservable,\n        LOAD_TYPE_FULL,\n        'load',\n        parameters,\n      ).subscribe();\n    }\n    return this.getCurrentUser();\n  }\n\n  public getCurrentUser(): Observable<GenericUser | null> {\n    // const observable = combineLatest([\n    //   this.currentUserId$.pipe(filter((id: number | null | undefined) => id !== undefined)),\n    //   this.dataStore$,\n    // ]).pipe(\n    //   map(([currentUserId, users]: [number | null, DataStore<GenericUser>]) => {\n    //     if (users && currentUserId) {\n    //       this.user$.next(users[currentUserId]);\n    //       return users[currentUserId];\n    //     }\n    //     return null;\n    //   }),\n    // );\n\n    return this.user$.pipe(\n      shareReplay(1),\n    );\n  }\n\n  public hasCurrentUser(): Observable<boolean> {\n    return this.getCurrentUser().pipe(\n      filter((user: GenericUser | null | undefined) => user !== undefined),\n      map((user: GenericUser | null) => user !== null),\n      shareReplay(1),\n    );\n  }\n\n  public refreshUserToken(): Observable<boolean> {\n    // FIXME: check that refresh token exists\n    const data = {\n      refresh_token: this.tokenService.getRefreshToken(),\n    };\n    return this.postRefreshToken(data).pipe(\n      map(({token, refresh_token}) => {\n        this.tokenService.setUserTokens(token, refresh_token);\n        // FIXME: If all went well, return true, otherwise return false\n        return true;\n      }),\n    );\n  }\n\n  public postRefreshToken(data: {refresh_token: string}): Observable<any> {\n    return this.apiClient.post<any>('/token/refresh', data);\n  }\n\n  public login(username: string, password: string, errorPassthrough = false): Observable<GenericUser> {\n    const data = {username, password};\n\n    return this.apiClient.post<{ token: string; refresh_token: string; id: string | number }>(\n      this.apiLoginUrl,\n      data,\n      {errorPassthrough}\n    ).pipe(\n      concatMap(\n        ({token, refresh_token}) => {\n          this.tokenService.setUserTokens(token, refresh_token);\n          return this.loadCurrentUser(true).pipe(\n            filter(user => user !== null),\n            first(),\n          );\n        }\n      ),\n      // catchError(\n      //   (e) => {\n      //     this.alertService.push('Erreur d\\'authentification', this.alertService.ALERT_DANGER);\n      //     return throwError(e);\n      //   }\n      // ),\n    );\n  }\n\n  public logout(): Observable<void> {\n    return of(null).pipe(\n      map(() => {\n        this.tokenService.removeUserTokens();\n        this.user$.next(null);\n      }),\n    );\n    // return new Observable(\n    //   () => {\n    //     this.removeUserTokens();\n    //     this.user$.next(null);\n    //   }\n    // );\n  }\n\n  public patch(guest: GenericUser, patchedFields?: string[]): void {\n    console.log('todo');\n  }\n\n  //   return this.apiService.patch('/guest/' + guest.id, guest, undefined, patchedFields).pipe(\n  //     map((data: Guest | {token: string, refresh_token: string}) => {\n  //       if ('token' in data) {\n  //         // this.setUserTokens(data.token, data?.refresh_token);\n  //         // current user was already emitted by current user interceptor if we are here.\n  //         return;\n  //       }\n  //       this.user$.next(data);\n  //     }),\n  //   );\n  // }\n  public getRolesCurrentUser(): Observable<string[]> {\n    return this.user$.pipe(map((user: AbstractUser) => {\n        if (user) {\n          return user.getRoles();\n        }\n      }\n    ));\n  }\n\n  public isGranted(role: string): Observable<boolean> {\n    return this.getRolesCurrentUser().pipe(\n      map((roles: string[]) => {\n          if (roles) {\n            return roles.includes(role);\n          }\n        }\n      )\n    );\n  }\n}\n\n\nexport const CURRENT_USER_SERVICE = new InjectionToken<CurrentUserServiceInterface<AbstractUser>>('CURRENT_USER_SERVICE');\n"]} |
import { Injectable } from '@angular/core'; | ||
import * as i0 from "@angular/core"; | ||
export class TokenService { | ||
@@ -36,7 +35,6 @@ constructor() { | ||
} | ||
/** @nocollapse */ TokenService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ TokenService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return []; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZvcmxhYnMvYXBpLWJyaWRnZS9zcmMvbGliL2N1cnJlbnQtdXNlci90b2tlbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBSXpDLE1BQU0sT0FBTyxZQUFZO0lBSXZCO1FBQ0UsSUFBSSxDQUFDLFNBQVMsR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ25ELElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRU0sWUFBWTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUVNLGVBQWU7UUFDcEIsT0FBTyxJQUFJLENBQUMsWUFBWSxDQUFDO0lBQzNCLENBQUM7SUFFTSxZQUFZO1FBQ2pCLE9BQU8sT0FBTyxJQUFJLENBQUMsWUFBWSxFQUFFLEtBQUssUUFBUSxDQUFDO0lBQ2pELENBQUM7SUFFTSxhQUFhLENBQUMsS0FBYSxFQUFFLGVBQXVCLElBQUk7UUFDN0QsWUFBWSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDekMsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDdkIsSUFBSSxZQUFZLEtBQUssSUFBSSxFQUFFO1lBQ3pCLFlBQVksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ25ELElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1NBQ2xDO1FBQ0QscUJBQXFCO1FBQ3JCLG9HQUFvRztRQUNwRyxrQ0FBa0M7UUFDbEMsSUFBSTtJQUNOLENBQUM7SUFFTSxnQkFBZ0I7UUFDckIsWUFBWSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNyQyxZQUFZLENBQUMsVUFBVSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzNCLElBQUksQ0FBQyxZQUFZLEdBQUcsU0FBUyxDQUFDO0lBQ2hDLENBQUM7OzRIQXZDVSxZQUFZO2dJQUFaLFlBQVk7MkZBQVosWUFBWTtrQkFEeEIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFRva2VuU2VydmljZSB7XG4gIHByb3RlY3RlZCB1c2VyVG9rZW46IHN0cmluZyB8IG51bGw7XG4gIHByb3RlY3RlZCByZWZyZXNoVG9rZW46IHN0cmluZyB8IG51bGw7XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMudXNlclRva2VuID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oJ3VzZXJUb2tlbicpO1xuICAgIHRoaXMucmVmcmVzaFRva2VuID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oJ3JlZnJlc2hUb2tlbicpO1xuICB9XG5cbiAgcHVibGljIGdldFVzZXJUb2tlbigpOiBzdHJpbmcgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy51c2VyVG9rZW47XG4gIH1cblxuICBwdWJsaWMgZ2V0UmVmcmVzaFRva2VuKCk6IHN0cmluZyB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLnJlZnJlc2hUb2tlbjtcbiAgfVxuXG4gIHB1YmxpYyBoYXNVc2VyVG9rZW4oKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGlzLmdldFVzZXJUb2tlbigpID09PSAnc3RyaW5nJztcbiAgfVxuXG4gIHB1YmxpYyBzZXRVc2VyVG9rZW5zKHRva2VuOiBzdHJpbmcsIHJlZnJlc2hUb2tlbjogc3RyaW5nID0gbnVsbCk6IHZvaWQge1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCd1c2VyVG9rZW4nLCB0b2tlbik7XG4gICAgdGhpcy51c2VyVG9rZW4gPSB0b2tlbjtcbiAgICBpZiAocmVmcmVzaFRva2VuICE9PSBudWxsKSB7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgncmVmcmVzaFRva2VuJywgcmVmcmVzaFRva2VuKTtcbiAgICAgIHRoaXMucmVmcmVzaFRva2VuID0gcmVmcmVzaFRva2VuO1xuICAgIH1cbiAgICAvLyBpZiAoaWQgIT09IG51bGwpIHtcbiAgICAvLyAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdjdXJyZW50VXNlcklkJywgaWQgYXMgc3RyaW5nKTsgLy8gVE9ETzogZG9lc24ndCBwcmVzZXJ2ZSB0aGUgbnVtYmVyIHR5cGU/XG4gICAgLy8gICB0aGlzLmN1cnJlbnRVc2VySWQkLm5leHQoaWQpO1xuICAgIC8vIH1cbiAgfVxuXG4gIHB1YmxpYyByZW1vdmVVc2VyVG9rZW5zKCk6IHZvaWQge1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKCd1c2VyVG9rZW4nKTtcbiAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbSgncmVmcmVzaFRva2VuJyk7XG4gICAgdGhpcy51c2VyVG9rZW4gPSB1bmRlZmluZWQ7XG4gICAgdGhpcy5yZWZyZXNoVG9rZW4gPSB1bmRlZmluZWQ7XG4gIH1cbn1cbiJdfQ== | ||
TokenService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
TokenService.ctorParameters = () => []; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZvcmxhYnMvYXBpLWJyaWRnZS9zcmMvbGliL2N1cnJlbnQtdXNlci90b2tlbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFJekMsTUFBTSxPQUFPLFlBQVk7SUFJdkI7UUFDRSxJQUFJLENBQUMsU0FBUyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFTSxZQUFZO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRU0sZUFBZTtRQUNwQixPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDM0IsQ0FBQztJQUVNLFlBQVk7UUFDakIsT0FBTyxPQUFPLElBQUksQ0FBQyxZQUFZLEVBQUUsS0FBSyxRQUFRLENBQUM7SUFDakQsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFhLEVBQUUsZUFBdUIsSUFBSTtRQUM3RCxZQUFZLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUN6QyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUN2QixJQUFJLFlBQVksS0FBSyxJQUFJLEVBQUU7WUFDekIsWUFBWSxDQUFDLE9BQU8sQ0FBQyxjQUFjLEVBQUUsWUFBWSxDQUFDLENBQUM7WUFDbkQsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7U0FDbEM7UUFDRCxxQkFBcUI7UUFDckIsb0dBQW9HO1FBQ3BHLGtDQUFrQztRQUNsQyxJQUFJO0lBQ04sQ0FBQztJQUVNLGdCQUFnQjtRQUNyQixZQUFZLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ3JDLFlBQVksQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDeEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLFlBQVksR0FBRyxTQUFTLENBQUM7SUFDaEMsQ0FBQzs7O1lBeENGLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUb2tlblNlcnZpY2Uge1xuICBwcm90ZWN0ZWQgdXNlclRva2VuOiBzdHJpbmcgfCBudWxsO1xuICBwcm90ZWN0ZWQgcmVmcmVzaFRva2VuOiBzdHJpbmcgfCBudWxsO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLnVzZXJUb2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKCd1c2VyVG9rZW4nKTtcbiAgICB0aGlzLnJlZnJlc2hUb2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdyZWZyZXNoVG9rZW4nKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXRVc2VyVG9rZW4oKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMudXNlclRva2VuO1xuICB9XG5cbiAgcHVibGljIGdldFJlZnJlc2hUb2tlbigpOiBzdHJpbmcgfCBudWxsIHtcbiAgICByZXR1cm4gdGhpcy5yZWZyZXNoVG9rZW47XG4gIH1cblxuICBwdWJsaWMgaGFzVXNlclRva2VuKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0eXBlb2YgdGhpcy5nZXRVc2VyVG9rZW4oKSA9PT0gJ3N0cmluZyc7XG4gIH1cblxuICBwdWJsaWMgc2V0VXNlclRva2Vucyh0b2tlbjogc3RyaW5nLCByZWZyZXNoVG9rZW46IHN0cmluZyA9IG51bGwpOiB2b2lkIHtcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgndXNlclRva2VuJywgdG9rZW4pO1xuICAgIHRoaXMudXNlclRva2VuID0gdG9rZW47XG4gICAgaWYgKHJlZnJlc2hUb2tlbiAhPT0gbnVsbCkge1xuICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oJ3JlZnJlc2hUb2tlbicsIHJlZnJlc2hUb2tlbik7XG4gICAgICB0aGlzLnJlZnJlc2hUb2tlbiA9IHJlZnJlc2hUb2tlbjtcbiAgICB9XG4gICAgLy8gaWYgKGlkICE9PSBudWxsKSB7XG4gICAgLy8gICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnY3VycmVudFVzZXJJZCcsIGlkIGFzIHN0cmluZyk7IC8vIFRPRE86IGRvZXNuJ3QgcHJlc2VydmUgdGhlIG51bWJlciB0eXBlP1xuICAgIC8vICAgdGhpcy5jdXJyZW50VXNlcklkJC5uZXh0KGlkKTtcbiAgICAvLyB9XG4gIH1cblxuICBwdWJsaWMgcmVtb3ZlVXNlclRva2VucygpOiB2b2lkIHtcbiAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbSgndXNlclRva2VuJyk7XG4gICAgbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oJ3JlZnJlc2hUb2tlbicpO1xuICAgIHRoaXMudXNlclRva2VuID0gdW5kZWZpbmVkO1xuICAgIHRoaXMucmVmcmVzaFRva2VuID0gdW5kZWZpbmVkO1xuICB9XG59XG4iXX0= |
import { Subject } from 'rxjs'; | ||
import { Injectable } from '@angular/core'; | ||
import * as i0 from "@angular/core"; | ||
export class ErrorEventsService { | ||
@@ -9,7 +8,5 @@ constructor() { | ||
} | ||
/** @nocollapse */ ErrorEventsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ ErrorEventsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService, decorators: [{ | ||
type: Injectable | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3ItZXZlbnRzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9lcnJvci1ldmVudHMvZXJyb3ItZXZlbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQUd6QyxNQUFNLE9BQU8sa0JBQWtCO0lBRC9CO1FBRVMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFFLENBQUM7S0FDakM7O2tJQUZZLGtCQUFrQjtzSUFBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEVycm9yRXZlbnRzU2VydmljZSB7XG4gIHB1YmxpYyBtZXNzYWdlJCA9IG5ldyBTdWJqZWN0KCk7XG59XG4iXX0= | ||
ErrorEventsService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3ItZXZlbnRzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3JsYWJzL2FwaS1icmlkZ2Uvc3JjL2xpYi9lcnJvci1ldmVudHMvZXJyb3ItZXZlbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUM3QixPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBR3pDLE1BQU0sT0FBTyxrQkFBa0I7SUFEL0I7UUFFUyxhQUFRLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUNsQyxDQUFDOzs7WUFIQSxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBFcnJvckV2ZW50c1NlcnZpY2Uge1xuICBwdWJsaWMgbWVzc2FnZSQgPSBuZXcgU3ViamVjdCgpO1xufVxuIl19 |
@@ -9,5 +9,2 @@ import { HttpErrorResponse } from '@angular/common/http'; | ||
import { HeadersService } from './headers.service'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "../error-events/error-events.service"; | ||
import * as i2 from "./headers.service"; | ||
const ExceptionUUIDs = { | ||
@@ -88,7 +85,10 @@ TokenExpired: '02a35cd6-8a6e-11eb-8dcd-0242ac130003', | ||
} | ||
/** @nocollapse */ ErrorInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor, deps: [{ token: i0.Injector }, { token: i1.ErrorEventsService }, { token: i2.HeadersService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ ErrorInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.ErrorEventsService }, { type: i2.HeadersService }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error.interceptor.js","sourceRoot":"","sources":["../../../../../../projects/forlabs/api-bridge/src/lib/interceptor/error.interceptor.ts"],"names":[],"mappings":"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","sourcesContent":["import {HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest} from '@angular/common/http';\nimport {Observable, Subject, throwError} from 'rxjs';\nimport {catchError, switchMap} from 'rxjs/operators';\nimport {Injectable, Injector} from '@angular/core';\nimport {CURRENT_USER_SERVICE, CurrentUserServiceInterface} from '../current-user/abstract-current-user.service';\nimport {InterceptorHttpParams} from '../api-client/abstract.api.client';\nimport {AbstractUser} from '../abstract-entity/abstract-user.model';\nimport {ErrorEventsService} from '../error-events/error-events.service';\nimport {HeadersService} from './headers.service';\n\n\nconst ExceptionUUIDs = {\n  TokenExpired: '02a35cd6-8a6e-11eb-8dcd-0242ac130003',\n};\n\n@Injectable()\nexport class ErrorInterceptor implements HttpInterceptor {\n  protected refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  // Looks like this works to avoid circular dependencies on DIes (currentUserService ends up requiring angular's\n  // http client, which requires HTTP_INTERCEPTORS).\n  protected get currentUserService(): CurrentUserServiceInterface<AbstractUser> {\n    this._currentUserService ??= this.injector.get<CurrentUserServiceInterface<AbstractUser>>(CURRENT_USER_SERVICE);\n    return this._currentUserService;\n  }\n\n  private _currentUserService: CurrentUserServiceInterface<AbstractUser>;\n\n  constructor(\n    protected injector: Injector,\n    protected errorEventsService: ErrorEventsService,\n    protected headersService: HeadersService,\n  ) {\n  }\n\n  public intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n    return next.handle(request).pipe(\n      catchError((error, caughtObservable: Observable<any>) => {\n        // If error is not HttpErrorResponse, don't do anything\n        if (!(error instanceof HttpErrorResponse)) {\n          return throwError(error);\n        }\n        if (request.params instanceof InterceptorHttpParams && request.params.interceptorConfig.errorPassthrough) {\n          return throwError(error);\n        }\n\n        const uuid: string = (error as { error: { uuid?: string } }).error?.uuid;\n        const alert = () => this.errorEventsService.message$.next({message, error});\n\n        let message = (error as { error: { message?: string } }).error?.message\n          ?? error.message\n          ?? error.toString();\n        switch (true) {\n          // Token expired\n          case uuid === ExceptionUUIDs.TokenExpired:\n            // Refresh token, and when this is done, update request with new token and send it again\n            return this.refreshUserToken().pipe(\n              switchMap((refreshWorked: boolean) => {\n                if (refreshWorked) {\n                  return next.handle(\n                    this.headersService.clonedRequestsWithProperHeaders(request),\n                  );\n                }\n                return this.currentUserService.logout();\n              }),\n            );\n          // Token is invalid for some reason (other than expired):\n          //    - One example is {code: 401, message: 'Refresh token \"<...>\" does not exist.'}\n          //    - Other scenarios?\n          case error.status === 401:\n            alert();\n            return this.currentUserService.logout();\n          // Forbidden: user token might be alright but user cannot view page, or no token provided but it was required\n          // case error.status === 403:\n          //   // FIXME: handle other scenarios\n          //   return throwError(error);\n          default:\n            alert();\n            return throwError(error);\n        }\n      }),\n    ) as Observable<HttpEvent<any>>;\n  }\n\n  // Observable that resolves when we have refreshed our token,\n  // but only one API call is made if this is called several times before we get a response.\n  protected refreshUserToken(): Subject<boolean> {\n    // FIXME: Subject.observers will be made internal in rxjs v8, find an alternative\n    // Only do something if this is the first time refreshUserToken is called since refreshSubject last completed.\n    if (this.refreshSubject.observers.length === 0) {\n      this.refreshSubject.subscribe({\n        complete: () => this.refreshSubject = new Subject<boolean>(),\n      });\n      this.currentUserService.refreshUserToken().subscribe(this.refreshSubject);\n    }\n    return this.refreshSubject;\n  }\n\n  protected isExpiredTokenError(error: HttpErrorResponse): boolean {\n    return error.status === 401\n      && (error as { error: { message?: string } })?.error.message === 'Expired JWT Token';\n  }\n}\n"]} | ||
ErrorInterceptor.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
ErrorInterceptor.ctorParameters = () => [ | ||
{ type: Injector }, | ||
{ type: ErrorEventsService }, | ||
{ type: HeadersService } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error.interceptor.js","sourceRoot":"","sources":["../../../../../../projects/forlabs/api-bridge/src/lib/interceptor/error.interceptor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAuD,MAAM,sBAAsB,CAAC;AAC7G,OAAO,EAAa,OAAO,EAAE,UAAU,EAAC,MAAM,MAAM,CAAC;AACrD,OAAO,EAAC,UAAU,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAC,UAAU,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AACnD,OAAO,EAAC,oBAAoB,EAA8B,MAAM,+CAA+C,CAAC;AAChH,OAAO,EAAC,qBAAqB,EAAC,MAAM,mCAAmC,CAAC;AAExE,OAAO,EAAC,kBAAkB,EAAC,MAAM,sCAAsC,CAAC;AACxE,OAAO,EAAC,cAAc,EAAC,MAAM,mBAAmB,CAAC;AAGjD,MAAM,cAAc,GAAG;IACrB,YAAY,EAAE,sCAAsC;CACrD,CAAC;AAGF,MAAM,OAAO,gBAAgB;IAY3B,YACY,QAAkB,EAClB,kBAAsC,EACtC,cAA8B;QAF9B,aAAQ,GAAR,QAAQ,CAAU;QAClB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,mBAAc,GAAd,cAAc,CAAgB;QAdhC,mBAAc,GAAqB,IAAI,OAAO,EAAW,CAAC;IAgBpE,CAAC;IAdD,+GAA+G;IAC/G,kDAAkD;IAClD,IAAc,kBAAkB;;QAC9B,MAAA,IAAI,CAAC,mBAAmB,oCAAxB,IAAI,CAAC,mBAAmB,GAAK,IAAI,CAAC,QAAQ,CAAC,GAAG,CAA4C,oBAAoB,CAAC,EAAC;QAChH,OAAO,IAAI,CAAC,mBAAmB,CAAC;IAClC,CAAC;IAWM,SAAS,CAAC,OAAyB,EAAE,IAAiB;QAC3D,OAAO,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAC9B,UAAU,CAAC,CAAC,KAAK,EAAE,gBAAiC,EAAE,EAAE;;YACtD,uDAAuD;YACvD,IAAI,CAAC,CAAC,KAAK,YAAY,iBAAiB,CAAC,EAAE;gBACzC,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;aAC1B;YACD,IAAI,OAAO,CAAC,MAAM,YAAY,qBAAqB,IAAI,OAAO,CAAC,MAAM,CAAC,iBAAiB,CAAC,gBAAgB,EAAE;gBACxG,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;aAC1B;YAED,MAAM,IAAI,GAAW,MAAC,KAAsC,CAAC,KAAK,0CAAE,IAAI,CAAC;YACzE,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,KAAK,EAAC,CAAC,CAAC;YAE5E,IAAI,OAAO,GAAG,MAAA,MAAA,MAAC,KAAyC,CAAC,KAAK,0CAAE,OAAO,mCAClE,KAAK,CAAC,OAAO,mCACb,KAAK,CAAC,QAAQ,EAAE,CAAC;YACtB,QAAQ,IAAI,EAAE;gBACZ,gBAAgB;gBAChB,KAAK,IAAI,KAAK,cAAc,CAAC,YAAY;oBACvC,wFAAwF;oBACxF,OAAO,IAAI,CAAC,gBAAgB,EAAE,CAAC,IAAI,CACjC,SAAS,CAAC,CAAC,aAAsB,EAAE,EAAE;wBACnC,IAAI,aAAa,EAAE;4BACjB,OAAO,IAAI,CAAC,MAAM,CAChB,IAAI,CAAC,cAAc,CAAC,+BAA+B,CAAC,OAAO,CAAC,CAC7D,CAAC;yBACH;wBACD,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;oBAC1C,CAAC,CAAC,CACH,CAAC;gBACJ,yDAAyD;gBACzD,oFAAoF;gBACpF,wBAAwB;gBACxB,KAAK,KAAK,CAAC,MAAM,KAAK,GAAG;oBACvB,KAAK,EAAE,CAAC;oBACR,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;gBAC1C,6GAA6G;gBAC7G,6BAA6B;gBAC7B,qCAAqC;gBACrC,8BAA8B;gBAC9B;oBACE,KAAK,EAAE,CAAC;oBACR,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;aAC5B;QACH,CAAC,CAAC,CAC2B,CAAC;IAClC,CAAC;IAED,6DAA6D;IAC7D,0FAA0F;IAChF,gBAAgB;QACxB,iFAAiF;QACjF,8GAA8G;QAC9G,IAAI,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE;YAC9C,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC;gBAC5B,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,GAAG,IAAI,OAAO,EAAW;aAC7D,CAAC,CAAC;YACH,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAC3E;QACD,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAES,mBAAmB,CAAC,KAAwB;;QACpD,OAAO,KAAK,CAAC,MAAM,KAAK,GAAG;eACtB,CAAA,MAAC,KAAyC,0CAAE,KAAK,CAAC,OAAO,MAAK,mBAAmB,CAAC;IACzF,CAAC;;;YAtFF,UAAU;;;YAZS,QAAQ;YAIpB,kBAAkB;YAClB,cAAc","sourcesContent":["import {HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest} from '@angular/common/http';\nimport {Observable, Subject, throwError} from 'rxjs';\nimport {catchError, switchMap} from 'rxjs/operators';\nimport {Injectable, Injector} from '@angular/core';\nimport {CURRENT_USER_SERVICE, CurrentUserServiceInterface} from '../current-user/abstract-current-user.service';\nimport {InterceptorHttpParams} from '../api-client/abstract.api.client';\nimport {AbstractUser} from '../abstract-entity/abstract-user.model';\nimport {ErrorEventsService} from '../error-events/error-events.service';\nimport {HeadersService} from './headers.service';\n\n\nconst ExceptionUUIDs = {\n  TokenExpired: '02a35cd6-8a6e-11eb-8dcd-0242ac130003',\n};\n\n@Injectable()\nexport class ErrorInterceptor implements HttpInterceptor {\n  protected refreshSubject: Subject<boolean> = new Subject<boolean>();\n\n  // Looks like this works to avoid circular dependencies on DIes (currentUserService ends up requiring angular's\n  // http client, which requires HTTP_INTERCEPTORS).\n  protected get currentUserService(): CurrentUserServiceInterface<AbstractUser> {\n    this._currentUserService ??= this.injector.get<CurrentUserServiceInterface<AbstractUser>>(CURRENT_USER_SERVICE);\n    return this._currentUserService;\n  }\n\n  private _currentUserService: CurrentUserServiceInterface<AbstractUser>;\n\n  constructor(\n    protected injector: Injector,\n    protected errorEventsService: ErrorEventsService,\n    protected headersService: HeadersService,\n  ) {\n  }\n\n  public intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n    return next.handle(request).pipe(\n      catchError((error, caughtObservable: Observable<any>) => {\n        // If error is not HttpErrorResponse, don't do anything\n        if (!(error instanceof HttpErrorResponse)) {\n          return throwError(error);\n        }\n        if (request.params instanceof InterceptorHttpParams && request.params.interceptorConfig.errorPassthrough) {\n          return throwError(error);\n        }\n\n        const uuid: string = (error as { error: { uuid?: string } }).error?.uuid;\n        const alert = () => this.errorEventsService.message$.next({message, error});\n\n        let message = (error as { error: { message?: string } }).error?.message\n          ?? error.message\n          ?? error.toString();\n        switch (true) {\n          // Token expired\n          case uuid === ExceptionUUIDs.TokenExpired:\n            // Refresh token, and when this is done, update request with new token and send it again\n            return this.refreshUserToken().pipe(\n              switchMap((refreshWorked: boolean) => {\n                if (refreshWorked) {\n                  return next.handle(\n                    this.headersService.clonedRequestsWithProperHeaders(request),\n                  );\n                }\n                return this.currentUserService.logout();\n              }),\n            );\n          // Token is invalid for some reason (other than expired):\n          //    - One example is {code: 401, message: 'Refresh token \"<...>\" does not exist.'}\n          //    - Other scenarios?\n          case error.status === 401:\n            alert();\n            return this.currentUserService.logout();\n          // Forbidden: user token might be alright but user cannot view page, or no token provided but it was required\n          // case error.status === 403:\n          //   // FIXME: handle other scenarios\n          //   return throwError(error);\n          default:\n            alert();\n            return throwError(error);\n        }\n      }),\n    ) as Observable<HttpEvent<any>>;\n  }\n\n  // Observable that resolves when we have refreshed our token,\n  // but only one API call is made if this is called several times before we get a response.\n  protected refreshUserToken(): Subject<boolean> {\n    // FIXME: Subject.observers will be made internal in rxjs v8, find an alternative\n    // Only do something if this is the first time refreshUserToken is called since refreshSubject last completed.\n    if (this.refreshSubject.observers.length === 0) {\n      this.refreshSubject.subscribe({\n        complete: () => this.refreshSubject = new Subject<boolean>(),\n      });\n      this.currentUserService.refreshUserToken().subscribe(this.refreshSubject);\n    }\n    return this.refreshSubject;\n  }\n\n  protected isExpiredTokenError(error: HttpErrorResponse): boolean {\n    return error.status === 401\n      && (error as { error: { message?: string } })?.error.message === 'Expired JWT Token';\n  }\n}\n"]} |
import { Injectable } from '@angular/core'; | ||
import { HeadersService } from './headers.service'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "./headers.service"; | ||
export class HeadersInterceptor { | ||
@@ -13,7 +11,8 @@ constructor(headersService) { | ||
} | ||
/** @nocollapse */ HeadersInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor, deps: [{ token: i1.HeadersService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ HeadersInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: i1.HeadersService }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVycy5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZvcmxhYnMvYXBpLWJyaWRnZS9zcmMvbGliL2ludGVyY2VwdG9yL2hlYWRlcnMuaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7OztBQUlqRCxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLFlBQXNCLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtJQUFHLENBQUM7SUFFakQsU0FBUyxDQUFDLE9BQXlCLEVBQUUsSUFBaUI7UUFDM0QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsK0JBQStCLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQztJQUNuRixDQUFDOztrSUFMVSxrQkFBa0I7c0lBQWxCLGtCQUFrQjsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtIdHRwRXZlbnQsIEh0dHBIYW5kbGVyLCBIdHRwSW50ZXJjZXB0b3IsIEh0dHBSZXF1ZXN0fSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQge0luamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7SGVhZGVyc1NlcnZpY2V9IGZyb20gJy4vaGVhZGVycy5zZXJ2aWNlJztcblxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgSGVhZGVyc0ludGVyY2VwdG9yIGltcGxlbWVudHMgSHR0cEludGVyY2VwdG9yIHtcbiAgY29uc3RydWN0b3IocHJvdGVjdGVkIGhlYWRlcnNTZXJ2aWNlOiBIZWFkZXJzU2VydmljZSkge31cblxuICBwdWJsaWMgaW50ZXJjZXB0KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8YW55Pj4ge1xuICAgIHJldHVybiBuZXh0LmhhbmRsZSh0aGlzLmhlYWRlcnNTZXJ2aWNlLmNsb25lZFJlcXVlc3RzV2l0aFByb3BlckhlYWRlcnMocmVxdWVzdCkpO1xuICB9XG59XG4iXX0= | ||
HeadersInterceptor.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
HeadersInterceptor.ctorParameters = () => [ | ||
{ type: HeadersService } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVycy5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ZvcmxhYnMvYXBpLWJyaWRnZS9zcmMvbGliL2ludGVyY2VwdG9yL2hlYWRlcnMuaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFDLFVBQVUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sbUJBQW1CLENBQUM7QUFJakQsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUFzQixjQUE4QjtRQUE5QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7SUFBRyxDQUFDO0lBRWpELFNBQVMsQ0FBQyxPQUF5QixFQUFFLElBQWlCO1FBQzNELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLCtCQUErQixDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDbkYsQ0FBQzs7O1lBTkYsVUFBVTs7O1lBSEgsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SHR0cEV2ZW50LCBIdHRwSGFuZGxlciwgSHR0cEludGVyY2VwdG9yLCBIdHRwUmVxdWVzdH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge0hlYWRlcnNTZXJ2aWNlfSBmcm9tICcuL2hlYWRlcnMuc2VydmljZSc7XG5cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIEhlYWRlcnNJbnRlcmNlcHRvciBpbXBsZW1lbnRzIEh0dHBJbnRlcmNlcHRvciB7XG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBoZWFkZXJzU2VydmljZTogSGVhZGVyc1NlcnZpY2UpIHt9XG5cbiAgcHVibGljIGludGVyY2VwdChyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcbiAgICByZXR1cm4gbmV4dC5oYW5kbGUodGhpcy5oZWFkZXJzU2VydmljZS5jbG9uZWRSZXF1ZXN0c1dpdGhQcm9wZXJIZWFkZXJzKHJlcXVlc3QpKTtcbiAgfVxufVxuIl19 |
import { Injectable } from '@angular/core'; | ||
import { TokenService } from '../current-user/token.service'; | ||
import { InterceptorHttpParams } from '../api-client/abstract.api.client'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "../current-user/token.service"; | ||
export class HeadersService { | ||
@@ -27,7 +25,8 @@ constructor(tokenService) { | ||
} | ||
/** @nocollapse */ HeadersService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService, deps: [{ token: i1.TokenService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ HeadersService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: i1.TokenService }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVycy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybGFicy9hcGktYnJpZGdlL3NyYy9saWIvaW50ZXJjZXB0b3IvaGVhZGVycy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzNELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLG1DQUFtQyxDQUFDOzs7QUFJeEUsTUFBTSxPQUFPLGNBQWM7SUFDekIsWUFBc0IsWUFBMEI7UUFBMUIsaUJBQVksR0FBWixZQUFZLENBQWM7SUFDaEQsQ0FBQztJQUVNLCtCQUErQixDQUFJLE9BQXVCO1FBQy9ELElBQUksVUFBVSxHQUFnQixPQUFPLENBQUMsT0FBTyxDQUFDO1FBRTlDLE1BQU0saUJBQWlCLEdBQUcsT0FBTyxDQUFDLE1BQU0sWUFBWSxxQkFBcUI7WUFDdkUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsaUJBQWlCO1lBQ2xDLENBQUMsQ0FBQyxFQUFFLENBQ0w7UUFFRCxJQUFJLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLEVBQUU7WUFDcEMsSUFBSSxDQUFDLGlEQUFpRCxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUU7Z0JBQ3hFLFVBQVUsR0FBRyxVQUFVLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxVQUFVLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2FBQzVGO1NBQ0Y7UUFDRCxJQUFJLE9BQU8sQ0FBQyxNQUFNLEtBQUssU0FBUyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxDQUFBLGlCQUFpQixhQUFqQixpQkFBaUIsdUJBQWpCLGlCQUFpQixDQUFFLHdCQUF3QixDQUFBLEVBQUU7WUFDeEgsVUFBVSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsY0FBYyxFQUFFLGtCQUFrQixDQUFDLENBQUM7U0FDakU7UUFDRCxVQUFVLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsa0JBQWtCLENBQUMsQ0FBQztRQUUxRCxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBQyxPQUFPLEVBQUUsVUFBVSxFQUFDLENBQUMsQ0FBQztJQUM5QyxDQUFDOzs4SEF2QlUsY0FBYztrSUFBZCxjQUFjOzJGQUFkLGNBQWM7a0JBRDFCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0h0dHBIZWFkZXJzLCBIdHRwUmVxdWVzdH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VG9rZW5TZXJ2aWNlfSBmcm9tICcuLi9jdXJyZW50LXVzZXIvdG9rZW4uc2VydmljZSc7XG5pbXBvcnQge0ludGVyY2VwdG9ySHR0cFBhcmFtc30gZnJvbSAnLi4vYXBpLWNsaWVudC9hYnN0cmFjdC5hcGkuY2xpZW50JztcblxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgSGVhZGVyc1NlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgdG9rZW5TZXJ2aWNlOiBUb2tlblNlcnZpY2UpIHtcbiAgfVxuXG4gIHB1YmxpYyBjbG9uZWRSZXF1ZXN0c1dpdGhQcm9wZXJIZWFkZXJzPFQ+KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PFQ+KTogSHR0cFJlcXVlc3Q8VD4ge1xuICAgIGxldCBuZXdIZWFkZXJzOiBIdHRwSGVhZGVycyA9IHJlcXVlc3QuaGVhZGVycztcblxuICAgIGNvbnN0IGludGVyY2VwdG9yQ29uZmlnID0gcmVxdWVzdC5wYXJhbXMgaW5zdGFuY2VvZiBJbnRlcmNlcHRvckh0dHBQYXJhbXNcbiAgICAgID8gcmVxdWVzdC5wYXJhbXMuaW50ZXJjZXB0b3JDb25maWdcbiAgICAgIDoge31cbiAgICA7XG5cbiAgICBpZiAodGhpcy50b2tlblNlcnZpY2UuaGFzVXNlclRva2VuKCkpIHtcbiAgICAgIGlmICghL1xcL1xcL1teL10rXFwvYXBpXFwvKGF1dGhlbnRpY2F0aW9ufHJlZnJlc2gpX3Rva2VuJC8uZXhlYyhyZXF1ZXN0LnVybCkpIHtcbiAgICAgICAgbmV3SGVhZGVycyA9IG5ld0hlYWRlcnMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3RoaXMudG9rZW5TZXJ2aWNlLmdldFVzZXJUb2tlbigpfWApO1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAocmVxdWVzdC5tZXRob2QgIT09ICdPUFRJT05TJyAmJiAhcmVxdWVzdC5oZWFkZXJzLmhhcygnQ29udGVudC1UeXBlJykgJiYgIWludGVyY2VwdG9yQ29uZmlnPy5kb250U2V0Q29udGVudFR5cGVIZWFkZXIpIHtcbiAgICAgIG5ld0hlYWRlcnMgPSBuZXdIZWFkZXJzLnNldCgnQ29udGVudC1UeXBlJywgJ2FwcGxpY2F0aW9uL2pzb24nKTtcbiAgICB9XG4gICAgbmV3SGVhZGVycyA9IG5ld0hlYWRlcnMuc2V0KCdBY2NlcHQnLCAnYXBwbGljYXRpb24vanNvbicpO1xuXG4gICAgcmV0dXJuIHJlcXVlc3QuY2xvbmUoe2hlYWRlcnM6IG5ld0hlYWRlcnN9KTtcbiAgfVxufVxuIl19 | ||
HeadersService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
HeadersService.ctorParameters = () => [ | ||
{ type: TokenService } | ||
]; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVycy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybGFicy9hcGktYnJpZGdlL3NyYy9saWIvaW50ZXJjZXB0b3IvaGVhZGVycy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLCtCQUErQixDQUFDO0FBQzNELE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLG1DQUFtQyxDQUFDO0FBSXhFLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLFlBQXNCLFlBQTBCO1FBQTFCLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQ2hELENBQUM7SUFFTSwrQkFBK0IsQ0FBSSxPQUF1QjtRQUMvRCxJQUFJLFVBQVUsR0FBZ0IsT0FBTyxDQUFDLE9BQU8sQ0FBQztRQUU5QyxNQUFNLGlCQUFpQixHQUFHLE9BQU8sQ0FBQyxNQUFNLFlBQVkscUJBQXFCO1lBQ3ZFLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLGlCQUFpQjtZQUNsQyxDQUFDLENBQUMsRUFBRSxDQUNMO1FBRUQsSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxFQUFFO1lBQ3BDLElBQUksQ0FBQyxpREFBaUQsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFO2dCQUN4RSxVQUFVLEdBQUcsVUFBVSxDQUFDLEdBQUcsQ0FBQyxlQUFlLEVBQUUsVUFBVSxJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxFQUFFLENBQUMsQ0FBQzthQUM1RjtTQUNGO1FBQ0QsSUFBSSxPQUFPLENBQUMsTUFBTSxLQUFLLFNBQVMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQSxpQkFBaUIsYUFBakIsaUJBQWlCLHVCQUFqQixpQkFBaUIsQ0FBRSx3QkFBd0IsQ0FBQSxFQUFFO1lBQ3hILFVBQVUsR0FBRyxVQUFVLENBQUMsR0FBRyxDQUFDLGNBQWMsRUFBRSxrQkFBa0IsQ0FBQyxDQUFDO1NBQ2pFO1FBQ0QsVUFBVSxHQUFHLFVBQVUsQ0FBQyxHQUFHLENBQUMsUUFBUSxFQUFFLGtCQUFrQixDQUFDLENBQUM7UUFFMUQsT0FBTyxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUMsT0FBTyxFQUFFLFVBQVUsRUFBQyxDQUFDLENBQUM7SUFDOUMsQ0FBQzs7O1lBeEJGLFVBQVU7OztZQUpILFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0h0dHBIZWFkZXJzLCBIdHRwUmVxdWVzdH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHtJbmplY3RhYmxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VG9rZW5TZXJ2aWNlfSBmcm9tICcuLi9jdXJyZW50LXVzZXIvdG9rZW4uc2VydmljZSc7XG5pbXBvcnQge0ludGVyY2VwdG9ySHR0cFBhcmFtc30gZnJvbSAnLi4vYXBpLWNsaWVudC9hYnN0cmFjdC5hcGkuY2xpZW50JztcblxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgSGVhZGVyc1NlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcm90ZWN0ZWQgdG9rZW5TZXJ2aWNlOiBUb2tlblNlcnZpY2UpIHtcbiAgfVxuXG4gIHB1YmxpYyBjbG9uZWRSZXF1ZXN0c1dpdGhQcm9wZXJIZWFkZXJzPFQ+KHJlcXVlc3Q6IEh0dHBSZXF1ZXN0PFQ+KTogSHR0cFJlcXVlc3Q8VD4ge1xuICAgIGxldCBuZXdIZWFkZXJzOiBIdHRwSGVhZGVycyA9IHJlcXVlc3QuaGVhZGVycztcblxuICAgIGNvbnN0IGludGVyY2VwdG9yQ29uZmlnID0gcmVxdWVzdC5wYXJhbXMgaW5zdGFuY2VvZiBJbnRlcmNlcHRvckh0dHBQYXJhbXNcbiAgICAgID8gcmVxdWVzdC5wYXJhbXMuaW50ZXJjZXB0b3JDb25maWdcbiAgICAgIDoge31cbiAgICA7XG5cbiAgICBpZiAodGhpcy50b2tlblNlcnZpY2UuaGFzVXNlclRva2VuKCkpIHtcbiAgICAgIGlmICghL1xcL1xcL1teL10rXFwvYXBpXFwvKGF1dGhlbnRpY2F0aW9ufHJlZnJlc2gpX3Rva2VuJC8uZXhlYyhyZXF1ZXN0LnVybCkpIHtcbiAgICAgICAgbmV3SGVhZGVycyA9IG5ld0hlYWRlcnMuc2V0KCdBdXRob3JpemF0aW9uJywgYEJlYXJlciAke3RoaXMudG9rZW5TZXJ2aWNlLmdldFVzZXJUb2tlbigpfWApO1xuICAgICAgfVxuICAgIH1cbiAgICBpZiAocmVxdWVzdC5tZXRob2QgIT09ICdPUFRJT05TJyAmJiAhcmVxdWVzdC5oZWFkZXJzLmhhcygnQ29udGVudC1UeXBlJykgJiYgIWludGVyY2VwdG9yQ29uZmlnPy5kb250U2V0Q29udGVudFR5cGVIZWFkZXIpIHtcbiAgICAgIG5ld0hlYWRlcnMgPSBuZXdIZWFkZXJzLnNldCgnQ29udGVudC1UeXBlJywgJ2FwcGxpY2F0aW9uL2pzb24nKTtcbiAgICB9XG4gICAgbmV3SGVhZGVycyA9IG5ld0hlYWRlcnMuc2V0KCdBY2NlcHQnLCAnYXBwbGljYXRpb24vanNvbicpO1xuXG4gICAgcmV0dXJuIHJlcXVlc3QuY2xvbmUoe2hlYWRlcnM6IG5ld0hlYWRlcnN9KTtcbiAgfVxufVxuIl19 |
@@ -8,4 +8,3 @@ import { Entity, EntityBuilder } from '@decahedron/entity'; | ||
import { HttpParams, HttpHeaders, HttpErrorResponse } from '@angular/common/http'; | ||
import * as i0 from '@angular/core'; | ||
import { InjectionToken, Injectable, NgModule } from '@angular/core'; | ||
import { InjectionToken, Injectable, Injector, NgModule } from '@angular/core'; | ||
import { CommonModule } from '@angular/common'; | ||
@@ -21,2 +20,3 @@ | ||
const parseDate = (str) => str !== null ? new Date(str) : null; | ||
const ɵ0 = parseDate; | ||
const objectToUri = (entityClass) => (unNormalized) => { | ||
@@ -28,2 +28,3 @@ if (typeof unNormalized === 'string') { | ||
}; | ||
const ɵ1 = objectToUri; | ||
const NORMALIZERS = { | ||
@@ -530,5 +531,5 @@ parseDate, | ||
} | ||
login(username, password) { | ||
login(username, password, errorPassthrough = false) { | ||
const data = { username, password }; | ||
return this.apiClient.post(this.apiLoginUrl, data, { errorPassthrough: false }).pipe(concatMap(({ token, refresh_token }) => { | ||
return this.apiClient.post(this.apiLoginUrl, data, { errorPassthrough }).pipe(concatMap(({ token, refresh_token }) => { | ||
this.tokenService.setUserTokens(token, refresh_token); | ||
@@ -614,7 +615,6 @@ return this.loadCurrentUser(true).pipe(filter(user => user !== null), first()); | ||
} | ||
/** @nocollapse */ TokenService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ TokenService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: TokenService, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return []; } }); | ||
TokenService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
TokenService.ctorParameters = () => []; | ||
@@ -626,7 +626,5 @@ class ErrorEventsService { | ||
} | ||
/** @nocollapse */ ErrorEventsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ ErrorEventsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorEventsService, decorators: [{ | ||
type: Injectable | ||
}] }); | ||
ErrorEventsService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
@@ -654,7 +652,8 @@ class HeadersService { | ||
} | ||
/** @nocollapse */ HeadersService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService, deps: [{ token: TokenService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ HeadersService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersService, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: TokenService }]; } }); | ||
HeadersService.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
HeadersService.ctorParameters = () => [ | ||
{ type: TokenService } | ||
]; | ||
@@ -736,7 +735,10 @@ const ExceptionUUIDs = { | ||
} | ||
/** @nocollapse */ ErrorInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor, deps: [{ token: i0.Injector }, { token: ErrorEventsService }, { token: HeadersService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ ErrorInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ErrorInterceptor, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: ErrorEventsService }, { type: HeadersService }]; } }); | ||
ErrorInterceptor.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
ErrorInterceptor.ctorParameters = () => [ | ||
{ type: Injector }, | ||
{ type: ErrorEventsService }, | ||
{ type: HeadersService } | ||
]; | ||
@@ -751,34 +753,25 @@ class HeadersInterceptor { | ||
} | ||
/** @nocollapse */ HeadersInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor, deps: [{ token: HeadersService }], target: i0.ɵɵFactoryTarget.Injectable }); | ||
/** @nocollapse */ HeadersInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: HeadersInterceptor, decorators: [{ | ||
type: Injectable | ||
}], ctorParameters: function () { return [{ type: HeadersService }]; } }); | ||
HeadersInterceptor.decorators = [ | ||
{ type: Injectable } | ||
]; | ||
HeadersInterceptor.ctorParameters = () => [ | ||
{ type: HeadersService } | ||
]; | ||
class ApiBridgeModule { | ||
} | ||
/** @nocollapse */ ApiBridgeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); | ||
/** @nocollapse */ ApiBridgeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, imports: [CommonModule] }); | ||
/** @nocollapse */ ApiBridgeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
], imports: [[ | ||
CommonModule, | ||
]] }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.0", ngImport: i0, type: ApiBridgeModule, decorators: [{ | ||
type: NgModule, | ||
args: [{ | ||
imports: [ | ||
CommonModule, | ||
], | ||
exports: [], | ||
declarations: [], | ||
providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
] | ||
}] | ||
}] }); | ||
ApiBridgeModule.decorators = [ | ||
{ type: NgModule, args: [{ | ||
imports: [ | ||
CommonModule, | ||
], | ||
exports: [], | ||
declarations: [], | ||
providers: [ | ||
TokenService, | ||
ErrorEventsService, | ||
HeadersService, | ||
] | ||
},] } | ||
]; | ||
@@ -789,3 +782,3 @@ /** | ||
export { API_CLIENT, AbstractApiClient, AbstractCurrentUserService, AbstractDataService, AbstractEntity, AbstractEntitydataService, AbstractUser, ApiBridgeModule, CACHE_STATUS_BEING_REFRESHED, CACHE_STATUS_FRESH, CACHE_STATUS_OLD, CURRENT_USER_SERVICE, CacheExpirationTracker, ErrorEventsService, ErrorInterceptor, HeadersInterceptor, HeadersService, InterceptorHttpParams, LOAD_TYPE_COLLECTION, LOAD_TYPE_FULL, LOAD_TYPE_UNSPECIFIED, NORMALIZERS, Normalizer, NormalizerMetadata, NormalizerMetadataStorage, TokenService, defaultNormalizerMetadataStorage }; | ||
export { API_CLIENT, AbstractApiClient, AbstractCurrentUserService, AbstractDataService, AbstractEntity, AbstractEntitydataService, AbstractUser, ApiBridgeModule, CACHE_STATUS_BEING_REFRESHED, CACHE_STATUS_FRESH, CACHE_STATUS_OLD, CURRENT_USER_SERVICE, CacheExpirationTracker, ErrorEventsService, ErrorInterceptor, HeadersInterceptor, HeadersService, InterceptorHttpParams, LOAD_TYPE_COLLECTION, LOAD_TYPE_FULL, LOAD_TYPE_UNSPECIFIED, NORMALIZERS, Normalizer, NormalizerMetadata, NormalizerMetadataStorage, TokenService, defaultNormalizerMetadataStorage, ɵ0, ɵ1 }; | ||
//# sourceMappingURL=forlabs-api-bridge.js.map |
/** | ||
* Generated bundle index. Do not edit. | ||
*/ | ||
/// <amd-module name="@forlabs/api-bridge" /> | ||
export * from './public-api'; |
@@ -1,7 +0,2 @@ | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "@angular/common"; | ||
export declare class ApiBridgeModule { | ||
static ɵfac: i0.ɵɵFactoryDeclaration<ApiBridgeModule, never>; | ||
static ɵmod: i0.ɵɵNgModuleDeclaration<ApiBridgeModule, never, [typeof i1.CommonModule], never>; | ||
static ɵinj: i0.ɵɵInjectorDeclaration<ApiBridgeModule>; | ||
} |
@@ -33,3 +33,3 @@ import { BehaviorSubject, Observable } from 'rxjs'; | ||
}): Observable<any>; | ||
login(username: string, password: string): Observable<GenericUser>; | ||
login(username: string, password: string, errorPassthrough?: boolean): Observable<GenericUser>; | ||
logout(): Observable<void>; | ||
@@ -36,0 +36,0 @@ patch(guest: GenericUser, patchedFields?: string[]): void; |
@@ -1,2 +0,1 @@ | ||
import * as i0 from "@angular/core"; | ||
export declare class TokenService { | ||
@@ -11,4 +10,2 @@ protected userToken: string | null; | ||
removeUserTokens(): void; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<TokenService, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<TokenService>; | ||
} |
import { Subject } from 'rxjs'; | ||
import * as i0 from "@angular/core"; | ||
export declare class ErrorEventsService { | ||
message$: Subject<unknown>; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<ErrorEventsService, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<ErrorEventsService>; | ||
} |
@@ -8,3 +8,2 @@ import { HttpErrorResponse, HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http'; | ||
import { HeadersService } from './headers.service'; | ||
import * as i0 from "@angular/core"; | ||
export declare class ErrorInterceptor implements HttpInterceptor { | ||
@@ -21,4 +20,2 @@ protected injector: Injector; | ||
protected isExpiredTokenError(error: HttpErrorResponse): boolean; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<ErrorInterceptor, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<ErrorInterceptor>; | ||
} |
import { HttpEvent, HttpHandler, HttpInterceptor, HttpRequest } from '@angular/common/http'; | ||
import { Observable } from 'rxjs'; | ||
import { HeadersService } from './headers.service'; | ||
import * as i0 from "@angular/core"; | ||
export declare class HeadersInterceptor implements HttpInterceptor { | ||
@@ -9,4 +8,2 @@ protected headersService: HeadersService; | ||
intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>>; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<HeadersInterceptor, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<HeadersInterceptor>; | ||
} |
import { HttpRequest } from '@angular/common/http'; | ||
import { TokenService } from '../current-user/token.service'; | ||
import * as i0 from "@angular/core"; | ||
export declare class HeadersService { | ||
@@ -8,4 +7,2 @@ protected tokenService: TokenService; | ||
clonedRequestsWithProperHeaders<T>(request: HttpRequest<T>): HttpRequest<T>; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<HeadersService, never>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<HeadersService>; | ||
} |
{ | ||
"name": "@forlabs/api-bridge", | ||
"version": "0.0.10", | ||
"version": "0.0.11", | ||
"license": "MIT", | ||
@@ -18,2 +18,3 @@ "peerDependencies": { | ||
"typings": "forlabs-api-bridge.d.ts", | ||
"metadata": "forlabs-api-bridge.metadata.json", | ||
"sideEffects": false, | ||
@@ -20,0 +21,0 @@ "dependencies": { |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
0
415135
37
3053