tango-app-ui-auth 3.5.0-beta.7 → 3.5.0-beta.9

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.
@@ -18,14 +18,33 @@ export class AuthGuard {
18
18
  }
19
19
  });
20
20
  }
21
- canActivate(route, state) {
22
- // const currentUser = localStorage.getItem('isLoggedIn');
23
- const currentUser = localStorage.getItem(this.authlocalStorageToken);
24
- if (currentUser) {
25
- // this.route.navigate(['/manage']);
26
- return true;
21
+ // canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
22
+ // // const currentUser = localStorage.getItem('isLoggedIn');
23
+ // const currentUser = localStorage.getItem(this.authlocalStorageToken);
24
+ // if (currentUser) {
25
+ // // this.route.navigate(['/manage']);
26
+ // return true;
27
+ // } else {
28
+ // this.route.navigate(['/auth/login']);
29
+ // return false;
30
+ // }
31
+ // }
32
+ canActivate() {
33
+ const tokenStr = this.authService.getCookie(this.authlocalStorageToken);
34
+ if (!tokenStr) {
35
+ this.route.navigate(['/auth/login']);
36
+ return false;
37
+ }
38
+ try {
39
+ const tokenData = JSON.parse(tokenStr);
40
+ const isValid = !!tokenData?.authenticationToken;
41
+ if (!isValid) {
42
+ this.route.navigate(['/auth/login']);
43
+ }
44
+ return isValid;
27
45
  }
28
- else {
46
+ catch (e) {
47
+ console.error('Invalid token in cookie', e);
29
48
  this.route.navigate(['/auth/login']);
30
49
  return false;
31
50
  }
@@ -37,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
37
56
  type: Injectable,
38
57
  args: [{ providedIn: 'root' }]
39
58
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i3.Router }] });
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWF1dGgvc3JjL2xpYi9ndWFyZHMvYXV0aC5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQU8zQyxNQUFNLE9BQU8sU0FBUztJQUVBO0lBQWlDO0lBQzNDO0lBRkYscUJBQXFCLENBQUs7SUFDbEMsWUFBb0IsV0FBd0IsRUFBUyxFQUFxQixFQUNoRSxLQUFhO1FBREgsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxPQUFFLEdBQUYsRUFBRSxDQUFtQjtRQUNoRSxVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQ3JCLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3BDLElBQUksR0FBRyxFQUFFO2dCQUNaLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQ2pFO1FBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBQ0QsV0FBVyxDQUFDLEtBQTZCLEVBQUUsS0FBMEI7UUFFbkUsMERBQTBEO1FBQzFELE1BQU0sV0FBVyxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFDckUsSUFBSSxXQUFXLEVBQUU7WUFDVCx3Q0FBd0M7WUFDNUMsT0FBTyxJQUFJLENBQUM7U0FDZjthQUFNO1lBQ0MsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO1lBRXpDLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQzt3R0F0QlUsU0FBUzs0R0FBVCxTQUFTLGNBREksTUFBTTs7NEZBQ25CLFNBQVM7a0JBRHJCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBSb3V0ZXIsIFJvdXRlclN0YXRlU25hcHNob3QgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2F1dGguc2VydmljZSc7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJ3RhbmdvLWFwcC11aS1nbG9iYWwnO1xyXG5cclxuXHJcbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXHJcbmV4cG9ydCBjbGFzcyBBdXRoR3VhcmQgIHtcclxuICBwcml2YXRlIGF1dGhsb2NhbFN0b3JhZ2VUb2tlbjphbnk7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UscHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJvdXRlOiBSb3V0ZXIpIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpID0+IHtcclxuICAgICAgaWYgKGVudikge1xyXG4gICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDtcclxuICAgICAgfVxyXG4gICAgfSlcclxuICB9XHJcbiAgY2FuQWN0aXZhdGUocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KSB7XHJcblxyXG4gICAgLy8gY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnaXNMb2dnZWRJbicpO1xyXG4gICAgY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbik7XHJcbiAgICBpZiAoY3VycmVudFVzZXIpIHtcclxuICAgICAgICAgICAgLy8gdGhpcy5yb3V0ZS5uYXZpZ2F0ZShbJy9tYW5hZ2UnXSk7ICAgIFxyXG4gICAgICAgIHJldHVybiB0cnVlOyAgXHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICB0aGlzLnJvdXRlLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7ICAgIFxyXG5cclxuICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5ndWFyZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWF1dGgvc3JjL2xpYi9ndWFyZHMvYXV0aC5ndWFyZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7OztBQU8zQyxNQUFNLE9BQU8sU0FBUztJQUVBO0lBQWlDO0lBQzNDO0lBRkYscUJBQXFCLENBQUs7SUFDbEMsWUFBb0IsV0FBd0IsRUFBUyxFQUFxQixFQUNoRSxLQUFhO1FBREgsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFBUyxPQUFFLEdBQUYsRUFBRSxDQUFtQjtRQUNoRSxVQUFLLEdBQUwsS0FBSyxDQUFRO1FBQ3JCLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQ3BDLElBQUksR0FBRyxFQUFFO2dCQUNaLElBQUksQ0FBQyxxQkFBcUIsR0FBRyxHQUFHLEdBQUcsQ0FBQyxVQUFVLElBQUksR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQ2pFO1FBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBQ0QsMkVBQTJFO0lBRTNFLCtEQUErRDtJQUMvRCwwRUFBMEU7SUFDMUUsdUJBQXVCO0lBQ3ZCLHFEQUFxRDtJQUNyRCx1QkFBdUI7SUFDdkIsYUFBYTtJQUNiLHNEQUFzRDtJQUV0RCxzQkFBc0I7SUFDdEIsTUFBTTtJQUNOLElBQUk7SUFFSixXQUFXO1FBQ1QsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLENBQUM7UUFFeEUsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNiLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztZQUNyQyxPQUFPLEtBQUssQ0FBQztTQUNkO1FBRUQsSUFBSTtZQUNGLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDdkMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxDQUFDLFNBQVMsRUFBRSxtQkFBbUIsQ0FBQztZQUVqRCxJQUFJLENBQUMsT0FBTyxFQUFFO2dCQUNaLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQzthQUN0QztZQUVELE9BQU8sT0FBTyxDQUFDO1NBQ2hCO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixPQUFPLENBQUMsS0FBSyxDQUFDLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzVDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQztZQUNyQyxPQUFPLEtBQUssQ0FBQztTQUNkO0lBQ0gsQ0FBQzt3R0E5Q1UsU0FBUzs0R0FBVCxTQUFTLGNBREksTUFBTTs7NEZBQ25CLFNBQVM7a0JBRHJCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBY3RpdmF0ZWRSb3V0ZVNuYXBzaG90LCBSb3V0ZXIsIFJvdXRlclN0YXRlU25hcHNob3QgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2F1dGguc2VydmljZSc7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJ3RhbmdvLWFwcC11aS1nbG9iYWwnO1xyXG5cclxuXHJcbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXHJcbmV4cG9ydCBjbGFzcyBBdXRoR3VhcmQgIHtcclxuICBwcml2YXRlIGF1dGhsb2NhbFN0b3JhZ2VUb2tlbjphbnk7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoU2VydmljZTogQXV0aFNlcnZpY2UscHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UsXHJcbiAgICBwcml2YXRlIHJvdXRlOiBSb3V0ZXIpIHtcclxuICAgIHRoaXMuZ3MuZW52aXJvbm1lbnQuc3Vic2NyaWJlKChlbnYpID0+IHtcclxuICAgICAgaWYgKGVudikge1xyXG4gICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDtcclxuICAgICAgfVxyXG4gICAgfSlcclxuICB9XHJcbiAgLy8gY2FuQWN0aXZhdGUocm91dGU6IEFjdGl2YXRlZFJvdXRlU25hcHNob3QsIHN0YXRlOiBSb3V0ZXJTdGF0ZVNuYXBzaG90KSB7XHJcblxyXG4gIC8vICAgLy8gY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnaXNMb2dnZWRJbicpO1xyXG4gIC8vICAgY29uc3QgY3VycmVudFVzZXIgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbik7XHJcbiAgLy8gICBpZiAoY3VycmVudFVzZXIpIHtcclxuICAvLyAgICAgICAgICAgLy8gdGhpcy5yb3V0ZS5uYXZpZ2F0ZShbJy9tYW5hZ2UnXSk7ICAgIFxyXG4gIC8vICAgICAgIHJldHVybiB0cnVlOyAgXHJcbiAgLy8gICB9IGVsc2Uge1xyXG4gIC8vICAgICAgICAgICB0aGlzLnJvdXRlLm5hdmlnYXRlKFsnL2F1dGgvbG9naW4nXSk7ICAgIFxyXG5cclxuICAvLyAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgLy8gICB9XHJcbiAgLy8gfVxyXG5cclxuICBjYW5BY3RpdmF0ZSgpOiBib29sZWFuIHtcclxuICAgIGNvbnN0IHRva2VuU3RyID0gdGhpcy5hdXRoU2VydmljZS5nZXRDb29raWUodGhpcy5hdXRobG9jYWxTdG9yYWdlVG9rZW4pO1xyXG5cclxuICAgIGlmICghdG9rZW5TdHIpIHtcclxuICAgICAgdGhpcy5yb3V0ZS5uYXZpZ2F0ZShbJy9hdXRoL2xvZ2luJ10pO1xyXG4gICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcblxyXG4gICAgdHJ5IHtcclxuICAgICAgY29uc3QgdG9rZW5EYXRhID0gSlNPTi5wYXJzZSh0b2tlblN0cik7XHJcbiAgICAgIGNvbnN0IGlzVmFsaWQgPSAhIXRva2VuRGF0YT8uYXV0aGVudGljYXRpb25Ub2tlbjtcclxuXHJcbiAgICAgIGlmICghaXNWYWxpZCkge1xyXG4gICAgICAgIHRoaXMucm91dGUubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgICAgfVxyXG5cclxuICAgICAgcmV0dXJuIGlzVmFsaWQ7XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgIGNvbnNvbGUuZXJyb3IoJ0ludmFsaWQgdG9rZW4gaW4gY29va2llJywgZSk7XHJcbiAgICAgIHRoaXMucm91dGUubmF2aWdhdGUoWycvYXV0aC9sb2dpbiddKTtcclxuICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,3 +1,4 @@
1
+ import { HttpHeaders } from "@angular/common/http";
1
2
  import { Injectable } from "@angular/core";
