common-header-lib 0.0.1

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.
Files changed (195) hide show
  1. package/README.md +24 -0
  2. package/assets/.gitkeep +0 -0
  3. package/assets/i18n/ar.json +83 -0
  4. package/assets/i18n/de.json +83 -0
  5. package/assets/i18n/en.json +83 -0
  6. package/assets/i18n/es.json +83 -0
  7. package/assets/i18n/fr.json +83 -0
  8. package/assets/i18n/hi.json +83 -0
  9. package/assets/i18n/ja.json +83 -0
  10. package/assets/i18n/ko.json +83 -0
  11. package/assets/images/APP019.svg +6 -0
  12. package/assets/images/APP020.svg +4 -0
  13. package/assets/images/APP021.svg +6 -0
  14. package/assets/images/APP022.svg +6 -0
  15. package/assets/images/APP023.svg +11 -0
  16. package/assets/images/APP024.svg +9 -0
  17. package/assets/images/APP025.svg +8 -0
  18. package/assets/images/APP026.svg +4 -0
  19. package/assets/images/APP027.svg +5 -0
  20. package/assets/images/APP028.svg +6 -0
  21. package/assets/images/APP029.svg +12 -0
  22. package/assets/images/APP030.svg +20 -0
  23. package/assets/images/APP031.svg +14 -0
  24. package/assets/images/APP032.svg +17 -0
  25. package/assets/images/Frame.svg +104 -0
  26. package/assets/images/apps-1.svg +22 -0
  27. package/assets/images/bell-icon.svg +3 -0
  28. package/assets/images/check_circle.svg +3 -0
  29. package/assets/images/close copy.svg +5 -0
  30. package/assets/images/close.svg +5 -0
  31. package/assets/images/copy-img.svg +3 -0
  32. package/assets/images/cross-search.svg +4 -0
  33. package/assets/images/domain_img.svg +3 -0
  34. package/assets/images/east.svg +3 -0
  35. package/assets/images/error.svg +3 -0
  36. package/assets/images/filepath.svg +8 -0
  37. package/assets/images/flag1.svg +3 -0
  38. package/assets/images/gc-mail.svg +3 -0
  39. package/assets/images/grey-arrow.svg +3 -0
  40. package/assets/images/info.svg +3 -0
  41. package/assets/images/local.svg +3 -0
  42. package/assets/images/lock-pass.svg +3 -0
  43. package/assets/images/lock1.svg +3 -0
  44. package/assets/images/login-bg/default_bg.svg +448 -0
  45. package/assets/images/login-bg/visibility.svg +3 -0
  46. package/assets/images/login-bg/visibility_off.svg +3 -0
  47. package/assets/images/logo.png +0 -0
  48. package/assets/images/logout.svg +3 -0
  49. package/assets/images/mail-icon.svg +3 -0
  50. package/assets/images/marker-pin.svg +4 -0
  51. package/assets/images/noti_ticket.svg +3 -0
  52. package/assets/images/pass-img.svg +3 -0
  53. package/assets/images/refresh-1.svg +3 -0
  54. package/assets/images/schedule.svg +1 -0
  55. package/assets/images/search-filter.svg +3 -0
  56. package/assets/images/search-icon.svg +3 -0
  57. package/assets/images/settings.svg +3 -0
  58. package/assets/images/successful.svg +10 -0
  59. package/assets/images/user-name.svg +3 -0
  60. package/assets/scss/_sidebar.scss +267 -0
  61. package/assets/scss/styles.scss +577 -0
  62. package/esm2020/common-header-lib.mjs +5 -0
  63. package/esm2020/lib/Validators/noSpaceAllowed.mjs +16 -0
  64. package/esm2020/lib/common-header-lib.component.mjs +612 -0
  65. package/esm2020/lib/common-header-lib.module.mjs +208 -0
  66. package/esm2020/lib/common-header-lib.service.mjs +200 -0
  67. package/esm2020/lib/components/confirm-dialog/confirm-dialog.component.mjs +49 -0
  68. package/esm2020/lib/components/general-configuration/general-configuration.component.mjs +402 -0
  69. package/esm2020/lib/components/general-configuration/landingpg-config/landingpg-config.component.mjs +124 -0
  70. package/esm2020/lib/components/general-configuration/timezone-configuration/timezone-configuration.component.mjs +138 -0
  71. package/esm2020/lib/components/grid-pagination/grid-pagination.component.mjs +39 -0
  72. package/esm2020/lib/components/ng-translation/ng-translation.component.mjs +65 -0
  73. package/esm2020/lib/components/no-service-my-access-pg/no-service-my-access-pg.component.mjs +19 -0
  74. package/esm2020/lib/components/notification-sidebar/notification-sidebar.component.mjs +40 -0
  75. package/esm2020/lib/components/side-popup/side-popup.component.mjs +34 -0
  76. package/esm2020/lib/components/user-mailbox/user-mailbox.component.mjs +173 -0
  77. package/esm2020/lib/components/user-sidebar/user-sidebar.component.mjs +279 -0
  78. package/esm2020/lib/components/viewpassword-popup/viewpassword-popup.component.mjs +196 -0
  79. package/esm2020/lib/model/data_model.mjs +217 -0
  80. package/esm2020/lib/pipes/custome-dateformat.pipe.mjs +27 -0
  81. package/esm2020/lib/pipes/date-diff.pipe.mjs +56 -0
  82. package/esm2020/lib/pipes/slice-to-two.pipe.mjs +34 -0
  83. package/esm2020/lib/services/EncrypDecryp_RSA.service.mjs +100 -0
  84. package/esm2020/lib/services/async-passwordcheck.service.mjs +72 -0
  85. package/esm2020/lib/services/cookie-storage-manager.service.mjs +78 -0
  86. package/esm2020/lib/services/encrpdata.service.mjs +55 -0
  87. package/esm2020/lib/services/encrydecrydata.service.mjs +207 -0
  88. package/esm2020/lib/services/event.service.mjs +133 -0
  89. package/esm2020/lib/services/http/http-common.service.mjs +216 -0
  90. package/esm2020/lib/services/http/http-general-config.service.mjs +84 -0
  91. package/esm2020/lib/services/rest-login-form.service.mjs +296 -0
  92. package/esm2020/lib/services/rest-signalr.service.mjs +100 -0
  93. package/esm2020/lib/services/storage.service.mjs +33 -0
  94. package/esm2020/lib/services/toast-msg.service.mjs +95 -0
  95. package/esm2020/lib/services/vapt-validation.service.mjs +31 -0
  96. package/esm2020/public-api.mjs +13 -0
  97. package/fesm2015/common-header-lib.mjs +4165 -0
  98. package/fesm2015/common-header-lib.mjs.map +1 -0
  99. package/fesm2020/common-header-lib.mjs +4146 -0
  100. package/fesm2020/common-header-lib.mjs.map +1 -0
  101. package/index.d.ts +5 -0
  102. package/lib/Validators/noSpaceAllowed.d.ts +2 -0
  103. package/lib/common-header-lib.component.d.ts +148 -0
  104. package/lib/common-header-lib.module.d.ts +43 -0
  105. package/lib/common-header-lib.service.d.ts +25 -0
  106. package/lib/components/confirm-dialog/confirm-dialog.component.d.ts +13 -0
  107. package/lib/components/general-configuration/general-configuration.component.d.ts +86 -0
  108. package/lib/components/general-configuration/landingpg-config/landingpg-config.component.d.ts +37 -0
  109. package/lib/components/general-configuration/timezone-configuration/timezone-configuration.component.d.ts +38 -0
  110. package/lib/components/grid-pagination/grid-pagination.component.d.ts +20 -0
  111. package/lib/components/ng-translation/ng-translation.component.d.ts +22 -0
  112. package/lib/components/no-service-my-access-pg/no-service-my-access-pg.component.d.ts +8 -0
  113. package/lib/components/notification-sidebar/notification-sidebar.component.d.ts +16 -0
  114. package/lib/components/side-popup/side-popup.component.d.ts +14 -0
  115. package/lib/components/user-mailbox/user-mailbox.component.d.ts +40 -0
  116. package/lib/components/user-sidebar/user-sidebar.component.d.ts +61 -0
  117. package/lib/components/viewpassword-popup/viewpassword-popup.component.d.ts +47 -0
  118. package/lib/model/data_model.d.ts +184 -0
  119. package/lib/pipes/custome-dateformat.pipe.d.ts +8 -0
  120. package/lib/pipes/date-diff.pipe.d.ts +9 -0
  121. package/lib/pipes/slice-to-two.pipe.d.ts +7 -0
  122. package/lib/services/EncrypDecryp_RSA.service.d.ts +15 -0
  123. package/lib/services/async-passwordcheck.service.d.ts +18 -0
  124. package/lib/services/cookie-storage-manager.service.d.ts +16 -0
  125. package/lib/services/encrpdata.service.d.ts +12 -0
  126. package/lib/services/encrydecrydata.service.d.ts +33 -0
  127. package/lib/services/event.service.d.ts +30 -0
  128. package/lib/services/http/http-common.service.d.ts +30 -0
  129. package/lib/services/http/http-general-config.service.d.ts +15 -0
  130. package/lib/services/rest-login-form.service.d.ts +39 -0
  131. package/lib/services/rest-signalr.service.d.ts +23 -0
  132. package/lib/services/storage.service.d.ts +11 -0
  133. package/lib/services/toast-msg.service.d.ts +21 -0
  134. package/lib/services/vapt-validation.service.d.ts +7 -0
  135. package/package.json +49 -0
  136. package/public-api.d.ts +8 -0
  137. package/src/assets/i18n/ar.json +83 -0
  138. package/src/assets/i18n/de.json +83 -0
  139. package/src/assets/i18n/en.json +83 -0
  140. package/src/assets/i18n/es.json +83 -0
  141. package/src/assets/i18n/fr.json +83 -0
  142. package/src/assets/i18n/hi.json +83 -0
  143. package/src/assets/i18n/ja.json +83 -0
  144. package/src/assets/i18n/ko.json +83 -0
  145. package/src/assets/images/APP019.svg +6 -0
  146. package/src/assets/images/APP020.svg +4 -0
  147. package/src/assets/images/APP021.svg +6 -0
  148. package/src/assets/images/APP022.svg +6 -0
  149. package/src/assets/images/APP023.svg +11 -0
  150. package/src/assets/images/APP024.svg +9 -0
  151. package/src/assets/images/APP025.svg +8 -0
  152. package/src/assets/images/APP026.svg +4 -0
  153. package/src/assets/images/APP027.svg +5 -0
  154. package/src/assets/images/APP028.svg +6 -0
  155. package/src/assets/images/APP029.svg +12 -0
  156. package/src/assets/images/APP030.svg +20 -0
  157. package/src/assets/images/APP031.svg +14 -0
  158. package/src/assets/images/APP032.svg +17 -0
  159. package/src/assets/images/Frame.svg +104 -0
  160. package/src/assets/images/apps-1.svg +22 -0
  161. package/src/assets/images/bell-icon.svg +3 -0
  162. package/src/assets/images/check_circle.svg +3 -0
  163. package/src/assets/images/close copy.svg +5 -0
  164. package/src/assets/images/close.svg +5 -0
  165. package/src/assets/images/copy-img.svg +3 -0
  166. package/src/assets/images/cross-search.svg +4 -0
  167. package/src/assets/images/domain_img.svg +3 -0
  168. package/src/assets/images/east.svg +3 -0
  169. package/src/assets/images/error.svg +3 -0
  170. package/src/assets/images/filepath.svg +8 -0
  171. package/src/assets/images/flag1.svg +3 -0
  172. package/src/assets/images/gc-mail.svg +3 -0
  173. package/src/assets/images/grey-arrow.svg +3 -0
  174. package/src/assets/images/info.svg +3 -0
  175. package/src/assets/images/local.svg +3 -0
  176. package/src/assets/images/lock-pass.svg +3 -0
  177. package/src/assets/images/lock1.svg +3 -0
  178. package/src/assets/images/login-bg/default_bg.svg +448 -0
  179. package/src/assets/images/login-bg/visibility.svg +3 -0
  180. package/src/assets/images/login-bg/visibility_off.svg +3 -0
  181. package/src/assets/images/logo.png +0 -0
  182. package/src/assets/images/logout.svg +3 -0
  183. package/src/assets/images/mail-icon.svg +3 -0
  184. package/src/assets/images/marker-pin.svg +4 -0
  185. package/src/assets/images/noti_ticket.svg +3 -0
  186. package/src/assets/images/pass-img.svg +3 -0
  187. package/src/assets/images/refresh-1.svg +3 -0
  188. package/src/assets/images/schedule.svg +1 -0
  189. package/src/assets/images/search-filter.svg +3 -0
  190. package/src/assets/images/search-icon.svg +3 -0
  191. package/src/assets/images/settings.svg +3 -0
  192. package/src/assets/images/successful.svg +10 -0
  193. package/src/assets/images/user-name.svg +3 -0
  194. package/src/assets/scss/_sidebar.scss +267 -0
  195. package/src/assets/scss/styles.scss +577 -0
