ssi-security-commons 0.0.3 → 0.0.6

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.
@@ -1,8 +1,8 @@
1
1
  /* eslint-disable */
2
2
  import { Injectable } from '@angular/core';
3
- import { HttpErrorResponse } from '@angular/common/http';
3
+ import { HttpErrorResponse, HttpResponse } from '@angular/common/http';
4
4
  import { BehaviorSubject, throwError } from 'rxjs';
5
- import { catchError, filter, switchMap, take } from 'rxjs/operators';
5
+ import { catchError, filter, map, switchMap, take } from 'rxjs/operators';
6
6
  import { MessagesService } from './messages.service';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "./crypto.service";
@@ -43,9 +43,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImpor
43
43
  type: Injectable
44
44
  }], ctorParameters: function () { return [{ type: i1.CryptoService }]; } });
45
45
  export class ResponseInterceptor {
46
- constructor(injector, router, sessionService) {
46
+ constructor(injector, router, cryptoService, sessionService) {
47
47
  this.injector = injector;
48
48
  this.router = router;
49
+ this.cryptoService = cryptoService;
49
50
  this.sessionService = sessionService;
50
51
  this.isRefreshing = false;
51
52
  this.refreshTokenSubject = new BehaviorSubject(null);
@@ -55,25 +56,51 @@ export class ResponseInterceptor {
55
56
  });
56
57
  }
57
58
  intercept(request, next) {
58
- return next.handle(request).pipe(catchError(error => {
59
+ return next.handle(request).pipe(map((event) => {
60
+ if (event instanceof HttpResponse) {
61
+ console.log(request.headers.get('encrypted'));
62
+ let encrypt = request.headers.get('encrypted');
63
+ if (encrypt && encrypt === 'true') {
64
+ event = event.clone({ body: this.decryptBody(event.body) });
65
+ }
66
+ }
67
+ return event;
68
+ }), catchError(error => {
59
69
  if (error instanceof HttpErrorResponse) {
60
70
  console.error(error);
61
- if (error.status === 401) {
71
+ let nerror = error;
72
+ /*let encrypt = request.headers.get('encrypted');
73
+ if(encrypt && encrypt === 'true'){
74
+ nerror = new HttpErrorResponse({
75
+ error: this.decryptBody(error.error),
76
+ headers: error.headers,
77
+ status: error.status,
78
+ statusText: error.statusText,
79
+ url: error.url || request.urlWithParams || undefined,
80
+ });
81
+ }*/
82
+ if (nerror.status === 401) {
62
83
  console.log(this.router.url);
63
84
  if (this.router.url != '/login' && this.router.url.indexOf('/login') < 0) {
64
85
  console.log('401--->' + request.url);
65
86
  return this.handle401Error(request, next);
66
87
  }
67
88
  else {
68
- return throwError(error);
89
+ return throwError(nerror);
69
90
  }
70
91
  }
71
92
  else {
72
- this.messages?.showErrorMessage(error);
93
+ this.messages?.showErrorMessage(nerror);
73
94
  }
74
95
  }
75
96
  }));
76
97
  }
98
+ decryptBody(body) {
99
+ console.log(body);
100
+ let encrypted = body.encrypted;
101
+ let strJson = this.cryptoService.decrypt(encrypted);
102
+ return JSON.parse(strJson);
103
+ }
77
104
  handle401Error(request, next) {
78
105
  console.log('handle401Error');
79
106
  console.log(this.isRefreshing);
@@ -119,9 +146,9 @@ export class ResponseInterceptor {
119
146
  });
120
147
  }
121
148
  }
122
- ResponseInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: ResponseInterceptor, deps: [{ token: i0.Injector }, { token: i2.Router }, { token: i3.SessionService }], target: i0.ɵɵFactoryTarget.Injectable });
149
+ ResponseInterceptor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: ResponseInterceptor, deps: [{ token: i0.Injector }, { token: i2.Router }, { token: i1.CryptoService }, { token: i3.SessionService }], target: i0.ɵɵFactoryTarget.Injectable });
123
150
  ResponseInterceptor.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: ResponseInterceptor });