2
3
  import { BehaviorSubject, catchError, map, of, throwError, } from "rxjs";
3
4
  import * as i0 from "@angular/core";
@@ -33,12 +34,45 @@ export class AuthService {
33
34
  }
34
35
  });
35
36
  }
37
+ base64Encode(str) {
38
+ return btoa(encodeURIComponent(str));
39
+ }
40
+ base64Decode(str) {
41
+ return decodeURIComponent(atob(str));
42
+ }
43
+ setCookie(name, value, days = 1) {
44
+ const encodedValue = this.base64Encode(value);
45
+ const expires = new Date(Date.now() + days * 864e5).toUTCString();
46
+ document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;
47
+ }
48
+ getCookie(name) {
49
+ const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));
50
+ return match ? this.base64Decode(match[2]) : null;
51
+ }
52
+ // getHeaders() {
53
+ // const user: any = JSON.parse(
54
+ // localStorage.getItem(this.authlocalStorageToken) || "{}"
55
+ // );
56
+ // const headers = {
57
+ // Authorization: "Bearer " + user.authenticationToken,
58
+ // };
59
+ // return headers;
60
+ // }
36
61
  getHeaders() {
37
- const user = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || "{}");
38
- const headers = {
39
- Authorization: "Bearer " + user.authenticationToken,
62
+ const userTokenStr = this.getCookie(this.authlocalStorageToken);
63
+ let token = '';
64
+ if (userTokenStr) {
65
+ try {
66
+ const user = JSON.parse(userTokenStr);
67
+ token = user?.authenticationToken || '';
68
+ }
69
+ catch (e) {
70
+ console.error('Invalid token JSON in cookie');
71
+ }
72
+ }
73
+ return {
74
+ Authorization: 'Bearer ' + token
40
75
  };
41
- return headers;
42
76
  }