@@ -0,0 +1,296 @@
1
+ import { HttpClient } from '@angular/common/http';
2
+ import { Injectable } from '@angular/core';
3
+ import { GlobalConstants } from '../model/data_model';
4
+ import { throwError } from 'rxjs';
5
+ import { map, catchError } from 'rxjs/operators';
6
+ import { CookieStorageManagerService } from './cookie-storage-manager.service';
7
+ import { EncrydecrydataService } from './encrydecrydata.service';
8
+ import { decode } from '@msgpack/msgpack';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common/http";
11
+ import * as i2 from "./cookie-storage-manager.service";
12
+ import * as i3 from "./encrydecrydata.service";
13
+ export class RESTLoginFormService {
14
+ constructor(_http, cookieService, _encryptDec) {
15
+ this._http = _http;
16
+ this.cookieService = cookieService;
17
+ this._encryptDec = _encryptDec;
18
+ }
19
+ /*Method : GET
20
+ Action : Fetch Domain List */
21
+ fetchDomainList() {
22
+ return this._http
23
+ .get(GlobalConstants.baseURL + 'meta/api/Metadata/Domains')
24
+ .pipe(map((response) => {
25
+ let result = [];
26
+ if (response['statusCode'] === 200) {
27
+ if (response['result'].length > 0) {
28
+ let result = response['result'];
29
+ return result;
30
+ }
31
+ else {
32
+ return [];
33
+ }
34
+ }
35
+ }), catchError((e) => throwError(this.errorHandler(e))));
36
+ }
37
+ errorHandler(e) {
38
+ throw new Error('Method not implemented.');
39
+ }
40
+ /*Method : POST
41
+ Parameter : subID , id
42
+ Action : Get configuration ID based on to show hide DOMAIN dropdown
43
+ */
44
+ getglobalConfigDetails(subid, id) {
45
+ return this._http
46
+ .post(GlobalConstants.baseURL +
47
+ 'meta/api/Metadata/GetArcosConfigsValues?subId=' +
48
+ subid, id)
49
+ .pipe(map((response) => {
50
+ let result = [];
51
+ if (response['statusCode'] === 200) {
52
+ let result = response['result'];
53
+ return result;
54
+ }
55
+ }), catchError((e) => throwError(this.errorHandler(e))));
56
+ }
57
+ /*Method : POST
58
+ Action : get login to user
59
+ */
60
+ // userAuthentication(userDetails: any) {
61
+ // return this._http
62
+ // .post(
63
+ // GlobalConstants.baseURL + 'xaccess/api/SecureAccess/Authenticate',
64
+ // userDetails
65
+ // )
66
+ // .pipe(
67
+ // map((response: any) => {
68
+ // if (response && response['data']) {
69
+ // return this.getDecryptAPIResponse(response['data']);
70
+ // }
71
+ // }),
72
+ // catchError((e) => throwError(this.errorHandler(e)))
73
+ // );
74
+ // }
75
+ /*Method : POST
76
+ Action : RESET Password for First Time User
77
+ */
78
+ setNewpassword(loggedInUserDetails) {
79
+ return this._http
80
+ .post(GlobalConstants.baseURL +
81
+ 'xaccess/api/SecureAccess/ChangeUserArcXwdManually', loggedInUserDetails)
82
+ .pipe(catchError((e) => throwError(this.errorHandler(e))));
83
+ }
84
+ /*Method : POST
85
+ Action :Will validate User entered PWD as
86
+ per Password Policy Set
87
+ */
88
+ validatePassword(userDetails) {
89
+ return this._http
90
+ .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidatePassword', userDetails)
91
+ .pipe(catchError((e) => throwError(this.errorHandler(e))));
92
+ }
93
+ /*Method : POST
94
+ Action : Get Public Key for encryption of Data */
95
+ getPrivateKey(params) {
96
+ return this._http
97
+ .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/XKEDSync', params)
98
+ .pipe(catchError((e) => throwError(this.errorHandler(e))));
99
+ }
100
+ /* Method : POST
101
+ Action : Send request for OTP of MFA Authenticator */
102
+ sendMFAOTPRequest(mfaDetails) {
103
+ return this._http
104
+ .post(GlobalConstants.baseURL + 'xmfa/api/Mfa/mfa', mfaDetails)
105
+ .pipe(map((response) => {
106
+ let result = [];
107
+ if (response['success']) {
108
+ let result = response['result'];
109
+ return result;
110
+ }
111
+ }), catchError((e) => throwError(this.errorHandler(e))));
112
+ }
113
+ /* Method : POST
114
+ Action : Submit User Enter OTP of MFA Authenticator */
115
+ submitOtpForMfaVerification(mfaDetails) {
116
+ return this._http
117
+ .post(GlobalConstants.baseURL + 'xmfa/api/Mfa/mfavalidation', mfaDetails)
118
+ .pipe(map((response) => {
119
+ let result = [];
120
+ if (response['success']) {
121
+ let result = response['result'];
122
+ return result;
123
+ }
124
+ }), catchError((e) => throwError(this.errorHandler(e))));
125
+ }
126
+ /*Method : POST
127
+ Action : It will provide Token which used for multiple Application access */
128
+ getAuthToken(userDetails) {
129
+ return this._http
130
+ .post(GlobalConstants.baseURL + 'xauth/api/Token/GenerateJwtTokenApplication', userDetails)
131
+ .pipe(map((response) => {
132
+ if (response) {
133
+ return response;
134
+ }
135
+ else {
136
+ return '';
137
+ }
138
+ }), catchError((e) => throwError(this.errorHandler(e))));
139
+ }
140
+ /* Method : GET
141
+ Action : It will provide Token which used to established MFA Method */
142
+ // getMFAAccessTokenKey() {
143
+ // return this._http
144
+ // .get<any>(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetMfaDetails')
145
+ // .pipe(
146
+ // map((response) => {
147
+ // if (response && response['data']) {
148
+ // return this.getDecryptAPIResponse(response['data']);
149
+ // }
150
+ // return {};
151
+ // }),
152
+ // catchError((e) => throwError(this.errorHandler(e)))
153
+ // );
154
+ // }
155
+ /* Method : POST
156
+ Action : It will check Valida User or not */
157
+ // checkUserExists(userDetails: any) {
158
+ // return this._http
159
+ // .post(
160
+ // GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUser',
161
+ // userDetails
162
+ // )
163
+ // .pipe(
164
+ // map((response: any) => {
165
+ // if (response && response['data']) {
166
+ // return this.getDecryptAPIResponse(response['data']);
167
+ // }
168
+ // return {};
169
+ // }),
170
+ // catchError((e) => throwError(this.errorHandler(e)))
171
+ // );
172
+ // }
173
+ /* Method : POST
174
+ Action : Unlock User to enable login process */
175
+ unlockUserAccount(userDetails) {
176
+ return this._http
177
+ .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUser', userDetails)
178
+ .pipe(map((result) => {
179
+ return result;
180
+ }), catchError((e) => throwError(this.errorHandler(e))));
181
+ }
182
+ /* Method : GET
183
+ Action : It will provide Third Parth AUth Method etc. Google, Okta, Microsoft */
184
+ // getThirdPartySignInMethods() {
185
+ // return this._http
186
+ // .get(
187
+ // GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetThirdPartyDetail'
188
+ // )
189
+ // .pipe(
190
+ // map((response: any) => {
191
+ // let result: any = [];
192
+ // if (response['success']) {
193
+ // return response['result'];
194
+ // }
195
+ // return result;
196
+ // }),
197
+ // catchError((error: any) => throwError(this.errorHandler(error)))
198
+ // );
199
+ // }
200
+ /* Method : POST
201
+ Action : It will Verify plugin version is correct or not */
202
+ // public verifyUserInstalledPluginVersion(pluginInfo: any) {
203
+ // return this._http
204
+ // .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/CheckAutoUpdatePAMPlugin',
205
+ // pluginInfo).pipe(
206
+ // map((response: any) => {
207
+ // return response['result'];
208
+ // }),
209
+ // catchError((error: any) => throwError(this.errorHandler(error)))
210
+ // );
211
+ // }
212
+ /**
213
+ * Verifies user authentication using Windows credentials.
214
+ */
215
+ // public checkAuthenticateWithWindowsCredentials(pluginInfo: any) {
216
+ // return this._http
217
+ // .post(GlobalConstants.baseURL + 'xdomainauth/api/DomainAuthentication/DomainAuth',
218
+ // // .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/DomainAuth',
219
+ // pluginInfo).pipe(
220
+ // map((response: any) => {
221
+ // if (response && response['data']) {
222
+ // return this.getDecryptAPIResponse(response['data']);
223
+ // }
224
+ // return {};
225
+ // }),
226
+ // catchError((error: any) => throwError(this.errorHandler(error)))
227
+ // );
228
+ // }
229
+ /*Method : GET
230
+ Action : Get User Background Image and Logo */
231
+ getUserBackgroundImageAndLogo() {
232
+ return this._http
233
+ .get(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetBackgroundImage')
234
+ .pipe(map((response) => {
235
+ return response;
236
+ }), catchError((error) => throwError(this.errorHandler(error))));
237
+ }
238
+ // public getVerifiedUserSessionDetails(authToken: string) {
239
+ // return this._http.post(
240
+ // GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUserSessionDetail', { state: authToken }).pipe(
241
+ // map((response: any) => {
242
+ // if (response && response['data']) {
243
+ // return this.getDecryptAPIResponse(response['data']);
244
+ // }
245
+ // return {};
246
+ // }),
247
+ // catchError((error: any) => throwError(this.errorHandler(error)))
248
+ // );
249
+ // }
250
+ deleteCookieData(payload) {
251
+ const url = this.cookieService.getCookieValue('baseurl');
252
+ const delCookieEndpoint = `${url}xaccess/api/SecureAccess/cookiesUpdation`;
253
+ return this._http.post(delCookieEndpoint, payload);
254
+ }
255
+ /**
256
+ * Decrypts a base64-encoded, MessagePack-encoded ciphertext into its original tuple form.
257
+ *
258
+ * @param cipherText - The encrypted string received from the API.
259
+ * @returns The decoded tuple [key, value] if decryption is successful; otherwise, an empty object.
260
+ *
261
+ * Steps:
262
+ * 1. Decrypts the cipherText using custom crypto method.
263
+ * 2. Decodes the base64 response into a binary Uint8Array.
264
+ * 3. Deserializes the binary using MessagePack's decode to get the original data.
265
+ */
266
+ // private getDecryptAPIResponse_old(cipherText: string): any {
267
+ // if (cipherText) {
268
+ // const responseString =
269
+ // this._encryptDec.decryptResponseViaCrypto(cipherText);
270
+ // const binary = Uint8Array.from(atob(responseString), c => c.charCodeAt(0));
271
+ // const decodedArray = decode(binary) as [string, string];
272
+ // // console.log(decodedArray);
273
+ // return decodedArray
274
+ // }
275
+ // return {};
276
+ // }
277
+ async getDecryptAPIResponse(cipherText) {
278
+ if (cipherText) {
279
+ const responseString = await this._encryptDec.decryptResponseViaCrypto(cipherText); // await here
280
+ const binary = Uint8Array.from(atob(responseString), (c) => c.charCodeAt(0));
281
+ const decodedArray = decode(binary);
282
+ // console.log(decodedArray);
283
+ return decodedArray;
284
+ }
285
+ return {};
286
+ }
287
+ }
288
+ RESTLoginFormService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RESTLoginFormService, deps: [{ token: i1.HttpClient }, { token: i2.CookieStorageManagerService }, { token: i3.EncrydecrydataService }], target: i0.ɵɵFactoryTarget.Injectable });
289
+ RESTLoginFormService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RESTLoginFormService, providedIn: 'root' });
290
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RESTLoginFormService, decorators: [{
291
+ type: Injectable,
292
+ args: [{
293
+ providedIn: 'root',
294
+ }]
295
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.CookieStorageManagerService }, { type: i3.EncrydecrydataService }]; } });
296
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rest-login-form.service.js","sourceRoot":"","sources":["../../../../../projects/common-header-lib/src/lib/services/rest-login-form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpParams } from '@angular/common/http';\r\nimport { Injectable } from '@angular/core';\r\nimport { GlobalConstants } from '../model/data_model';\r\nimport { throwError } from 'rxjs';\r\nimport { map, catchError } from 'rxjs/operators';\r\nimport { CookieStorageManagerService } from './cookie-storage-manager.service';\r\nimport { EncrydecrydataService } from './encrydecrydata.service';\r\nimport { decode } from '@msgpack/msgpack';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class RESTLoginFormService {\r\n  constructor(\r\n    private readonly _http: HttpClient,\r\n    private readonly cookieService: CookieStorageManagerService,\r\n    private readonly _encryptDec: EncrydecrydataService\r\n  ) {}\r\n\r\n  /*Method : GET\r\n   Action : Fetch Domain List  */\r\n  fetchDomainList() {\r\n    return this._http\r\n      .get(GlobalConstants.baseURL + 'meta/api/Metadata/Domains')\r\n      .pipe(\r\n        map((response: any) => {\r\n          let result = [];\r\n          if (response['statusCode'] === 200) {\r\n            if (response['result'].length > 0) {\r\n              let result = response['result'];\r\n              return result;\r\n            } else {\r\n              return [];\r\n            }\r\n          }\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  errorHandler(e: any): any {\r\n    throw new Error('Method not implemented.');\r\n  }\r\n\r\n  /*Method : POST\r\n  Parameter : subID  , id\r\n   Action : Get configuration ID based on to show hide DOMAIN dropdown\r\n     */\r\n\r\n  getglobalConfigDetails(subid: string, id: number[]) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL +\r\n          'meta/api/Metadata/GetArcosConfigsValues?subId=' +\r\n          subid,\r\n        id\r\n      )\r\n      .pipe(\r\n        map((response: any) => {\r\n          let result = [];\r\n          if (response['statusCode'] === 200) {\r\n            let result = response['result'];\r\n            return result;\r\n          }\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  /*Method : POST\r\n   Action : get login to user\r\n     */\r\n  // userAuthentication(userDetails: any) {\r\n  //   return this._http\r\n  //     .post(\r\n  //       GlobalConstants.baseURL + 'xaccess/api/SecureAccess/Authenticate',\r\n  //       userDetails\r\n  //     )\r\n  //     .pipe(\r\n  //       map((response: any) => {\r\n  //         if (response && response['data']) {\r\n\r\n  //           return this.getDecryptAPIResponse(response['data']);\r\n  //         }\r\n  //       }),\r\n  //       catchError((e) => throwError(this.errorHandler(e)))\r\n  //     );\r\n  // }\r\n\r\n  /*Method : POST\r\n   Action : RESET Password for First Time User\r\n     */\r\n  setNewpassword(loggedInUserDetails: any) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL +\r\n          'xaccess/api/SecureAccess/ChangeUserArcXwdManually',\r\n        loggedInUserDetails\r\n      )\r\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\r\n  }\r\n\r\n  /*Method : POST\r\n   Action :Will validate User entered PWD as\r\n  per Password Policy Set\r\n     */\r\n  validatePassword(userDetails: any) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidatePassword',\r\n        userDetails\r\n      )\r\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\r\n  }\r\n\r\n  /*Method : POST\r\n    Action : Get Public Key for encryption of Data  */\r\n  getPrivateKey(params: any) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL + 'xaccess/api/SecureAccess/XKEDSync',\r\n        params\r\n      )\r\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\r\n  }\r\n\r\n  /* Method : POST\r\n   Action : Send request for OTP of MFA Authenticator  */\r\n  sendMFAOTPRequest(mfaDetails: any) {\r\n    return this._http\r\n      .post(GlobalConstants.baseURL + 'xmfa/api/Mfa/mfa', mfaDetails)\r\n      .pipe(\r\n        map((response: any) => {\r\n          let result = [];\r\n          if (response['success']) {\r\n            let result = response['result'];\r\n            return result;\r\n          }\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  /* Method : POST\r\n   Action : Submit User Enter OTP of MFA Authenticator  */\r\n  submitOtpForMfaVerification(mfaDetails: any) {\r\n    return this._http\r\n      .post(GlobalConstants.baseURL + 'xmfa/api/Mfa/mfavalidation', mfaDetails)\r\n      .pipe(\r\n        map((response: any) => {\r\n          let result = [];\r\n          if (response['success']) {\r\n            let result = response['result'];\r\n            return result;\r\n          }\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  /*Method : POST\r\n   Action : It will provide Token which used for multiple Application access */\r\n  getAuthToken(userDetails: {}) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL + 'xauth/api/Token/GenerateJwtTokenApplication',\r\n        userDetails\r\n      )\r\n      .pipe(\r\n        map((response) => {\r\n          if (response) {\r\n            return response;\r\n          } else {\r\n            return '';\r\n          }\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  /* Method : GET\r\n   Action : It will provide Token which used to established MFA Method  */\r\n  // getMFAAccessTokenKey() {\r\n  //   return this._http\r\n  //     .get<any>(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetMfaDetails')\r\n  //     .pipe(\r\n  //       map((response) => {\r\n  //         if (response && response['data']) {\r\n  //           return this.getDecryptAPIResponse(response['data']);\r\n  //         }\r\n  //         return {};\r\n  //       }),\r\n  //       catchError((e) => throwError(this.errorHandler(e)))\r\n  //     );\r\n  // }\r\n\r\n  /* Method : POST\r\n   Action : It will check Valida User or not  */\r\n  // checkUserExists(userDetails: any) {\r\n  //   return this._http\r\n  //     .post(\r\n  //       GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUser',\r\n  //       userDetails\r\n  //     )\r\n  //     .pipe(\r\n  //       map((response: any) => {\r\n  //         if (response && response['data']) {\r\n  //           return this.getDecryptAPIResponse(response['data']);\r\n  //         }\r\n  //         return {};\r\n  //       }),\r\n  //       catchError((e) => throwError(this.errorHandler(e)))\r\n  //     );\r\n  // }\r\n\r\n  /* Method : POST\r\n   Action : Unlock User to enable login process */\r\n  unlockUserAccount(userDetails: any) {\r\n    return this._http\r\n      .post(\r\n        GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUser',\r\n        userDetails\r\n      )\r\n      .pipe(\r\n        map((result) => {\r\n          return result;\r\n        }),\r\n        catchError((e) => throwError(this.errorHandler(e)))\r\n      );\r\n  }\r\n\r\n  /* Method : GET\r\n   Action : It will provide Third Parth AUth Method etc. Google, Okta, Microsoft  */\r\n  // getThirdPartySignInMethods() {\r\n  //   return this._http\r\n  //     .get(\r\n  //       GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetThirdPartyDetail'\r\n  //     )\r\n  //     .pipe(\r\n  //       map((response: any) => {\r\n  //         let result: any = [];\r\n  //         if (response['success']) {\r\n  //           return response['result'];\r\n  //         }\r\n  //         return result;\r\n  //       }),\r\n  //       catchError((error: any) => throwError(this.errorHandler(error)))\r\n  //     );\r\n  // }\r\n\r\n  /* Method : POST\r\n   Action : It will Verify plugin version is correct or not */\r\n  // public verifyUserInstalledPluginVersion(pluginInfo: any) {\r\n  //   return this._http\r\n  //     .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/CheckAutoUpdatePAMPlugin',\r\n  //       pluginInfo).pipe(\r\n  //         map((response: any) => {\r\n  //           return response['result'];\r\n  //         }),\r\n  //         catchError((error: any) => throwError(this.errorHandler(error)))\r\n  //       );\r\n  // }\r\n\r\n  /**\r\n   * Verifies user authentication using Windows credentials.\r\n   */\r\n  // public checkAuthenticateWithWindowsCredentials(pluginInfo: any) {\r\n  //   return this._http\r\n  //     .post(GlobalConstants.baseURL + 'xdomainauth/api/DomainAuthentication/DomainAuth',\r\n  //       // .post(GlobalConstants.baseURL + 'xaccess/api/SecureAccess/DomainAuth',\r\n  //       pluginInfo).pipe(\r\n  //         map((response: any) => {\r\n  //           if (response && response['data']) {\r\n  //             return this.getDecryptAPIResponse(response['data']);\r\n  //           }\r\n  //           return {};\r\n  //         }),\r\n  //         catchError((error: any) => throwError(this.errorHandler(error)))\r\n  //       );\r\n  // }\r\n\r\n  /*Method : GET\r\n   Action : Get User Background Image and Logo  */\r\n  public getUserBackgroundImageAndLogo() {\r\n    return this._http\r\n      .get(\r\n        GlobalConstants.baseURL + 'xaccess/api/SecureAccess/GetBackgroundImage'\r\n      )\r\n      .pipe(\r\n        map((response: any) => {\r\n          return response;\r\n        }),\r\n        catchError((error: any) => throwError(this.errorHandler(error)))\r\n      );\r\n  }\r\n\r\n  // public getVerifiedUserSessionDetails(authToken: string) {\r\n  //   return this._http.post(\r\n  //     GlobalConstants.baseURL + 'xaccess/api/SecureAccess/ValidateUserSessionDetail', { state: authToken }).pipe(\r\n  //       map((response: any) => {\r\n  //         if (response && response['data']) {\r\n  //           return this.getDecryptAPIResponse(response['data']);\r\n  //         }\r\n  //         return {};\r\n  //       }),\r\n  //       catchError((error: any) => throwError(this.errorHandler(error)))\r\n  //     );\r\n  // }\r\n\r\n  deleteCookieData(payload: any) {\r\n    const url = this.cookieService.getCookieValue('baseurl');\r\n    const delCookieEndpoint = `${url}xaccess/api/SecureAccess/cookiesUpdation`;\r\n    return this._http.post(delCookieEndpoint, payload);\r\n  }\r\n\r\n  /**\r\n   * Decrypts a base64-encoded, MessagePack-encoded ciphertext into its original tuple form.\r\n   *\r\n   * @param cipherText - The encrypted string received from the API.\r\n   * @returns The decoded tuple [key, value] if decryption is successful; otherwise, an empty object.\r\n   *\r\n   * Steps:\r\n   * 1. Decrypts the cipherText using custom crypto method.\r\n   * 2. Decodes the base64 response into a binary Uint8Array.\r\n   * 3. Deserializes the binary using MessagePack's decode to get the original data.\r\n   */\r\n  // private getDecryptAPIResponse_old(cipherText: string): any {\r\n  //   if (cipherText) {\r\n  //     const responseString =\r\n  //       this._encryptDec.decryptResponseViaCrypto(cipherText);\r\n  //     const binary = Uint8Array.from(atob(responseString), c => c.charCodeAt(0));\r\n  //     const decodedArray = decode(binary) as [string, string];\r\n  //     // console.log(decodedArray);\r\n  //     return decodedArray\r\n  //   }\r\n  //   return {};\r\n  // }\r\n\r\n  private async getDecryptAPIResponse(cipherText: string): Promise<any> {\r\n    if (cipherText) {\r\n      const responseString = await this._encryptDec.decryptResponseViaCrypto(\r\n        cipherText\r\n      ); // await here\r\n      const binary = Uint8Array.from(atob(responseString), (c) =>\r\n        c.charCodeAt(0)\r\n      );\r\n      const decodedArray = decode(binary) as [string, string];\r\n      // console.log(decodedArray);\r\n      return decodedArray;\r\n    }\r\n    return {};\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,100 @@
1
+ import { COOKIECONSTANT, GlobalConstants, } from '../model/data_model';
2
+ import { Injectable } from '@angular/core';
3
+ import * as signalR from '@microsoft/signalr';
4
+ import { BehaviorSubject } from 'rxjs';
5
+ import { StorageService } from './storage.service';
6
+ import { EncrpdataService } from './encrpdata.service';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "./storage.service";
9
+ import * as i2 from "./encrpdata.service";
10
+ // import { CookieStorageManagerService } from '../cookie-storage-manager.service';
11
+ export class RestSignalRService {
12
+ constructor(_localStorage, _encrpdataService) {
13
+ this._localStorage = _localStorage;
14
+ this._encrpdataService = _encrpdataService;
15
+ this.eventMsg = new BehaviorSubject({});
16
+ this.AuthToken = "";
17
+ this.hubURLS = [];
18
+ //Method: Established the Connection With SignalR to get RealTime Data
19
+ this.establishedConnection = async () => {
20
+ // console.log('Token SingalR: ', this.AuthToken);
21
+ this.hubConnection = new signalR.HubConnectionBuilder()
22
+ .withUrl(`${GlobalConstants.signalRURL}/chatHub`, {
23
+ skipNegotiation: true,
24
+ transport: signalR.HttpTransportType.WebSockets,
25
+ headers: { Authorization: `Bearer ${this.AuthToken}` },
26
+ })
27
+ .build();
28
+ try {
29
+ await this.hubConnection.start();
30
+ console.log('SignalR connection established successfully');
31
+ this.addMessageListener();
32
+ }
33
+ catch (error) {
34
+ console.error('Error establishing SignalR connection:', error);
35
+ throw error;
36
+ }
37
+ };
38
+ }
39
+ async initializeSignalRConnection() {
40
+ if (!GlobalConstants.signalRURL) {
41
+ throw new Error('No hub URLs provided');
42
+ }
43
+ this.hubURLS = GlobalConstants.signalRURL ? GlobalConstants.signalRURL.split(',') : [];
44
+ if (this.hubURLS.length === 1) {
45
+ GlobalConstants.signalRURL = this.hubURLS[0];
46
+ await this.establishedConnection();
47
+ return;
48
+ }
49
+ let lastUsedIndex = this.getLastUsedIndex();
50
+ for (let i = 0; i < this.hubURLS.length; i++) {
51
+ const index = (lastUsedIndex + i) % this.hubURLS.length;
52
+ GlobalConstants.signalRURL = this.hubURLS[index];
53
+ try {
54
+ await this.establishedConnection();
55
+ this.setLastUsedIndex(index + 1); // Update for next round
56
+ break; // Exit the loop if connection is successful
57
+ }
58
+ catch (error) {
59
+ console.error(`Error connecting to hub ${this.hubURLS[index]}:`, error);
60
+ }
61
+ }
62
+ if (!this.hubConnection) {
63
+ throw new Error("All SignalR connections failed");
64
+ }
65
+ }
66
+ addMessageListener() {
67
+ this.hubConnection.on('ReceiveMessage', (user, data) => {
68
+ console.log('Rx SignalR: ', user, 'Data: ', data);
69
+ data = JSON.parse(data);
70
+ this.emitEventMsg(data);
71
+ });
72
+ }
73
+ emitEventMsg(data) {
74
+ this.eventMsg.next(data);
75
+ }
76
+ listenerEventMsg() {
77
+ return this.eventMsg.asObservable();
78
+ }
79
+ getLastUsedIndexv1() {
80
+ const lastIndex = this._localStorage.getData(COOKIECONSTANT.SIGNALR_INDEX);
81
+ return lastIndex ? Number(this._encrpdataService.decodeToBase64(lastIndex)) || 0 : 0;
82
+ }
83
+ getLastUsedIndex() {
84
+ const lastIndex = this._localStorage.getData(COOKIECONSTANT.SIGNALR_INDEX);
85
+ return lastIndex ? Number(this._encrpdataService.decodeToBase64(lastIndex)) || 0 : 0;
86
+ }
87
+ setLastUsedIndex(index) {
88
+ const lastIndex = this._encrpdataService.encodeToBase64(index.toString());
89
+ this._localStorage.saveData(COOKIECONSTANT.SIGNALR_INDEX, lastIndex);
90
+ }
91
+ }
92
+ RestSignalRService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RestSignalRService, deps: [{ token: i1.StorageService }, { token: i2.EncrpdataService }], target: i0.ɵɵFactoryTarget.Injectable });
93
+ RestSignalRService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RestSignalRService, providedIn: 'root' });
94
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RestSignalRService, decorators: [{
95
+ type: Injectable,
96
+ args: [{
97
+ providedIn: 'root',
98
+ }]
99
+ }], ctorParameters: function () { return [{ type: i1.StorageService }, { type: i2.EncrpdataService }]; } });
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rest-signalr.service.js","sourceRoot":"","sources":["../../../../../projects/common-header-lib/src/lib/services/rest-signalr.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  COOKIECONSTANT,\r\n  GlobalConstants,\r\n} from '../model/data_model';\r\nimport { Injectable } from '@angular/core';\r\nimport * as signalR from '@microsoft/signalr';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { StorageService } from './storage.service';\r\nimport { EncrpdataService } from './encrpdata.service';\r\n// import { CookieStorageManagerService } from '../cookie-storage-manager.service';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class RestSignalRService {\r\n  private hubConnection!: signalR.HubConnection;\r\n  protected eventMsg = new BehaviorSubject<any>({});\r\n  protected AuthToken: string = \"\";\r\n  private hubURLS: string[] = [];\r\n\r\n  constructor(\r\n    private readonly _localStorage: StorageService, private readonly _encrpdataService: EncrpdataService\r\n  ) { }\r\n\r\n  //Method: Established the Connection With SignalR to get RealTime Data\r\n  public establishedConnection = async () => {\r\n    // console.log('Token SingalR: ', this.AuthToken);\r\n    this.hubConnection = new signalR.HubConnectionBuilder()\r\n      .withUrl(`${GlobalConstants.signalRURL}/chatHub`, {\r\n        skipNegotiation: true,\r\n        transport: signalR.HttpTransportType.WebSockets,\r\n        headers: { Authorization: `Bearer ${this.AuthToken}` },\r\n      })\r\n      .build();\r\n\r\n    try {\r\n      await this.hubConnection.start();\r\n      console.log('SignalR connection established successfully');\r\n      this.addMessageListener();\r\n    }\r\n    catch (error) {\r\n      console.error('Error establishing SignalR connection:', error);\r\n      throw error;\r\n    }\r\n\r\n\r\n  };\r\n\r\n  public async initializeSignalRConnection(): Promise<void> {\r\n\r\n    if (!GlobalConstants.signalRURL) {\r\n      throw new Error('No hub URLs provided');\r\n    }\r\n\r\n    this.hubURLS = GlobalConstants.signalRURL ? GlobalConstants.signalRURL.split(',') : [];\r\n    if (this.hubURLS.length === 1) {\r\n      GlobalConstants.signalRURL = this.hubURLS[0];\r\n      await this.establishedConnection();\r\n      return;\r\n    }\r\n\r\n    let lastUsedIndex = this.getLastUsedIndex();\r\n\r\n    for (let i = 0; i < this.hubURLS.length; i++) {\r\n      const index = (lastUsedIndex + i) % this.hubURLS.length;\r\n      GlobalConstants.signalRURL = this.hubURLS[index];\r\n      try {\r\n        await this.establishedConnection();\r\n        this.setLastUsedIndex(index + 1);  // Update for next round\r\n        break;                            // Exit the loop if connection is successful\r\n      } catch (error) {\r\n        console.error(`Error connecting to hub ${this.hubURLS[index]}:`, error);\r\n      }\r\n    }\r\n\r\n    if (!this.hubConnection) {\r\n      throw new Error(\"All SignalR connections failed\");\r\n    }\r\n  }\r\n\r\n  public addMessageListener() {\r\n    this.hubConnection.on('ReceiveMessage', (user: any, data: any) => {\r\n      console.log('Rx SignalR: ', user, 'Data: ', data);\r\n      data = JSON.parse(data);\r\n      this.emitEventMsg(data);\r\n    });\r\n  }\r\n\r\n  emitEventMsg(data: any) {\r\n    this.eventMsg.next(data);\r\n  }\r\n\r\n  listenerEventMsg() {\r\n    return this.eventMsg.asObservable();\r\n  }\r\n\r\n  private getLastUsedIndexv1(): Number {\r\n    const lastIndex = this._localStorage.getData(COOKIECONSTANT.SIGNALR_INDEX);\r\n    return lastIndex ? Number(this._encrpdataService.decodeToBase64(lastIndex)) || 0 : 0;\r\n  }\r\n  private getLastUsedIndex(): number {\r\n    const lastIndex = this._localStorage.getData(COOKIECONSTANT.SIGNALR_INDEX);\r\n    return lastIndex ? Number(this._encrpdataService.decodeToBase64(lastIndex)) || 0 : 0;\r\n  }\r\n\r\n  private setLastUsedIndex(index: number): void {\r\n    const lastIndex = this._encrpdataService.encodeToBase64(index.toString());\r\n    this._localStorage.saveData(COOKIECONSTANT.SIGNALR_INDEX, lastIndex);\r\n  }\r\n\r\n}\r\n"]}
@@ -0,0 +1,33 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class StorageService {
4
+ constructor() { }
5
+ saveData(key, value) {
6
+ localStorage.setItem(key, value);
7
+ }
8
+ getData(key) {
9
+ return localStorage.getItem(key);
10
+ }
11
+ removeData(key) {
12
+ localStorage.removeItem(key);
13
+ }
14
+ clearData() {
15
+ localStorage.clear();
16
+ }
17
+ checkData(key) {
18
+ const data = localStorage.getItem(key);
19
+ if (data) {
20
+ return true;
21
+ }
22
+ return false;
23
+ }
24
+ }
25
+ StorageService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: StorageService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
26
+ StorageService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: StorageService, providedIn: 'root' });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: StorageService, decorators: [{
28
+ type: Injectable,
29
+ args: [{
30
+ providedIn: 'root',
31
+ }]
32
+ }], ctorParameters: function () { return []; } });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmFnZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uLWhlYWRlci1saWIvc3JjL2xpYi9zZXJ2aWNlcy9zdG9yYWdlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGNBQWM7SUFDekIsZ0JBQWUsQ0FBQztJQUVULFFBQVEsQ0FBQyxHQUFXLEVBQUUsS0FBYTtRQUN4QyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRU0sT0FBTyxDQUFDLEdBQVc7UUFDeEIsT0FBTyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ25DLENBQUM7SUFDTSxVQUFVLENBQUMsR0FBVztRQUMzQixZQUFZLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxTQUFTO1FBQ2QsWUFBWSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFTSxTQUFTLENBQUMsR0FBVztRQUMxQixNQUFNLElBQUksR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3ZDLElBQUksSUFBSSxFQUFFO1lBQ1IsT0FBTyxJQUFJLENBQUM7U0FDYjtRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzs7MkdBeEJVLGNBQWM7K0dBQWQsY0FBYyxjQUZiLE1BQU07MkZBRVAsY0FBYztrQkFIMUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU3RvcmFnZVNlcnZpY2Uge1xyXG4gIGNvbnN0cnVjdG9yKCkge31cclxuXHJcbiAgcHVibGljIHNhdmVEYXRhKGtleTogc3RyaW5nLCB2YWx1ZTogc3RyaW5nKSB7XHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShrZXksIHZhbHVlKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXREYXRhKGtleTogc3RyaW5nKSB7XHJcbiAgICByZXR1cm4gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICB9XHJcbiAgcHVibGljIHJlbW92ZURhdGEoa2V5OiBzdHJpbmcpIHtcclxuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGtleSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2xlYXJEYXRhKCkge1xyXG4gICAgbG9jYWxTdG9yYWdlLmNsZWFyKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2hlY2tEYXRhKGtleTogc3RyaW5nKTogYm9vbGVhbiB7XHJcbiAgICBjb25zdCBkYXRhID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oa2V5KTtcclxuICAgIGlmIChkYXRhKSB7XHJcbiAgICAgIHJldHVybiB0cnVlO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,95 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { ToastrService } from 'ngx-toastr';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "ngx-toastr";
5
+ export class ToastMsgService {
6
+ constructor(toastr) {
7
+ this.toastr = toastr;
8
+ this.toastType_sucess = 'toast-success';
9
+ this.toastType_info = 'toast-info';
10
+ this.toastType_error = 'toast-error';
11
+ this.toastType_warning = 'toast-warn';
12
+ }
13
+ success(textMessage) {
14
+ console.log(this.isToastMsgActive(), textMessage);
15
+ if (this.isToastMsgActive()) {
16
+ if (this.checkActiveToastMessagesByType(this.toastType_sucess)) {
17
+ this.updateActiveToastMessage(textMessage, this.toastType_sucess);
18
+ }
19
+ else {
20
+ this.toastr.success(textMessage);
21
+ }
22
+ }
23
+ else {
24
+ this.toastr.success(textMessage);
25
+ }
26
+ }
27
+ error(textMessage) {
28
+ if (this.isToastMsgActive()) {
29
+ if (this.checkActiveToastMessagesByType(this.toastType_error)) {
30
+ this.updateActiveToastMessage(textMessage, this.toastType_error);
31
+ }
32
+ else {
33
+ this.toastr.error(textMessage);
34
+ }
35
+ }
36
+ else {
37
+ this.toastr.error(textMessage);
38
+ }
39
+ }
40
+ info(textMessage) {
41
+ if (this.isToastMsgActive()) {
42
+ if (this.checkActiveToastMessagesByType(this.toastType_info)) {
43
+ this.updateActiveToastMessage(textMessage, this.toastType_info);
44
+ }
45
+ else {
46
+ this.toastr.info(textMessage);
47
+ }
48
+ }
49
+ else {
50
+ this.toastr.info(textMessage);
51
+ }
52
+ }
53
+ warning(textMessage) {
54
+ if (this.isToastMsgActive()) {
55
+ if (this.checkActiveToastMessagesByType(this.toastType_warning)) {
56
+ this.updateActiveToastMessage(textMessage, this.toastType_warning);
57
+ }
58
+ else {
59
+ this.toastr.warning(textMessage);
60
+ }
61
+ }
62
+ else {
63
+ this.toastr.warning(textMessage);
64
+ }
65
+ }
66
+ updateActiveToastMessage(textMessage, ToastType) {
67
+ const activeToasts = this.getActiveToastMessagesByType(ToastType);
68
+ if (activeToasts.length > 0) {
69
+ const toastObj = activeToasts[0];
70
+ toastObj.toastRef.componentInstance.message = textMessage;
71
+ // console.log('Updated Toast: ', toastObj.toastRef.componentInstance);
72
+ }
73
+ }
74
+ isToastMsgActive() {
75
+ return this.toastr.currentlyActive ? true : false;
76
+ }
77
+ getActiveToastMessagesByType(type) {
78
+ return this.toastr.toasts.filter((toastItem) => toastItem.toastRef.componentInstance.toastPackage.toastType.includes(type));
79
+ }
80
+ checkActiveToastMessagesByType(type) {
81
+ return this.toastr.toasts.some((toastItem) => toastItem.toastRef.componentInstance.toastPackage.toastType == type);
82
+ }
83
+ clear() {
84
+ this.toastr.clear();
85
+ }
86
+ }
87
+ ToastMsgService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ToastMsgService, deps: [{ token: i1.ToastrService }], target: i0.ɵɵFactoryTarget.Injectable });
88
+ ToastMsgService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ToastMsgService, providedIn: 'root' });
89
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ToastMsgService, decorators: [{
90
+ type: Injectable,
91
+ args: [{
92
+ providedIn: 'root',
93
+ }]
94
+ }], ctorParameters: function () { return [{ type: i1.ToastrService }]; } });
95
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QtbXNnLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21tb24taGVhZGVyLWxpYi9zcmMvbGliL3NlcnZpY2VzL3RvYXN0LW1zZy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUE2QixhQUFhLEVBQUUsTUFBTSxZQUFZLENBQUM7OztBQUt0RSxNQUFNLE9BQU8sZUFBZTtJQU0xQixZQUFvQixNQUFxQjtRQUFyQixXQUFNLEdBQU4sTUFBTSxDQUFlO1FBTGpDLHFCQUFnQixHQUFXLGVBQWUsQ0FBQztRQUMzQyxtQkFBYyxHQUFXLFlBQVksQ0FBQztRQUN0QyxvQkFBZSxHQUFXLGFBQWEsQ0FBQztRQUN4QyxzQkFBaUIsR0FBVyxZQUFZLENBQUM7SUFFTCxDQUFDO0lBRTdDLE9BQU8sQ0FBQyxXQUFtQjtRQUN6QixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBRWxELElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLEVBQUU7WUFDM0IsSUFBSSxJQUFJLENBQUMsOEJBQThCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEVBQUU7Z0JBQzlELElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7YUFDbkU7aUJBQU07Z0JBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7YUFDbEM7U0FDRjthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDbEM7SUFDSCxDQUFDO0lBRUQsS0FBSyxDQUFDLFdBQW1CO1FBQ3ZCLElBQUksSUFBSSxDQUFDLGdCQUFnQixFQUFFLEVB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VSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBY3RpdmVUb2FzdCwgVG9hc3RQYWNrYWdlLCBUb2FzdHJTZXJ2aWNlIH0gZnJvbSAnbmd4LXRvYXN0cic7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVG9hc3RNc2dTZXJ2aWNlIHtcclxuICBwcml2YXRlIHRvYXN0VHlwZV9zdWNlc3M6IHN0cmluZyA9ICd0b2FzdC1zdWNjZXNzJztcclxuICBwcml2YXRlIHRvYXN0VHlwZV9pbmZvOiBzdHJpbmcgPSAndG9hc3QtaW5mbyc7XHJcbiAgcHJpdmF0ZSB0b2FzdFR5cGVfZXJyb3I6IHN0cmluZyA9ICd0b2FzdC1lcnJvcic7XHJcbiAgcHJpdmF0ZSB0b2FzdFR5cGVfd2FybmluZzogc3RyaW5nID0gJ3RvYXN0LXdhcm4nO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHRvYXN0cjogVG9hc3RyU2VydmljZSkge31cclxuXHJcbiAgc3VjY2Vzcyh0ZXh0TWVzc2FnZTogc3RyaW5nKSB7XHJcbiAgICBjb25zb2xlLmxvZyh0aGlzLmlzVG9hc3RNc2dBY3RpdmUoKSwgdGV4dE1lc3NhZ2UpO1xyXG5cclxuICAgIGlmICh0aGlzLmlzVG9hc3RNc2dBY3RpdmUoKSkge1xyXG4gICAgICBpZiAodGhpcy5jaGVja0FjdGl2ZVRvYXN0TWVzc2FnZXNCeVR5cGUodGhpcy50b2FzdFR5cGVfc3VjZXNzKSkge1xyXG4gICAgICAgIHRoaXMudXBkYXRlQWN0aXZlVG9hc3RNZXNzYWdlKHRleHRNZXNzYWdlLCB0aGlzLnRvYXN0VHlwZV9zdWNlc3MpO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRoaXMudG9hc3RyLnN1Y2Nlc3ModGV4dE1lc3NhZ2UpO1xyXG4gICAgICB9XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLnRvYXN0ci5zdWNjZXNzKHRleHRNZXNzYWdlKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGVycm9yKHRleHRNZXNzYWdlOiBzdHJpbmcpIHtcclxuICAgIGlmICh0aGlzLmlzVG9hc3RNc2dBY3RpdmUoKSkge1xyXG4gICAgICBpZiAodGhpcy5jaGVja0FjdGl2ZVRvYXN0TWVzc2FnZXNCeVR5cGUodGhpcy50b2FzdFR5cGVfZXJyb3IpKSB7XHJcbiAgICAgICAgdGhpcy51cGRhdGVBY3RpdmVUb2FzdE1lc3NhZ2UodGV4dE1lc3NhZ2UsIHRoaXMudG9hc3RUeXBlX2Vycm9yKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICB0aGlzLnRvYXN0ci5lcnJvcih0ZXh0TWVzc2FnZSk7XHJcbiAgICAgIH1cclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMudG9hc3RyLmVycm9yKHRleHRNZXNzYWdlKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIGluZm8odGV4dE1lc3NhZ2U6IHN0cmluZykge1xyXG4gICAgaWYgKHRoaXMuaXNUb2FzdE1zZ0FjdGl2ZSgpKSB7XHJcbiAgICAgIGlmICh0aGlzLmNoZWNrQWN0aXZlVG9hc3RNZXNzYWdlc0J5VHlwZSh0aGlzLnRvYXN0VHlwZV9pbmZvKSkge1xyXG4gICAgICAgIHRoaXMudXBkYXRlQWN0aXZlVG9hc3RNZXNzYWdlKHRleHRNZXNzYWdlLCB0aGlzLnRvYXN0VHlwZV9pbmZvKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICB0aGlzLnRvYXN0ci5pbmZvKHRleHRNZXNzYWdlKTtcclxuICAgICAgfVxyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy50b2FzdHIuaW5mbyh0ZXh0TWVzc2FnZSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICB3YXJuaW5nKHRleHRNZXNzYWdlOiBzdHJpbmcpIHtcclxuICAgIGlmICh0aGlzLmlzVG9hc3RNc2dBY3RpdmUoKSkge1xyXG4gICAgICBpZiAodGhpcy5jaGVja0FjdGl2ZVRvYXN0TWVzc2FnZXNCeVR5cGUodGhpcy50b2FzdFR5cGVfd2FybmluZykpIHtcclxuICAgICAgICB0aGlzLnVwZGF0ZUFjdGl2ZVRvYXN0TWVzc2FnZSh0ZXh0TWVzc2FnZSwgdGhpcy50b2FzdFR5cGVfd2FybmluZyk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgdGhpcy50b2FzdHIud2FybmluZyh0ZXh0TWVzc2FnZSk7XHJcbiAgICAgIH1cclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMudG9hc3RyLndhcm5pbmcodGV4dE1lc3NhZ2UpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSB1cGRhdGVBY3RpdmVUb2FzdE1lc3NhZ2UoXHJcbiAgICB0ZXh0TWVzc2FnZTogc3RyaW5nLFxyXG4gICAgVG9hc3RUeXBlOiBzdHJpbmdcclxuICApOiB2b2lkIHtcclxuICAgIGNvbnN0IGFjdGl2ZVRvYXN0cyA9IHRoaXMuZ2V0QWN0aXZlVG9hc3RNZXNzYWdlc0J5VHlwZShUb2FzdFR5cGUpO1xyXG5cclxuICAgIGlmIChhY3RpdmVUb2FzdHMubGVuZ3RoID4gMCkge1xyXG4gICAgICBjb25zdCB0b2FzdE9iaiA9IGFjdGl2ZVRvYXN0c1swXTtcclxuICAgICAgdG9hc3RPYmoudG9hc3RSZWYuY29tcG9uZW50SW5zdGFuY2UubWVzc2FnZSA9IHRleHRNZXNzYWdlO1xyXG4gICAgICAvLyBjb25zb2xlLmxvZygnVXBkYXRlZCBUb2FzdDogJywgdG9hc3RPYmoudG9hc3RSZWYuY29tcG9uZW50SW5zdGFuY2UpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBpc1RvYXN0TXNnQWN0aXZlKCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMudG9hc3RyLmN1cnJlbnRseUFjdGl2ZSA/IHRydWUgOiBmYWxzZTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgZ2V0QWN0aXZlVG9hc3RNZXNzYWdlc0J5VHlwZSh0eXBlOiBzdHJpbmcpOiBBY3RpdmVUb2FzdDxhbnk+W10ge1xyXG4gICAgcmV0dXJuIHRoaXMudG9hc3RyLnRvYXN0cy5maWx0ZXIoKHRvYXN0SXRlbSkgPT5cclxuICAgICAgdG9hc3RJdGVtLnRvYXN0UmVmLmNvbXBvbmVudEluc3RhbmNlLnRvYXN0UGFja2FnZS50b2FzdFR5cGUuaW5jbHVkZXModHlwZSlcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIGNoZWNrQWN0aXZlVG9hc3RNZXNzYWdlc0J5VHlwZSh0eXBlOiBzdHJpbmcpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLnRvYXN0ci50b2FzdHMuc29tZShcclxuICAgICAgKHRvYXN0SXRlbSkgPT5cclxuICAgICAgICB0b2FzdEl0ZW0udG9hc3RSZWYuY29tcG9uZW50SW5zdGFuY2UudG9hc3RQYWNrYWdlLnRvYXN0VHlwZSA9PSB0eXBlXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGNsZWFyKCkge1xyXG4gICAgdGhpcy50b2FzdHIuY2xlYXIoKTtcclxuICB9XHJcbn1cclxuIl19
@@ -0,0 +1,31 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class VaptValidationService {
4
+ constructor() { }
5
+ hasUnsafeInput(formData) {
6
+ const dangerousPattern = /<\s*(script|iframe|object|embed|link|style)\b[^>]*>(.*?)<\s*\/\s*\1\s*>|<\s*(script|iframe|object|embed|link|style)\b[^>]*\/?>|<[^>]+>/gi;
7
+ function checkValue(value) {
8
+ if (typeof value === 'string') {
9
+ return dangerousPattern.test(value);
10
+ }
11
+ if (Array.isArray(value)) {
12
+ return value.some(checkValue);
13
+ }
14
+ if (typeof value === 'object' && value !== null) {
15
+ return Object.values(value).some(checkValue);
16
+ }
17
+ // If it's a number, boolean, null, or undefined, ignore
18
+ return false;
19
+ }
20
+ return checkValue(formData);
21
+ }
22
+ }
23
+ VaptValidationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: VaptValidationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
24
+ VaptValidationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: VaptValidationService, providedIn: 'root' });
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: VaptValidationService, decorators: [{
26
+ type: Injectable,
27
+ args: [{
28
+ providedIn: 'root'
29
+ }]
30
+ }], ctorParameters: function () { return []; } });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFwdC12YWxpZGF0aW9uLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21tb24taGVhZGVyLWxpYi9zcmMvbGliL3NlcnZpY2VzL3ZhcHQtdmFsaWRhdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxxQkFBcUI7SUFFaEMsZ0JBQWdCLENBQUM7SUFFakIsY0FBYyxDQUFDLFFBQWE7UUFDMUIsTUFBTSxnQkFBZ0IsR0FBRywwSUFBMEksQ0FBQztRQUVwSyxTQUFTLFVBQVUsQ0FBQyxLQUFVO1lBQzVCLElBQUksT0FBTyxLQUFLLEtBQUssUUFBUSxFQUFFO2dCQUM3QixPQUFPLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNyQztZQUVELElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDeEIsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2FBQy9CO1lBRUQsSUFBSSxPQUFPLEtBQUssS0FBSyxRQUFRLElBQUksS0FBSyxLQUFLLElBQUksRUFBRTtnQkFDL0MsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQzthQUM5QztZQUVELHdEQUF3RDtZQUN4RCxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFFRCxPQUFPLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUM5QixDQUFDOztrSEF6QlUscUJBQXFCO3NIQUFyQixxQkFBcUIsY0FGcEIsTUFBTTsyRkFFUCxxQkFBcUI7a0JBSGpDLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFwdFZhbGlkYXRpb25TZXJ2aWNlIHtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgaGFzVW5zYWZlSW5wdXQoZm9ybURhdGE6IGFueSk6IGJvb2xlYW4ge1xyXG4gICAgY29uc3QgZGFuZ2Vyb3VzUGF0dGVybiA9IC88XFxzKihzY3JpcHR8aWZyYW1lfG9iamVjdHxlbWJlZHxsaW5rfHN0eWxlKVxcYltePl0qPiguKj8pPFxccypcXC9cXHMqXFwxXFxzKj58PFxccyooc2NyaXB0fGlmcmFtZXxvYmplY3R8ZW1iZWR8bGlua3xzdHlsZSlcXGJbXj5dKlxcLz8+fDxbXj5dKz4vZ2k7XHJcblxyXG4gICAgZnVuY3Rpb24gY2hlY2tWYWx1ZSh2YWx1ZTogYW55KTogYm9vbGVhbiB7XHJcbiAgICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XHJcbiAgICAgICAgcmV0dXJuIGRhbmdlcm91c1BhdHRlcm4udGVzdCh2YWx1ZSk7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIGlmIChBcnJheS5pc0FycmF5KHZhbHVlKSkge1xyXG4gICAgICAgIHJldHVybiB2YWx1ZS5zb21lKGNoZWNrVmFsdWUpO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBpZiAodHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiB2YWx1ZSAhPT0gbnVsbCkge1xyXG4gICAgICAgIHJldHVybiBPYmplY3QudmFsdWVzKHZhbHVlKS5zb21lKGNoZWNrVmFsdWUpO1xyXG4gICAgICB9XHJcblxyXG4gICAgICAvLyBJZiBpdCdzIGEgbnVtYmVyLCBib29sZWFuLCBudWxsLCBvciB1bmRlZmluZWQsIGlnbm9yZVxyXG4gICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGNoZWNrVmFsdWUoZm9ybURhdGEpO1xyXG4gIH1cclxufVxyXG4iXX0=