@nakedcreativity/membrs-angular-helper 0.1.4 → 0.1.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/auth.interceptor.mjs +66 -0
- package/esm2022/lib/membrs.module.mjs +155 -0
- package/esm2022/lib/membrs.service.mjs +128 -0
- package/{fesm2020 → fesm2022}/nakedcreativity-membrs-angular-helper.mjs +129 -57
- package/fesm2022/nakedcreativity-membrs-angular-helper.mjs.map +1 -0
- package/lib/auth.interceptor.d.ts +9 -3
- package/lib/membrs.service.d.ts +3 -0
- package/package.json +8 -14
- package/esm2020/lib/auth.interceptor.mjs +0 -25
- package/esm2020/lib/membrs.module.mjs +0 -150
- package/esm2020/lib/membrs.service.mjs +0 -101
- package/fesm2015/nakedcreativity-membrs-angular-helper.mjs +0 -299
- package/fesm2015/nakedcreativity-membrs-angular-helper.mjs.map +0 -1
- package/fesm2020/nakedcreativity-membrs-angular-helper.mjs.map +0 -1
- /package/{esm2020 → esm2022}/lib/config.interface.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/config.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/router.config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/token.mjs +0 -0
- /package/{esm2020 → esm2022}/nakedcreativity-membrs-angular-helper.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { from, throwError } from "rxjs";
|
|
3
|
+
import { switchMap, catchError, finalize, tap } from "rxjs/operators";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@auth0/angular-jwt";
|
|
6
|
+
import * as i2 from "./membrs.service";
|
|
7
|
+
import * as i3 from "@uirouter/angular";
|
|
8
|
+
export class TokenInterceptor {
|
|
9
|
+
jwtHelper;
|
|
10
|
+
membrsService;
|
|
11
|
+
stateService;
|
|
12
|
+
constructor(jwtHelper, membrsService, stateService) {
|
|
13
|
+
this.jwtHelper = jwtHelper;
|
|
14
|
+
this.membrsService = membrsService;
|
|
15
|
+
this.stateService = stateService;
|
|
16
|
+
}
|
|
17
|
+
intercept(request, next) {
|
|
18
|
+
const token = localStorage.getItem("membrs");
|
|
19
|
+
if (token && this.jwtHelper.isTokenExpired(token)) {
|
|
20
|
+
console.log("Token expired. Attempting to reissue.");
|
|
21
|
+
return from(this.membrsService.reissue()).pipe(switchMap(() => {
|
|
22
|
+
const refreshedToken = localStorage.getItem("membrs");
|
|
23
|
+
if (refreshedToken && !this.jwtHelper.isTokenExpired(refreshedToken)) {
|
|
24
|
+
console.log("Token successfully reissued.");
|
|
25
|
+
request = request.clone({
|
|
26
|
+
setHeaders: {
|
|
27
|
+
Authorization: refreshedToken,
|
|
28
|
+
},
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return next.handle(request);
|
|
32
|
+
}), catchError((err) => {
|
|
33
|
+
console.warn("Token refresh failed. Logging out.");
|
|
34
|
+
this.membrsService.logout();
|
|
35
|
+
this.stateService.go("");
|
|
36
|
+
return throwError(() => err);
|
|
37
|
+
}), finalize(() => {
|
|
38
|
+
// this.busyService.finished()
|
|
39
|
+
}));
|
|
40
|
+
}
|
|
41
|
+
if (token && !this.jwtHelper.isTokenExpired(token)) {
|
|
42
|
+
request = request.clone({
|
|
43
|
+
setHeaders: {
|
|
44
|
+
Authorization: token,
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
return next.handle(request).pipe(tap((event) => {
|
|
49
|
+
// If this is an HttpResponse, check for x-new-token header
|
|
50
|
+
if (event && event.type === 4 && event.headers) {
|
|
51
|
+
const newToken = event.headers.get('x-new-token');
|
|
52
|
+
if (newToken) {
|
|
53
|
+
localStorage.setItem('membrs', newToken);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}), finalize(() => {
|
|
57
|
+
// this.busyService.finished()
|
|
58
|
+
}));
|
|
59
|
+
}
|
|
60
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TokenInterceptor, deps: [{ token: i1.JwtHelperService }, { token: i2.MembrsService }, { token: i3.StateService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
61
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TokenInterceptor });
|
|
62
|
+
}
|
|
63
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TokenInterceptor, decorators: [{
|
|
64
|
+
type: Injectable
|
|
65
|
+
}], ctorParameters: () => [{ type: i1.JwtHelperService }, { type: i2.MembrsService }, { type: i3.StateService }] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5pbnRlcmNlcHRvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21lbWJycy9zcmMvbGliL2F1dGguaW50ZXJjZXB0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQWMsSUFBSSxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNwRCxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBS3RFLE1BQU0sT0FBTyxnQkFBZ0I7SUFDUDtJQUFxQztJQUFzQztJQUEvRixZQUFvQixTQUEyQixFQUFVLGFBQTRCLEVBQVUsWUFBMEI7UUFBckcsY0FBUyxHQUFULFNBQVMsQ0FBa0I7UUFBVSxrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUFVLGlCQUFZLEdBQVosWUFBWSxDQUFjO0lBQUcsQ0FBQztJQUU3SCxTQUFTLENBQUMsT0FBeUIsRUFBRSxJQUFpQjtRQUNwRCxNQUFNLEtBQUssR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTdDLElBQUksS0FBSyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ2pELE9BQU8sQ0FBQyxHQUFHLENBQUMsdUNBQXVDLENBQUMsQ0FBQztZQUNyRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsSUFBSSxDQUM1QyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUNiLE1BQU0sY0FBYyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ3RELElBQUksY0FBYyxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsY0FBYyxDQUFDLEVBQUU7b0JBQ3BFLE9BQU8sQ0FBQyxHQUFHLENBQUMsOEJBQThCLENBQUMsQ0FBQztvQkFDNUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7d0JBQ3RCLFVBQVUsRUFBRTs0QkFDVixhQUFhLEVBQUUsY0FBYzt5QkFDOUI7cUJBQ0YsQ0FBQyxDQUFDO2lCQUNKO2dCQUNELE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUM5QixDQUFDLENBQUMsRUFDRixVQUFVLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxvQ0FBb0MsQ0FBQyxDQUFDO2dCQUNuRCxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sRUFBRSxDQUFDO2dCQUM1QixJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDekIsT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDL0IsQ0FBQyxDQUFDLEVBQ0YsUUFBUSxDQUFDLEdBQUcsRUFBRTtnQkFDWiw4QkFBOEI7WUFDaEMsQ0FBQyxDQUFDLENBQ0gsQ0FBQztTQUNIO1FBRUQsSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNsRCxPQUFPLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQztnQkFDdEIsVUFBVSxFQUFFO29CQUNWLGFBQWEsRUFBRSxLQUFLO2lCQUNyQjthQUNGLENBQUMsQ0FBQztTQUNKO1FBRUQsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FDOUIsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDWiwyREFBMkQ7WUFDM0QsSUFBSSxLQUFLLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLE9BQU8sRUFBRTtnQkFDOUMsTUFBTSxRQUFRLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLENBQUM7Z0JBQ2xELElBQUksUUFBUSxFQUFFO29CQUNaLFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO2lCQUMxQzthQUNGO1FBQ0gsQ0FBQyxDQUFDLEVBQ0YsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNaLDhCQUE4QjtRQUNoQyxDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQzt3R0F2RFUsZ0JBQWdCOzRHQUFoQixnQkFBZ0I7OzRGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBKd3RIZWxwZXJTZXJ2aWNlIH0gZnJvbSBcIkBhdXRoMC9hbmd1bGFyLWp3dFwiO1xuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBIdHRwUmVxdWVzdCwgSHR0cEhhbmRsZXIsIEh0dHBFdmVudCwgSHR0cEludGVyY2VwdG9yIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vbi9odHRwXCI7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBmcm9tLCB0aHJvd0Vycm9yIH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IHN3aXRjaE1hcCwgY2F0Y2hFcnJvciwgZmluYWxpemUsIHRhcCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuaW1wb3J0IHsgTWVtYnJzU2VydmljZSB9IGZyb20gXCIuL21lbWJycy5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBTdGF0ZVNlcnZpY2UgfSBmcm9tIFwiQHVpcm91dGVyL2FuZ3VsYXJcIjtcblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIFRva2VuSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGp3dEhlbHBlcjogSnd0SGVscGVyU2VydmljZSwgcHJpdmF0ZSBtZW1icnNTZXJ2aWNlOiBNZW1icnNTZXJ2aWNlLCBwcml2YXRlIHN0YXRlU2VydmljZTogU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIGludGVyY2VwdChyZXF1ZXN0OiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcik6IE9ic2VydmFibGU8SHR0cEV2ZW50PGFueT4+IHtcbiAgICBjb25zdCB0b2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKFwibWVtYnJzXCIpO1xuXG4gICAgaWYgKHRva2VuICYmIHRoaXMuand0SGVscGVyLmlzVG9rZW5FeHBpcmVkKHRva2VuKSkge1xuICAgICAgY29uc29sZS5sb2coXCJUb2tlbiBleHBpcmVkLiBBdHRlbXB0aW5nIHRvIHJlaXNzdWUuXCIpO1xuICAgICAgcmV0dXJuIGZyb20odGhpcy5tZW1icnNTZXJ2aWNlLnJlaXNzdWUoKSkucGlwZShcbiAgICAgICAgc3dpdGNoTWFwKCgpID0+IHtcbiAgICAgICAgICBjb25zdCByZWZyZXNoZWRUb2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKFwibWVtYnJzXCIpO1xuICAgICAgICAgIGlmIChyZWZyZXNoZWRUb2tlbiAmJiAhdGhpcy5qd3RIZWxwZXIuaXNUb2tlbkV4cGlyZWQocmVmcmVzaGVkVG9rZW4pKSB7XG4gICAgICAgICAgICBjb25zb2xlLmxvZyhcIlRva2VuIHN1Y2Nlc3NmdWxseSByZWlzc3VlZC5cIik7XG4gICAgICAgICAgICByZXF1ZXN0ID0gcmVxdWVzdC5jbG9uZSh7XG4gICAgICAgICAgICAgIHNldEhlYWRlcnM6IHtcbiAgICAgICAgICAgICAgICBBdXRob3JpemF0aW9uOiByZWZyZXNoZWRUb2tlbixcbiAgICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIH0pO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdCk7XG4gICAgICAgIH0pLFxuICAgICAgICBjYXRjaEVycm9yKChlcnIpID0+IHtcbiAgICAgICAgICBjb25zb2xlLndhcm4oXCJUb2tlbiByZWZyZXNoIGZhaWxlZC4gTG9nZ2luZyBvdXQuXCIpO1xuICAgICAgICAgIHRoaXMubWVtYnJzU2VydmljZS5sb2dvdXQoKTtcbiAgICAgICAgICB0aGlzLnN0YXRlU2VydmljZS5nbyhcIlwiKTtcbiAgICAgICAgICByZXR1cm4gdGhyb3dFcnJvcigoKSA9PiBlcnIpO1xuICAgICAgICB9KSxcbiAgICAgICAgZmluYWxpemUoKCkgPT4ge1xuICAgICAgICAgIC8vIHRoaXMuYnVzeVNlcnZpY2UuZmluaXNoZWQoKVxuICAgICAgICB9KVxuICAgICAgKTtcbiAgICB9XG5cbiAgICBpZiAodG9rZW4gJiYgIXRoaXMuand0SGVscGVyLmlzVG9rZW5FeHBpcmVkKHRva2VuKSkge1xuICAgICAgcmVxdWVzdCA9IHJlcXVlc3QuY2xvbmUoe1xuICAgICAgICBzZXRIZWFkZXJzOiB7XG4gICAgICAgICAgQXV0aG9yaXphdGlvbjogdG9rZW4sXG4gICAgICAgIH0sXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdCkucGlwZShcbiAgICAgIHRhcCgoZXZlbnQpID0+IHtcbiAgICAgICAgLy8gSWYgdGhpcyBpcyBhbiBIdHRwUmVzcG9uc2UsIGNoZWNrIGZvciB4LW5ldy10b2tlbiBoZWFkZXJcbiAgICAgICAgaWYgKGV2ZW50ICYmIGV2ZW50LnR5cGUgPT09IDQgJiYgZXZlbnQuaGVhZGVycykge1xuICAgICAgICAgIGNvbnN0IG5ld1Rva2VuID0gZXZlbnQuaGVhZGVycy5nZXQoJ3gtbmV3LXRva2VuJyk7XG4gICAgICAgICAgaWYgKG5ld1Rva2VuKSB7XG4gICAgICAgICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbWVtYnJzJywgbmV3VG9rZW4pO1xuICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgfSksXG4gICAgICBmaW5hbGl6ZSgoKSA9PiB7XG4gICAgICAgIC8vIHRoaXMuYnVzeVNlcnZpY2UuZmluaXNoZWQoKVxuICAgICAgfSlcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MembrsService } from './membrs.service';
|
|
4
|
+
import { JwtModule } from "@auth0/angular-jwt";
|
|
5
|
+
import { HttpClientModule } from "@angular/common/http";
|
|
6
|
+
import { UIRouterModule } from '@uirouter/angular';
|
|
7
|
+
import { Transition, UIRouter } from '@uirouter/angular';
|
|
8
|
+
import { routerConfigFn } from './router.config';
|
|
9
|
+
import { MembrsConfigService } from './config.service';
|
|
10
|
+
import { retrieveToken } from './token';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export const validateResolve = {
|
|
13
|
+
token: 'reissue',
|
|
14
|
+
deps: [Transition, UIRouter, MembrsService, MembrsConfigService],
|
|
15
|
+
resolveFn: validateResolveFn
|
|
16
|
+
};
|
|
17
|
+
export const reissueResolve = {
|
|
18
|
+
token: 'reissue',
|
|
19
|
+
deps: [Transition, UIRouter, MembrsService, MembrsConfigService],
|
|
20
|
+
resolveFn: reissueResolveFn
|
|
21
|
+
};
|
|
22
|
+
export const reissueState = {
|
|
23
|
+
name: 'reissue',
|
|
24
|
+
url: '/reissue?token',
|
|
25
|
+
views: {},
|
|
26
|
+
resolve: [
|
|
27
|
+
reissueResolve
|
|
28
|
+
]
|
|
29
|
+
};
|
|
30
|
+
export function reissueResolveFn(transition, router, membrsService, membrsConfig) {
|
|
31
|
+
//console.log(membrsService)
|
|
32
|
+
return new Promise((resolve, reject) => {
|
|
33
|
+
// console.log('reissue promise resolve')
|
|
34
|
+
// console.log(transition.params().token)
|
|
35
|
+
membrsService.reissue(transition.params().token).then((response) => {
|
|
36
|
+
if (localStorage.getItem('redirectUrlAfterLogin')) {
|
|
37
|
+
const redirect = localStorage.getItem('redirectUrlAfterLogin');
|
|
38
|
+
localStorage.removeItem('redirectUrlAfterLogin');
|
|
39
|
+
window.location.pathname = redirect;
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
router.stateService.go(membrsConfig.defaultState, {}, { inherit: false });
|
|
43
|
+
}
|
|
44
|
+
reject();
|
|
45
|
+
}).catch(error => {
|
|
46
|
+
//console.log('error in reissue resolve')
|
|
47
|
+
//console.log(error)
|
|
48
|
+
//window.location.href = environment.login
|
|
49
|
+
reject(error);
|
|
50
|
+
});
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
export function validateResolveFn(transition, router, membrsService, membrsConfig) {
|
|
54
|
+
//console.log(membrsService)
|
|
55
|
+
return new Promise((resolve, reject) => {
|
|
56
|
+
// console.log('validate promise resolve')
|
|
57
|
+
membrsService.reissue().then((response) => {
|
|
58
|
+
if (localStorage.getItem('redirectUrlAfterLogin')) {
|
|
59
|
+
const redirect = localStorage.getItem('redirectUrlAfterLogin');
|
|
60
|
+
localStorage.removeItem('redirectUrlAfterLogin');
|
|
61
|
+
window.location.pathname = redirect;
|
|
62
|
+
}
|
|
63
|
+
resolve(null);
|
|
64
|
+
}).catch(error => {
|
|
65
|
+
localStorage.setItem('redirectUrlAfterLogin', window.location.pathname);
|
|
66
|
+
window.location.href = membrsConfig.login;
|
|
67
|
+
reject(error);
|
|
68
|
+
});
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
export function jwtOptionsFactory(config) {
|
|
72
|
+
// console.log('jwt options factory')
|
|
73
|
+
// console.log(config)
|
|
74
|
+
return {
|
|
75
|
+
tokenGetter: () => {
|
|
76
|
+
console.log('token getter', localStorage.getItem('membrs'));
|
|
77
|
+
return localStorage.getItem('membrs');
|
|
78
|
+
},
|
|
79
|
+
allowedDomains: [config.api]
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
/** The top level state(s) */
|
|
83
|
+
export const STATES = [
|
|
84
|
+
reissueState
|
|
85
|
+
];
|
|
86
|
+
export class MembrsModule {
|
|
87
|
+
static forRoot(config) {
|
|
88
|
+
const moduleProviders = UIRouterModule.forChild({
|
|
89
|
+
states: STATES,
|
|
90
|
+
config: routerConfigFn
|
|
91
|
+
}).providers;
|
|
92
|
+
moduleProviders.push(JwtModule.forRoot({
|
|
93
|
+
config: {
|
|
94
|
+
tokenGetter: retrieveToken,
|
|
95
|
+
allowedDomains: []
|
|
96
|
+
}
|
|
97
|
+
}).providers);
|
|
98
|
+
moduleProviders.push(MembrsService);
|
|
99
|
+
moduleProviders.push({ provide: MembrsConfigService, useValue: config });
|
|
100
|
+
return {
|
|
101
|
+
ngModule: MembrsModule,
|
|
102
|
+
providers: moduleProviders //[{provide: MembrsConfigService,useValue: config}]
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
106
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: MembrsModule, imports: [CommonModule,
|
|
107
|
+
HttpClientModule,
|
|
108
|
+
JwtModule
|
|
109
|
+
// JwtModule.forRoot({
|
|
110
|
+
// config: {
|
|
111
|
+
// tokenGetter: retrieveToken
|
|
112
|
+
// }
|
|
113
|
+
// })
|
|
114
|
+
// UIRouterModule.forChild({
|
|
115
|
+
// states: STATES,
|
|
116
|
+
// config: routerConfigFn,
|
|
117
|
+
// }),
|
|
118
|
+
// JwtModule.forRoot({})
|
|
119
|
+
] });
|
|
120
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsModule, imports: [CommonModule,
|
|
121
|
+
HttpClientModule,
|
|
122
|
+
JwtModule
|
|
123
|
+
// JwtModule.forRoot({
|
|
124
|
+
// config: {
|
|
125
|
+
// tokenGetter: retrieveToken
|
|
126
|
+
// }
|
|
127
|
+
// })
|
|
128
|
+
// UIRouterModule.forChild({
|
|
129
|
+
// states: STATES,
|
|
130
|
+
// config: routerConfigFn,
|
|
131
|
+
// }),
|
|
132
|
+
// JwtModule.forRoot({})
|
|
133
|
+
] });
|
|
134
|
+
}
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsModule, decorators: [{
|
|
136
|
+
type: NgModule,
|
|
137
|
+
args: [{
|
|
138
|
+
imports: [
|
|
139
|
+
CommonModule,
|
|
140
|
+
HttpClientModule,
|
|
141
|
+
JwtModule
|
|
142
|
+
// JwtModule.forRoot({
|
|
143
|
+
// config: {
|
|
144
|
+
// tokenGetter: retrieveToken
|
|
145
|
+
// }
|
|
146
|
+
// })
|
|
147
|
+
// UIRouterModule.forChild({
|
|
148
|
+
// states: STATES,
|
|
149
|
+
// config: routerConfigFn,
|
|
150
|
+
// }),
|
|
151
|
+
// JwtModule.forRoot({})
|
|
152
|
+
]
|
|
153
|
+
}]
|
|
154
|
+
}] });
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"membrs.module.js","sourceRoot":"","sources":["../../../../projects/membrs/src/lib/membrs.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, ModuleWithProviders, Injector } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MembrsService } from './membrs.service';\nimport { JwtModule, JWT_OPTIONS } from \"@auth0/angular-jwt\";\nimport { HttpClientModule } from \"@angular/common/http\";\nimport { UIRouterModule } from '@uirouter/angular'\n\nimport { Ng2StateDeclaration } from '@uirouter/angular';\nimport { Transition, UIRouter } from '@uirouter/angular'\n\nimport { routerConfigFn } from './router.config';\nimport { MembrsConfig } from './config.interface';\nimport { MembrsConfigService } from './config.service';\nimport { retrieveToken } from './token';\n\nexport const validateResolve = {\n    token: 'reissue',\n    deps: [ Transition, UIRouter, MembrsService, MembrsConfigService ],\n    resolveFn: validateResolveFn\n}\n\nexport const reissueResolve = {\n  token: 'reissue',\n  deps: [ Transition, UIRouter, MembrsService, MembrsConfigService ],\n  resolveFn: reissueResolveFn\n}\n\nexport const reissueState:Ng2StateDeclaration = {\n\tname: 'reissue', \n\turl: '/reissue?token',\n\tviews: { },\n\tresolve: [\n    reissueResolve\n\t]\n}\n\nexport function reissueResolveFn(transition, router, membrsService, membrsConfig:MembrsConfig) {\n    \n    //console.log(membrsService)\n    return new Promise((resolve, reject) => {\n      // console.log('reissue promise resolve')\n      // console.log(transition.params().token)\n      membrsService.reissue(transition.params().token).then((response)=>{\n          if(localStorage.getItem('redirectUrlAfterLogin')){\n            const redirect = localStorage.getItem('redirectUrlAfterLogin')\n            localStorage.removeItem('redirectUrlAfterLogin')\n            window.location.pathname = redirect\n          }else {\n            router.stateService.go(membrsConfig.defaultState, {}, {inherit:false})\n          }\n          reject()\n      }).catch(error=>{\n          //console.log('error in reissue resolve')\n          //console.log(error)\n          //window.location.href = environment.login\n          reject(error)\n      })\n\n\t})\n}\n\nexport function validateResolveFn(transition, router, membrsService, membrsConfig:MembrsConfig) {\n  \n  //console.log(membrsService)\n  return new Promise((resolve, reject) => {\n    // console.log('validate promise resolve')\n    \n    membrsService.reissue().then((response)=>{\n      if(localStorage.getItem('redirectUrlAfterLogin')){\n        const redirect = localStorage.getItem('redirectUrlAfterLogin')\n        localStorage.removeItem('redirectUrlAfterLogin')\n        window.location.pathname = redirect\n      }\n      resolve(null)\n    }).catch(error=>{\n      localStorage.setItem('redirectUrlAfterLogin', window.location.pathname)\n      window.location.href = membrsConfig.login\n      reject(error)\n    })\n\n})\n}\n\nexport function jwtOptionsFactory(config) {\n  // console.log('jwt options factory')\n  // console.log(config)\n  return {\n    tokenGetter: () => {\n      console.log('token getter',  localStorage.getItem('membrs'))\n      return localStorage.getItem('membrs');\n    },\n    allowedDomains: [config.api]\n  }\n}\n\n\n/** The top level state(s) */\nexport const STATES = [\n    reissueState\n]\n\n\n@NgModule({\n  imports: [\n    CommonModule,\n    HttpClientModule,\n    JwtModule\n    // JwtModule.forRoot({\n    //   config: {\n    //     tokenGetter: retrieveToken\n    //   }\n    // })\n    // UIRouterModule.forChild({\n    //   states: STATES,\n    //   config: routerConfigFn,\n    // }),\n    // JwtModule.forRoot({})\n  ]\n})\n\n\n\nexport class MembrsModule { \n  static forRoot(config: MembrsConfig): ModuleWithProviders<MembrsModule> {\n\n\n    const moduleProviders = UIRouterModule.forChild({\n      states: STATES,\n      config: routerConfigFn\n    }).providers\n\n    moduleProviders.push(JwtModule.forRoot({\n      config: {\n        tokenGetter: retrieveToken,\n        allowedDomains: []\n      }\n    }).providers)\n      \n    moduleProviders.push(MembrsService)\n    moduleProviders.push({provide: MembrsConfigService,useValue: config});\n    \n   \n    return {\n      ngModule: MembrsModule, \n      providers: moduleProviders //[{provide: MembrsConfigService,useValue: config}]\n    };\n    \n  }\n\n}\n"]}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import { Injectable, Inject } from '@angular/core';
|
|
2
|
+
import { JwtHelperService } from '@auth0/angular-jwt';
|
|
3
|
+
import { MembrsConfigService } from './config.service';
|
|
4
|
+
import { BehaviorSubject } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
const jwtService = new JwtHelperService();
|
|
8
|
+
export class MembrsService {
|
|
9
|
+
http;
|
|
10
|
+
config;
|
|
11
|
+
_token;
|
|
12
|
+
_decoded;
|
|
13
|
+
decodedReady = new BehaviorSubject(null);
|
|
14
|
+
_lsKey = 'membrs';
|
|
15
|
+
_loggedInObservable = new BehaviorSubject(false);
|
|
16
|
+
constructor(http, config) {
|
|
17
|
+
this.http = http;
|
|
18
|
+
this.config = config;
|
|
19
|
+
// console.log('membrs constructor')
|
|
20
|
+
// if the token exists in local storage, retrieve it back to the service
|
|
21
|
+
if (localStorage.getItem(this._lsKey)) {
|
|
22
|
+
this.token = localStorage.getItem(this._lsKey);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
reissue(token) {
|
|
26
|
+
console.log('Reissuing token...'); // Log function entry
|
|
27
|
+
return new Promise((resolve, reject) => {
|
|
28
|
+
if (!token && !this._token) {
|
|
29
|
+
console.log('No token provided and no token found.'); // Log missing token
|
|
30
|
+
reject('NOT_LOGGED_IN');
|
|
31
|
+
}
|
|
32
|
+
if (token) {
|
|
33
|
+
console.log(`Token provided: ${token}`); // Log provided token
|
|
34
|
+
this.token = token;
|
|
35
|
+
}
|
|
36
|
+
// check stored token has not expired, or needs to be reissued soon
|
|
37
|
+
var reissueIn = this._decoded.exp - Math.floor(Date.now() / 1000);
|
|
38
|
+
// token has expired
|
|
39
|
+
if (reissueIn < 0) {
|
|
40
|
+
console.log('Token has expired.'); // Log expired token
|
|
41
|
+
reject('NOT_LOGGED_IN');
|
|
42
|
+
}
|
|
43
|
+
// token expiring soon
|
|
44
|
+
if (reissueIn < 300) {
|
|
45
|
+
console.log('Token expiring soon. Reissuing...'); // Log imminent expiration
|
|
46
|
+
this.http.post(this.config.apiProtocol + this.config.api + '/token/' + this._token, {}).subscribe((response) => {
|
|
47
|
+
if (response.token) {
|
|
48
|
+
this.token = response.token;
|
|
49
|
+
this._loggedInObservable.next(true);
|
|
50
|
+
console.log('Token successfully reissued.'); // Log success
|
|
51
|
+
resolve(this._token);
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
console.log('Failed to reissue token.'); // Log failure
|
|
55
|
+
reject('NOT_LOGGED_IN');
|
|
56
|
+
}
|
|
57
|
+
}, (error) => {
|
|
58
|
+
console.log('Error reissuing token:', error); // Log error details
|
|
59
|
+
reject('NOT_LOGGED_IN');
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
this._loggedInObservable.next(true);
|
|
64
|
+
console.log('Token is valid. No need to reissue.'); // Log valid token
|
|
65
|
+
resolve(this._token);
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
set token(token) {
|
|
70
|
+
this._token = token;
|
|
71
|
+
console.log('Token set.');
|
|
72
|
+
localStorage.setItem(this._lsKey, token);
|
|
73
|
+
this._decoded = jwtService.decodeToken(this._token);
|
|
74
|
+
}
|
|
75
|
+
deleteToken() {
|
|
76
|
+
localStorage.removeItem(this._lsKey);
|
|
77
|
+
}
|
|
78
|
+
isLoggedIn() {
|
|
79
|
+
return this.token ? true : false;
|
|
80
|
+
}
|
|
81
|
+
get profile() {
|
|
82
|
+
return this._decoded;
|
|
83
|
+
}
|
|
84
|
+
setProfile(decodedData) {
|
|
85
|
+
this._decoded = decodedData;
|
|
86
|
+
this.decodedReady.next(decodedData); // Emit the new value when profile is set
|
|
87
|
+
console.log(this.decodedReady);
|
|
88
|
+
}
|
|
89
|
+
get decodedReady$() {
|
|
90
|
+
return this.decodedReady.asObservable();
|
|
91
|
+
}
|
|
92
|
+
get token() {
|
|
93
|
+
return this._token;
|
|
94
|
+
}
|
|
95
|
+
get admin() {
|
|
96
|
+
return this.profile.permission == 1;
|
|
97
|
+
}
|
|
98
|
+
get isLoggedInObservable() {
|
|
99
|
+
return this._loggedInObservable;
|
|
100
|
+
}
|
|
101
|
+
logout() {
|
|
102
|
+
return new Promise((resolve, reject) => {
|
|
103
|
+
this.http.delete(this.config.apiProtocol + this.config.api + '/token/' + this._token).subscribe((response) => {
|
|
104
|
+
this._token = null;
|
|
105
|
+
localStorage.removeItem(this._lsKey);
|
|
106
|
+
resolve(this.config.login);
|
|
107
|
+
}, error => {
|
|
108
|
+
// If the API call fails (e.g. token already invalid/expired), still clear local state
|
|
109
|
+
console.warn('Logout API call failed, clearing local token anyway', error);
|
|
110
|
+
this._token = null;
|
|
111
|
+
localStorage.removeItem(this._lsKey);
|
|
112
|
+
resolve(this.config.login);
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsService, deps: [{ token: i1.HttpClient }, { token: MembrsConfigService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
117
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsService, providedIn: 'root' });
|
|
118
|
+
}
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MembrsService, decorators: [{
|
|
120
|
+
type: Injectable,
|
|
121
|
+
args: [{
|
|
122
|
+
providedIn: 'root'
|
|
123
|
+
}]
|
|
124
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: undefined, decorators: [{
|
|
125
|
+
type: Inject,
|
|
126
|
+
args: [MembrsConfigService]
|
|
127
|
+
}] }] });
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"membrs.service.js","sourceRoot":"","sources":["../../../../projects/membrs/src/lib/membrs.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Inject } from '@angular/core';\nimport { JwtHelperService } from '@auth0/angular-jwt';\nimport { HttpClient } from '@angular/common/http'\nimport { MembrsConfigService } from './config.service'\nimport { MembrsConfig } from './config.interface';\nimport { BehaviorSubject } from 'rxjs';\nconst jwtService = new JwtHelperService()\n\n@Injectable({\n  providedIn: 'root'\n})\n\n\nexport class MembrsService {\n\n  _token: string;\n  _decoded: any;\n\n  public decodedReady = new BehaviorSubject<any>(null);\n\n  _lsKey: string = 'membrs';\n  _loggedInObservable: BehaviorSubject<Boolean> = new BehaviorSubject(false)\n\n  constructor(private http: HttpClient, @Inject(MembrsConfigService) private config: MembrsConfig) {\n\n    // console.log('membrs constructor')\n    // if the token exists in local storage, retrieve it back to the service\n    if(localStorage.getItem(this._lsKey)){\n      this.token = localStorage.getItem(this._lsKey)\n    }\n  \n  }\n\n  reissue(token?: string) {\n    console.log('Reissuing token...'); // Log function entry\n    \n    return new Promise((resolve, reject) => {\n      if (!token && !this._token) {\n        console.log('No token provided and no token found.'); // Log missing token\n        reject('NOT_LOGGED_IN');\n      }\n  \n      if (token) {\n        console.log(`Token provided: ${token}`); // Log provided token\n        this.token = token;\n      }\n  \n      // check stored token has not expired, or needs to be reissued soon\n      var reissueIn = this._decoded.exp - Math.floor(Date.now() / 1000);\n  \n      // token has expired\n      if (reissueIn < 0) {\n        console.log('Token has expired.'); // Log expired token\n        reject('NOT_LOGGED_IN');\n      }\n  \n      // token expiring soon\n      if (reissueIn < 300) {\n        console.log('Token expiring soon. Reissuing...'); // Log imminent expiration\n        this.http.post(this.config.apiProtocol + this.config.api + '/token/' + this._token, {}).subscribe(\n          (response: any) => {\n            if (response.token) {\n              this.token = response.token;\n              this._loggedInObservable.next(true);\n              console.log('Token successfully reissued.'); // Log success\n              resolve(this._token);\n            } else {\n              console.log('Failed to reissue token.'); // Log failure\n              reject('NOT_LOGGED_IN');\n            }\n          },\n          (error) => {\n            console.log('Error reissuing token:', error); // Log error details\n            reject('NOT_LOGGED_IN');\n          }\n        );\n      } else {\n        this._loggedInObservable.next(true);\n        console.log('Token is valid. No need to reissue.'); // Log valid token\n        resolve(this._token);\n      }\n    });\n  }\n  \n\n  set token(token){\n    this._token = token\n    console.log('Token set.');\n    localStorage.setItem(this._lsKey, token)\n    this._decoded = jwtService.decodeToken(this._token)\n  }\n\n  deleteToken(){\n    localStorage.removeItem(this._lsKey)\n  }\n\n  isLoggedIn(){\n    return this.token ? true : false\n  }\n\n  get profile(){\n    return this._decoded\n  }\n\n  setProfile(decodedData) {\n    this._decoded = decodedData;\n    this.decodedReady.next(decodedData); // Emit the new value when profile is set\n    console.log(this.decodedReady);\n  }\n\n  get decodedReady$() {\n    return this.decodedReady.asObservable();\n  }\n\n  get token(){\n    return this._token\n  }\n\n  get admin (){\n    return this.profile.permission == 1\n  }\n\n  get isLoggedInObservable(){\n    return this._loggedInObservable\n  }\n  \n  logout(){\n    return new Promise((resolve, reject)=>{\n      this.http.delete(this.config.apiProtocol + this.config.api + '/token/' + this._token).subscribe((response:any)=>{\n        this._token = null;\n        localStorage.removeItem(this._lsKey);\n        resolve(this.config.login);\n      }, error => {\n        // If the API call fails (e.g. token already invalid/expired), still clear local state\n        console.warn('Logout API call failed, clearing local token anyway', error);\n        this._token = null;\n        localStorage.removeItem(this._lsKey);\n        resolve(this.config.login);\n      });\n    });\n  }\n\n\n}\n"]}
|