43
77
  logout() {
44
78
  localStorage.removeItem(this.authlocalStorageToken);
@@ -71,16 +105,32 @@ export class AuthService {
71
105
  return this.http.post(`${this.userApiUrl}/login`, data);
72
106
  }
73
107
  userProfileDet() {
108
+ // debugger
74
109
  const user = localStorage.getItem("user-info");
75
110
  if (user)
76
111
  return of(JSON.parse(user));
112
+ // console.log(this.getHeaders())
113
+ const headers = new HttpHeaders(this.getHeaders());
77
114
  return this.http
78
- .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
115
+ .get(`${this.userApiUrl}/profileV2`, { headers: headers })
79
116
  .pipe(map((response) => {
80
117
  localStorage.setItem("user-info", JSON.stringify(response.data));
81
118
  return response;
82
119
  }), catchError(this.handleError));
83
120
  }
121
+ // userProfileDet(): Observable<any> {
122
+ // const userStr = this.getCookie("user-info");
123
+ // if (userStr) return of(JSON.parse(userStr));
124
+ // return this.http
125
+ // .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
126
+ // .pipe(
127
+ // map((response: any) => {
128
+ // this.setCookie("user-info", JSON.stringify(response.data), 7);
129
+ // return response;
130
+ // }),
131
+ // catchError(this.handleError)
132
+ // );
133
+ // }
84
134
  getAllCountries() {
85
135
  return this.http.get(`${this.middlewareApiUrl}/get-countries`);
86
136
  }
@@ -114,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
114
164
  providedIn: "root",
115
165
  }]
