@doolehealth/service-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 (72) hide show
  1. package/README.md +24 -0
  2. package/esm2022/doolehealth-service-lib.mjs +5 -0
  3. package/esm2022/lib/configuration.mjs +5 -0
  4. package/esm2022/lib/models/user.mjs +2 -0
  5. package/esm2022/lib/service-lib.component.mjs +19 -0
  6. package/esm2022/lib/service-lib.module.mjs +33 -0
  7. package/esm2022/lib/services/analytics.service.mjs +73 -0
  8. package/esm2022/lib/services/api-endpoints.service.mjs +51 -0
  9. package/esm2022/lib/services/authentication.service.mjs +400 -0
  10. package/esm2022/lib/services/change-endpoints.service.mjs +90 -0
  11. package/esm2022/lib/services/date.service.mjs +419 -0
  12. package/esm2022/lib/services/doole.service.mjs +1299 -0
  13. package/esm2022/lib/services/encryption.service.mjs +31 -0
  14. package/esm2022/lib/services/error.service.mjs +49 -0
  15. package/esm2022/lib/services/events.service.mjs +63 -0
  16. package/esm2022/lib/services/highcharts.service.mjs +621 -0
  17. package/esm2022/lib/services/http.service.mjs +124 -0
  18. package/esm2022/lib/services/language.service.mjs +38 -0
  19. package/esm2022/lib/services/loading.service.mjs +45 -0
  20. package/esm2022/lib/services/logging.service.mjs +28 -0
  21. package/esm2022/lib/services/navigation.service.mjs +41 -0
  22. package/esm2022/lib/services/network.service.mjs +42 -0
  23. package/esm2022/lib/services/notification.service.mjs +202 -0
  24. package/esm2022/lib/services/opentok.service.mjs +25 -0
  25. package/esm2022/lib/services/roles.service.mjs +44 -0
  26. package/esm2022/lib/services/storage.service.mjs +37 -0
  27. package/esm2022/lib/services/token.service.mjs +59 -0
  28. package/esm2022/lib/util/chatParameters.mjs +17 -0
  29. package/esm2022/lib/util/data-store.mjs +54 -0
  30. package/esm2022/lib/util/environment.mjs +29 -0
  31. package/esm2022/lib/util/language.model.mjs +3 -0
  32. package/esm2022/lib/util/notification-options.mjs +245 -0
  33. package/esm2022/lib/util/query-string-parameters.mjs +11 -0
  34. package/esm2022/lib/util/url-builder.mjs +15 -0
  35. package/esm2022/public-api.mjs +30 -0
  36. package/fesm2022/doolehealth-service-lib.mjs +4025 -0
  37. package/fesm2022/doolehealth-service-lib.mjs.map +1 -0
  38. package/index.d.ts +5 -0
  39. package/lib/configuration.d.ts +46 -0
  40. package/lib/models/user.d.ts +133 -0
  41. package/lib/service-lib.component.d.ts +5 -0
  42. package/lib/service-lib.module.d.ts +13 -0
  43. package/lib/services/analytics.service.d.ts +17 -0
  44. package/lib/services/api-endpoints.service.d.ts +13 -0
  45. package/lib/services/authentication.service.d.ts +102 -0
  46. package/lib/services/change-endpoints.service.d.ts +38 -0
  47. package/lib/services/date.service.d.ts +58 -0
  48. package/lib/services/doole.service.d.ts +169 -0
  49. package/lib/services/encryption.service.d.ts +9 -0
  50. package/lib/services/error.service.d.ts +11 -0
  51. package/lib/services/events.service.d.ts +32 -0
  52. package/lib/services/highcharts.service.d.ts +69 -0
  53. package/lib/services/http.service.d.ts +28 -0
  54. package/lib/services/language.service.d.ts +15 -0
  55. package/lib/services/loading.service.d.ts +22 -0
  56. package/lib/services/logging.service.d.ts +9 -0
  57. package/lib/services/navigation.service.d.ts +13 -0
  58. package/lib/services/network.service.d.ts +14 -0
  59. package/lib/services/notification.service.d.ts +25 -0
  60. package/lib/services/opentok.service.d.ts +17 -0
  61. package/lib/services/roles.service.d.ts +28 -0
  62. package/lib/services/storage.service.d.ts +10 -0
  63. package/lib/services/token.service.d.ts +16 -0
  64. package/lib/util/chatParameters.d.ts +25 -0
  65. package/lib/util/data-store.d.ts +13 -0
  66. package/lib/util/environment.d.ts +18 -0
  67. package/lib/util/language.model.d.ts +4 -0
  68. package/lib/util/notification-options.d.ts +145 -0
  69. package/lib/util/query-string-parameters.d.ts +6 -0
  70. package/lib/util/url-builder.d.ts +9 -0
  71. package/package.json +38 -0
  72. package/public-api.d.ts +23 -0
