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,133 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { CookieService } from 'ngx-cookie-service';
3
+ import { BehaviorSubject, Subject } from 'rxjs';
4
+ import { COOKIECONSTANT } from '../model/data_model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "ngx-cookie-service";
7
+ export class EventService {
8
+ constructor(_cookie) {
9
+ this._cookie = _cookie;
10
+ this.getUserLOB = new BehaviorSubject({});
11
+ this.getAssetType = new BehaviorSubject({});
12
+ this.refreshSidebar = new BehaviorSubject({});
13
+ this.filterRecords = new Subject();
14
+ this.AuthMethods = new BehaviorSubject([]);
15
+ this.refreshEmails = new BehaviorSubject({});
16
+ this.timeZone = new BehaviorSubject({});
17
+ }
18
+ emitLOBEvent(data) {
19
+ this.getUserLOB.next(data);
20
+ }
21
+ listenerLOBEvent() {
22
+ return this.getUserLOB.asObservable();
23
+ }
24
+ emitAssetTypeEvent(data) {
25
+ this.getAssetType.next(data);
26
+ }
27
+ listenerAssetTypeEvent() {
28
+ return this.getAssetType.asObservable();
29
+ }
30
+ emitrefreshSidebar(data) {
31
+ this.refreshSidebar.next(data);
32
+ }
33
+ listenerrefreshSidebar() {
34
+ return this.refreshSidebar.asObservable();
35
+ }
36
+ emitFilterRecords(data) {
37
+ this.filterRecords.next(data);
38
+ }
39
+ listenerFilterEvent() {
40
+ return this.filterRecords.asObservable();
41
+ }
42
+ emitAuthMethod(data) {
43
+ this.AuthMethods.next(data);
44
+ }
45
+ listenerAuthMethod() {
46
+ return this.AuthMethods.asObservable();
47
+ }
48
+ emitUserEmail(data) {
49
+ this.refreshEmails.next(data);
50
+ }
51
+ listenerUserEmail() {
52
+ return this.refreshEmails.asObservable();
53
+ }
54
+ emitTimezone(data) {
55
+ this.timeZone.next(data);
56
+ }
57
+ listenerTimezone() {
58
+ return this.timeZone.asObservable();
59
+ }
60
+ // checkMFAv1(mfaUrl: string) {
61
+ // return new Promise((resolve, reject) => {
62
+ // const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,
63
+ // width=600,height=500,left=350,top=150`;
64
+ // const mfaWindow = open(mfaUrl, 'CI Authentication', params);
65
+ // //setInterval to check cookie every second
66
+ // const interval = setInterval(() => {
67
+ // if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {
68
+ // clearInterval(interval);
69
+ // // clearTimeout(timeout);
70
+ // mfaWindow.close();
71
+ // resolve(true);
72
+ // }
73
+ // else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {
74
+ // clearInterval(interval);
75
+ // mfaWindow.close();
76
+ // reject(false);
77
+ // }
78
+ // }, 1000);
79
+ // //when use close window manually
80
+ // let flag = false;
81
+ // mfaWindow.onunload = () => {
82
+ // if (flag) {
83
+ // console.log("window closed manually");
84
+ // clearInterval(interval);
85
+ // // clearTimeout(timeout);
86
+ // reject(false);
87
+ // }
88
+ // flag = true;
89
+ // }
90
+ // })
91
+ // }
92
+ checkMFA(mfaUrl) {
93
+ return new Promise((resolve, reject) => {
94
+ const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,
95
+ width=600,height=500,left=350,top=150`;
96
+ const mfaWindow = window.open(mfaUrl, 'CI Authentication', params);
97
+ if (!mfaWindow) {
98
+ reject(new Error("Failed to open MFA window. Popup blocked?"));
99
+ return;
100
+ }
101
+ // Polling interval to check cookie every second
102
+ const interval = setInterval(() => {
103
+ if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {
104
+ clearInterval(interval);
105
+ mfaWindow.close();
106
+ resolve(true);
107
+ }
108
+ else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {
109
+ clearInterval(interval);
110
+ mfaWindow.close();
111
+ reject(false);
112
+ }
113
+ }, 1000);
114
+ // Detect manual close of popup window
115
+ const checkPopupClosed = setInterval(() => {
116
+ if (mfaWindow.closed) {
117
+ clearInterval(interval);
118
+ clearInterval(checkPopupClosed);
119
+ reject(false);
120
+ }
121
+ }, 500);
122
+ });
123
+ }
124
+ }
125
+ EventService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, deps: [{ token: i1.CookieService }], target: i0.ɵɵFactoryTarget.Injectable });
126
+ EventService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, providedIn: 'root' });
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: EventService, decorators: [{
128
+ type: Injectable,
129
+ args: [{
130
+ providedIn: 'root',
131
+ }]
132
+ }], ctorParameters: function () { return [{ type: i1.CookieService }]; } });
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.service.js","sourceRoot":"","sources":["../../../../../projects/common-header-lib/src/lib/services/event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { CookieService } from 'ngx-cookie-service';\r\nimport { BehaviorSubject, Subject } from 'rxjs';\r\nimport { COOKIECONSTANT } from '../model/data_model';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class EventService {\r\n  private getUserLOB = new BehaviorSubject<any>({});\r\n  private getAssetType = new BehaviorSubject<any>({});\r\n  private refreshSidebar = new BehaviorSubject<any>({});\r\n  private filterRecords = new Subject<any>();\r\n  private AuthMethods = new BehaviorSubject<any>([]);\r\n  private refreshEmails = new BehaviorSubject<any>({});\r\n  private timeZone = new BehaviorSubject<any>({});\r\n\r\n  constructor(private _cookie : CookieService) { }\r\n\r\n  emitLOBEvent(data: any) {\r\n    this.getUserLOB.next(data);\r\n  }\r\n\r\n  listenerLOBEvent() {\r\n    return this.getUserLOB.asObservable();\r\n  }\r\n\r\n  emitAssetTypeEvent(data: any) {\r\n    this.getAssetType.next(data);\r\n  }\r\n\r\n  listenerAssetTypeEvent() {\r\n    return this.getAssetType.asObservable();\r\n  }\r\n\r\n  emitrefreshSidebar(data: any) {\r\n    this.refreshSidebar.next(data);\r\n  }\r\n\r\n  listenerrefreshSidebar() {\r\n    return this.refreshSidebar.asObservable();\r\n  }\r\n\r\n  emitFilterRecords(data: any) {\r\n    this.filterRecords.next(data);\r\n  }\r\n\r\n  listenerFilterEvent() {\r\n    return this.filterRecords.asObservable();\r\n  }\r\n\r\n  emitAuthMethod(data: any) {\r\n    this.AuthMethods.next(data);\r\n  }\r\n\r\n  listenerAuthMethod() {\r\n    return this.AuthMethods.asObservable();\r\n  }\r\n\r\n  emitUserEmail(data: any) {\r\n    this.refreshEmails.next(data);\r\n  }\r\n\r\n  listenerUserEmail() {\r\n    return this.refreshEmails.asObservable();\r\n  }\r\n\r\n  emitTimezone(data: any) {\r\n    this.timeZone.next(data);\r\n  }\r\n\r\n  listenerTimezone() {\r\n    return this.timeZone.asObservable();\r\n  }\r\n\r\n  // checkMFAv1(mfaUrl: string) {\r\n  //   return new Promise((resolve, reject) => {\r\n  //     const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,\r\n  //     width=600,height=500,left=350,top=150`;\r\n  //     const mfaWindow = open(mfaUrl, 'CI Authentication', params);\r\n      \r\n\r\n  //     //setInterval to check cookie every second\r\n  //     const interval = setInterval(() => {\r\n  //       if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {\r\n  //         clearInterval(interval);\r\n  //         // clearTimeout(timeout);\r\n  //         mfaWindow.close();\r\n  //         resolve(true);\r\n  //       }\r\n  //       else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {\r\n  //         clearInterval(interval);\r\n  //         mfaWindow.close();\r\n  //         reject(false);\r\n  //       }\r\n  //     }, 1000);\r\n\r\n  //     //when use close window manually\r\n  //     let flag = false;\r\n  //     mfaWindow.onunload = () => {\r\n  //       if (flag) {\r\n  //         console.log(\"window closed manually\");\r\n  //         clearInterval(interval);\r\n  //         // clearTimeout(timeout);\r\n  //         reject(false);\r\n  //       }\r\n  //       flag = true;\r\n  //     }\r\n  //   })\r\n  // }\r\n  checkMFA(mfaUrl: string) {\r\n  return new Promise<boolean>((resolve, reject) => {\r\n    const params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,\r\n      width=600,height=500,left=350,top=150`;\r\n\r\n    const mfaWindow = window.open(mfaUrl, 'CI Authentication', params);\r\n\r\n    if (!mfaWindow) {\r\n      reject(new Error(\"Failed to open MFA window. Popup blocked?\"));\r\n      return;\r\n    }\r\n\r\n    // Polling interval to check cookie every second\r\n    const interval = setInterval(() => {\r\n      if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECK)) {\r\n        clearInterval(interval);\r\n        mfaWindow.close();\r\n        resolve(true);\r\n      } else if (this._cookie.get(COOKIECONSTANT.MFASTATUSCHECKFAIL)) {\r\n        clearInterval(interval);\r\n        mfaWindow.close();\r\n        reject(false);\r\n      }\r\n    }, 1000);\r\n\r\n    // Detect manual close of popup window\r\n    const checkPopupClosed = setInterval(() => {\r\n      if (mfaWindow.closed) {\r\n        clearInterval(interval);\r\n        clearInterval(checkPopupClosed);\r\n        reject(false);\r\n      }\r\n    }, 500);\r\n  });\r\n}\r\n\r\n}\r\n"]}
@@ -0,0 +1,216 @@
1
+ import { HttpClient, HttpParams } from '@angular/common/http';
2
+ import { Injectable } from '@angular/core';
3
+ import { catchError, map, throwError } from 'rxjs';
4
+ import { GlobalConstants } from '../../model/data_model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common/http";
7
+ export class HttpCommonService {
8
+ constructor(http) {
9
+ this.http = http;
10
+ this.xAccessAPIUrl = '/xaccess/api/SecureAccess/';
11
+ this.metaAPIUrl = '/meta/api/metadata/';
12
+ this.metaAPIUrl1 = '/meta/api/Metadata/';
13
+ this.xServiceAPIUrl = '/xservice/api/CIInfraAsset/';
14
+ this.workflowAPIUrl = '/workflow/api/Workflow/Workflow/';
15
+ }
16
+ getLogo() {
17
+ return this.http
18
+ .get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}BackgroundLogo`)
19
+ .pipe(map((response) => {
20
+ return response['result'];
21
+ }));
22
+ }
23
+ getGlobalTimeZone() {
24
+ return this.http
25
+ .get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetSystemTimeZones`)
26
+ .pipe(map((response) => {
27
+ if (response && response['success']) {
28
+ return response['result'];
29
+ }
30
+ else {
31
+ return [];
32
+ }
33
+ }));
34
+ }
35
+ updateUserTimeZone(tz) {
36
+ const params = new HttpParams().set('timezone', tz);
37
+ return this.http
38
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}UpdateTimeZone`, {}, { params: params })
39
+ .pipe(map((response) => {
40
+ if (response && response['success']) {
41
+ return response['result'];
42
+ }
43
+ else {
44
+ return '';
45
+ }
46
+ }));
47
+ }
48
+ getLOBList() {
49
+ return this.http
50
+ .get(`${GlobalConstants.baseURL}${this.metaAPIUrl}Lobs`)
51
+ .pipe(map((response) => {
52
+ return response;
53
+ }));
54
+ }
55
+ getUnreadUserEmailsCount() {
56
+ return this.http
57
+ .get(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBoxCount`)
58
+ .pipe(map((response) => {
59
+ if (response && response['success'] && response['result'] > 0) {
60
+ return response['result'];
61
+ }
62
+ else {
63
+ return 0;
64
+ }
65
+ }));
66
+ }
67
+ getUserAssignedMails(userDetails) {
68
+ return this.http
69
+ .post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBox`, userDetails)
70
+ .pipe(map((response) => {
71
+ if (response && response['success']) {
72
+ return response['result'];
73
+ }
74
+ else {
75
+ return [];
76
+ }
77
+ }));
78
+ }
79
+ /*Method : GET
80
+ Action : Get Application Password */
81
+ getAccessToViewServicePassword(mailDetails) {
82
+ return this.http
83
+ .post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}OpenServicePwd`, mailDetails)
84
+ .pipe(map((response) => {
85
+ if (response && response['success']) {
86
+ response['result'][1] = response['message'];
87
+ return response['result'];
88
+ }
89
+ else {
90
+ return [];
91
+ }
92
+ }), catchError((e) => throwError(this.errorHandler(e))));
93
+ }
94
+ getUserAssignedApps() {
95
+ return this.http
96
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUserPriviledgesList`, {})
97
+ .pipe(map((response) => {
98
+ if (response && response['success']) {
99
+ return response['result'].filter((x) => x.appCode != null);
100
+ }
101
+ else {
102
+ return [];
103
+ }
104
+ }));
105
+ }
106
+ getLoggedInUserDetails() {
107
+ return this.http
108
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUsersDetailsById`, {})
109
+ .pipe(map((response) => {
110
+ return response;
111
+ }));
112
+ }
113
+ //Method: Used to Total Notification count of user
114
+ //Action: It used get all notification count
115
+ getWorkFlowTicketCount(userDetails) {
116
+ return this.http
117
+ .post(`${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCount`, userDetails)
118
+ .pipe(map((response) => {
119
+ if (response && response[0]['Success']) {
120
+ if (response[0]['Data'][0]) {
121
+ return response[0]['Data'][0];
122
+ }
123
+ else {
124
+ return {};
125
+ }
126
+ }
127
+ else {
128
+ return {};
129
+ }
130
+ }), catchError((e) => throwError(this.errorHandler(e))));
131
+ }
132
+ getWorkFlowTicketEventwiseCount(userDetails) {
133
+ return this.http
134
+ .post(`${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCountEventWise`, userDetails)
135
+ .pipe(map((response) => {
136
+ if (response && response[0]['Success']) {
137
+ // return response[0]['Data'];
138
+ return [];
139
+ }
140
+ else {
141
+ return [];
142
+ }
143
+ }));
144
+ }
145
+ setLandingPgPreference(moduleId) {
146
+ return this.http
147
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}SetLandingPage`, {
148
+ moduleId: moduleId,
149
+ })
150
+ .pipe(map((response) => {
151
+ if (response && response['success']) {
152
+ return response['result'];
153
+ }
154
+ else {
155
+ return '';
156
+ }
157
+ }));
158
+ }
159
+ /*Method : POST
160
+ Action :Will validate User entered PWD as
161
+ per Password Policy Set
162
+ */
163
+ validatePassword(userDetails) {
164
+ return this.http
165
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}ValidatePassword`, userDetails)
166
+ .pipe(catchError((e) => throwError(this.errorHandler(e))));
167
+ }
168
+ /*Method : POST
169
+ Action : RESET Password for First Time User
170
+ */
171
+ setNewpassword(loggedInUserDetails) {
172
+ return this.http
173
+ .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}ChangeUserArcXwdManually`, loggedInUserDetails)
174
+ .pipe(catchError((e) => throwError(this.errorHandler(e))));
175
+ }
176
+ errorHandler(e) {
177
+ throw new Error('Method not implemented.');
178
+ }
179
+ /*Method : GET
180
+ Action : Get hiding the password for a service. */
181
+ getProtectedServiceCredentials(mailDetails) {
182
+ return this.http
183
+ .post(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}GetServicePasswordClose`, mailDetails)
184
+ .pipe(map((response) => {
185
+ if (response && response['success']) {
186
+ return response['result'];
187
+ }
188
+ else {
189
+ return false;
190
+ }
191
+ }), catchError((e) => throwError(this.errorHandler(e))));
192
+ }
193
+ /*Method : POST
194
+ Parameter : subID , id
195
+ Action : Get configuration ID based on to show hide DOMAIN dropdown
196
+ */
197
+ getglobalConfigDetails(subid, id) {
198
+ return this.http
199
+ .post(`${GlobalConstants.baseURL}${this.metaAPIUrl1}GetArcosConfigsValues?subId=${subid}`, id)
200
+ .pipe(map((response) => {
201
+ if (response['statusCode'] === 200) {
202
+ let result = response['result'];
203
+ return result;
204
+ }
205
+ }), catchError((e) => throwError(this.errorHandler(e))));
206
+ }
207
+ }
208
+ HttpCommonService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
209
+ HttpCommonService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, providedIn: 'root' });
210
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpCommonService, decorators: [{
211
+ type: Injectable,
212
+ args: [{
213
+ providedIn: 'root',
214
+ }]
215
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-common.service.js","sourceRoot":"","sources":["../../../../../../projects/common-header-lib/src/lib/services/http/http-common.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpParams } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { catchError, map, throwError } from 'rxjs';\nimport { GlobalConstants } from '../../model/data_model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class HttpCommonService {\n  private xAccessAPIUrl: string = '/xaccess/api/SecureAccess/';\n  private metaAPIUrl: string = '/meta/api/metadata/';\n  private metaAPIUrl1: string = '/meta/api/Metadata/';\n  private xServiceAPIUrl: string = '/xservice/api/CIInfraAsset/';\n  private workflowAPIUrl: string = '/workflow/api/Workflow/Workflow/';\n\n  constructor(private http: HttpClient) {}\n\n  getLogo() {\n    return this.http\n      .get<any>(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}BackgroundLogo`)\n      .pipe(\n        map((response) => {\n          return response['result'];\n        }),\n      );\n  }\n\n  getGlobalTimeZone() {\n    return this.http\n      .get(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetSystemTimeZones`)\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  updateUserTimeZone(tz: string) {\n    const params = new HttpParams().set('timezone', tz);\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}UpdateTimeZone`,\n        {},\n        { params: params },\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return '';\n          }\n        }),\n      );\n  }\n\n  getLOBList() {\n    return this.http\n      .get(`${GlobalConstants.baseURL}${this.metaAPIUrl}Lobs`)\n      .pipe(\n        map((response: any) => {\n          return response;\n        }),\n      );\n  }\n\n  getUnreadUserEmailsCount() {\n    return this.http\n      .get<any>(`${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBoxCount`)\n      .pipe(\n        map((response: any) => {\n          if (response && response['success'] && response['result'] > 0) {\n            return response['result'];\n          } else {\n            return 0;\n          }\n        }),\n      );\n  }\n\n  getUserAssignedMails(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}MailBox`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  /*Method : GET\n   Action : Get Application Password  */\n  getAccessToViewServicePassword(mailDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}OpenServicePwd`,\n        mailDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            response['result'][1] = response['message'];\n            return response['result'];\n          } else {\n            return [];\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  getUserAssignedApps() {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUserPriviledgesList`,\n        {},\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'].filter(\n              (x: any) => x.appCode != null,\n              // (x) => x.appCode !== 'APP026' && x.appCode != null\n            );\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  getLoggedInUserDetails() {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}GetUsersDetailsById`,\n        {},\n      )\n      .pipe(\n        map((response: any) => {\n          return response;\n        }),\n      );\n  }\n\n  //Method: Used to Total Notification count of user\n  //Action: It used get all notification count\n  getWorkFlowTicketCount(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCount`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response[0]['Success']) {\n            if (response[0]['Data'][0]) {\n              return response[0]['Data'][0];\n            } else {\n              return {};\n            }\n          } else {\n            return {};\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  getWorkFlowTicketEventwiseCount(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.workflowAPIUrl}GetWorkFlowTicketCountEventWise`,\n        userDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response[0]['Success']) {\n            // return response[0]['Data'];\n            return [];\n          } else {\n            return [];\n          }\n        }),\n      );\n  }\n\n  setLandingPgPreference(moduleId: string) {\n    return this.http\n      .post(`${GlobalConstants.baseURL}${this.xAccessAPIUrl}SetLandingPage`, {\n        moduleId: moduleId,\n      })\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return '';\n          }\n        }),\n      );\n  }\n\n  /*Method : POST\n   Action :Will validate User entered PWD as\n  per Password Policy Set\n     */\n  validatePassword(userDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}ValidatePassword`,\n        userDetails,\n      )\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\n  }\n\n  /*Method : POST\n   Action : RESET Password for First Time User\n     */\n  setNewpassword(loggedInUserDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xAccessAPIUrl}ChangeUserArcXwdManually`,\n        loggedInUserDetails,\n      )\n      .pipe(catchError((e) => throwError(this.errorHandler(e))));\n  }\n\n  errorHandler(e: any): any {\n    throw new Error('Method not implemented.');\n  }\n\n  /*Method : GET\n   Action : Get hiding the password for a service. */\n  getProtectedServiceCredentials(mailDetails: any) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.xServiceAPIUrl}GetServicePasswordClose`,\n        mailDetails,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response && response['success']) {\n            return response['result'];\n          } else {\n            return false;\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n\n  /*Method : POST\n  Parameter : subID  , id\n   Action : Get configuration ID based on to show hide DOMAIN dropdown\n     */\n\n  getglobalConfigDetails(subid: string, id: number[]) {\n    return this.http\n      .post(\n        `${GlobalConstants.baseURL}${this.metaAPIUrl1}GetArcosConfigsValues?subId=${subid}`,\n        id,\n      )\n      .pipe(\n        map((response: any) => {\n          if (response['statusCode'] === 200) {\n            let result = response['result'];\n            return result;\n          }\n        }),\n        catchError((e) => throwError(this.errorHandler(e))),\n      );\n  }\n}\n"]}
@@ -0,0 +1,84 @@
1
+ import { HttpClient } from '@angular/common/http';
2
+ import { Injectable } from '@angular/core';
3
+ import { catchError, map, throwError } from 'rxjs';
4
+ import { GlobalConstants } from '../../model/data_model';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common/http";
7
+ export class HttpGeneralConfigurationService {
8
+ constructor(http) {
9
+ this.http = http;
10
+ this.xPageRefAPIUrl = '/xaccess/api/PagePreference/';
11
+ }
12
+ getUserPreferredAssetTypeDetails() {
13
+ return this.http
14
+ .get(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetAssetTypeDetails`)
15
+ .pipe(map((response) => {
16
+ if (response && response['success']) {
17
+ return response['result'];
18
+ }
19
+ else {
20
+ return [];
21
+ }
22
+ }), catchError((e) => throwError(this.errorHandler(e))));
23
+ }
24
+ getUserPreferredAssetName(payload) {
25
+ return this.http
26
+ .post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetAssetName`, payload)
27
+ .pipe(map((response) => {
28
+ if (response && response['success']) {
29
+ return response['result'];
30
+ }
31
+ else {
32
+ return [];
33
+ }
34
+ }), catchError((e) => throwError(this.errorHandler(e))));
35
+ }
36
+ getServiceNameByAssetTypeEvent(payload) {
37
+ return this.http
38
+ .post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}GetServiceDetails`, payload)
39
+ .pipe(map((response) => {
40
+ if (response && response['success']) {
41
+ return response['result'];
42
+ }
43
+ else {
44
+ return [];
45
+ }
46
+ }), catchError((e) => throwError(this.errorHandler(e))));
47
+ }
48
+ getPreferencePathDetails(payload) {
49
+ return this.http
50
+ .post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}CurrentPreferencepathDetails`, payload)
51
+ .pipe(map((response) => {
52
+ if (response && response['success']) {
53
+ return response['result'];
54
+ }
55
+ else {
56
+ return {};
57
+ }
58
+ }), catchError((e) => throwError(this.errorHandler(e))));
59
+ }
60
+ updatePreferencePath(payload) {
61
+ return this.http
62
+ .post(`${GlobalConstants.baseURL}${this.xPageRefAPIUrl}UpdatePreferencePath`, payload)
63
+ .pipe(map((response) => {
64
+ if (response && response['success']) {
65
+ return true;
66
+ }
67
+ else {
68
+ return false;
69
+ }
70
+ }), catchError((e) => throwError(this.errorHandler(e))));
71
+ }
72
+ errorHandler(e) {
73
+ throw new Error('Method not implemented.');
74
+ }
75
+ }
76
+ HttpGeneralConfigurationService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
77
+ HttpGeneralConfigurationService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, providedIn: 'root' });
78
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HttpGeneralConfigurationService, decorators: [{
79
+ type: Injectable,
80
+ args: [{
81
+ providedIn: 'root',
82
+ }]
83
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
84
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaHR0cC1nZW5lcmFsLWNvbmZpZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uLWhlYWRlci1saWIvc3JjL2xpYi9zZXJ2aWNlcy9odHRwL2h0dHAtZ2VuZXJhbC1jb25maWcuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLEdBQUcsRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDbkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOzs7QUFLekQsTUFBTSxPQUFPLCtCQUErQjtJQUcxQyxZQUFvQixJQUFnQjtRQUFoQixTQUFJLEdBQUosSUFBSSxDQUFZO1FBRjVCLG1CQUFjLEdBQVcsOEJBQThCLENBQUM7SUFFekIsQ0FBQztJQUV4QyxnQ0FBZ0M7UUFDOUIsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLEdBQUcsQ0FDRixHQUFHLGVBQWUsQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLGNBQWMscUJBQXFCLENBQ3RFO2FBQ0EsSUFBSSxDQUNILEdBQUcsQ0FBQyxDQUFDLFFBQWEsRUFBRSxFQUFFO1lBQ3BCLElBQUksUUFBUSxJQUFJLFFBQVEsQ0FBQyxTQUFTLENBQUMsRUFBRTtnQkFDbkMsT0FBTyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDM0I7aUJBQU07Z0JBQ0wsT0FBTyxFQUFFLENBQUM7YUFDWDtRQUNILENBQUMsQ0FBQyxFQUNGLFVBQVUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUNwRCxDQUFDO0lBQ04sQ0FBQztJ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QUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgY2F0Y2hFcnJvciwgbWFwLCB0aHJvd0Vycm9yIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEdsb2JhbENvbnN0YW50cyB9IGZyb20gJy4uLy4uL21vZGVsL2RhdGFfbW9kZWwnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIEh0dHBHZW5lcmFsQ29uZmlndXJhdGlvblNlcnZpY2Uge1xyXG4gIHByaXZhdGUgeFBhZ2VSZWZBUElVcmw6IHN0cmluZyA9ICcveGFjY2Vzcy9hcGkvUGFnZVByZWZlcmVuY2UvJztcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7fVxyXG5cclxuICBnZXRVc2VyUHJlZmVycmVkQXNzZXRUeXBlRGV0YWlscygpIHtcclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLmdldChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9R2V0QXNzZXRUeXBlRGV0YWlsc2BcclxuICAgICAgKVxyXG4gICAgICAucGlwZShcclxuICAgICAgICBtYXAoKHJlc3BvbnNlOiBhbnkpID0+IHtcclxuICAgICAgICAgIGlmIChyZXNwb25zZSAmJiByZXNwb25zZVsnc3VjY2VzcyddKSB7XHJcbiAgICAgICAgICAgIHJldHVybiByZXNwb25zZVsncmVzdWx0J107XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICByZXR1cm4gW107XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSksXHJcbiAgICAgICAgY2F0Y2hFcnJvcigoZSkgPT4gdGhyb3dFcnJvcih0aGlzLmVycm9ySGFuZGxlcihlKSkpXHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBnZXRVc2VyUHJlZmVycmVkQXNzZXROYW1lKHBheWxvYWQ6IGFueSkge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cFxyXG4gICAgICAucG9zdChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9R2V0QXNzZXROYW1lYCxcclxuICAgICAgICBwYXlsb2FkXHJcbiAgICAgIClcclxuICAgICAgLnBpcGUoXHJcbiAgICAgICAgbWFwKChyZXNwb25zZTogYW55KSA9PiB7XHJcbiAgICAgICAgICBpZiAocmVzcG9uc2UgJiYgcmVzcG9uc2VbJ3N1Y2Nlc3MnXSkge1xyXG4gICAgICAgICAgICByZXR1cm4gcmVzcG9uc2VbJ3Jlc3VsdCddO1xyXG4gICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgcmV0dXJuIFtdO1xyXG4gICAgICAgICAgfVxyXG4gICAgICAgIH0pLFxyXG4gICAgICAgIGNhdGNoRXJyb3IoKGUpID0+IHRocm93RXJyb3IodGhpcy5lcnJvckhhbmRsZXIoZSkpKVxyXG4gICAgICApO1xyXG4gIH1cclxuICBnZXRTZXJ2aWNlTmFtZUJ5QXNzZXRUeXBlRXZlbnQocGF5bG9hZDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0KFxyXG4gICAgICAgIGAke0dsb2JhbENvbnN0YW50cy5iYXNlVVJMfSR7dGhpcy54UGFnZVJlZkFQSVVybH1HZXRTZXJ2aWNlRGV0YWlsc2AsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlWydyZXN1bHQnXTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiBbXTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlKSA9PiB0aHJvd0Vycm9yKHRoaXMuZXJyb3JIYW5kbGVyKGUpKSlcclxuICAgICAgKTtcclxuICB9XHJcbiAgZ2V0UHJlZmVyZW5jZVBhdGhEZXRhaWxzKHBheWxvYWQ6IGFueSkge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cFxyXG4gICAgICAucG9zdChcclxuICAgICAgICBgJHtHbG9iYWxDb25zdGFudHMuYmFzZVVSTH0ke3RoaXMueFBhZ2VSZWZBUElVcmx9Q3VycmVudFByZWZlcmVuY2VwYXRoRGV0YWlsc2AsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHJlc3BvbnNlWydyZXN1bHQnXTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHJldHVybiB7fTtcclxuICAgICAgICAgIH1cclxuICAgICAgICB9KSxcclxuICAgICAgICBjYXRjaEVycm9yKChlKSA9PiB0aHJvd0Vycm9yKHRoaXMuZXJyb3JIYW5kbGVyKGUpKSlcclxuICAgICAgKTtcclxuICB9XHJcbiAgdXBkYXRlUHJlZmVyZW5jZVBhdGgocGF5bG9hZDogYW55KSB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwXHJcbiAgICAgIC5wb3N0KFxyXG4gICAgICAgIGAke0dsb2JhbENvbnN0YW50cy5iYXNlVVJMfSR7dGhpcy54UGFnZVJlZkFQSVVybH1VcGRhdGVQcmVmZXJlbmNlUGF0aGAsXHJcbiAgICAgICAgcGF5bG9hZFxyXG4gICAgICApXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzcG9uc2U6IGFueSkgPT4ge1xyXG4gICAgICAgICAgaWYgKHJlc3BvbnNlICYmIHJlc3BvbnNlWydzdWNjZXNzJ10pIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgfSksXHJcbiAgICAgICAgY2F0Y2hFcnJvcigoZSkgPT4gdGhyb3dFcnJvcih0aGlzLmVycm9ySGFuZGxlcihlKSkpXHJcbiAgICAgICk7XHJcbiAgfVxyXG5cclxuICBlcnJvckhhbmRsZXIoZTogYW55KTogYW55IHtcclxuICAgIHRocm93IG5ldyBFcnJvcignTWV0aG9kIG5vdCBpbXBsZW1lbnRlZC4nKTtcclxuICB9XHJcbn1cclxuIl19