116
166
  }], ctorParameters: () => [{ type: i1.Router }, { type: i2.HttpClient }, { type: i3.GlobalStateService }] });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-auth/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from \"@angular/common/http\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport {\r\n  BehaviorSubject,\r\n  Observable,\r\n  catchError,\r\n  map,\r\n  of,\r\n  throwError,\r\n} from \"rxjs\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class AuthService {\r\n  aboutFormData = new BehaviorSubject<any>(null);\r\n  pricingFormData = new BehaviorSubject<any>(null);\r\n  currentUserSubject = new BehaviorSubject<any>(null);\r\n  leadApiUrl: string = \"\";\r\n  middlewareApiUrl: string = \"\";\r\n  userApiUrl: string = \"\";\r\n  authlocalStorageToken: string;\r\n  paymentSubscriptionApiUrl: string;\r\n  get currentUserValue(): any {\r\n    return this.currentUserSubject.value;\r\n  }\r\n  constructor(\r\n    private router: Router,\r\n    private http: HttpClient,\r\n    private gs: GlobalStateService\r\n  ) {\r\n    this.gs.environment.subscribe((env) => {\r\n      if (env) {\r\n        this.leadApiUrl = env.leadApiUrl;\r\n        this.middlewareApiUrl = env.middlewareApiUrl;\r\n        this.paymentSubscriptionApiUrl = env.paymentSubscriptionApiUrl;\r\n        (this.userApiUrl = env.userApiUrl),\r\n          (this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`);\r\n      }\r\n    });\r\n  }\r\n\r\n  getHeaders() {\r\n    const user: any = JSON.parse(\r\n      localStorage.getItem(this.authlocalStorageToken) || \"{}\"\r\n    );\r\n    const headers = {\r\n      Authorization: \"Bearer \" + user.authenticationToken,\r\n    };\r\n\r\n    return headers;\r\n  }\r\n\r\n  logout() {\r\n    localStorage.removeItem(this.authlocalStorageToken);\r\n    this.router.navigate([\"/auth/login\"], {\r\n      queryParams: {},\r\n    });\r\n  }\r\n\r\n  sendSignupOtp(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/signup-otp`, data);\r\n  }\r\n\r\n  signup(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/signup`, data);\r\n  }\r\n\r\n  requestCallback(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/request-callback`, data);\r\n  }\r\n\r\n  isClientnameTaken(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/isClientExist`, data);\r\n  }\r\n\r\n  isEmailTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?corporateEmail=${data}`);\r\n  }\r\n\r\n  isMobileTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?mobileNumber=${data}`);\r\n  }\r\n\r\n  getCountryCodes(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/country-code`);\r\n  }\r\n\r\n  login(data: any): Observable<any> {\r\n    return this.http.post(`${this.userApiUrl}/login`, data);\r\n  }\r\n\r\n  userProfileDet(): Observable<any> {\r\n    const user: any = localStorage.getItem(\"user-info\");\r\n    if (user) return of(JSON.parse(user));\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  getAllCountries(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/get-countries`);\r\n  }\r\n\r\n  handleError(res: any) {\r\n    return throwError(res.error);\r\n  }\r\n\r\n  getPricing(data: any): Observable<any> {\r\n    return this.http.post(\r\n      `${this.paymentSubscriptionApiUrl}/basePricing`,\r\n      data\r\n    );\r\n  }\r\n\r\n  forgotPasswordTrigger(params: any): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/forgot-password-email`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  forgotPassword(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/forgot-password-update`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  termsAndConditionUpdate(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/termsAndConditionUpdate`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  \r\n}\r\n"]}