@@ -0,0 +1,400 @@
1
+ import { Inject, Injectable, PLATFORM_ID, ViewChild } from '@angular/core';
2
+ import { Preferences } from '@capacitor/preferences';
3
+ import { map, tap } from 'rxjs/operators';
4
+ import { BehaviorSubject } from 'rxjs';
5
+ import { HttpErrorResponse } from '@angular/common/http';
6
+ import { RouterOutlet } from '@angular/router';
7
+ import { TranslateService } from '@ngx-translate/core';
8
+ import { Capacitor } from '@capacitor/core';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common/http";
11
+ import * as i2 from "./token.service";
12
+ import * as i3 from "../services/api-endpoints.service";
13
+ import * as i4 from "@ionic/angular";
14
+ import * as i5 from "@angular/fire/compat/auth";
15
+ import * as i6 from "@angular/router";
16
+ import * as i7 from "./change-endpoints.service";
17
+ const TOKEN_KEY = 'token';
18
+ const INTRO_KEY = 'intro';
19
+ const TOKENS = 'tokens';
20
+ const TWO_FACTOR_CENTER = 'two-factor-center';
21
+ export class User {
22
+ constructor(idUser, secret, name, first_name, image) {
23
+ this.roles = [];
24
+ this.listFamilyUnit = [];
25
+ this.idUser = idUser;
26
+ this.secret = secret;
27
+ this.name = name;
28
+ this.first_name = first_name;
29
+ this.image = image;
30
+ }
31
+ ;
32
+ }
33
+ export class AuthenticationService {
34
+ constructor(platformId, http, tokenService, api, platform, firebaseAuth, router, alertController, injector, endpoints) {
35
+ this.platformId = platformId;
36
+ this.http = http;
37
+ this.tokenService = tokenService;
38
+ this.api = api;
39
+ this.platform = platform;
40
+ this.firebaseAuth = firebaseAuth;
41
+ this.router = router;
42
+ this.alertController = alertController;
43
+ this.injector = injector;
44
+ this.endpoints = endpoints;
45
+ this.isAuthenticated = new BehaviorSubject(false);
46
+ this.isRecovery = false;
47
+ this.agendaUser = [];
48
+ this.tokens = [];
49
+ this.showingSignInAlert = false;
50
+ this.setUser();
51
+ }
52
+ getIndexEndPoint() {
53
+ this.indexEndPoint = Number(localStorage.getItem('endpoint'));
54
+ console.log("[AuthService] indexEndPoint: ", this.indexEndPoint);
55
+ }
56
+ getAuthToken() {
57
+ const token = this.tokenService.getAuthToken();
58
+ //console.log("[AuthService] getAuthToken: ", token);
59
+ return token;
60
+ }
61
+ setAuthToken(token) {
62
+ this.tokenService.setAuthToken(token);
63
+ }
64
+ // getAuthToken() {
65
+ // const token = localStorage.getItem(TOKEN_KEY);
66
+ // return token;
67
+ // }
68
+ // setAuthToken(token) {
69
+ // localStorage.setItem(TOKEN_KEY, token);
70
+ // }
71
+ login(credentials) {
72
+ const endpoint = this.api.getEndpoint('patient/login');
73
+ console.log('credentials: ', credentials);
74
+ return this.http.post(endpoint, credentials).pipe(map((res) => {
75
+ console.log("[AuthService] login() OK ");
76
+ console.log("[AuthService] endpoint", endpoint);
77
+ if (!res.success) {
78
+ return res;
79
+ }
80
+ // save user's token
81
+ if (res.token) {
82
+ this.tokenService.setAuthToken(res.token);
83
+ this.setAuthToken(res.token);
84
+ }
85
+ // Set indexEndPoint ios_dev if it is QA
86
+ this.getIndexEndPoint();
87
+ if (Capacitor.isNativePlatform()) {
88
+ //console.log(data);
89
+ let access = true;
90
+ if (this.deviceToken && this.devicePlatform)
91
+ this.registerDevice(this.deviceToken, this.devicePlatform);
92
+ if (this.platform.is('ios')) {
93
+ if (this.voipDeviceToken)
94
+ this.registerDevice(this.voipDeviceToken, this.endpoints._ENVIROMENT.device_ios.ios_voip);
95
+ //this.registerDevice(this.voipDeviceToken, (this.indexEndPoint!==0)?'iosvoipdev':'iosvoip');
96
+ }
97
+ }
98
+ this.user = new User(res.idUser, credentials.password, res.name, res.first_name, res.temporary_url);
99
+ this.id_user = res.idUser;
100
+ this.setUserLocalstorage(this.user);
101
+ this.setTwoFactor(res.twoFactorCenter);
102
+ if (res?.familyUnit.length > 0) {
103
+ this.user.listFamilyUnit = res.familyUnit;
104
+ }
105
+ return res;
106
+ }), tap(_ => {
107
+ this.isAuthenticated.next(true);
108
+ }));
109
+ }
110
+ setUser() {
111
+ if (!this.user) {
112
+ this.getUserLocalstorage().then(user => {
113
+ console.log("[AuthenticationService] setUser()", user);
114
+ if (user)
115
+ this.user = user;
116
+ });
117
+ }
118
+ }
119
+ setUserLocalstorage(user) {
120
+ console.log(`[AuthenticationService] setUserLocalstorage()`, user);
121
+ Preferences.set({
122
+ key: 'user',
123
+ value: JSON.stringify(user)
124
+ });
125
+ }
126
+ setFamilyUnitLocalstorage(familyUnit) {
127
+ familyUnit.forEach(member => {
128
+ let s = member['name'];
129
+ let fullname = s.split(',');
130
+ let u = new User(member['id'], '', fullname[1], fullname[0], member['thumbnail']);
131
+ console.log("familyUnit Local:", u);
132
+ Preferences.set({
133
+ key: String(u.idUser),
134
+ value: JSON.stringify(u)
135
+ });
136
+ });
137
+ }
138
+ getFamilyUnitLocalstorage(id) {
139
+ return Preferences.get({ key: id }).then((val) => {
140
+ console.log(`[AuthenticationService] getFamilyUnitLocalstorage(${id})`, val);
141
+ return JSON.parse(val.value);
142
+ });
143
+ }
144
+ async setFamilyUnit(user) {
145
+ this.isFamily = true;
146
+ let s = user['name'];
147
+ let fullname = s.split(',');
148
+ this.user = new User(user.id, '', fullname[0].replace(',', ''), fullname[1], user.thumbnail);
149
+ this.user.familyUnit = user.id;
150
+ Preferences.set({
151
+ key: String(user.id),
152
+ value: JSON.stringify(this.user)
153
+ });
154
+ }
155
+ getUserLocalstorage() {
156
+ return Preferences.get({ key: 'user' }).then((val) => {
157
+ return JSON.parse(val.value);
158
+ });
159
+ }
160
+ async setUserFamilyId(id) {
161
+ await this.getUserLocalstorage().then(user => {
162
+ console.log(`[AuthenticationService] MEMBER(${id})`, user);
163
+ let s = user['name'];
164
+ let fullname = s.split(',');
165
+ this.user = new User(user['idUser'], '', fullname[0].replace(',', ''), fullname[1], user['image']);
166
+ this.user.familyUnit = id;
167
+ this.setUserLocalstorage(this.user);
168
+ });
169
+ }
170
+ getShowIntroLocalstorage() {
171
+ return Preferences.get({ key: 'showIntro' }).then((val) => {
172
+ return Boolean(val.value);
173
+ });
174
+ }
175
+ async setShowIntroLocalstorage() {
176
+ await Preferences.set({
177
+ key: 'showIntro',
178
+ value: 'true'
179
+ });
180
+ }
181
+ setTwoFactor(tfCenter) {
182
+ localStorage.setItem('two-factor-center', tfCenter);
183
+ }
184
+ async logout1() {
185
+ console.log('logout');
186
+ this.isAuthenticated.next(false);
187
+ const enviroment = this.endpoints._ENVIROMENT;
188
+ //localStorage.removeItem(enviroment?.registered_user)
189
+ await Preferences.remove({ key: 'user' }).then((val) => { });
190
+ return Preferences.remove({ key: TOKEN_KEY });
191
+ }
192
+ logout(allDevices) {
193
+ this.getAllTokenDevices();
194
+ let params = {
195
+ tokens: this.tokens,
196
+ allDevices: allDevices ? allDevices : false
197
+ };
198
+ console.log('logout', params);
199
+ let path = 'patient/logout';
200
+ const endpoint = this.api.getEndpoint(path);
201
+ return this.http.post(endpoint, params).pipe(map((res) => {
202
+ console.log(`[AuthenticationService] logout(${path}) res: `, JSON.stringify(res));
203
+ this.isAuthenticated.next(false);
204
+ const enviroment = this.endpoints._ENVIROMENT;
205
+ //localStorage.removeItem(enviroment?.registered_user)
206
+ Preferences.remove({ key: 'user' }).then((val) => { });
207
+ Preferences.remove({ key: TOKEN_KEY });
208
+ return res;
209
+ }));
210
+ }
211
+ getAllTokenDevices() {
212
+ let list = JSON.parse(localStorage.getItem(TOKENS));
213
+ this.tokens = list ? list : [];
214
+ }
215
+ increaseNumloginFailed() {
216
+ let numFailLogin = 0;
217
+ let num = localStorage.getItem('num-fail-login');
218
+ if (num) {
219
+ let numFailLogin = Number(JSON.parse(num)) + 1;
220
+ localStorage.setItem('num-fail-login', '' + numFailLogin);
221
+ localStorage.setItem('login_request_locked_at', '' + (new Date().getTime()));
222
+ }
223
+ else {
224
+ localStorage.setItem('num-fail-login', '1');
225
+ localStorage.setItem('login_request_locked_at', '' + (new Date().getTime()));
226
+ numFailLogin = 1;
227
+ }
228
+ console.log('[AuthenticationService] increaseNumloginFailed()', numFailLogin);
229
+ }
230
+ increaseNumFPAIOFailed() {
231
+ let num = localStorage.getItem('num-fail-finger-print');
232
+ if (num) {
233
+ localStorage.setItem('num-fail-login', '' + (Number(JSON.parse(num)) + 1));
234
+ localStorage.setItem('login_request_locked_at', '' + (new Date().getTime()));
235
+ }
236
+ else {
237
+ localStorage.setItem('num-fail-login', '1');
238
+ localStorage.setItem('login_request_locked_at', '' + (new Date().getTime()));
239
+ }
240
+ }
241
+ getNumloginFailed() {
242
+ let num = localStorage.getItem('num-fail-login');
243
+ if (num)
244
+ return Number(JSON.parse(num));
245
+ return 0;
246
+ }
247
+ getDateloginFailed() {
248
+ let num = localStorage.getItem('login_request_locked_at');
249
+ if (num)
250
+ return Number(JSON.parse(num));
251
+ return 0;
252
+ }
253
+ getNumFingerPrinterFailed() {
254
+ let num = localStorage.getItem('num-fail-finger-print');
255
+ if (num)
256
+ return Number(JSON.parse(num));
257
+ return 0;
258
+ }
259
+ removeNumloginFailed() {
260
+ localStorage.removeItem('num-fail-login');
261
+ localStorage.removeItem('login_request_locked_at');
262
+ }
263
+ removeNumFirgerPFailed() {
264
+ localStorage.removeItem('num-fail-finger-print');
265
+ localStorage.removeItem('login_request_locked_at');
266
+ }
267
+ get(endpt) {
268
+ const endpoint = this.api.getEndpoint(endpt);
269
+ return this.http.get(endpoint).pipe(map((res) => {
270
+ return res;
271
+ }));
272
+ }
273
+ post(endpt, items) {
274
+ const endpoint = this.api.getEndpoint(endpt);
275
+ return this.http.post(endpoint, items).pipe(map((res) => {
276
+ return res;
277
+ }));
278
+ }
279
+ throwError(error) {
280
+ if (error instanceof HttpErrorResponse)
281
+ throw new HttpErrorResponse(error);
282
+ else
283
+ throw new Error(error);
284
+ }
285
+ registerDevice(token, platform) {
286
+ console.log("response IOSDEV", platform);
287
+ if (platform == 'FCM')
288
+ platform = 'android';
289
+ if (platform == 'APNS')
290
+ platform = this.endpoints._ENVIROMENT.device_ios.ios_push;
291
+ if (platform == 'ios')
292
+ platform = this.endpoints._ENVIROMENT.device_ios.ios_push;
293
+ const postData = {
294
+ token: token,
295
+ platform: platform
296
+ };
297
+ console.log("postData: ", postData);
298
+ return this.post('user/device/register', postData).subscribe(async (data) => {
299
+ let response = data;
300
+ console.log("response user/device/register");
301
+ console.log(response);
302
+ this.saveAllTokenDevices(postData);
303
+ return response;
304
+ }, (error) => {
305
+ // Called when error
306
+ console.log('error user/device/register: ', error);
307
+ throw error;
308
+ });
309
+ }
310
+ saveAllTokenDevices(token) {
311
+ this.tokens.push(token);
312
+ localStorage.setItem(TOKENS, JSON.stringify(this.tokens));
313
+ }
314
+ async showIntro() {
315
+ return Preferences.get({ key: INTRO_KEY }).then(async (data) => {
316
+ let showIntro = Boolean(data.value);
317
+ console.log(`[AuthService] showIntro()`, showIntro);
318
+ return showIntro;
319
+ });
320
+ }
321
+ postAPIbiometric(params) {
322
+ let path = `user/biometric`;
323
+ const endpoint = this.api.getEndpoint(path);
324
+ return this.http.post(endpoint, params).pipe(map((res) => {
325
+ console.log(`[DooleService] postAPIbiometric(${path}) res: `, res);
326
+ return res;
327
+ }));
328
+ }
329
+ putAPIbiometric(id, params) {
330
+ let path = `user/biometric/${id}`;
331
+ const endpoint = this.api.getEndpoint(path);
332
+ return this.http.put(endpoint, params).pipe(map((res) => {
333
+ console.log(`[DooleService] putAPIbiometric(${path}) res: `, res);
334
+ return res;
335
+ }));
336
+ }
337
+ deleteAPIbiometric(id) {
338
+ let path = `user/biometric/${id}`;
339
+ const endpoint = this.api.getEndpoint(path);
340
+ return this.http.delete(endpoint).pipe(map((res) => {
341
+ console.log(`[DooleService] deleteAPIbiometric(${path}) res: ${res}`, JSON.stringify(res));
342
+ return res;
343
+ }));
344
+ }
345
+ redirectLogin() {
346
+ this.router.navigateByUrl('/landing');
347
+ }
348
+ async redirectUnauthenticated() {
349
+ const translateService = this.injector.get(TranslateService);
350
+ const alert = await this.alertController.create({
351
+ cssClass: "alertClass",
352
+ header: translateService.instant('info.title'),
353
+ backdropDismiss: false,
354
+ // subHeader: 'Subtitle',
355
+ message: translateService.instant('landing.login_again'),
356
+ buttons: [
357
+ { text: translateService.instant('button.accept'),
358
+ handler: () => {
359
+ this.router.navigateByUrl(`/landing`);
360
+ }
361
+ }
362
+ ]
363
+ });
364
+ await alert.present();
365
+ }
366
+ getShowGoogleFitLocalstorage() {
367
+ return Preferences.get({ key: 'showGoogleFit' }).then((val) => {
368
+ return Boolean(val.value);
369
+ });
370
+ }
371
+ async setShowGoogleFitLocalstorage() {
372
+ await Preferences.set({
373
+ key: 'showGoogleFit',
374
+ value: 'true'
375
+ });
376
+ }
377
+ setCanceledGoogleFitLocalstorage(mostrar) {
378
+ localStorage.setItem('cancelGoogleFit', mostrar);
379
+ }
380
+ getCanceledGoogleFitLocalstorage() {
381
+ const value = localStorage.getItem('cancelGoogleFit');
382
+ console.log("Booelan: ", value);
383
+ return value !== null ? JSON.parse(value) : false;
384
+ }
385
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: AuthenticationService, deps: [{ token: PLATFORM_ID }, { token: i1.HttpClient }, { token: i2.TokenService }, { token: i3.ApiEndpointsService }, { token: i4.Platform }, { token: i5.AngularFireAuth }, { token: i6.Router }, { token: i4.AlertController }, { token: i0.Injector }, { token: i7.ChangeEndpointsService }], target: i0.ɵɵFactoryTarget.Injectable }); }
386
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: AuthenticationService, providedIn: 'root' }); }
387
+ }
388
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: AuthenticationService, decorators: [{
389
+ type: Injectable,
390
+ args: [{
391
+ providedIn: 'root'
392
+ }]
393
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
394
+ type: Inject,
395
+ args: [PLATFORM_ID]
396
+ }] }, { type: i1.HttpClient }, { type: i2.TokenService }, { type: i3.ApiEndpointsService }, { type: i4.Platform }, { type: i5.AngularFireAuth }, { type: i6.Router }, { type: i4.AlertController }, { type: i0.Injector }, { type: i7.ChangeEndpointsService }], propDecorators: { outlet: [{
397
+ type: ViewChild,
398
+ args: [RouterOutlet]
399
+ }] } });
400
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aGVudGljYXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NlcnZpY2UtbGliL3NyYy9saWIvc2VydmljZXMvYXV0aGVudGljYXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBWSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzFDLE9BQU8sRUFBRSxlQUFlLEVBQWMsTUFBTSxNQUFNLENBQUM7QUFFbkQsT0FBTyxFQUFjLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFHckUsT0FBTyxFQUFVLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXZELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRXZELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7Ozs7O0FBRzVDLE1BQU0sU0FBUyxHQUFHLE9BQU8sQ0FBQztBQUMxQixNQUFNLFNBQVMsR0FBRyxPQUFPLENBQUM7QUFDMUIsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDO0FBQ3hCLE1BQU0saUJBQWlCLEdBQUcsbUJBQW1CLENBQUM7QUFFOUMsTUFBTSxPQUFPLElBQUk7SUFXZixZQUFZLE1BQWMsRUFBRSxNQUFjLEVBQUUsSUFBWSxFQUFFLFVBQWtCLEVBQUUsS0FBYTtRQUozRixVQUFLLEdBQVEsRUFBRSxDQUFDO1FBR2hCLG1CQUFjLEdBQWlCLEVBQUUsQ0FBQztRQUVoQyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQTtRQUNwQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FB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SSxNQUFNO3NCQUE5QixTQUFTO3VCQUFDLFlBQVkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUsIEluamVjdG9yLCBQTEFURk9STV9JRCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQcmVmZXJlbmNlcyB9IGZyb20gJ0BjYXBhY2l0b3IvcHJlZmVyZW5jZXMnO1xuaW1wb3J0IHsgbWFwLCB0YXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEFwaUVuZHBvaW50c1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hcGktZW5kcG9pbnRzLnNlcnZpY2UnO1xuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEVycm9yUmVzcG9uc2UgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBBbGVydENvbnRyb2xsZXIsIFBsYXRmb3JtIH0gZnJvbSAnQGlvbmljL2FuZ3VsYXInO1xuaW1wb3J0IHsgQW5ndWxhckZpcmVBdXRoIH0gZnJvbSBcIkBhbmd1bGFyL2ZpcmUvY29tcGF0L2F1dGhcIjtcbmltcG9ydCB7IFJvdXRlciwgUm91dGVyT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IEZhbWlseVVuaXQgfSBmcm9tICcuLi9tb2RlbHMvdXNlcic7XG5pbXBvcnQgeyBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBUb2tlblNlcnZpY2UgfSBmcm9tICcuL3Rva2VuLnNlcnZpY2UnO1xuaW1wb3J0IHsgQ2FwYWNpdG9yIH0gZnJvbSAnQGNhcGFjaXRvci9jb3JlJztcbmltcG9ydCB7IENoYW5nZUVuZHBvaW50c1NlcnZpY2UgfSBmcm9tICcuL2NoYW5nZS1lbmRwb2ludHMuc2VydmljZSc7XG5cbmNvbnN0IFRPS0VOX0tFWSA9ICd0b2tlbic7XG5jb25zdCBJTlRST19LRVkgPSAnaW50cm8nO1xuY29uc3QgVE9LRU5TID0gJ3Rva2Vucyc7XG5jb25zdCBUV09fRkFDVE9SX0NFTlRFUiA9ICd0d28tZmFjdG9yLWNlbnRlcic7XG5cbmV4cG9ydCBjbGFzcyBVc2VyIHtcbiAgY29uZGljaW9uX2xlZ2FsPzogYm9vbGVhbjtcbiAgaW1hZ2U6IGFueTtcbiAgaWRQYXRpZW50Pzogc3RyaW5nO1xuICBpZFVzZXI6IHN0cmluZztcbiAgZmlyc3RfbmFtZTogc3RyaW5nO1xuICBzZWNyZXQ6IHN0cmluZztcbiAgcm9sZXM6IGFueSA9IFtdO1xuICBmYW1pbHlVbml0Pzogc3RyaW5nO1xuICBuYW1lOiBzdHJpbmc7XG4gIGxpc3RGYW1pbHlVbml0OiBGYW1pbHlVbml0W10gPSBbXTtcbiAgY29uc3RydWN0b3IoaWRVc2VyOiBzdHJpbmcsIHNlY3JldDogc3RyaW5nLCBuYW1lOiBzdHJpbmcsIGZpcnN0X25hbWU6IHN0cmluZywgaW1hZ2U6IHN0cmluZykge1xuICAgIHRoaXMuaWRVc2VyID0gaWRVc2VyXG4gICAgdGhpcy5zZWNyZXQgPSBzZWNyZXRcbiAgICB0aGlzLm5hbWUgPSBuYW1lXG4gICAgdGhpcy5maXJzdF9uYW1lID0gZmlyc3RfbmFtZVxuICAgIHRoaXMuaW1hZ2UgPSBpbWFnZVxuICB9O1xuXG59XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIEF1dGhlbnRpY2F0aW9uU2VydmljZSB7XG4gIGlzQXV0aGVudGljYXRlZDogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSk7XG4gIHB1YmxpYyB1c2VyPzogVXNlcjtcbiAgcHVibGljIGlzUmVjb3Zlcnk6IGJvb2xlYW4gPSBmYWxzZTtcbiAgcHVibGljIGFjdGlvbj86IHN0cmluZztcbiAgcHVibGljIGlkX3VzZXI/OiBzdHJpbmc7XG4gIHB1YmxpYyBkYXRhPzogQXJyYXk8YW55PjtcbiAgcHVibGljIGVtYWlsPzogc3RyaW5nO1xuICBwdWJsaWMgYWdlbmRhVXNlciA9IFtdO1xuICBwdWJsaWMgdGllbmVfZW1haWw/OiBib29sZWFuO1xuICBwdWJsaWMgZGV2aWNlVG9rZW4/OiBzdHJpbmc7XG4gIHB1YmxpYyBkZXZpY2VQbGF0Zm9ybT86IHN0cmluZztcbiAgcHVibGljIHZvaXBEZXZpY2VUb2tlbj86IHN0cmluZztcbiAgcHVibGljIHZvaXBEZXZpY2VQbGF0Zm9ybT86IHN0cmluZztcbiAgcHVibGljIGRpZXRzQW5kQWR2aWNlcz86IFtdO1xuICBwdWJsaWMgaXNGYW1pbHk/OmJvb2xlYW47XG4gIHB1YmxpYyB2ZXJzaW9uX2FwcD86c3RyaW5nO1xuICBwcml2YXRlIGluZGV4RW5kUG9pbnQ/OiBudW1iZXI7XG4gIHByaXZhdGUgdG9rZW5zID0gW11cbiAgc2hvd2luZ1NpZ25JbkFsZXJ0OiBib29sZWFuID0gZmFsc2U7XG4gIEBWaWV3Q2hpbGQoUm91dGVyT3V0bGV0KSBvdXRsZXQ/OiBSb3V0ZXJPdXRsZXQ7XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoUExBVEZPUk1fSUQpIHByaXZhdGUgcGxhdGZvcm1JZDogb2JqZWN0LFxuICAgIHByaXZhdGUgaHR0cDogSHR0cENsaWVudCxcbiAgICBwcml2YXRlIHRva2VuU2VydmljZTogVG9rZW5TZXJ2aWNlLFxuICAgIHByaXZhdGUgYXBpOiBBcGlFbmRwb2ludHNTZXJ2aWNlLFxuICAgIHB1YmxpYyBwbGF0Zm9ybTogUGxhdGZvcm0sXG4gICAgcHVibGljIGZpcmViYXNlQXV0aDogQW5ndWxhckZpcmVBdXRoLFxuICAgIHB1YmxpYyByb3V0ZXI6IFJvdXRlcixcbiAgICBwdWJsaWMgYWxlcnRDb250cm9sbGVyOiBBbGVydENvbnRyb2xsZXIsXG4gICAgcHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgcHJpdmF0ZSBlbmRwb2ludHM6IENoYW5nZUVuZHBvaW50c1NlcnZpY2UsKSB7XG4gICAgICB0aGlzLnNldFVzZXIoKTtcbiAgfVxuXG4gIGdldEluZGV4RW5kUG9pbnQoKXtcbiAgICB0aGlzLmluZGV4RW5kUG9pbnQgPSBOdW1iZXIobG9jYWxTdG9yYWdlLmdldEl0ZW0oJ2VuZHBvaW50JykpXG4gICAgY29uc29sZS5sb2coXCJbQXV0aFNlcnZpY2VdIGluZGV4RW5kUG9pbnQ6IFwiLCB0aGlzLmluZGV4RW5kUG9pbnQpO1xuICB9XG5cbiAgZ2V0QXV0aFRva2VuKCkge1xuICAgIGNvbnN0IHRva2VuID0gIHRoaXMudG9rZW5TZXJ2aWNlLmdldEF1dGhUb2tlbigpXG4gICAgLy9jb25zb2xlLmxvZyhcIltBdXRoU2VydmljZV0gZ2V0QXV0aFRva2VuOiBcIiwgdG9rZW4pO1xuICAgIHJldHVybiB0b2tlbjtcbiAgfVxuXG4gIHNldEF1dGhUb2tlbih0b2tlbiA6IGFueSkge1xuICAgIHRoaXMudG9rZW5TZXJ2aWNlLnNldEF1dGhUb2tlbih0b2tlbilcbiAgfVxuXG4gIC8vIGdldEF1dGhUb2tlbigpIHtcbiAgLy8gICBjb25zdCB0b2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKFRPS0VOX0tFWSk7XG4gIC8vICAgcmV0dXJuIHRva2VuO1xuICAvLyB9XG5cbiAgLy8gc2V0QXV0aFRva2VuKHRva2VuKSB7XG4gIC8vICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oVE9LRU5fS0VZLCB0b2tlbik7XG4gIC8vIH1cblxuICBsb2dpbihjcmVkZW50aWFsczogeyB1c2VybmFtZSwgcGFzc3dvcmQsIGhhc2ggfSk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgY29uc3QgZW5kcG9pbnQgPSB0aGlzLmFwaS5nZXRFbmRwb2ludCgncGF0aWVudC9sb2dpbicpO1xuXG4gICAgY29uc29sZS5sb2coJ2NyZWRlbnRpYWxzOiAnLCBjcmVkZW50aWFscyk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0KGVuZHBvaW50LCBjcmVkZW50aWFscykucGlwZShcbiAgICAgIG1hcCgocmVzOiBhbnkpID0+IHtcblxuICAgICAgICBjb25zb2xlLmxvZyhcIltBdXRoU2VydmljZV0gbG9naW4oKSBPSyBcIik7XG4gICAgICAgIGNvbnNvbGUubG9nKFwiW0F1dGhTZXJ2aWNlXSBlbmRwb2ludFwiLCBlbmRwb2ludCk7XG4gICAgICAgIGlmICghcmVzLnN1Y2Nlc3MpIHtcbiAgICAgICAgICByZXR1cm4gcmVzXG4gICAgICAgIH1cbiAgICAgICAgLy8gc2F2ZSB1c2VyJ3MgdG9rZW5cbiAgICAgICAgaWYgKHJlcy50b2tlbil7XG4gICAgICAgICAgdGhpcy50b2tlblNlcnZpY2Uuc2V0QXV0aFRva2VuKHJlcy50b2tlbik7XG4gICAgICAgICAgdGhpcy5zZXRBdXRoVG9rZW4ocmVzLnRva2VuKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIFNldCBpbmRleEVuZFBvaW50IGlvc19kZXYgaWYgaXQgaXMgUUFcbiAgICAgICAgICB0aGlzLmdldEluZGV4RW5kUG9pbnQoKVxuICAgICAgICAgICAgaWYgKENhcGFjaXRvci5pc05hdGl2ZVBsYXRmb3JtKCkpIHtcbiAgICAgICAgICAgICAgLy9jb25zb2xlLmxvZyhkYXRhKTtcbiAgICAgICAgICAgICAgbGV0IGFjY2VzcyA9IHRydWU7XG4gICAgICAgICAgICAgIGlmKHRoaXMuZGV2aWNlVG9rZW4gJiYgdGhpcy5kZXZpY2VQbGF0Zm9ybSlcbiAgICAgICAgICAgICAgICB0aGlzLnJlZ2lzdGVyRGV2aWNlKHRoaXMuZGV2aWNlVG9rZW4sIHRoaXMuZGV2aWNlUGxhdGZvcm0pO1xuXG4gICAgICAgICAgICAgIGlmICh0aGlzLnBsYXRmb3JtLmlzKCdpb3MnKSl7XG4gICAgICAgICAgICAgICAgaWYodGhpcy52b2lwRGV2aWNlVG9rZW4pXG4gICAgICAgICAgICAgICAgdGhpcy5yZWdpc3RlckRldmljZSh0aGlzLnZvaXBEZXZpY2VUb2tlbiwgdGhpcy5lbmRwb2ludHMuX0VOVklST01FTlQuZGV2aWNlX2lvcy5pb3Nfdm9pcCk7XG4gICAgICAgICAgICAgICAgLy90aGlzLnJlZ2lzdGVyRGV2aWNlKHRoaXMudm9pcERldmljZVRva2VuLCAodGhpcy5pbmRleEVuZFBvaW50IT09MCk/J2lvc3ZvaXBkZXYnOidpb3N2b2lwJyk7XG4gICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgfVxuXG4gICAgICAgIHRoaXMudXNlciA9IG5ldyBVc2VyKHJlcy5pZFVzZXIsIGNyZWRlbnRpYWxzLnBhc3N3b3JkLCByZXMubmFtZSwgcmVzLmZpcnN0X25hbWUsIHJlcy50ZW1wb3JhcnlfdXJsKTtcbiAgICAgICAgXG4gICAgICAgIHRoaXMuaWRfdXNlciA9IHJlcy5pZFVzZXI7XG4gICAgICAgIHRoaXMuc2V0VXNlckxvY2Fsc3RvcmFnZSh0aGlzLnVzZXIpXG4gICAgICAgIHRoaXMuc2V0VHdvRmFjdG9yKHJlcy50d29GYWN0b3JDZW50ZXIpXG4gICAgICAgIGlmIChyZXM/LmZhbWlseVVuaXQubGVuZ3RoID4gMCkge1xuICAgICAgICAgIHRoaXMudXNlci5saXN0RmFtaWx5VW5pdCA9IHJlcy5mYW1pbHlVbml0O1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHJlcztcblxuICAgICAgfSksXG4gICAgICB0YXAoXyA9PiB7XG4gICAgICAgIHRoaXMuaXNBdXRoZW50aWNhdGVkLm5leHQodHJ1ZSk7XG4gICAgICB9KSxcbiAgICApO1xuICB9XG5cbiAgc2V0VXNlcigpIHtcbiAgICBpZiAoIXRoaXMudXNlcikge1xuICAgICAgdGhpcy5nZXRVc2VyTG9jYWxzdG9yYWdlKCkudGhlbih1c2VyID0+IHtcbiAgICAgICAgY29uc29sZS5sb2coXCJbQXV0aGVudGljYXRpb25TZXJ2aWNlXSBzZXRVc2VyKClcIiwgdXNlcik7XG4gICAgICAgIGlmICh1c2VyKVxuICAgICAgICAgIHRoaXMudXNlciA9IHVzZXJcbiAgICAgIH0pXG4gICAgfVxuXG4gIH1cblxuICBzZXRVc2VyTG9jYWxzdG9yYWdlKHVzZXI6IGFueSkge1xuICAgIGNvbnNvbGUubG9nKGBbQXV0aGVudGljYXRpb25TZXJ2aWNlXSBzZXRVc2VyTG9jYWxzdG9yYWdlKClgLCB1c2VyKTtcbiAgICBQcmVmZXJlbmNlcy5zZXQoe1xuICAgICAga2V5OiAndXNlcicsXG4gICAgICB2YWx1ZTogSlNPTi5zdHJpbmdpZnkodXNlcilcbiAgICB9KTtcblxuICB9XG5cbiAgc2V0RmFtaWx5VW5pdExvY2Fsc3RvcmFnZShmYW1pbHlVbml0OiBbXSkge1xuXG5cbiAgICBmYW1pbHlVbml0LmZvckVhY2gobWVtYmVyID0+IHtcbiAgICAgIGxldCBzOiBzdHJpbmcgPSBtZW1iZXJbJ25hbWUnXTtcbiAgICAgIGxldCBmdWxsbmFtZSA9IHMuc3BsaXQoJywnKTtcbiAgICAgIGxldCB1ID0gbmV3IFVzZXIobWVtYmVyWydpZCddLCAnJywgZnVsbG5hbWVbMV0sIGZ1bGxuYW1lWzBdLCBtZW1iZXJbJ3RodW1ibmFpbCddKTtcbiAgICAgIGNvbnNvbGUubG9nKFwiZmFtaWx5VW5pdCBMb2NhbDpcIiwgdSk7XG4gICAgICBQcmVmZXJlbmNlcy5zZXQoe1xuICAgICAgICBrZXk6IFN0cmluZyh1LmlkVXNlciksXG4gICAgICAgIHZhbHVlOiBKU09OLnN0cmluZ2lmeSh1KVxuICAgICAgfSk7XG4gICAgfSlcbiAgfVxuXG4gIGdldEZhbWlseVVuaXRMb2NhbHN0b3JhZ2UoaWQ6IGFueSk6IFByb21pc2U8VXNlcj4ge1xuICAgIHJldHVybiBQcmVmZXJlbmNlcy5nZXQoeyBrZXk6IGlkIH0pLnRoZW4oKHZhbCkgPT4ge1xuICAgICAgY29uc29sZS5sb2coYFtBdXRoZW50aWNhdGlvblNlcnZpY2VdIGdldEZhbWlseVVuaXRMb2NhbHN0b3JhZ2UoJHtpZH0pYCwgdmFsKTtcbiAgICAgIHJldHVybiBKU09OLnBhcnNlKHZhbC52YWx1ZSk7XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc2V0RmFtaWx5VW5pdCh1c2VyOiBhbnkpIHtcbiAgICB0aGlzLmlzRmFtaWx5ID0gdHJ1ZTtcbiAgICBsZXQgczogc3RyaW5nID0gdXNlclsnbmFtZSddO1xuICAgIGxldCBmdWxsbmFtZSA9IHMuc3BsaXQoJywnKTtcbiAgICB0aGlzLnVzZXIgPSBuZXcgVXNlcih1c2VyLmlkLCAnJywgZnVsbG5hbWVbMF0ucmVwbGFjZSgnLCcsJycpLCBmdWxsbmFtZVsxXSwgdXNlci50aHVtYm5haWwpO1xuICAgIHRoaXMudXNlci5mYW1pbHlVbml0ID0gdXNlci5pZDtcbiAgICBQcmVmZXJlbmNlcy5zZXQoe1xuICAgICAga2V5OiBTdHJpbmcodXNlci5pZCksXG4gICAgICB2YWx1ZTogSlNPTi5zdHJpbmdpZnkodGhpcy51c2VyKVxuICAgIH0pO1xuXG5cbiAgfVxuXG4gIGdldFVzZXJMb2NhbHN0b3JhZ2UoKTogUHJvbWlzZTxVc2VyPiB7XG4gICAgcmV0dXJuIFByZWZlcmVuY2VzLmdldCh7IGtleTogJ3VzZXInIH0pLnRoZW4oKHZhbCkgPT4ge1xuICAgICAgcmV0dXJuIEpTT04ucGFyc2UodmFsLnZhbHVlKTtcbiAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzZXRVc2VyRmFtaWx5SWQoaWQpIHtcblxuICAgIGF3YWl0IHRoaXMuZ2V0VXNlckxvY2Fsc3RvcmFnZSgpLnRoZW4odXNlciA9PiB7XG4gICAgICBjb25zb2xlLmxvZyhgW0F1dGhlbnRpY2F0aW9uU2VydmljZV0gTUVNQkVSKCR7aWR9KWAsIHVzZXIpO1xuICAgICAgbGV0IHM6IHN0cmluZyA9IHVzZXJbJ25hbWUnXTtcbiAgICAgIGxldCBmdWxsbmFtZSA9IHMuc3BsaXQoJywnKTtcbiAgICAgIHRoaXMudXNlciA9IG5ldyBVc2VyKHVzZXJbJ2lkVXNlciddLCAnJywgZnVsbG5hbWVbMF0ucmVwbGFjZSgnLCcsJycpLCBmdWxsbmFtZVsxXSwgdXNlclsnaW1hZ2UnXSk7XG4gICAgICB0aGlzLnVzZXIuZmFtaWx5VW5pdCA9IGlkO1xuICAgICAgdGhpcy5zZXRVc2VyTG9jYWxzdG9yYWdlKHRoaXMudXNlcilcbiAgICB9KVxuICB9XG5cbiAgZ2V0U2hvd0ludHJvTG9jYWxzdG9yYWdlKCk6IFByb21pc2U8YW55PiB7XG4gICAgcmV0dXJuIFByZWZlcmVuY2VzLmdldCh7IGtleTogJ3Nob3dJbnRybycgfSkudGhlbigodmFsKSA9PiB7XG4gICAgICByZXR1cm4gQm9vbGVhbih2YWwudmFsdWUpXG4gICAgfSk7XG4gIH1cblxuICBhc3luYyBzZXRTaG93SW50cm9Mb2NhbHN0b3JhZ2UoKSB7XG4gICAgYXdhaXQgUHJlZmVyZW5jZXMuc2V0KHtcbiAgICAgIGtleTogJ3Nob3dJbnRybycsXG4gICAgICB2YWx1ZTogJ3RydWUnXG4gICAgfSk7XG4gIH1cblxuICBzZXRUd29GYWN0b3IodGZDZW50ZXI6IGFueSl7XG4gICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oJ3R3by1mYWN0b3ItY2VudGVyJywgdGZDZW50ZXIpO1xuICB9XG5cbiAgYXN5bmMgbG9nb3V0MSgpOiBQcm9taXNlPHZvaWQ+e1xuICAgIGNvbnNvbGUubG9nKCdsb2dvdXQnKTtcbiAgICB0aGlzLmlzQXV0aGVudGljYXRlZC5uZXh0KGZhbHNlKTtcbiAgICBjb25zdCBlbnZpcm9tZW50ID0gdGhpcy5lbmRwb2ludHMuX0VOVklST01FTlRcbiAgICAvL2xvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKGVudmlyb21lbnQ/LnJlZ2lzdGVyZWRfdXNlcilcbiAgICBhd2FpdCBQcmVmZXJlbmNlcy5yZW1vdmUoeyBrZXk6ICd1c2VyJyB9KS50aGVuKCh2YWwpID0+IHsgfSk7XG4gICAgcmV0dXJuIFByZWZlcmVuY2VzLnJlbW92ZSh7IGtleTogVE9LRU5fS0VZIH0pO1xuICB9XG5cbiAgbG9nb3V0KGFsbERldmljZXM/KTogT2JzZXJ2YWJsZTxhbnk+ICB7XG4gICAgdGhpcy5nZXRBbGxUb2tlbkRldmljZXMoKVxuICAgIGxldCBwYXJhbXMgPSB7XG4gICAgICB0b2tlbnM6IHRoaXMudG9rZW5zLFxuICAgICAgYWxsRGV2aWNlczogYWxsRGV2aWNlcz8gYWxsRGV2aWNlczogZmFsc2VcbiAgICB9XG4gICAgY29uc29sZS5sb2coJ2xvZ291dCcsIHBhcmFtcyApO1xuICAgIGxldCBwYXRoID0gJ3BhdGllbnQvbG9nb3V0J1xuICAgIGNvbnN0IGVuZHBvaW50ID0gdGhpcy5hcGkuZ2V0RW5kcG9pbnQocGF0aCk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0KGVuZHBvaW50LCBwYXJhbXMpLnBpcGUoXG4gICAgICBtYXAoIChyZXM6IGFueSkgPT4ge1xuICAgICAgICBjb25zb2xlLmxvZyhgW0F1dGhlbnRpY2F0aW9uU2VydmljZV0gbG9nb3V0KCR7cGF0aH0pIHJlczogYCwgSlNPTi5zdHJpbmdpZnkocmVzKSApO1xuICAgICAgICB0aGlzLmlzQXV0aGVudGljYXRlZC5uZXh0KGZhbHNlKTtcbiAgICAgICAgY29uc3QgZW52aXJvbWVudCA9IHRoaXMuZW5kcG9pbnRzLl9FTlZJUk9NRU5UXG4gICAgICAgIC8vbG9jYWxTdG9yYWdlLnJlbW92ZUl0ZW0oZW52aXJvbWVudD8ucmVnaXN0ZXJlZF91c2VyKVxuICAgICAgICAgUHJlZmVyZW5jZXMucmVtb3ZlKHsga2V5OiAndXNlcicgfSkudGhlbigodmFsKSA9PiB7IH0pO1xuICAgICAgICAgUHJlZmVyZW5jZXMucmVtb3ZlKHsga2V5OiBUT0tFTl9LRVkgfSk7XG4gICAgICAgIHJldHVybiByZXM7XG4gICAgICB9KVxuICAgICk7XG59XG5nZXRBbGxUb2tlbkRldmljZXMoKXtcbiAgbGV0IGxpc3QgPSBKU09OLnBhcnNlKGxvY2FsU3RvcmFnZS5nZXRJdGVtKFRPS0VOUykpXG4gIHRoaXMudG9rZW5zID0gbGlzdD8gbGlzdDpbXVxufVxuXG5cblxuICBpbmNyZWFzZU51bWxvZ2luRmFpbGVkKCl7XG4gICAgbGV0IG51bUZhaWxMb2dpbiA9IDBcbiAgICBsZXQgbnVtID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oJ251bS1mYWlsLWxvZ2luJyk7XG4gICAgaWYobnVtKXtcbiAgICAgIGxldCBudW1GYWlsTG9naW4gPSBOdW1iZXIoSlNPTi5wYXJzZShudW0pKSArIDFcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdudW0tZmFpbC1sb2dpbicsJycrbnVtRmFpbExvZ2luKTtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdsb2dpbl9yZXF1ZXN0X2xvY2tlZF9hdCcsJycrKG5ldyBEYXRlKCkuZ2V0VGltZSgpKSk7XG4gICAgfWVsc2V7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbnVtLWZhaWwtbG9naW4nLCcxJyk7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbG9naW5fcmVxdWVzdF9sb2NrZWRfYXQnLCcnKyhuZXcgRGF0ZSgpLmdldFRpbWUoKSkpO1xuICAgICAgbnVtRmFpbExvZ2luID0gMVxuICAgIH1cbiAgICBjb25zb2xlLmxvZygnW0F1dGhlbnRpY2F0aW9uU2VydmljZV0gaW5jcmVhc2VOdW1sb2dpbkZhaWxlZCgpJywgbnVtRmFpbExvZ2luKTtcbiAgfVxuXG4gIGluY3JlYXNlTnVtRlBBSU9GYWlsZWQoKXtcbiAgICBsZXQgbnVtID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oJ251bS1mYWlsLWZpbmdlci1wcmludCcpO1xuICAgIGlmKG51bSl7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbnVtLWZhaWwtbG9naW4nLCcnKyhOdW1iZXIoSlNPTi5wYXJzZShudW0pKSArIDEpKTtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdsb2dpbl9yZXF1ZXN0X2xvY2tlZF9hdCcsJycrKG5ldyBEYXRlKCkuZ2V0VGltZSgpKSk7XG4gICAgfWVsc2V7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbnVtLWZhaWwtbG9naW4nLCcxJyk7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnbG9naW5fcmVxdWVzdF9sb2NrZWRfYXQnLCcnKyhuZXcgRGF0ZSgpLmdldFRpbWUoKSkpO1xuICAgIH1cbiAgfVxuXG4gIGdldE51bWxvZ2luRmFpbGVkKCl7XG4gICAgbGV0IG51bSA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdudW0tZmFpbC1sb2dpbicpO1xuICAgIGlmKG51bSkgcmV0dXJuIE51bWJlcihKU09OLnBhcnNlKG51bSkpXG4gICAgcmV0dXJuIDBcbiAgfVxuXG4gIGdldERhdGVsb2dpbkZhaWxlZCgpe1xuICAgIGxldCBudW0gPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnbG9naW5fcmVxdWVzdF9sb2NrZWRfYXQnKTtcbiAgICBpZihudW0pIHJldHVybiBOdW1iZXIoSlNPTi5wYXJzZShudW0pKVxuICAgIHJldHVybiAwXG4gIH1cblxuICBnZXROdW1GaW5nZXJQcmludGVyRmFpbGVkKCl7XG4gICAgbGV0IG51bSA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKCdudW0tZmFpbC1maW5nZXItcHJpbnQnKTtcbiAgICBpZihudW0pIHJldHVybiBOdW1iZXIoSlNPTi5wYXJzZShudW0pKVxuICAgIHJldHVybiAwXG4gIH1cblxuICByZW1vdmVOdW1sb2dpbkZhaWxlZCgpe1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKCdudW0tZmFpbC1sb2dpbicpO1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKCdsb2dpbl9yZXF1ZXN0X2xvY2tlZF9hdCcpO1xuICB9XG5cbiAgcmVtb3ZlTnVtRmlyZ2VyUEZhaWxlZCgpe1xuICAgIGxvY2FsU3RvcmFnZS5yZW1vdmVJdGVtKCdudW0tZmFpbC1maW5nZXItcHJpbnQnKTtcbiAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbSgnbG9naW5fcmVxdWVzdF9sb2NrZWRfYXQnKTtcbiAgfVxuXG4gIGdldChlbmRwdCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgY29uc3QgZW5kcG9pbnQgPSB0aGlzLmFwaS5nZXRFbmRwb2ludChlbmRwdCk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoZW5kcG9pbnQpLnBpcGUoXG4gICAgICBtYXAoKHJlczogYW55KSA9PiB7XG4gICAgICAgIHJldHVybiByZXM7XG4gICAgICB9KVxuICAgICk7XG5cbiAgfVxuXG4gIHBvc3QoZW5kcHQsIGl0ZW1zKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICBjb25zdCBlbmRwb2ludCA9IHRoaXMuYXBpLmdldEVuZHBvaW50KGVuZHB0KTtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoZW5kcG9pbnQsIGl0ZW1zKS5waXBlKFxuICAgICAgbWFwKChyZXM6IGFueSkgPT4ge1xuICAgICAgICByZXR1cm4gcmVzO1xuICAgICAgfSlcbiAgICApO1xuICB9XG5cbiAgdGhyb3dFcnJvcihlcnJvcjogYW55KSB7XG5cbiAgICBpZiAoZXJyb3IgaW5zdGFuY2VvZiBIdHRwRXJyb3JSZXNwb25zZSlcbiAgICAgIHRocm93IG5ldyBIdHRwRXJyb3JSZXNwb25zZShlcnJvcik7XG4gICAgZWxzZVxuICAgICAgdGhyb3cgbmV3IEVycm9yKGVycm9yKTtcbiAgfVxuXG5cbiAgcHVibGljIHJlZ2lzdGVyRGV2aWNlKHRva2VuLCBwbGF0Zm9ybSkge1xuXG4gICAgY29uc29sZS5sb2coXCJyZXNwb25zZSBJT1NERVZcIiwgcGxhdGZvcm0pO1xuICAgIGlmKHBsYXRmb3JtID09ICdGQ00nKVxuICAgICAgcGxhdGZvcm0gPSAnYW5kcm9pZCc7XG4gICAgaWYocGxhdGZvcm0gPT0gJ0FQTlMnKVxuICAgICAgcGxhdGZvcm0gPSB0aGlzLmVuZHBvaW50cy5fRU5WSVJPTUVOVC5kZXZpY2VfaW9zLmlvc19wdXNoO1xuICAgIGlmKHBsYXRmb3JtID09ICdpb3MnKVxuICAgICAgcGxhdGZvcm0gPSB0aGlzLmVuZHBvaW50cy5fRU5WSVJPTUVOVC5kZXZpY2VfaW9zLmlvc19wdXNoO1xuXG4gICAgIGNvbnN0IHBvc3REYXRhID0ge1xuICAgICAgdG9rZW46IHRva2VuLFxuICAgICAgcGxhdGZvcm06IHBsYXRmb3JtXG4gICAgfTtcblxuICAgIGNvbnNvbGUubG9nKFwicG9zdERhdGE6IFwiLCAgcG9zdERhdGEpO1xuXG4gICAgcmV0dXJuIHRoaXMucG9zdCgndXNlci9kZXZpY2UvcmVnaXN0ZXInLCBwb3N0RGF0YSkuc3Vic2NyaWJlKFxuICAgICAgYXN5bmMgKGRhdGEpID0+IHtcbiAgICAgICAgbGV0IHJlc3BvbnNlPWRhdGE7XG4gICAgICAgIGNvbnNvbGUubG9nKFwicmVzcG9uc2UgdXNlci9kZXZpY2UvcmVnaXN0ZXJcIik7XG4gICAgICAgIGNvbnNvbGUubG9nKHJlc3BvbnNlKTtcbiAgICAgICAgdGhpcy5zYXZlQWxsVG9rZW5EZXZpY2VzKHBvc3REYXRhKVxuICAgICAgICByZXR1cm4gcmVzcG9uc2U7XG4gICAgICB9LFxuICAgICAgKGVycm9yKSA9PiB7XG4gICAgICAgIC8vIENhbGxlZCB3aGVuIGVycm9yXG4gICAgICAgIGNvbnNvbGUubG9nKCdlcnJvciB1c2VyL2RldmljZS9yZWdpc3RlcjogJywgZXJyb3IpO1xuICAgICAgICB0aHJvdyBlcnJvcjtcbiAgICAgIH0pO1xuICB9XG5cbiAgc2F2ZUFsbFRva2VuRGV2aWNlcyh0b2tlbil7XG4gICAgdGhpcy50b2tlbnMucHVzaCh0b2tlbilcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShUT0tFTlMsSlNPTi5zdHJpbmdpZnkodGhpcy50b2tlbnMpKVxuICB9XG5cbiAgYXN5bmMgc2hvd0ludHJvKCkge1xuICAgIHJldHVybiBQcmVmZXJlbmNlcy5nZXQoeyBrZXk6IElOVFJPX0tFWSB9KS50aGVuKGFzeW5jIChkYXRhKSA9PiB7XG4gICAgICBsZXQgc2hvd0ludHJvID0gQm9vbGVhbihkYXRhLnZhbHVlKVxuICAgICAgY29uc29sZS5sb2coYFtBdXRoU2VydmljZV0gc2hvd0ludHJvKClgLCBzaG93SW50cm8pO1xuICAgICAgcmV0dXJuIHNob3dJbnRybztcblxuICAgIH0pXG4gIH1cblxuICBwb3N0QVBJYmlvbWV0cmljKHBhcmFtczogT2JqZWN0KTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICBsZXQgcGF0aCA9IGB1c2VyL2Jpb21ldHJpY2A7XG4gICAgY29uc3QgZW5kcG9pbnQgPSB0aGlzLmFwaS5nZXRFbmRwb2ludChwYXRoKTtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoZW5kcG9pbnQsIHBhcmFtcykucGlwZShcbiAgICAgIG1hcCgocmVzOiBhbnkpID0+IHtcbiAgICAgICAgY29uc29sZS5sb2coYFtEb29sZVNlcnZpY2VdIHBvc3RBUEliaW9tZXRyaWMoJHtwYXRofSkgcmVzOiBgLCByZXMpO1xuICAgICAgICByZXR1cm4gcmVzO1xuXG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICBwdXRBUEliaW9tZXRyaWMoaWQ6IGFueSwgcGFyYW1zOiBPYmplY3QpOiBPYnNlcnZhYmxlPGFueT4ge1xuICAgIGxldCBwYXRoID0gYHVzZXIvYmlvbWV0cmljLyR7aWR9YDtcbiAgICBjb25zdCBlbmRwb2ludCA9IHRoaXMuYXBpLmdldEVuZHBvaW50KHBhdGgpO1xuICAgIHJldHVybiB0aGlzLmh0dHAucHV0KGVuZHBvaW50LCBwYXJhbXMpLnBpcGUoXG4gICAgICBtYXAoKHJlczogYW55KSA9PiB7XG4gICAgICAgIGNvbnNvbGUubG9nKGBbRG9vbGVTZXJ2aWNlXSBwdXRBUEliaW9tZXRyaWMoJHtwYXRofSkgcmVzOiBgLCByZXMpO1xuICAgICAgICByZXR1cm4gcmVzO1xuXG4gICAgICB9KVxuICAgICk7XG4gIH1cblxuICBkZWxldGVBUEliaW9tZXRyaWMoaWQ6IE9iamVjdCk6IE9ic2VydmFibGU8YW55PiB7XG4gICAgbGV0IHBhdGggPSBgdXNlci9iaW9tZXRyaWMvJHtpZH1gO1xuICAgIGNvbnN0IGVuZHBvaW50ID0gdGhpcy5hcGkuZ2V0RW5kcG9pbnQocGF0aCk7XG4gICAgcmV0dXJuIHRoaXMuaHR0cC5kZWxldGUoZW5kcG9pbnQpLnBpcGUoXG4gICAgICBtYXAoKHJlczogYW55KSA9PiB7XG4gICAgICAgIGNvbnNvbGUubG9nKGBbRG9vbGVTZXJ2aWNlXSBkZWxldGVBUEliaW9tZXRyaWMoJHtwYXRofSkgcmVzOiAke3Jlc31gLCBKU09OLnN0cmluZ2lmeShyZXMpKTtcbiAgICAgICAgcmV0dXJuIHJlcztcbiAgICAgIH0pXG4gICAgKTtcbiAgfVxuXG4gIHJlZGlyZWN0TG9naW4oKXtcbiAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZUJ5VXJsKCcvbGFuZGluZycpO1xuICB9XG5cbiAgYXN5bmMgcmVkaXJlY3RVbmF1dGhlbnRpY2F0ZWQoKSB7XG4gICAgICBjb25zdCB0cmFuc2xhdGVTZXJ2aWNlID0gdGhpcy5pbmplY3Rvci5nZXQoVHJhbnNsYXRlU2VydmljZSlcbiAgICAgIGNvbnN0IGFsZXJ0ID0gYXdhaXQgdGhpcy5hbGVydENvbnRyb2xsZXIuY3JlYXRlKHtcbiAgICAgICAgY3NzQ2xhc3M6IFwiYWxlcnRDbGFzc1wiLFxuICAgICAgICBoZWFkZXI6ICB0cmFuc2xhdGVTZXJ2aWNlLmluc3RhbnQoJ2luZm8udGl0bGUnKSxcbiAgICAgICAgYmFja2Ryb3BEaXNtaXNzOmZhbHNlLFxuICAgICAgICAvLyBzdWJIZWFkZXI6ICdTdWJ0aXRsZScsXG4gICAgICAgIG1lc3NhZ2U6IHRyYW5zbGF0ZVNlcnZpY2UuaW5zdGFudCgnbGFuZGluZy5sb2dpbl9hZ2FpbicpLFxuICAgICAgICBidXR0b25zOiBbXG4gICAgICAgICAge3RleHQ6IHRyYW5zbGF0ZVNlcnZpY2UuaW5zdGFudCgnYnV0dG9uLmFjY2VwdCcpLFxuICAgICAgICAgIGhhbmRsZXI6ICgpID0+IHtcbiAgICAgICAgICAgIHRoaXMucm91dGVyLm5hdmlnYXRlQnlVcmwoYC9sYW5kaW5nYCk7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIF1cbiAgICAgIH0pO1xuXG4gICAgICBhd2FpdCBhbGVydC5wcmVzZW50KCk7XG4gICAgfVxuXG4gICAgZ2V0U2hvd0dvb2dsZUZpdExvY2Fsc3RvcmFnZSgpOiBQcm9taXNlPGFueT4ge1xuICAgICAgcmV0dXJuIFByZWZlcmVuY2VzLmdldCh7IGtleTogJ3Nob3dHb29nbGVGaXQnIH0pLnRoZW4oKHZhbCkgPT4ge1xuICAgICAgICByZXR1cm4gQm9vbGVhbih2YWwudmFsdWUpXG4gICAgICB9KTtcbiAgICB9XG4gICAgXG4gICAgYXN5bmMgc2V0U2hvd0dvb2dsZUZpdExvY2Fsc3RvcmFnZSgpIHtcbiAgICAgIGF3YWl0IFByZWZlcmVuY2VzLnNldCh7XG4gICAgICAgIGtleTogJ3Nob3dHb29nbGVGaXQnLFxuICAgICAgICB2YWx1ZTogJ3RydWUnXG4gICAgICB9KTtcbiAgICB9XG5cbiAgICBzZXRDYW5jZWxlZEdvb2dsZUZpdExvY2Fsc3RvcmFnZShtb3N0cmFyOiBzdHJpbmcpIHtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKCdjYW5jZWxHb29nbGVGaXQnLCBtb3N0cmFyKTtcbiAgICB9XG5cbiAgICBnZXRDYW5jZWxlZEdvb2dsZUZpdExvY2Fsc3RvcmFnZSgpOmJvb2xlYW4ge1xuICAgICAgY29uc3QgdmFsdWUgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbSgnY2FuY2VsR29vZ2xlRml0JylcbiAgICAgIGNvbnNvbGUubG9nKFwiQm9vZWxhbjogXCIsIHZhbHVlKTtcbiAgICAgIHJldHVybiB2YWx1ZSAhPT0gbnVsbCA/IEpTT04ucGFyc2UodmFsdWUpIDogZmFsc2U7XG4gICAgfVxufVxuIl19
@@ -0,0 +1,90 @@
1
+ import { Injectable, Inject } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import { CONFIGURACION_TOKEN, PUSHERS_CONFIG_TOKEN } from '../configuration';
4
+ import * as i0 from "@angular/core";
5
+ export var _INDEX_ENPOINT = 0; //Por defecto index 0
6
+ const ENDPOINT = 'endpoint';
7
+ export class ChangeEndpointsService {
8
+ constructor(constants, pusher) {
9
+ this.constants = constants;
10
+ this.pusher = pusher;
11
+ this._endpointIndex = new BehaviorSubject(this.getIndexEndPointLocalstorage());
12
+ this._LIST_ENPOINT = [];
13
+ this.addEndPoint();
14
+ this.setDefaultEndPoint();
15
+ }
16
+ async addEndPoint() {
17
+ this._LIST_ENPOINT = [];
18
+ this._LIST_ENPOINT.push({
19
+ id: 0,
20
+ name: 'enviroment.production',
21
+ api: this.constants.API_DOOLE_ENDPOINT,
22
+ endpoint: this.constants.DOOLE_ENDPOINT,
23
+ device_ios: { ios_push: 'ios_dev', ios_voip: 'iosvoipdev' },
24
+ pusher_key: this.pusher.PUSHER_KEY_PRO,
25
+ color: 'primary',
26
+ settings_bio: 'settings-bio0',
27
+ biometric: 'biometric0',
28
+ show_bio_dialog: 'show-bio-dialog0',
29
+ registered_user: 'registered-user0',
30
+ });
31
+ this._LIST_ENPOINT.push({
32
+ id: 1,
33
+ name: 'enviroment.development',
34
+ api: this.constants.API_ENDPOINT_DEV,
35
+ endpoint: this.constants.ENDPOINT_DEV,
36
+ device_ios: { ios_push: 'ios_dev', ios_voip: 'iosvoipdev' },
37
+ pusher_key: this.pusher.PUSHER_KEY_DEV,
38
+ color: 'warning',
39
+ settings_bio: 'settings-bio1',
40
+ biometric: 'biometric1',
41
+ show_bio_dialog: 'show-bio-dialog1',
42
+ registered_user: 'registered-user1',
43
+ });
44
+ // device_ios: {ios_push: 'ios', ios_voip: 'iosvoip'},
45
+ }
46
+ setEndPoint(index) {
47
+ console.log("DINTRE DEL LIB");
48
+ this._ENVIROMENT = this._LIST_ENPOINT[index];
49
+ _INDEX_ENPOINT = index;
50
+ this.API_ENDPOINT = this._ENVIROMENT.api;
51
+ this.DOOLE_ENDPOINT = this._ENVIROMENT.endpoint;
52
+ this.setIndexEndPointLocalstorage(index);
53
+ this._endpointIndex.next(index);
54
+ }
55
+ setIndexEndPointLocalstorage(endpoint) {
56
+ localStorage.setItem(ENDPOINT, JSON.stringify(endpoint));
57
+ }
58
+ getIndexEndPointLocalstorage() {
59
+ let endpoint = localStorage.getItem(ENDPOINT);
60
+ //console.log(`[ChangeEndpointsService] setEndPointLocalstorage()`, endpoint);
61
+ if (endpoint)
62
+ return Number(JSON.parse(endpoint));
63
+ return undefined;
64
+ }
65
+ getEndpointIndexObservable() {
66
+ return this._endpointIndex.asObservable();
67
+ }
68
+ setDefaultEndPoint() {
69
+ if (this.API_ENDPOINT == undefined || this.DOOLE_ENDPOINT == undefined) {
70
+ let index = this.getIndexEndPointLocalstorage();
71
+ index = (index == undefined) ? _INDEX_ENPOINT : index;
72
+ this.setEndPoint(index);
73
+ }
74
+ }
75
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: ChangeEndpointsService, deps: [{ token: CONFIGURACION_TOKEN }, { token: PUSHERS_CONFIG_TOKEN }], target: i0.ɵɵFactoryTarget.Injectable }); }
76
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: ChangeEndpointsService, providedIn: 'root' }); }
77
+ }
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: ChangeEndpointsService, decorators: [{
79
+ type: Injectable,
80
+ args: [{
81
+ providedIn: 'root'
82
+ }]
83
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
84
+ type: Inject,
85
+ args: [CONFIGURACION_TOKEN]
86
+ }] }, { type: undefined, decorators: [{
87
+ type: Inject,
88
+ args: [PUSHERS_CONFIG_TOKEN]
89
+ }] }] });
90
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbmdlLWVuZHBvaW50cy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2VydmljZS1saWIvc3JjL2xpYi9zZXJ2aWNlcy9jaGFuZ2UtZW5kcG9pbnRzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN2QyxPQUFPLEVBQUUsbUJBQW1CLEVBQWlCLG9CQUFvQixFQUE0QixNQUFNLGtCQUFrQixDQUFDOztBQUN0SCxNQUFNLENBQUMsSUFBSSxjQUFjLEdBQVcsQ0FBQyxDQUFBLENBQUMsc0JBQXNCO0FBQzVELE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQztBQWtCNUIsTUFBTSxPQUFPLHNCQUFzQjtJQVFqQyxZQUN1QyxTQUF3QixFQUN2QixNQUFxQjtRQUR0QixjQUFTLEdBQVQsU0FBUyxDQUFlO1FBQ3ZCLFdBQU0sR0FBTixNQUFNLENBQWU7UUFUckQsbUJBQWMsR0FBRyxJQUFJLGVBQWUsQ0FBUyxJQUFJLENBQUMsNEJBQTRCLEVBQUUsQ0FBQyxDQUFDO1FBSW5GLGtCQUFhLEdBQXNCLEVBQUUsQ0FBQTtRQU10QyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUE7UUFDbEIsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUE7SUFDNUIsQ0FBQztJQUVHLEtBQUssQ0FBQyxXQUFXO1FBQ3RCLElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBRSxDQUFBO1FBQ3ZCLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDO1lBQ3RCLEVBQUUsRUFBQyxDQUFDO1lBQ0osSUFBSSxFQUFFLHVCQUF1QjtZQUM3QixHQUFHLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0I7WUFDdEMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsY0FBYztZQUN2QyxVQUFVLEVBQUUsRUFBQyxRQUFRLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUM7WUFDekQsVUFBVSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYztZQUN0QyxLQUFLLEVBQUUsU0FBUztZQUNoQixZQUFZLEVBQUUsZUFBZTtZQUM3QixTQUFTLEVBQUUsWUFBWTtZQUN2QixlQUFlLEVBQUUsa0JBQWtCO1lBQ25DLGVBQWUsRUFBRSxrQkFBa0I7U0FDcEMsQ0FBQyxDQUFBO1FBQ0YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUM7WUFDdEIsRUFBRSxFQUFDLENBQUM7WUFDSixJQUFJLEVBQUUsd0JBQXdCO1lBQzlCLEdBQUcsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLGdCQUFnQjtZQUNwQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZO1lBQ3JDLFVBQVUsRUFBRSxFQUFDLFFBQVEsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLFlBQVksRUFBQztZQUN6RCxVQUFVLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjO1lBQ3RDLEtBQUssRUFBRSxTQUFTO1lBQ2hCLFlBQVksRUFBRSxlQUFlO1lBQzdCLFNBQVMsRUFBRSxZQUFZO1lBQ3ZCLGVBQWUsRUFBRSxrQkFBa0I7WUFDbkMsZUFBZSxFQUFFLGtCQUFrQjtTQUVwQyxDQUFDLENBQUE7UUFDSiwyREFBMkQ7SUFDM0QsQ0FBQztJQUVNLFdBQVcsQ0FBQyxLQUFLO1FBQ3RCLE9BQU8sQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUM5QixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDNUMsY0FBYyxHQUFHLEtBQUssQ0FBQTtRQUV0QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFBO1FBQ3hDLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUE7UUFDL0MsSUFBSSxDQUFDLDRCQUE0QixDQUFDLEtBQUssQ0FBQyxDQUFBO1FBQ3hDLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFRCw0QkFBNEIsQ0FBQyxRQUFRO1FBQ25DLFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQsNEJBQTRCO1FBQzFCLElBQUksUUFBUSxHQUFHLFlBQVksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDOUMsOEVBQThFO1FBQzlFLElBQUcsUUFBUTtZQUFFLE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQTtRQUNoRCxPQUFPLFNBQVMsQ0FBQTtJQUNsQixDQUFDO0lBQ0QsMEJBQTBCO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUM1QyxDQUFDO0lBQ0Qsa0JBQWtCO1FBQ2hCLElBQUcsSUFBSSxDQUFDLFlBQVksSUFBSSxTQUFTLElBQUksSUFBSSxDQUFDLGNBQWMsSUFBSSxTQUFTLEVBQUMsQ0FBQztZQUNyRSxJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsNEJBQTRCLEVBQUUsQ0FBQTtZQUMvQyxLQUFLLEdBQUcsQ0FBQyxLQUFLLElBQUksU0FBUyxDQUFDLENBQUEsQ0FBQyxDQUFDLGNBQWMsQ0FBQSxDQUFDLENBQUMsS0FBSyxDQUFBO1lBQ25ELElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDekIsQ0FBQztJQUNILENBQUM7K0dBN0VVLHNCQUFzQixrQkFTdkIsbUJBQW1CLGFBQ25CLG9CQUFvQjttSEFWbkIsc0JBQXNCLGNBRnJCLE1BQU07OzRGQUVQLHNCQUFzQjtrQkFIbEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQVVJLE1BQU07MkJBQUMsbUJBQW1COzswQkFDMUIsTUFBTTsyQkFBQyxvQkFBb0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFuZ3VsYXJGaXJlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZmlyZS9jb21wYXQnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBDT05GSUdVUkFDSU9OX1RPS0VOLCBDb25maWd1cmFjaW9uLCBQVVNIRVJTX0NPTkZJR19UT0tFTiwgUHVzaGVyS2V5LCBQdXNoZXJzQ29uZmlnIH0gZnJvbSAnLi4vY29uZmlndXJhdGlvbic7XG5leHBvcnQgdmFyIF9JTkRFWF9FTlBPSU5UOiBudW1iZXIgPSAwIC8vUG9yIGRlZmVjdG8gaW5kZXggMCBcbmNvbnN0IEVORFBPSU5UID0gJ2VuZHBvaW50JztcblxuZXhwb3J0IGludGVyZmFjZSBlbnZpcm9tZW50IHtcbiAgaWQ6bnVtYmVyLFxuICBuYW1lOiBzdHJpbmcsIFxuICBhcGk6IHN0cmluZywgXG4gIGVuZHBvaW50OiBzdHJpbmcsXG4gIGRldmljZV9pb3M6IHtpb3NfcHVzaDogc3RyaW5nLCBpb3Nfdm9pcDogc3RyaW5nfSxcbiAgY29sb3I/OiBzdHJpbmcsXG4gIHB1c2hlcl9rZXk6IFB1c2hlcktleSxcbiAgc2V0dGluZ3NfYmlvPzogc3RyaW5nLFxuICBiaW9tZXRyaWM/OiBzdHJpbmcsXG4gIHNob3dfYmlvX2RpYWxvZz86IHN0cmluZyxcbiAgcmVnaXN0ZXJlZF91c2VyPzogc3RyaW5nLFxufVxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgQ2hhbmdlRW5kcG9pbnRzU2VydmljZSB7XG4gIHByaXZhdGUgX2VuZHBvaW50SW5kZXggPSBuZXcgQmVoYXZpb3JTdWJqZWN0PG51bWJlcj4odGhpcy5nZXRJbmRleEVuZFBvaW50TG9jYWxzdG9yYWdlKCkpO1xuICBwdWJsaWMgQVBJX0VORFBPSU5UOiBzdHJpbmc7XG4gIHB1YmxpYyBET09MRV9FTkRQT0lOVDogc3RyaW5nO1xuXG4gIHB1YmxpYyBfTElTVF9FTlBPSU5UOiBBcnJheTxlbnZpcm9tZW50PiA9IFtdIFxuICBwdWJsaWMgX0VOVklST01FTlQ6IGVudmlyb21lbnQ7XG4gIHB1YmxpYyBzdGF0aWMgdXJsQmFja0VuZDogc3RyaW5nO1xuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KENPTkZJR1VSQUNJT05fVE9LRU4pIHByaXZhdGUgY29uc3RhbnRzOiBDb25maWd1cmFjaW9uLFxuICAgIEBJbmplY3QoUFVTSEVSU19DT05GSUdfVE9LRU4pIHByaXZhdGUgcHVzaGVyOiBQdXNoZXJzQ29uZmlnLCkge1xuICAgICAgICB0aGlzLmFkZEVuZFBvaW50KClcbiAgICAgICAgdGhpcy5zZXREZWZhdWx0RW5kUG9pbnQoKVxuICAgICB9XG5cbiAgcHVibGljIGFzeW5jIGFkZEVuZFBvaW50KCl7ICAgXG4gICAgdGhpcy5fTElTVF9FTlBPSU5UID0gW10gXG4gICAgdGhpcy5fTElTVF9FTlBPSU5ULnB1c2goeyBcbiAgICAgIGlkOjAsXG4gICAgICBuYW1lOiAnZW52aXJvbWVudC5wcm9kdWN0aW9uJywgXG4gICAgICBhcGk6IHRoaXMuY29uc3RhbnRzLkFQSV9ET09MRV9FTkRQT0lOVCwgXG4gICAgICBlbmRwb2ludDogdGhpcy5jb25zdGFudHMuRE9PTEVfRU5EUE9JTlQsXG4gICAgICBkZXZpY2VfaW9zOiB7aW9zX3B1c2g6ICdpb3NfZGV2JywgaW9zX3ZvaXA6ICdpb3N2b2lwZGV2J30sXG4gICAgICBwdXNoZXJfa2V5OiB0aGlzLnB1c2hlci5QVVNIRVJfS0VZX1BSTyxcbiAgICAgIGNvbG9yOiAncHJpbWFyeScsXG4gICAgICBzZXR0aW5nc19iaW86ICdzZXR0aW5ncy1iaW8wJyxcbiAgICAgIGJpb21ldHJpYzogJ2Jpb21ldHJpYzAnLFxuICAgICAgc2hvd19iaW9fZGlhbG9nOiAnc2hvdy1iaW8tZGlhbG9nMCcsXG4gICAgICByZWdpc3RlcmVkX3VzZXI6ICdyZWdpc3RlcmVkLXVzZXIwJyxcbiAgICB9KSBcbiAgICB0aGlzLl9MSVNUX0VOUE9JTlQucHVzaCh7XG4gICAgICBpZDoxLFxuICAgICAgbmFtZTogJ2Vudmlyb21lbnQuZGV2ZWxvcG1lbnQnLCBcbiAgICAgIGFwaTogdGhpcy5jb25zdGFudHMuQVBJX0VORFBPSU5UX0RFViwgXG4gICAgICBlbmRwb2ludDogdGhpcy5jb25zdGFudHMuRU5EUE9JTlRfREVWLFxuICAgICAgZGV2aWNlX2lvczoge2lvc19wdXNoOiAnaW9zX2RldicsIGlvc192b2lwOiAnaW9zdm9pcGRldid9LFxuICAgICAgcHVzaGVyX2tleTogdGhpcy5wdXNoZXIuUFVTSEVSX0tFWV9ERVYsXG4gICAgICBjb2xvcjogJ3dhcm5pbmcnLFxuICAgICAgc2V0dGluZ3NfYmlvOiAnc2V0dGluZ3MtYmlvMScsXG4gICAgICBiaW9tZXRyaWM6ICdiaW9tZXRyaWMxJyxcbiAgICAgIHNob3dfYmlvX2RpYWxvZzogJ3Nob3ctYmlvLWRpYWxvZzEnLFxuICAgICAgcmVnaXN0ZXJlZF91c2VyOiAncmVnaXN0ZXJlZC11c2VyMScsXG4gICAgIFxuICAgIH0pXG4gIC8vICAgICAgZGV2aWNlX2lvczoge2lvc19wdXNoOiAnaW9zJywgaW9zX3ZvaXA6ICdpb3N2b2lwJ30sXG4gIH1cblxuICBwdWJsaWMgc2V0RW5kUG9pbnQoaW5kZXgpe1xuICAgIGNvbnNvbGUubG9nKFwiRElOVFJFIERFTCBMSUJcIik7XG4gICAgdGhpcy5fRU5WSVJPTUVOVCA9IHRoaXMuX0xJU1RfRU5QT0lOVFtpbmRleF1cbiAgICBfSU5ERVhfRU5QT0lOVCA9IGluZGV4XG5cbiAgICB0aGlzLkFQSV9FTkRQT0lOVCA9IHRoaXMuX0VOVklST01FTlQuYXBpXG4gICAgdGhpcy5ET09MRV9FTkRQT0lOVCA9IHRoaXMuX0VOVklST01FTlQuZW5kcG9pbnRcbiAgICB0aGlzLnNldEluZGV4RW5kUG9pbnRMb2NhbHN0b3JhZ2UoaW5kZXgpXG4gICAgdGhpcy5fZW5kcG9pbnRJbmRleC5uZXh0KGluZGV4KTsgXG4gIH1cblxuICBzZXRJbmRleEVuZFBvaW50TG9jYWxzdG9yYWdlKGVuZHBvaW50KSB7XG4gICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oRU5EUE9JTlQsIEpTT04uc3RyaW5naWZ5KGVuZHBvaW50KSk7XG4gIH1cblxuICBnZXRJbmRleEVuZFBvaW50TG9jYWxzdG9yYWdlKCkge1xuICAgIGxldCBlbmRwb2ludCA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKEVORFBPSU5UKTtcbiAgICAvL2NvbnNvbGUubG9nKGBbQ2hhbmdlRW5kcG9pbnRzU2VydmljZV0gc2V0RW5kUG9pbnRMb2NhbHN0b3JhZ2UoKWAsIGVuZHBvaW50KTtcbiAgICBpZihlbmRwb2ludCkgcmV0dXJuIE51bWJlcihKU09OLnBhcnNlKGVuZHBvaW50KSlcbiAgICByZXR1cm4gdW5kZWZpbmVkXG4gIH1cbiAgZ2V0RW5kcG9pbnRJbmRleE9ic2VydmFibGUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2VuZHBvaW50SW5kZXguYXNPYnNlcnZhYmxlKCk7XG4gIH1cbiAgc2V0RGVmYXVsdEVuZFBvaW50KCl7XG4gICAgaWYodGhpcy5BUElfRU5EUE9JTlQgPT0gdW5kZWZpbmVkIHx8IHRoaXMuRE9PTEVfRU5EUE9JTlQgPT0gdW5kZWZpbmVkKXtcbiAgICAgIGxldCBpbmRleCA9IHRoaXMuZ2V0SW5kZXhFbmRQb2ludExvY2Fsc3RvcmFnZSgpXG4gICAgICBpbmRleCA9IChpbmRleCA9PSB1bmRlZmluZWQpPyBfSU5ERVhfRU5QT0lOVDogaW5kZXhcbiAgICAgIHRoaXMuc2V0RW5kUG9pbnQoaW5kZXgpXG4gICAgfVxuICB9XG59XG4iXX0=