124
151
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: ResponseInterceptor, decorators: [{
125
152
  type: Injectable
126
- }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i2.Router }, { type: i3.SessionService }]; } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-interceptor.service.js","sourceRoot":"","sources":["../../../../../projects/ssi-security-commons/src/lib/services/auth-interceptor.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nimport { Injectable, Injector } from '@angular/core';\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n  HttpErrorResponse,\n  HttpResponse\n} from '@angular/common/http';\nimport { BehaviorSubject, Observable, throwError } from 'rxjs';\nimport { catchError, filter, switchMap, take, tap } from 'rxjs/operators';\nimport { MessagesService } from './messages.service';\nimport { CryptoService } from './crypto.service';\nimport { Router } from '@angular/router';\nimport { SessionService } from './session.service';\n\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  constructor(private cryptoService: CryptoService) { }\n\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n\n    const token = window.localStorage.getItem('TOKEN');\n\n    console.log(request);\n    console.log(request.headers.get('encrypted'));\n\n    let encrypt = request.headers.get('encrypted');\n    if(encrypt && encrypt === 'true'){\n      let body = request.body;\n      let bodyStr = JSON.stringify(body);\n      var newBody = {\n        encrypted: this.cryptoService.encrypt(bodyStr)\n      }\n      request = request.clone({\n        body: newBody\n      });\n    }\n\n    if (token) {\n      request = request.clone({\n        setHeaders: {\n          Authorization: 'Bearer ' + token,\n        }\n      });\n    }\n    return next.handle(request);\n  }\n}\n\n\n@Injectable()\nexport class ResponseInterceptor implements HttpInterceptor {\n\n  private messages: MessagesService | undefined;\n  private isRefreshing = false;\n  private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\n\n  constructor(private injector: Injector,\n    private router: Router,\n    private sessionService: SessionService) {\n    console.log('ResponseInterceptor constructor');\n    setTimeout(() => {\n      this.messages = this.injector.get(MessagesService);\n    })\n  }\n\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n\n    return next.handle(request).pipe(catchError(error => {\n      if (error instanceof HttpErrorResponse) {\n            console.error(error);\n            if (error.status === 401) {\n              console.log(this.router.url);\n              if (this.router.url != '/login' && this.router.url.indexOf('/login')<0) {\n                  console.log('401--->'+ request.url);\n                  return this.handle401Error(request, next);\n              } else {\n                return throwError(error);\n              }\n            } else {\n              this.messages?.showErrorMessage(error);\n            }\n        }\n      })) as Observable<HttpEvent<any>>;\n  }\n\n\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler) {\n    console.log('handle401Error');\n    console.log(this.isRefreshing);\n    if (!this.isRefreshing) {\n        this.isRefreshing = true;\n        this.refreshTokenSubject.next(null);\n        const refreshToken = this.sessionService.getRefreshToken();\n        console.log(refreshToken);\n        if (refreshToken){\n            return this.sessionService.getNewToken(refreshToken).pipe(\n                switchMap((res: any) => {\n                    console.log(res);\n                    this.isRefreshing = false;\n                    this.sessionService.setToken(res.data.accessToken);\n                    this.sessionService.setRefreshToken(res.data.refreshToken);\n                    this.refreshTokenSubject.next(res.data.accessToken);\n                    return next.handle(this.addTokenHeader(request, res.data.accessToken));\n                }),\n                catchError((err) => {\n                    this.isRefreshing = false;\n                    this.sessionService.logout();\n                    //this.router.navigate(['/login']);\n                    this.goToLogin();\n                    return throwError(err);\n                })\n            );\n        }\n    } else {\n        return this.refreshTokenSubject.pipe(\n            filter(token => token !== null),\n            take(1),\n            switchMap((token) => next.handle(this.addTokenHeader(request, token)))\n        );\n    }\n  }\n\n  private addTokenHeader(request: HttpRequest<any>, token: string) {\n    return request.clone({ headers: request.headers.set('Authorization', 'Bearer ' + token) });\n  }\n\n  private goToLogin(): void {\n    this.sessionService.getLoginUrl().subscribe(res => {\n      console.log(res);\n      const loginUrl = res.data;\n      const url = window.location.href;\n      if (url.indexOf(loginUrl)<0) {\n        window.location.href = loginUrl + '?continue='+encodeURIComponent(url);\n      }\n    }, (err) => {\n      console.error(err);\n    });\n  }\n\n}\n\n\n\n\n"]}
153
+ }], ctorParameters: function () { return [{ type: i0.Injector }, { type: i2.Router }, { type: i1.CryptoService }, { type: i3.SessionService }]; } });
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth-interceptor.service.js","sourceRoot":"","sources":["../../../../../projects/ssi-security-commons/src/lib/services/auth-interceptor.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nimport { Injectable, Injector } from '@angular/core';\nimport {\n  HttpRequest,\n  HttpHandler,\n  HttpEvent,\n  HttpInterceptor,\n  HttpErrorResponse,\n  HttpResponse\n} from '@angular/common/http';\nimport { BehaviorSubject, Observable, throwError } from 'rxjs';\nimport { catchError, filter, map, switchMap, take, tap } from 'rxjs/operators';\nimport { MessagesService } from './messages.service';\nimport { CryptoService } from './crypto.service';\nimport { Router } from '@angular/router';\nimport { SessionService } from './session.service';\n\n\n@Injectable()\nexport class AuthInterceptor implements HttpInterceptor {\n\n  constructor(private cryptoService: CryptoService) { }\n\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n\n    const token = window.localStorage.getItem('TOKEN');\n\n    console.log(request);\n    console.log(request.headers.get('encrypted'));\n\n    let encrypt = request.headers.get('encrypted');\n    if(encrypt && encrypt === 'true'){\n      let body = request.body;\n      let bodyStr = JSON.stringify(body);\n      var newBody = {\n        encrypted: this.cryptoService.encrypt(bodyStr)\n      }\n      request = request.clone({\n        body: newBody\n      });\n    }\n\n    if (token) {\n      request = request.clone({\n        setHeaders: {\n          Authorization: 'Bearer ' + token,\n        }\n      });\n    }\n    return next.handle(request);\n  }\n}\n\n\n@Injectable()\nexport class ResponseInterceptor implements HttpInterceptor {\n\n  private messages: MessagesService | undefined;\n  private isRefreshing = false;\n  private refreshTokenSubject: BehaviorSubject<any> = new BehaviorSubject<any>(null);\n\n  constructor(private injector: Injector,\n    private router: Router,\n    private cryptoService: CryptoService,\n    private sessionService: SessionService) {\n    console.log('ResponseInterceptor constructor');\n    setTimeout(() => {\n      this.messages = this.injector.get(MessagesService);\n    })\n  }\n\n  intercept(request: HttpRequest<any>, next: HttpHandler): Observable<HttpEvent<any>> {\n\n    return next.handle(request).pipe(\n      map((event: HttpEvent<any>) => {\n          if (event instanceof HttpResponse) {\n            console.log(request.headers.get('encrypted'));\n            let encrypt = request.headers.get('encrypted');\n            if(encrypt && encrypt === 'true'){\n              event = event.clone({body: this.decryptBody(event.body)});\n            }\n          }\n          return event;\n      }),\n      catchError(error => {\n        if (error instanceof HttpErrorResponse) {\n            console.error(error);\n            let nerror = error;\n            /*let encrypt = request.headers.get('encrypted');\n            if(encrypt && encrypt === 'true'){\n              nerror = new HttpErrorResponse({\n                error: this.decryptBody(error.error),\n                headers: error.headers,\n                status: error.status,\n                statusText: error.statusText,\n                url: error.url || request.urlWithParams || undefined,\n              });\n            }*/\n            if (nerror.status === 401) {\n              console.log(this.router.url);\n              if (this.router.url != '/login' && this.router.url.indexOf('/login')<0) {\n                  console.log('401--->'+ request.url);\n                  return this.handle401Error(request, next);\n              } else {\n                return throwError(nerror);\n              }\n            } else {\n              this.messages?.showErrorMessage(nerror);\n            }\n        }\n      })) as Observable<HttpEvent<any>>;\n  }\n\n  decryptBody(body: any): any {\n    console.log(body);\n    let encrypted = body.encrypted;\n    let strJson = this.cryptoService.decrypt(encrypted);\n    return JSON.parse(strJson);\n  }\n\n\n  private handle401Error(request: HttpRequest<any>, next: HttpHandler) {\n    console.log('handle401Error');\n    console.log(this.isRefreshing);\n    if (!this.isRefreshing) {\n        this.isRefreshing = true;\n        this.refreshTokenSubject.next(null);\n        const refreshToken = this.sessionService.getRefreshToken();\n        console.log(refreshToken);\n        if (refreshToken){\n            return this.sessionService.getNewToken(refreshToken).pipe(\n                switchMap((res: any) => {\n                    console.log(res);\n                    this.isRefreshing = false;\n                    this.sessionService.setToken(res.data.accessToken);\n                    this.sessionService.setRefreshToken(res.data.refreshToken);\n                    this.refreshTokenSubject.next(res.data.accessToken);\n                    return next.handle(this.addTokenHeader(request, res.data.accessToken));\n                }),\n                catchError((err) => {\n                    this.isRefreshing = false;\n                    this.sessionService.logout();\n                    //this.router.navigate(['/login']);\n                    this.goToLogin();\n                    return throwError(err);\n                })\n            );\n        }\n    } else {\n        return this.refreshTokenSubject.pipe(\n            filter(token => token !== null),\n            take(1),\n            switchMap((token) => next.handle(this.addTokenHeader(request, token)))\n        );\n    }\n  }\n\n  private addTokenHeader(request: HttpRequest<any>, token: string) {\n    return request.clone({ headers: request.headers.set('Authorization', 'Bearer ' + token) });\n  }\n\n  private goToLogin(): void {\n    this.sessionService.getLoginUrl().subscribe(res => {\n      console.log(res);\n      const loginUrl = res.data;\n      const url = window.location.href;\n      if (url.indexOf(loginUrl)<0) {\n        window.location.href = loginUrl + '?continue='+encodeURIComponent(url);\n      }\n    }, (err) => {\n      console.error(err);\n    });\n  }\n\n}\n\n\n\n\n"]}
@@ -2,6 +2,7 @@
2
2
  import { Inject, Injectable } from '@angular/core';
3
3
  import { HttpHeaders } from '@angular/common/http';
4
4
  import { map } from 'rxjs/operators';
5
+ import { CrossStorageClient } from 'cross-storage';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/common/http";
7
8
  export class SessionService {
@@ -9,30 +10,59 @@ export class SessionService {
9
10
  this.http = http;
10
11
  this.loginUrl = 'http://localhost:4200/login';
11
12
  this.endPoint = environment.endPoint;
13
+ const urlHub = environment.sessionHub;
14
+ console.log(urlHub);
15
+ this.storage = new CrossStorageClient(urlHub, { timeout: 5000 });
12
16
  }
13
17
  checkSessionData() {
14
- const data = window.localStorage.getItem('USERDATA');
15
- const token = window.localStorage.getItem('TOKEN');
16
- const refreshToken = window.localStorage.getItem('REFRESH_TOKEN');
17
- if (data && token && refreshToken) {
18
- const user = JSON.parse(data);
19
- this.saveCredentials(token, refreshToken);
20
- this.saveUserData(user);
21
- }
22
- else {
23
- this.destroyCredentials();
24
- this.destroyUserData();
25
- this.getLoginUrl().subscribe(res => {
18
+ var promise = new Promise((resolve, reject) => {
19
+ //const data = window.localStorage.getItem('USERDATA');
20
+ //const token = window.localStorage.getItem('TOKEN');
21
+ //const refreshToken = window.localStorage.getItem('REFRESH_TOKEN');
22
+ let data = undefined;
23
+ let token = undefined;
24
+ let refreshToken = undefined;
25
+ let self = this;
26
+ this.storage.onConnect().then(function () {
27
+ return self.storage.get('USERDATA', 'TOKEN', 'REFRESH_TOKEN');
28
+ }).then(function (res) {
26
29
  console.log(res);
27
- this.loginUrl = res.data;
28
- const url = window.location.href;
29
- if (url.indexOf('/login') < 0 && url.indexOf('/forgot') < 0 && url.indexOf('/reset') < 0) {
30
- window.location.href = this.loginUrl + '?continue=' + encodeURIComponent(url);
30
+ data = res[0];
31
+ token = res[1];
32
+ refreshToken = res[2];
33
+ if (data && token && refreshToken) {
34
+ const user = JSON.parse(data);
35
+ self.saveCredentials(token, refreshToken);
36
+ self.saveUserData(user);
37
+ resolve('OK');
31
38
  }
32
- }, (err) => {
39
+ else {
40
+ self.destroyCredentials();
41
+ self.destroyUserData();
42
+ self.getLoginUrl().subscribe(res => {
43
+ console.log(res);
44
+ self.loginUrl = res.data;
45
+ const url = window.location.href;
46
+ if (url.indexOf('/login') < 0 && url.indexOf('/forgot') < 0 && url.indexOf('/reset') < 0) {
47
+ window.location.href = self.loginUrl + '?continue=' + encodeURIComponent(url);
48
+ }
49
+ resolve('NOK');
50
+ }, (err) => {
51
+ console.error(err);
52
+ reject(err);
53
+ });
54
+ }
55
+ }).catch(function (err) {
33
56
  console.error(err);
57
+ reject(err);
34
58
  });
35
- }
59
+ });
60
+ return promise;
61
+ }
62
+ async reviewSessionData() {
63
+ const value = await this.checkSessionData();
64
+ console.log(`async result: ${value}`);
65
+ return value;
36
66
  }
37
67
  setUserdata(userdata) {
38
68
  this.userdata = userdata;
@@ -43,6 +73,9 @@ export class SessionService {
43
73
  setRefreshToken(refreshToken) {
44
74
  this.refreshToken = refreshToken;
45
75
  window.localStorage.setItem('REFRESH_TOKEN', refreshToken);
76
+ this.storage.onConnect().then(() => {
77
+ return this.storage.set('REFRESH_TOKEN', refreshToken);
78
+ });
46
79
  }
47
80
  getRefreshToken() {
48
81
  return this.refreshToken;
@@ -50,6 +83,9 @@ export class SessionService {
50
83
  setToken(token) {
51
84
  this.token = token;
52
85
  window.localStorage.setItem('TOKEN', token);
86
+ this.storage.onConnect().then(() => {
87
+ return this.storage.set('TOKEN', token);
88
+ });
53
89
  }
54
90
  getToken() {
55
91
  return this.token;
@@ -59,29 +95,53 @@ export class SessionService {
59
95
  this.refreshToken = undefined;
60
96
  window.localStorage.removeItem('TOKEN');
61
97
  window.localStorage.removeItem('REFRESH_TOKEN');
98
+ this.storage.onConnect().then(() => {
99
+ return this.storage.del('TOKEN', 'REFRESH_TOKEN');
100
+ });
62
101
  }
63
102
  destroyUserData() {
64
103
  this.userdata = undefined;
65
104
  window.localStorage.removeItem('USERDATA');
105
+ this.storage.onConnect().then(() => {
106
+ return this.storage.del('USERDATA');
107
+ });
66
108
  }
67
109
  saveCredentials(token, refreshToken) {
68
110
  this.token = token;
69
111
  this.refreshToken = refreshToken;
70
112
  window.localStorage.setItem('TOKEN', token);
71
113
  window.localStorage.setItem('REFRESH_TOKEN', refreshToken);
114
+ this.storage.onConnect().then(() => {
115
+ return this.storage.set('TOKEN', token);
116
+ });
117
+ this.storage.onConnect().then(() => {
118
+ return this.storage.set('REFRESH_TOKEN', refreshToken);
119
+ });
72
120
  }
73
121
  saveUserData(userdata) {
74
122
  this.userdata = userdata;
75
123
  window.localStorage.setItem('USERDATA', JSON.stringify(this.userdata));
124
+ this.storage.onConnect().then(() => {
125
+ return this.storage.set('USERDATA', JSON.stringify(this.userdata));
126
+ });
76
127
  }
77
128
  isLoggedIn() {
78
129
  return !!this.userdata;
79
130
  }
80
131
  logout() {
81
- return new Promise((resolve) => {
82
- this.destroyCredentials();
83
- this.destroyUserData();
84
- resolve(null);
132
+ return new Promise((resolve, reject) => {
133
+ this.logoutApi(this.userdata?.userId).subscribe(res => {
134
+ console.log(res);
135
+ this.destroyCredentials();
136
+ this.destroyUserData();
137
+ this.goToLogin();
138
+ resolve(null);
139
+ }, (err) => {
140
+ this.destroyCredentials();
141
+ this.destroyUserData();
142
+ console.error(err);
143
+ reject(err);
144
+ });
85
145
  });
86
146
  }
87
147
  getNewToken(refreshToken) {
@@ -95,6 +155,23 @@ export class SessionService {
95
155
  return this.http.get(this.endPoint + '/auth/login/url')
96
156
  .pipe(map(res => res));
97
157
  }
158
+ getHomeUrl() {
159
+ return this.http.get(this.endPoint + '/auth/home/url')
160
+ .pipe(map(res => res));
161
+ }
162
+ logoutApi(userId) {
163
+ return this.http.post(this.endPoint + '/auth/logout', { userId })
164
+ .pipe(map(res => res));
165
+ }
166
+ goToLogin() {
167
+ this.getLoginUrl().subscribe(res => {
168
+ console.log(res);
169
+ const loginUrl = res.data;
170
+ window.location.href = loginUrl;
171
+ }, (err) => {
172
+ console.error(err);
173
+ });
174
+ }
98
175
  }
99
176
  SessionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SessionService, deps: [{ token: i1.HttpClient }, { token: 'environment' }], target: i0.ɵɵFactoryTarget.Injectable });
100
177
  SessionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.3.3", ngImport: i0, type: SessionService });
@@ -104,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.3", ngImpor
104
181
  type: Inject,
105
182
  args: ['environment']
106
183
  }] }]; } });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"session.service.js","sourceRoot":"","sources":["../../../../../projects/ssi-security-commons/src/lib/services/session.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport { Inject, Injectable } from '@angular/core';\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { User } from '../user.model';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\n@Injectable()\nexport class SessionService {\n\n  userdata: User | undefined;\n  token: string | undefined;\n  refreshToken: string | undefined;\n  endPoint: string;\n  loginUrl = 'http://localhost:4200/login';\n\n  constructor(private http: HttpClient,\n    @Inject('environment') environment: any) {\n    this.endPoint = environment.endPoint;\n  }\n\n  public checkSessionData(): void {\n    const data = window.localStorage.getItem('USERDATA');\n    const token = window.localStorage.getItem('TOKEN');\n    const refreshToken = window.localStorage.getItem('REFRESH_TOKEN');\n\n    if (data && token && refreshToken) {\n      const user = JSON.parse(data);\n      this.saveCredentials(token, refreshToken);\n      this.saveUserData(user);\n    } else {\n      this.destroyCredentials();\n      this.destroyUserData();\n      this.getLoginUrl().subscribe(res => {\n        console.log(res);\n        this.loginUrl = res.data;\n        const url = window.location.href;\n        if (url.indexOf('/login')<0 && url.indexOf('/forgot')<0 && url.indexOf('/reset')<0) {\n          window.location.href = this.loginUrl + '?continue='+encodeURIComponent(url);\n        }\n      }, (err) => {\n        console.error(err);\n      });\n    }\n  }\n\n  public setUserdata(userdata: any): void {\n    this.userdata = userdata;\n  }\n\n  public getUserdata(): User | undefined {\n    return this.userdata;\n  }\n\n  public setRefreshToken(refreshToken: any): void {\n    this.refreshToken = refreshToken;\n    window.localStorage.setItem('REFRESH_TOKEN', refreshToken);\n  }\n\n  public getRefreshToken(): string | undefined {\n    return this.refreshToken;\n  }\n\n  public setToken(token: any): any {\n    this.token = token;\n    window.localStorage.setItem('TOKEN', token);\n  }\n\n  public getToken(): any {\n    return this.token;\n  }\n\n  public destroyCredentials(): void {\n    this.token = undefined;\n    this.refreshToken = undefined;\n    window.localStorage.removeItem('TOKEN');\n    window.localStorage.removeItem('REFRESH_TOKEN');\n  }\n\n  public destroyUserData(): void {\n    this.userdata = undefined;\n    window.localStorage.removeItem('USERDATA');\n  }\n\n  public saveCredentials(token: any, refreshToken: any): void {\n    this.token = token;\n    this.refreshToken = refreshToken;\n    window.localStorage.setItem('TOKEN', token);\n    window.localStorage.setItem('REFRESH_TOKEN', refreshToken);\n  }\n\n  public saveUserData(userdata: any): void {\n    this.userdata = userdata;\n    window.localStorage.setItem('USERDATA', JSON.stringify(this.userdata));\n  }\n\n  public isLoggedIn(): boolean {\n    return !!this.userdata;\n  }\n\n  logout(): Promise<any> {\n    return new Promise<any>((resolve) => {\n      this.destroyCredentials();\n      this.destroyUserData();\n      resolve(null);\n    });\n  }\n\n  getNewToken(refreshToken: string): any {\n    console.log('getNewToken');\n    const httpOptions = {\n      headers: new HttpHeaders({'Content-Type': 'application/json' })\n    };\n    return this.http.post(this.endPoint + '/auth/refresh-token', { refreshToken }, httpOptions);\n  }\n\n  getLoginUrl(): Observable<any> {\n    return this.http.get<any>(this.endPoint + '/auth/login/url')\n      .pipe(\n        map(res => res));\n  }\n\n\n}\n"]}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"session.service.js","sourceRoot":"","sources":["../../../../../projects/ssi-security-commons/src/lib/services/session.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/naming-convention */\nimport { Inject, Injectable } from '@angular/core';\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { User } from '../user.model';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { CrossStorageClient } from 'cross-storage';\n\n\n@Injectable()\nexport class SessionService {\n\n  userdata: User | undefined;\n  token: string | undefined;\n  refreshToken: string | undefined;\n  endPoint: string;\n  loginUrl = 'http://localhost:4200/login';\n  storage: any;\n\n  constructor(private http: HttpClient,\n    @Inject('environment') environment: any) {\n    this.endPoint = environment.endPoint;\n    const urlHub = environment.sessionHub;\n    console.log(urlHub);\n    this.storage = new CrossStorageClient(urlHub, {timeout: 5000});\n  }\n\n  public checkSessionData(){\n    var promise = new Promise((resolve, reject) => {\n      //const data = window.localStorage.getItem('USERDATA');\n      //const token = window.localStorage.getItem('TOKEN');\n      //const refreshToken = window.localStorage.getItem('REFRESH_TOKEN');\n      let data = undefined;\n      let token = undefined;\n      let refreshToken = undefined;\n\n      let self = this;\n      this.storage.onConnect().then(function() {\n        return self.storage.get('USERDATA', 'TOKEN', 'REFRESH_TOKEN');\n      }).then(function(res: any) {\n        console.log(res); \n        data = res[0];\n        token = res[1];\n        refreshToken = res[2];\n\n        if (data && token && refreshToken) {\n          const user = JSON.parse(data);\n          self.saveCredentials(token, refreshToken);\n          self.saveUserData(user);\n          resolve('OK');\n        } else {\n          self.destroyCredentials();\n          self.destroyUserData();\n          self.getLoginUrl().subscribe(res => {\n            console.log(res);\n            self.loginUrl = res.data;\n            const url = window.location.href;\n            if (url.indexOf('/login')<0 && url.indexOf('/forgot')<0 && url.indexOf('/reset')<0) {\n              window.location.href = self.loginUrl + '?continue='+encodeURIComponent(url);\n            }\n            resolve('NOK');\n          }, (err) => {\n            console.error(err);\n            reject(err);\n          });\n        }\n\n      }).catch(function(err: any) {\n        console.error(err);\n        reject(err);\n      });\n    });\n    return promise;\n  }\n\n  public async reviewSessionData() {\n    const value = <any>await this.checkSessionData();\n    console.log(`async result: ${value}`);\n    return value;\n  }\n\n  public setUserdata(userdata: any): void {\n    this.userdata = userdata;\n  }\n\n  public getUserdata(): User | undefined {\n    return this.userdata;\n  }\n\n  public setRefreshToken(refreshToken: any): void {\n    this.refreshToken = refreshToken;\n    window.localStorage.setItem('REFRESH_TOKEN', refreshToken);\n    this.storage.onConnect().then(() => {\n      return this.storage.set('REFRESH_TOKEN', refreshToken);\n    });\n  }\n\n  public getRefreshToken(): string | undefined {\n    return this.refreshToken;\n  }\n\n  public setToken(token: any): any {\n    this.token = token;\n    window.localStorage.setItem('TOKEN', token);\n    this.storage.onConnect().then(() => {\n      return this.storage.set('TOKEN', token);\n    });\n  }\n\n  public getToken(): any {\n    return this.token;\n  }\n\n  public destroyCredentials(): void {\n    this.token = undefined;\n    this.refreshToken = undefined;\n    window.localStorage.removeItem('TOKEN');\n    window.localStorage.removeItem('REFRESH_TOKEN');\n    this.storage.onConnect().then(() => {\n      return this.storage.del('TOKEN', 'REFRESH_TOKEN');\n    })\n  }\n\n  public destroyUserData(): void {\n    this.userdata = undefined;\n    window.localStorage.removeItem('USERDATA');\n    this.storage.onConnect().then(() => {\n      return this.storage.del('USERDATA');\n    });\n  }\n\n  public saveCredentials(token: any, refreshToken: any): void {\n    this.token = token;\n    this.refreshToken = refreshToken;\n    window.localStorage.setItem('TOKEN', token);\n    window.localStorage.setItem('REFRESH_TOKEN', refreshToken);\n    this.storage.onConnect().then(() => {\n      return this.storage.set('TOKEN', token);\n    });\n    this.storage.onConnect().then(() => {\n      return this.storage.set('REFRESH_TOKEN', refreshToken);\n    });\n  }\n\n  public saveUserData(userdata: any): void {\n    this.userdata = userdata;\n    window.localStorage.setItem('USERDATA', JSON.stringify(this.userdata));\n    this.storage.onConnect().then(() => {\n      return this.storage.set('USERDATA', JSON.stringify(this.userdata));\n    });\n  }\n\n  public isLoggedIn(): boolean {\n    return !!this.userdata;\n  }\n\n  logout(): Promise<any> {\n    return new Promise((resolve, reject) => {\n      this.logoutApi(this.userdata?.userId).subscribe(res => {\n        console.log(res);\n        this.destroyCredentials();\n        this.destroyUserData();\n        this.goToLogin();\n        resolve(null);\n      }, (err) => {\n        this.destroyCredentials();\n        this.destroyUserData();\n        console.error(err);\n        reject(err);\n      });\n    });\n  }\n\n  getNewToken(refreshToken: string): any {\n    console.log('getNewToken');\n    const httpOptions = {\n      headers: new HttpHeaders({'Content-Type': 'application/json' })\n    };\n    return this.http.post(this.endPoint + '/auth/refresh-token', { refreshToken }, httpOptions);\n  }\n\n  getLoginUrl(): Observable<any> {\n    return this.http.get<any>(this.endPoint + '/auth/login/url')\n      .pipe(\n        map(res => res));\n  }\n\n  getHomeUrl(): Observable<any> {\n    return this.http.get<any>(this.endPoint + '/auth/home/url')\n      .pipe(\n        map(res => res));\n  }\n\n  logoutApi(userId: any): Observable<any> {\n    return this.http.post<any>(this.endPoint + '/auth/logout', {userId})\n      .pipe(\n        map(res => res));\n  }\n\n  goToLogin(): void {\n    this.getLoginUrl().subscribe(res => {\n      console.log(res);\n      const loginUrl = res.data;\n      window.location.href = loginUrl;\n    }, (err) => {\n      console.error(err);\n    });\n  }\n\n\n}\n\n"]}