167
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.service.js","sourceRoot":"","sources":["../../../../../projects/tango-auth/src/lib/services/auth.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from \"@angular/common/http\";\r\nimport { Injectable } from \"@angular/core\";\r\nimport { Router } from \"@angular/router\";\r\nimport {\r\n  BehaviorSubject,\r\n  Observable,\r\n  catchError,\r\n  map,\r\n  of,\r\n  throwError,\r\n} from \"rxjs\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class AuthService {\r\n  aboutFormData = new BehaviorSubject<any>(null);\r\n  pricingFormData = new BehaviorSubject<any>(null);\r\n  currentUserSubject = new BehaviorSubject<any>(null);\r\n  leadApiUrl: string = \"\";\r\n  middlewareApiUrl: string = \"\";\r\n  userApiUrl: string = \"\";\r\n  authlocalStorageToken: string;\r\n  paymentSubscriptionApiUrl: string;\r\n  get currentUserValue(): any {\r\n    return this.currentUserSubject.value;\r\n  }\r\n  constructor(\r\n    private router: Router,\r\n    private http: HttpClient,\r\n    private gs: GlobalStateService\r\n  ) {\r\n    this.gs.environment.subscribe((env) => {\r\n      if (env) {\r\n        this.leadApiUrl = env.leadApiUrl;\r\n        this.middlewareApiUrl = env.middlewareApiUrl;\r\n        this.paymentSubscriptionApiUrl = env.paymentSubscriptionApiUrl;\r\n        (this.userApiUrl = env.userApiUrl),\r\n          (this.authlocalStorageToken = `${env.appVersion}-${env.USERDATA_KEY}`);\r\n      }\r\n    });\r\n  }\r\n  private base64Encode(str: any) {\r\n  return btoa(encodeURIComponent(str));\r\n}\r\n\r\nprivate base64Decode(str: any) {\r\n  return decodeURIComponent(atob(str));\r\n}\r\nsetCookie(name: string, value: string, days: number = 1): void {\r\n  const encodedValue = this.base64Encode(value);\r\n  const expires = new Date(Date.now() + days * 864e5).toUTCString();\r\n  document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;\r\n}\r\n\r\ngetCookie(name: string): string | null {\r\n  const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));\r\n  return match ? this.base64Decode(match[2]) : null;\r\n}\r\n  // getHeaders() {\r\n  //   const user: any = JSON.parse(\r\n  //     localStorage.getItem(this.authlocalStorageToken) || \"{}\"\r\n  //   );\r\n  //   const headers = {\r\n  //     Authorization: \"Bearer \" + user.authenticationToken,\r\n  //   };\r\n\r\n  //   return headers;\r\n  // }\r\ngetHeaders(): { [header: string]: string } {\r\n  const userTokenStr = this.getCookie(this.authlocalStorageToken);\r\n  let token = '';\r\n\r\n  if (userTokenStr) {\r\n    try {\r\n      const user = JSON.parse(userTokenStr);\r\n      token = user?.authenticationToken || '';\r\n    } catch (e) {\r\n      console.error('Invalid token JSON in cookie');\r\n    }\r\n  }\r\n\r\n  return {\r\n    Authorization: 'Bearer ' + token\r\n  };\r\n}\r\n  logout() {\r\n    localStorage.removeItem(this.authlocalStorageToken);\r\n    this.router.navigate([\"/auth/login\"], {\r\n      queryParams: {},\r\n    });\r\n  }\r\n\r\n  sendSignupOtp(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/signup-otp`, data);\r\n  }\r\n\r\n  signup(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/signup`, data);\r\n  }\r\n\r\n  requestCallback(data: any): Observable<any> {\r\n    return this.http.post(`${this.middlewareApiUrl}/request-callback`, data);\r\n  }\r\n\r\n  isClientnameTaken(data: any): Observable<any> {\r\n    return this.http.post(`${this.leadApiUrl}/isClientExist`, data);\r\n  }\r\n\r\n  isEmailTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?corporateEmail=${data}`);\r\n  }\r\n\r\n  isMobileTaken(data: string): Observable<any> {\r\n    return this.http.get(`${this.leadApiUrl}/isExists?mobileNumber=${data}`);\r\n  }\r\n\r\n  getCountryCodes(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/country-code`);\r\n  }\r\n\r\n  login(data: any): Observable<any> {\r\n    return this.http.post(`${this.userApiUrl}/login`, data);\r\n  }\r\n\r\n  userProfileDet(): Observable<any> {\r\n    // debugger\r\n    const user: any = localStorage.getItem(\"user-info\");\r\n    if (user) return of(JSON.parse(user));\r\n    // console.log(this.getHeaders())\r\n    const headers = new HttpHeaders(this.getHeaders());\r\n    return this.http\r\n      .get(`${this.userApiUrl}/profileV2`, { headers: headers })\r\n      .pipe(\r\n        map((response: any) => {\r\n          localStorage.setItem(\"user-info\", JSON.stringify(response.data));\r\n          return response;\r\n        }),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n// userProfileDet(): Observable<any> {\r\n//   const userStr = this.getCookie(\"user-info\");\r\n//   if (userStr) return of(JSON.parse(userStr));\r\n\r\n//   return this.http\r\n//     .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })\r\n//     .pipe(\r\n//       map((response: any) => {\r\n//         this.setCookie(\"user-info\", JSON.stringify(response.data), 7);\r\n//         return response;\r\n//       }),\r\n//       catchError(this.handleError)\r\n//     );\r\n// }\r\n\r\n  getAllCountries(): Observable<any> {\r\n    return this.http.get(`${this.middlewareApiUrl}/get-countries`);\r\n  }\r\n\r\n  handleError(res: any) {\r\n    return throwError(res.error);\r\n  }\r\n\r\n  getPricing(data: any): Observable<any> {\r\n    return this.http.post(\r\n      `${this.paymentSubscriptionApiUrl}/basePricing`,\r\n      data\r\n    );\r\n  }\r\n\r\n  forgotPasswordTrigger(params: any): Observable<any> {\r\n    return this.http\r\n      .get(`${this.userApiUrl}/forgot-password-email`, { params: params })\r\n      .pipe(\r\n        map((response: any) => response),\r\n        catchError(this.handleError)\r\n      );\r\n  }\r\n\r\n  forgotPassword(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/forgot-password-update`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  termsAndConditionUpdate(data: any): Observable<any> {\r\n    return this.http\r\n    .post(`${this.userApiUrl}/termsAndConditionUpdate`, data )\r\n    .pipe(\r\n      map((response: any) => response),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n  \r\n}\r\n"]}
@@ -11,6 +11,7 @@ import dayjs from 'dayjs';
11
11
  import * as CryptoJS from 'crypto-js';
12
12
  import CryptoJS__default from 'crypto-js';
13
13
  import * as i2 from '@angular/common/http';
14
+ import { HttpHeaders } from '@angular/common/http';
14
15
  import * as i4 from 'tango-app-ui-global';
15
16
  import * as i1 from '@ng-bootstrap/ng-bootstrap';
16
17
  import * as i5 from 'tango-app-ui-shared';
@@ -55,12 +56,45 @@ class AuthService {
55
56
  }
56
57
  });
57
58
  }
59
+ base64Encode(str) {
60
+ return btoa(encodeURIComponent(str));
61
+ }
62
+ base64Decode(str) {
63
+ return decodeURIComponent(atob(str));
64
+ }
65
+ setCookie(name, value, days = 1) {
66
+ const encodedValue = this.base64Encode(value);
67
+ const expires = new Date(Date.now() + days * 864e5).toUTCString();
68
+ document.cookie = `${name}=${encodedValue}; expires=${expires}; path=/; Secure; SameSite=Strict`;
69
+ }
70
+ getCookie(name) {
71
+ const match = document.cookie.match(new RegExp(`(^| )${name}=([^;]+)`));
72
+ return match ? this.base64Decode(match[2]) : null;
73
+ }
74
+ // getHeaders() {
75
+ // const user: any = JSON.parse(
76
+ // localStorage.getItem(this.authlocalStorageToken) || "{}"
77
+ // );
78
+ // const headers = {
79
+ // Authorization: "Bearer " + user.authenticationToken,
80
+ // };
81
+ // return headers;
82
+ // }
58
83
  getHeaders() {
59
- const user = JSON.parse(localStorage.getItem(this.authlocalStorageToken) || "{}");
60
- const headers = {
61
- Authorization: "Bearer " + user.authenticationToken,
84
+ const userTokenStr = this.getCookie(this.authlocalStorageToken);
85
+ let token = '';
86
+ if (userTokenStr) {
87
+ try {
88
+ const user = JSON.parse(userTokenStr);
89
+ token = user?.authenticationToken || '';
90
+ }
91
+ catch (e) {
92
+ console.error('Invalid token JSON in cookie');
93
+ }
94
+ }
95
+ return {
96
+ Authorization: 'Bearer ' + token
62
97
  };
63
- return headers;
64
98
  }
65
99
  logout() {
66
100
  localStorage.removeItem(this.authlocalStorageToken);
@@ -93,16 +127,32 @@ class AuthService {
93
127
  return this.http.post(`${this.userApiUrl}/login`, data);
94
128
  }
95
129
  userProfileDet() {
130
+ // debugger
96
131
  const user = localStorage.getItem("user-info");
97
132
  if (user)
98
133
  return of(JSON.parse(user));
134
+ // console.log(this.getHeaders())
135
+ const headers = new HttpHeaders(this.getHeaders());
99
136
  return this.http
100
- .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
137
+ .get(`${this.userApiUrl}/profileV2`, { headers: headers })
101
138
  .pipe(map((response) => {
102
139
  localStorage.setItem("user-info", JSON.stringify(response.data));
103
140
  return response;
104
141
  }), catchError(this.handleError));
105
142
  }
143
+ // userProfileDet(): Observable<any> {
144
+ // const userStr = this.getCookie("user-info");
145
+ // if (userStr) return of(JSON.parse(userStr));
146
+ // return this.http
147
+ // .get(`${this.userApiUrl}/profileV2`, { headers: this.getHeaders() })
148
+ // .pipe(
149
+ // map((response: any) => {
150
+ // this.setCookie("user-info", JSON.stringify(response.data), 7);
151
+ // return response;
152
+ // }),
153
+ // catchError(this.handleError)
154
+ // );
155
+ // }
106
156
  getAllCountries() {
107
157
  return this.http.get(`${this.middlewareApiUrl}/get-countries`);
108
158
  }
@@ -323,11 +373,21 @@ class TangoAuthLoginComponent {
323
373
  // this.router.navigateByUrl('/error/403')
324
374
  return;
325
375
  }
326
- let loginToken = localStorage.getItem(this.authlocalStorageToken);
376
+ // let loginToken: any =
377
+ // localStorage.getItem(this.authlocalStorageToken);
378
+ // if (loginToken) {
379
+ // loginToken = JSON.parse(loginToken);
380
+ // }
381
+ // localStorage.setItem(
382
+ // this.authlocalStorageToken,
383
+ // JSON.stringify(res?.data?.result)
384
+ // );
385
+ let loginToken = this.service.getCookie(this.authlocalStorageToken);
327
386
  if (loginToken) {
328
387
  loginToken = JSON.parse(loginToken);
329
388
  }
330
- localStorage.setItem(this.authlocalStorageToken, JSON.stringify(res?.data?.result));
389
+ // STEP 2: Store new token in cookie
390
+ this.service.setCookie(this.authlocalStorageToken, JSON.stringify(res?.data?.result), 7);
331
391
  if (!res?.data.termsAndCondition) {
332
392
  this.showTermsAndConditions();
333
393
  }
@@ -340,8 +400,10 @@ class TangoAuthLoginComponent {
340
400
  this.toastService.getErrorToast('Enter Valid Credentials');
341
401
  }
342
402
  else {
343
- this.credentials.password = originalPassword;
344
- this.toastService.getErrorToast('Enter Valid Credentials');
403
+ setTimeout(() => {
404
+ this.credentials.password = originalPassword;
405
+ this.toastService.getErrorToast('Enter Valid Credentials');
406
+ }, 100);
345
407
  }
346
408
  },
347
409
  error: (err) => {
@@ -1683,7 +1745,8 @@ class TangoAuthForgotPasswordComponent {
1683
1745
  const payload = {
1684
1746
  ...this.PasswordForm.value,
1685
1747
  password: encryptedPassword,
1686
- confirmPassword: encryptedPassword
1748
+ confirmPassword: encryptedPassword,
1749
+ loginType: "web",
1687
1750
  };
1688
1751
  this.authService.forgotPassword(payload).subscribe({
1689
1752
  next: (res) => {
@@ -1818,14 +1881,33 @@ class AuthGuard {
1818
1881
  }
1819
1882
  });
1820
1883
  }
1821
- canActivate(route, state) {
1822
- // const currentUser = localStorage.getItem('isLoggedIn');
1823
- const currentUser = localStorage.getItem(this.authlocalStorageToken);
1824
- if (currentUser) {
1825
- // this.route.navigate(['/manage']);
1826
- return true;
1884
+ // canActivate(route: ActivatedRouteSnapshot, state: RouterStateSnapshot) {
1885
+ // // const currentUser = localStorage.getItem('isLoggedIn');
1886
+ // const currentUser = localStorage.getItem(this.authlocalStorageToken);
1887
+ // if (currentUser) {
1888
+ // // this.route.navigate(['/manage']);
1889
+ // return true;
1890
+ // } else {
1891
+ // this.route.navigate(['/auth/login']);
1892
+ // return false;
1893
+ // }
1894
+ // }
1895
+ canActivate() {
1896
+ const tokenStr = this.authService.getCookie(this.authlocalStorageToken);
1897
+ if (!tokenStr) {
1898
+ this.route.navigate(['/auth/login']);
1899
+ return false;
1827
1900
  }
1828
- else {
1901
+ try {
1902
+ const tokenData = JSON.parse(tokenStr);
1903
+ const isValid = !!tokenData?.authenticationToken;
1904
+ if (!isValid) {
1905
+ this.route.navigate(['/auth/login']);
1906
+ }
1907
+ return isValid;
1908
+ }
1909
+ catch (e) {
1910
+ console.error('Invalid token in cookie', e);
1829
1911
  this.route.navigate(['/auth/login']);
1830
1912
  return false;
1831
1913
  }