@revxui/intellibid-client-ts 1.0.68 → 1.0.70

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 (105) hide show
  1. package/README.md +2 -2
  2. package/api/advertiserController.service.d.ts +137 -137
  3. package/api/api.d.ts +11 -11
  4. package/api/audienceController.service.d.ts +128 -128
  5. package/api/campaignController.service.d.ts +110 -127
  6. package/api/insightsController.service.d.ts +33 -33
  7. package/api/lookupDataController.service.d.ts +58 -58
  8. package/api.module.d.ts +11 -11
  9. package/configuration.d.ts +48 -48
  10. package/encoder.d.ts +10 -10
  11. package/esm2020/api/advertiserController.service.mjs +327 -327
  12. package/esm2020/api/api.mjs +11 -11
  13. package/esm2020/api/audienceController.service.mjs +326 -326
  14. package/esm2020/api/campaignController.service.mjs +297 -326
  15. package/esm2020/api/insightsController.service.mjs +107 -107
  16. package/esm2020/api/lookupDataController.service.mjs +134 -134
  17. package/esm2020/api.module.mjs +56 -56
  18. package/esm2020/configuration.mjs +58 -58
  19. package/esm2020/encoder.mjs +16 -16
  20. package/esm2020/index.mjs +5 -5
  21. package/esm2020/model/adAccountResponse.mjs +25 -25
  22. package/esm2020/model/advertiserMmpConversionEventResponse.mjs +12 -12
  23. package/esm2020/model/advertiserResponse.mjs +12 -12
  24. package/esm2020/model/advertiserSearchResponse.mjs +12 -12
  25. package/esm2020/model/audienceResponse.mjs +16 -16
  26. package/esm2020/model/blockedEventResponse.mjs +12 -12
  27. package/esm2020/model/businessZoneResponse.mjs +12 -12
  28. package/esm2020/model/campaignChangeLogResponse.mjs +23 -23
  29. package/esm2020/model/campaignInsightRecord.mjs +18 -18
  30. package/esm2020/model/campaignInsightsResponse.mjs +1 -1
  31. package/esm2020/model/campaignRequest.mjs +34 -34
  32. package/esm2020/model/campaignResponse.mjs +26 -26
  33. package/esm2020/model/campaignSearchResponse.mjs +12 -12
  34. package/esm2020/model/childAudience.mjs +37 -37
  35. package/esm2020/model/countryResponse.mjs +12 -12
  36. package/esm2020/model/createBlockedLiveAudienceRequest.mjs +21 -21
  37. package/esm2020/model/createBucketizedCustomAudienceRequest.mjs +36 -36
  38. package/esm2020/model/createBucketizedLiveAudienceRequest.mjs +25 -25
  39. package/esm2020/model/createDsCustomQueryAudienceRequest.mjs +32 -32
  40. package/esm2020/model/goalEventOptionDTO.mjs +13 -13
  41. package/esm2020/model/goalResponse.mjs +12 -12
  42. package/esm2020/model/models.mjs +37 -38
  43. package/esm2020/model/oSResponse.mjs +12 -12
  44. package/esm2020/model/pageAdvertiserResponse.mjs +2 -2
  45. package/esm2020/model/pageCampaignChangeLogResponse.mjs +2 -2
  46. package/esm2020/model/pageCampaignResponse.mjs +2 -2
  47. package/esm2020/model/pageableObject.mjs +1 -1
  48. package/esm2020/model/platformResponse.mjs +12 -12
  49. package/esm2020/model/productSetRequest.mjs +21 -21
  50. package/esm2020/model/productSetResponse.mjs +21 -21
  51. package/esm2020/model/scheduleUpdateRequest.mjs +18 -18
  52. package/esm2020/model/scheduledUpdates.mjs +12 -12
  53. package/esm2020/model/sortObject.mjs +12 -12
  54. package/esm2020/model/supportedGoalEventsResponseDTO.mjs +1 -1
  55. package/esm2020/model/updateAudienceNameRequest.mjs +21 -21
  56. package/esm2020/model/updateDsCustomQuerySqlRequest.mjs +21 -21
  57. package/esm2020/model/validateDsQueryRequest.mjs +12 -12
  58. package/esm2020/revxui-intellibid-client-ts.mjs +4 -4
  59. package/esm2020/variables.mjs +8 -8
  60. package/fesm2015/revxui-intellibid-client-ts.mjs +1661 -1690
  61. package/fesm2015/revxui-intellibid-client-ts.mjs.map +1 -1
  62. package/fesm2020/revxui-intellibid-client-ts.mjs +1788 -1829
  63. package/fesm2020/revxui-intellibid-client-ts.mjs.map +1 -1
  64. package/index.d.ts +5 -5
  65. package/model/adAccountResponse.d.ts +32 -32
  66. package/model/advertiserMmpConversionEventResponse.d.ts +15 -15
  67. package/model/advertiserResponse.d.ts +32 -32
  68. package/model/advertiserSearchResponse.d.ts +16 -16
  69. package/model/audienceResponse.d.ts +45 -45
  70. package/model/blockedEventResponse.d.ts +15 -15
  71. package/model/businessZoneResponse.d.ts +17 -17
  72. package/model/campaignChangeLogResponse.d.ts +34 -34
  73. package/model/campaignInsightRecord.d.ts +56 -56
  74. package/model/campaignInsightsResponse.d.ts +16 -16
  75. package/model/campaignRequest.d.ts +55 -55
  76. package/model/campaignResponse.d.ts +75 -75
  77. package/model/campaignSearchResponse.d.ts +15 -15
  78. package/model/childAudience.d.ts +69 -69
  79. package/model/countryResponse.d.ts +18 -18
  80. package/model/createBlockedLiveAudienceRequest.d.ts +27 -27
  81. package/model/createBucketizedCustomAudienceRequest.d.ts +56 -56
  82. package/model/createBucketizedLiveAudienceRequest.d.ts +40 -40
  83. package/model/createDsCustomQueryAudienceRequest.d.ts +48 -48
  84. package/model/goalEventOptionDTO.d.ts +14 -15
  85. package/model/goalResponse.d.ts +15 -15
  86. package/model/models.d.ts +36 -37
  87. package/model/oSResponse.d.ts +15 -15
  88. package/model/pageAdvertiserResponse.d.ts +27 -27
  89. package/model/pageCampaignChangeLogResponse.d.ts +27 -27
  90. package/model/pageCampaignResponse.d.ts +27 -27
  91. package/model/pageableObject.d.ts +20 -20
  92. package/model/platformResponse.d.ts +15 -15
  93. package/model/productSetRequest.d.ts +27 -27
  94. package/model/productSetResponse.d.ts +27 -27
  95. package/model/scheduleUpdateRequest.d.ts +22 -22
  96. package/model/scheduledUpdates.d.ts +15 -15
  97. package/model/sortObject.d.ts +18 -18
  98. package/model/supportedGoalEventsResponseDTO.d.ts +19 -19
  99. package/model/updateAudienceNameRequest.d.ts +26 -26
  100. package/model/updateDsCustomQuerySqlRequest.d.ts +26 -26
  101. package/model/validateDsQueryRequest.d.ts +14 -14
  102. package/package.json +1 -1
  103. package/variables.d.ts +8 -8
  104. package/esm2020/model/goalRequest.mjs +0 -13
  105. package/model/goalRequest.d.ts +0 -17
@@ -1,328 +1,328 @@
1
- /**
2
- * Intellibid API
3
- * API documentation for the Intellibid platform
4
- *
5
- * OpenAPI spec version: 1.0
6
- *
7
- *
8
- * NOTE: This class is auto generated by the swagger code generator program.
9
- * https://github.com/swagger-api/swagger-codegen.git
10
- * Do not edit the class manually.
11
- */ /* tslint:disable:no-unused-variable member-ordering */
12
- import { Inject, Injectable, Optional } from '@angular/core';
13
- import { HttpHeaders, HttpParams } from '@angular/common/http';
14
- import { CustomHttpUrlEncodingCodec } from '../encoder';
15
- import { BASE_PATH } from '../variables';
16
- import { Configuration } from '../configuration';
17
- import * as i0 from "@angular/core";
18
- import * as i1 from "@angular/common/http";
19
- import * as i2 from "../configuration";
20
- export class AdvertiserControllerService {
21
- constructor(httpClient, basePath, configuration) {
22
- this.httpClient = httpClient;
23
- this.basePath = 'http://dev1-intellibid-svc.revx.io';
24
- this.defaultHeaders = new HttpHeaders();
25
- this.configuration = new Configuration();
26
- if (basePath) {
27
- this.basePath = basePath;
28
- }
29
- if (configuration) {
30
- this.configuration = configuration;
31
- this.basePath = basePath || configuration.basePath || this.basePath;
32
- }
33
- }
34
- /**
35
- * @param consumes string[] mime-types
36
- * @return true: consumes contains 'multipart/form-data', false: otherwise
37
- */
38
- canConsumeForm(consumes) {
39
- const form = 'multipart/form-data';
40
- for (const consume of consumes) {
41
- if (form === consume) {
42
- return true;
43
- }
44
- }
45
- return false;
46
- }
47
- addProductSet(body, id, observe = 'body', reportProgress = false) {
48
- if (body === null || body === undefined) {
49
- throw new Error('Required parameter body was null or undefined when calling addProductSet.');
50
- }
51
- if (id === null || id === undefined) {
52
- throw new Error('Required parameter id was null or undefined when calling addProductSet.');
53
- }
54
- let headers = this.defaultHeaders;
55
- // to determine the Accept header
56
- let httpHeaderAccepts = [
57
- '*/*'
58
- ];
59
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
60
- if (httpHeaderAcceptSelected != undefined) {
61
- headers = headers.set('Accept', httpHeaderAcceptSelected);
62
- }
63
- // to determine the Content-Type header
64
- const consumes = [
65
- 'application/json'
66
- ];
67
- const httpContentTypeSelected = this.configuration.selectHeaderContentType(consumes);
68
- if (httpContentTypeSelected != undefined) {
69
- headers = headers.set('Content-Type', httpContentTypeSelected);
70
- }
71
- return this.httpClient.request('post', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/product-sets`, {
72
- body: body,
73
- withCredentials: this.configuration.withCredentials,
74
- headers: headers,
75
- observe: observe,
76
- reportProgress: reportProgress
77
- });
78
- }
79
- getAdAccounts(id, observe = 'body', reportProgress = false) {
80
- if (id === null || id === undefined) {
81
- throw new Error('Required parameter id was null or undefined when calling getAdAccounts.');
82
- }
83
- let headers = this.defaultHeaders;
84
- // to determine the Accept header
85
- let httpHeaderAccepts = [
86
- '*/*'
87
- ];
88
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
89
- if (httpHeaderAcceptSelected != undefined) {
90
- headers = headers.set('Accept', httpHeaderAcceptSelected);
91
- }
92
- // to determine the Content-Type header
93
- const consumes = [];
94
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/ad-accounts`, {
95
- withCredentials: this.configuration.withCredentials,
96
- headers: headers,
97
- observe: observe,
98
- reportProgress: reportProgress
99
- });
100
- }
101
- getAdvertiser(id, observe = 'body', reportProgress = false) {
102
- if (id === null || id === undefined) {
103
- throw new Error('Required parameter id was null or undefined when calling getAdvertiser.');
104
- }
105
- let headers = this.defaultHeaders;
106
- // to determine the Accept header
107
- let httpHeaderAccepts = [
108
- '*/*'
109
- ];
110
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
111
- if (httpHeaderAcceptSelected != undefined) {
112
- headers = headers.set('Accept', httpHeaderAcceptSelected);
113
- }
114
- // to determine the Content-Type header
115
- const consumes = [];
116
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}`, {
117
- withCredentials: this.configuration.withCredentials,
118
- headers: headers,
119
- observe: observe,
120
- reportProgress: reportProgress
121
- });
122
- }
123
- getAllAdvertisers(name, isActive, page, size, sort, observe = 'body', reportProgress = false) {
124
- let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
125
- if (name !== undefined && name !== null) {
126
- queryParameters = queryParameters.set('name', name);
127
- }
128
- if (isActive !== undefined && isActive !== null) {
129
- queryParameters = queryParameters.set('isActive', isActive);
130
- }
131
- if (page !== undefined && page !== null) {
132
- queryParameters = queryParameters.set('page', page);
133
- }
134
- if (size !== undefined && size !== null) {
135
- queryParameters = queryParameters.set('size', size);
136
- }
137
- if (sort) {
138
- sort.forEach((element) => {
139
- queryParameters = queryParameters.append('sort', element);
140
- });
141
- }
142
- let headers = this.defaultHeaders;
143
- // to determine the Accept header
144
- let httpHeaderAccepts = [
145
- '*/*'
146
- ];
147
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
148
- if (httpHeaderAcceptSelected != undefined) {
149
- headers = headers.set('Accept', httpHeaderAcceptSelected);
150
- }
151
- // to determine the Content-Type header
152
- const consumes = [];
153
- return this.httpClient.request('get', `${this.basePath}/api/advertiser`, {
154
- params: queryParameters,
155
- withCredentials: this.configuration.withCredentials,
156
- headers: headers,
157
- observe: observe,
158
- reportProgress: reportProgress
159
- });
160
- }
161
- getBlockedEventsByAdvertiser(id, observe = 'body', reportProgress = false) {
162
- if (id === null || id === undefined) {
163
- throw new Error('Required parameter id was null or undefined when calling getBlockedEventsByAdvertiser.');
164
- }
165
- let headers = this.defaultHeaders;
166
- // to determine the Accept header
167
- let httpHeaderAccepts = [
168
- '*/*'
169
- ];
170
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
171
- if (httpHeaderAcceptSelected != undefined) {
172
- headers = headers.set('Accept', httpHeaderAcceptSelected);
173
- }
174
- // to determine the Content-Type header
175
- const consumes = [];
176
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/blocked-events`, {
177
- withCredentials: this.configuration.withCredentials,
178
- headers: headers,
179
- observe: observe,
180
- reportProgress: reportProgress
181
- });
182
- }
183
- getGoalsByAdvertiser(id, observe = 'body', reportProgress = false) {
184
- if (id === null || id === undefined) {
185
- throw new Error('Required parameter id was null or undefined when calling getGoalsByAdvertiser.');
186
- }
187
- let headers = this.defaultHeaders;
188
- // to determine the Accept header
189
- let httpHeaderAccepts = [
190
- '*/*'
191
- ];
192
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
193
- if (httpHeaderAcceptSelected != undefined) {
194
- headers = headers.set('Accept', httpHeaderAcceptSelected);
195
- }
196
- // to determine the Content-Type header
197
- const consumes = [];
198
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/goals`, {
199
- withCredentials: this.configuration.withCredentials,
200
- headers: headers,
201
- observe: observe,
202
- reportProgress: reportProgress
203
- });
204
- }
205
- getMMPConversionEventsByAdvertiser(id, observe = 'body', reportProgress = false) {
206
- if (id === null || id === undefined) {
207
- throw new Error('Required parameter id was null or undefined when calling getMMPConversionEventsByAdvertiser.');
208
- }
209
- let headers = this.defaultHeaders;
210
- // to determine the Accept header
211
- let httpHeaderAccepts = [
212
- '*/*'
213
- ];
214
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
215
- if (httpHeaderAcceptSelected != undefined) {
216
- headers = headers.set('Accept', httpHeaderAcceptSelected);
217
- }
218
- // to determine the Content-Type header
219
- const consumes = [];
220
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/mmp-conversion-events`, {
221
- withCredentials: this.configuration.withCredentials,
222
- headers: headers,
223
- observe: observe,
224
- reportProgress: reportProgress
225
- });
226
- }
227
- getProductSets(id, sourcePlatform, adAccountId, observe = 'body', reportProgress = false) {
228
- if (id === null || id === undefined) {
229
- throw new Error('Required parameter id was null or undefined when calling getProductSets.');
230
- }
231
- if (sourcePlatform === null || sourcePlatform === undefined) {
232
- throw new Error('Required parameter sourcePlatform was null or undefined when calling getProductSets.');
233
- }
234
- let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
235
- if (sourcePlatform !== undefined && sourcePlatform !== null) {
236
- queryParameters = queryParameters.set('sourcePlatform', sourcePlatform);
237
- }
238
- if (adAccountId !== undefined && adAccountId !== null) {
239
- queryParameters = queryParameters.set('adAccountId', adAccountId);
240
- }
241
- let headers = this.defaultHeaders;
242
- // to determine the Accept header
243
- let httpHeaderAccepts = [
244
- '*/*'
245
- ];
246
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
247
- if (httpHeaderAcceptSelected != undefined) {
248
- headers = headers.set('Accept', httpHeaderAcceptSelected);
249
- }
250
- // to determine the Content-Type header
251
- const consumes = [];
252
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/product-sets`, {
253
- params: queryParameters,
254
- withCredentials: this.configuration.withCredentials,
255
- headers: headers,
256
- observe: observe,
257
- reportProgress: reportProgress
258
- });
259
- }
260
- getSupportedGoalEvents(advertiserId, platform, adAccountId, observe = 'body', reportProgress = false) {
261
- if (advertiserId === null || advertiserId === undefined) {
262
- throw new Error('Required parameter advertiserId was null or undefined when calling getSupportedGoalEvents.');
263
- }
264
- if (platform === null || platform === undefined) {
265
- throw new Error('Required parameter platform was null or undefined when calling getSupportedGoalEvents.');
266
- }
267
- if (adAccountId === null || adAccountId === undefined) {
268
- throw new Error('Required parameter adAccountId was null or undefined when calling getSupportedGoalEvents.');
269
- }
270
- let headers = this.defaultHeaders;
271
- // to determine the Accept header
272
- let httpHeaderAccepts = [
273
- '*/*'
274
- ];
275
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
276
- if (httpHeaderAcceptSelected != undefined) {
277
- headers = headers.set('Accept', httpHeaderAcceptSelected);
278
- }
279
- // to determine the Content-Type header
280
- const consumes = [];
281
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/advertisers/${encodeURIComponent(String(advertiserId))}/platforms/${encodeURIComponent(String(platform))}/ad-accounts/${encodeURIComponent(String(adAccountId))}/goal-events`, {
282
- withCredentials: this.configuration.withCredentials,
283
- headers: headers,
284
- observe: observe,
285
- reportProgress: reportProgress
286
- });
287
- }
288
- searchAdvertisers(q, observe = 'body', reportProgress = false) {
289
- if (q === null || q === undefined) {
290
- throw new Error('Required parameter q was null or undefined when calling searchAdvertisers.');
291
- }
292
- let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
293
- if (q !== undefined && q !== null) {
294
- queryParameters = queryParameters.set('q', q);
295
- }
296
- let headers = this.defaultHeaders;
297
- // to determine the Accept header
298
- let httpHeaderAccepts = [
299
- '*/*'
300
- ];
301
- const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
302
- if (httpHeaderAcceptSelected != undefined) {
303
- headers = headers.set('Accept', httpHeaderAcceptSelected);
304
- }
305
- // to determine the Content-Type header
306
- const consumes = [];
307
- return this.httpClient.request('get', `${this.basePath}/api/advertiser/search`, {
308
- params: queryParameters,
309
- withCredentials: this.configuration.withCredentials,
310
- headers: headers,
311
- observe: observe,
312
- reportProgress: reportProgress
313
- });
314
- }
315
- }
316
- AdvertiserControllerService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService, deps: [{ token: i1.HttpClient }, { token: BASE_PATH, optional: true }, { token: i2.Configuration, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
317
- AdvertiserControllerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService });
318
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService, decorators: [{
319
- type: Injectable
320
- }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: undefined, decorators: [{
321
- type: Optional
322
- }, {
323
- type: Inject,
324
- args: [BASE_PATH]
325
- }] }, { type: i2.Configuration, decorators: [{
326
- type: Optional
327
- }] }]; } });
1
+ /**
2
+ * Intellibid API
3
+ * API documentation for the Intellibid platform
4
+ *
5
+ * OpenAPI spec version: 1.0
6
+ *
7
+ *
8
+ * NOTE: This class is auto generated by the swagger code generator program.
9
+ * https://github.com/swagger-api/swagger-codegen.git
10
+ * Do not edit the class manually.
11
+ */ /* tslint:disable:no-unused-variable member-ordering */
12
+ import { Inject, Injectable, Optional } from '@angular/core';
13
+ import { HttpHeaders, HttpParams } from '@angular/common/http';
14
+ import { CustomHttpUrlEncodingCodec } from '../encoder';
15
+ import { BASE_PATH } from '../variables';
16
+ import { Configuration } from '../configuration';
17
+ import * as i0 from "@angular/core";
18
+ import * as i1 from "@angular/common/http";
19
+ import * as i2 from "../configuration";
20
+ export class AdvertiserControllerService {
21
+ constructor(httpClient, basePath, configuration) {
22
+ this.httpClient = httpClient;
23
+ this.basePath = 'http://dev1-intellibid-svc.revx.io';
24
+ this.defaultHeaders = new HttpHeaders();
25
+ this.configuration = new Configuration();
26
+ if (basePath) {
27
+ this.basePath = basePath;
28
+ }
29
+ if (configuration) {
30
+ this.configuration = configuration;
31
+ this.basePath = basePath || configuration.basePath || this.basePath;
32
+ }
33
+ }
34
+ /**
35
+ * @param consumes string[] mime-types
36
+ * @return true: consumes contains 'multipart/form-data', false: otherwise
37
+ */
38
+ canConsumeForm(consumes) {
39
+ const form = 'multipart/form-data';
40
+ for (const consume of consumes) {
41
+ if (form === consume) {
42
+ return true;
43
+ }
44
+ }
45
+ return false;
46
+ }
47
+ addProductSet(body, id, observe = 'body', reportProgress = false) {
48
+ if (body === null || body === undefined) {
49
+ throw new Error('Required parameter body was null or undefined when calling addProductSet.');
50
+ }
51
+ if (id === null || id === undefined) {
52
+ throw new Error('Required parameter id was null or undefined when calling addProductSet.');
53
+ }
54
+ let headers = this.defaultHeaders;
55
+ // to determine the Accept header
56
+ let httpHeaderAccepts = [
57
+ '*/*'
58
+ ];
59
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
60
+ if (httpHeaderAcceptSelected != undefined) {
61
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
62
+ }
63
+ // to determine the Content-Type header
64
+ const consumes = [
65
+ 'application/json'
66
+ ];
67
+ const httpContentTypeSelected = this.configuration.selectHeaderContentType(consumes);
68
+ if (httpContentTypeSelected != undefined) {
69
+ headers = headers.set('Content-Type', httpContentTypeSelected);
70
+ }
71
+ return this.httpClient.request('post', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/product-sets`, {
72
+ body: body,
73
+ withCredentials: this.configuration.withCredentials,
74
+ headers: headers,
75
+ observe: observe,
76
+ reportProgress: reportProgress
77
+ });
78
+ }
79
+ getAdAccounts(id, observe = 'body', reportProgress = false) {
80
+ if (id === null || id === undefined) {
81
+ throw new Error('Required parameter id was null or undefined when calling getAdAccounts.');
82
+ }
83
+ let headers = this.defaultHeaders;
84
+ // to determine the Accept header
85
+ let httpHeaderAccepts = [
86
+ '*/*'
87
+ ];
88
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
89
+ if (httpHeaderAcceptSelected != undefined) {
90
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
91
+ }
92
+ // to determine the Content-Type header
93
+ const consumes = [];
94
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/ad-accounts`, {
95
+ withCredentials: this.configuration.withCredentials,
96
+ headers: headers,
97
+ observe: observe,
98
+ reportProgress: reportProgress
99
+ });
100
+ }
101
+ getAdvertiser(id, observe = 'body', reportProgress = false) {
102
+ if (id === null || id === undefined) {
103
+ throw new Error('Required parameter id was null or undefined when calling getAdvertiser.');
104
+ }
105
+ let headers = this.defaultHeaders;
106
+ // to determine the Accept header
107
+ let httpHeaderAccepts = [
108
+ '*/*'
109
+ ];
110
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
111
+ if (httpHeaderAcceptSelected != undefined) {
112
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
113
+ }
114
+ // to determine the Content-Type header
115
+ const consumes = [];
116
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}`, {
117
+ withCredentials: this.configuration.withCredentials,
118
+ headers: headers,
119
+ observe: observe,
120
+ reportProgress: reportProgress
121
+ });
122
+ }
123
+ getAllAdvertisers(name, isActive, page, size, sort, observe = 'body', reportProgress = false) {
124
+ let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
125
+ if (name !== undefined && name !== null) {
126
+ queryParameters = queryParameters.set('name', name);
127
+ }
128
+ if (isActive !== undefined && isActive !== null) {
129
+ queryParameters = queryParameters.set('isActive', isActive);
130
+ }
131
+ if (page !== undefined && page !== null) {
132
+ queryParameters = queryParameters.set('page', page);
133
+ }
134
+ if (size !== undefined && size !== null) {
135
+ queryParameters = queryParameters.set('size', size);
136
+ }
137
+ if (sort) {
138
+ sort.forEach((element) => {
139
+ queryParameters = queryParameters.append('sort', element);
140
+ });
141
+ }
142
+ let headers = this.defaultHeaders;
143
+ // to determine the Accept header
144
+ let httpHeaderAccepts = [
145
+ '*/*'
146
+ ];
147
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
148
+ if (httpHeaderAcceptSelected != undefined) {
149
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
150
+ }
151
+ // to determine the Content-Type header
152
+ const consumes = [];
153
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser`, {
154
+ params: queryParameters,
155
+ withCredentials: this.configuration.withCredentials,
156
+ headers: headers,
157
+ observe: observe,
158
+ reportProgress: reportProgress
159
+ });
160
+ }
161
+ getBlockedEventsByAdvertiser(id, observe = 'body', reportProgress = false) {
162
+ if (id === null || id === undefined) {
163
+ throw new Error('Required parameter id was null or undefined when calling getBlockedEventsByAdvertiser.');
164
+ }
165
+ let headers = this.defaultHeaders;
166
+ // to determine the Accept header
167
+ let httpHeaderAccepts = [
168
+ '*/*'
169
+ ];
170
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
171
+ if (httpHeaderAcceptSelected != undefined) {
172
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
173
+ }
174
+ // to determine the Content-Type header
175
+ const consumes = [];
176
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/blocked-events`, {
177
+ withCredentials: this.configuration.withCredentials,
178
+ headers: headers,
179
+ observe: observe,
180
+ reportProgress: reportProgress
181
+ });
182
+ }
183
+ getGoalsByAdvertiser(id, observe = 'body', reportProgress = false) {
184
+ if (id === null || id === undefined) {
185
+ throw new Error('Required parameter id was null or undefined when calling getGoalsByAdvertiser.');
186
+ }
187
+ let headers = this.defaultHeaders;
188
+ // to determine the Accept header
189
+ let httpHeaderAccepts = [
190
+ '*/*'
191
+ ];
192
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
193
+ if (httpHeaderAcceptSelected != undefined) {
194
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
195
+ }
196
+ // to determine the Content-Type header
197
+ const consumes = [];
198
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/goals`, {
199
+ withCredentials: this.configuration.withCredentials,
200
+ headers: headers,
201
+ observe: observe,
202
+ reportProgress: reportProgress
203
+ });
204
+ }
205
+ getMMPConversionEventsByAdvertiser(id, observe = 'body', reportProgress = false) {
206
+ if (id === null || id === undefined) {
207
+ throw new Error('Required parameter id was null or undefined when calling getMMPConversionEventsByAdvertiser.');
208
+ }
209
+ let headers = this.defaultHeaders;
210
+ // to determine the Accept header
211
+ let httpHeaderAccepts = [
212
+ '*/*'
213
+ ];
214
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
215
+ if (httpHeaderAcceptSelected != undefined) {
216
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
217
+ }
218
+ // to determine the Content-Type header
219
+ const consumes = [];
220
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/mmp-conversion-events`, {
221
+ withCredentials: this.configuration.withCredentials,
222
+ headers: headers,
223
+ observe: observe,
224
+ reportProgress: reportProgress
225
+ });
226
+ }
227
+ getProductSets(id, sourcePlatform, adAccountId, observe = 'body', reportProgress = false) {
228
+ if (id === null || id === undefined) {
229
+ throw new Error('Required parameter id was null or undefined when calling getProductSets.');
230
+ }
231
+ if (sourcePlatform === null || sourcePlatform === undefined) {
232
+ throw new Error('Required parameter sourcePlatform was null or undefined when calling getProductSets.');
233
+ }
234
+ let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
235
+ if (sourcePlatform !== undefined && sourcePlatform !== null) {
236
+ queryParameters = queryParameters.set('sourcePlatform', sourcePlatform);
237
+ }
238
+ if (adAccountId !== undefined && adAccountId !== null) {
239
+ queryParameters = queryParameters.set('adAccountId', adAccountId);
240
+ }
241
+ let headers = this.defaultHeaders;
242
+ // to determine the Accept header
243
+ let httpHeaderAccepts = [
244
+ '*/*'
245
+ ];
246
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
247
+ if (httpHeaderAcceptSelected != undefined) {
248
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
249
+ }
250
+ // to determine the Content-Type header
251
+ const consumes = [];
252
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/${encodeURIComponent(String(id))}/product-sets`, {
253
+ params: queryParameters,
254
+ withCredentials: this.configuration.withCredentials,
255
+ headers: headers,
256
+ observe: observe,
257
+ reportProgress: reportProgress
258
+ });
259
+ }
260
+ getSupportedGoalEvents(advertiserId, platform, adAccountId, observe = 'body', reportProgress = false) {
261
+ if (advertiserId === null || advertiserId === undefined) {
262
+ throw new Error('Required parameter advertiserId was null or undefined when calling getSupportedGoalEvents.');
263
+ }
264
+ if (platform === null || platform === undefined) {
265
+ throw new Error('Required parameter platform was null or undefined when calling getSupportedGoalEvents.');
266
+ }
267
+ if (adAccountId === null || adAccountId === undefined) {
268
+ throw new Error('Required parameter adAccountId was null or undefined when calling getSupportedGoalEvents.');
269
+ }
270
+ let headers = this.defaultHeaders;
271
+ // to determine the Accept header
272
+ let httpHeaderAccepts = [
273
+ '*/*'
274
+ ];
275
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
276
+ if (httpHeaderAcceptSelected != undefined) {
277
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
278
+ }
279
+ // to determine the Content-Type header
280
+ const consumes = [];
281
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/advertisers/${encodeURIComponent(String(advertiserId))}/platforms/${encodeURIComponent(String(platform))}/ad-accounts/${encodeURIComponent(String(adAccountId))}/goal-events`, {
282
+ withCredentials: this.configuration.withCredentials,
283
+ headers: headers,
284
+ observe: observe,
285
+ reportProgress: reportProgress
286
+ });
287
+ }
288
+ searchAdvertisers(q, observe = 'body', reportProgress = false) {
289
+ if (q === null || q === undefined) {
290
+ throw new Error('Required parameter q was null or undefined when calling searchAdvertisers.');
291
+ }
292
+ let queryParameters = new HttpParams({ encoder: new CustomHttpUrlEncodingCodec() });
293
+ if (q !== undefined && q !== null) {
294
+ queryParameters = queryParameters.set('q', q);
295
+ }
296
+ let headers = this.defaultHeaders;
297
+ // to determine the Accept header
298
+ let httpHeaderAccepts = [
299
+ '*/*'
300
+ ];
301
+ const httpHeaderAcceptSelected = this.configuration.selectHeaderAccept(httpHeaderAccepts);
302
+ if (httpHeaderAcceptSelected != undefined) {
303
+ headers = headers.set('Accept', httpHeaderAcceptSelected);
304
+ }
305
+ // to determine the Content-Type header
306
+ const consumes = [];
307
+ return this.httpClient.request('get', `${this.basePath}/api/advertiser/search`, {
308
+ params: queryParameters,
309
+ withCredentials: this.configuration.withCredentials,
310
+ headers: headers,
311
+ observe: observe,
312
+ reportProgress: reportProgress
313
+ });
314
+ }
315
+ }
316
+ AdvertiserControllerService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService, deps: [{ token: i1.HttpClient }, { token: BASE_PATH, optional: true }, { token: i2.Configuration, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
317
+ AdvertiserControllerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService });
318
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AdvertiserControllerService, decorators: [{
319
+ type: Injectable
320
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: undefined, decorators: [{
321
+ type: Optional
322
+ }, {
323
+ type: Inject,
324
+ args: [BASE_PATH]
325
+ }] }, { type: i2.Configuration, decorators: [{
326
+ type: Optional
327
+ }] }]; } });
328
328
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWR2ZXJ0aXNlckNvbnRyb2xsZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL2FwaS9hZHZlcnRpc2VyQ29udHJvbGxlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7O0dBVUcsQ0FBQSx1REFBdUQ7QUFFMUQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQTJCLGVBQWUsQ0FBQztBQUNsRixPQUFPLEVBQWMsV0FBVyxFQUFFLFVBQVUsRUFDVixNQUFnQyxzQkFBc0IsQ0FBQztBQUN6RixPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBNkIsWUFBWSxDQUFDO0FBZS9FLE9BQU8sRUFBRSxTQUFTLEVBQXNCLE1BQTBCLGNBQWMsQ0FBQztBQUNqRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQTBDLGtCQUFrQixDQUFDOzs7O0FBSXJGLE1BQU0sT0FBTywyQkFBMkI7SUFNcEMsWUFBc0IsVUFBc0IsRUFBZ0MsUUFBZ0IsRUFBYyxhQUE0QjtRQUFoSCxlQUFVLEdBQVYsVUFBVSxDQUFZO1FBSmxDLGFBQVEsR0FBRyxvQ0FBb0MsQ0FBQztRQUNuRCxtQkFBYyxHQUFHLElBQUksV0FBVyxFQUFFLENBQUM7UUFDbkMsa0JBQWEsR0FBRyxJQUFJLGFBQWEsRUFBRSxDQUFDO1FBR3ZDLElBQUksUUFBUSxFQUFFO1lBQ1YsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7U0FDNUI7UUFDRCxJQUFJLGFBQWEsRUFBRTtZQUNmLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1lBQ25DLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxJQUFJLGFBQWEsQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQztTQUN2RTtJQUNMLENBQUM7SUFFRDs7O09BR0c7SUFDSyxjQUFjLENBQUMsUUFBa0I7UUFDckMsTUFBTSxJQUFJLEdBQUcscUJBQXFCLENBQUM7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UUFBUSxHQUFhLEVBQzFCLENBQUM7UUFFRixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFrQyxLQUFLLEVBQUMsR0FBRyxJQUFJLENBQUMsUUFBUSx3QkFBd0IsRUFDMUc7WUFDSSxNQUFNLEVBQUUsZUFBZTtZQUN2QixlQUFlLEVBQUUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxlQUFlO1lBQ25ELE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLGNBQWMsRUFBRSxjQUFjO1NBQ2pDLENBQ0osQ0FBQztJQUNOLENBQUM7O3lIQTNmUSwyQkFBMkIsNENBTTZCLFNBQVM7NkhBTmpFLDJCQUEyQjs0RkFBM0IsMkJBQTJCO2tCQUR2QyxVQUFVOzswQkFPd0MsUUFBUTs7MEJBQUcsTUFBTTsyQkFBQyxTQUFTOzswQkFBcUIsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW50ZWxsaWJpZCBBUElcbiAqIEFQSSBkb2N1bWVudGF0aW9uIGZvciB0aGUgSW50ZWxsaWJpZCBwbGF0Zm9ybVxuICpcbiAqIE9wZW5BUEkgc3BlYyB2ZXJzaW9uOiAxLjBcbiAqIFxuICpcbiAqIE5PVEU6IFRoaXMgY2xhc3MgaXMgYXV0byBnZW5lcmF0ZWQgYnkgdGhlIHN3YWdnZXIgY29kZSBnZW5lcmF0b3IgcHJvZ3JhbS5cbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9zd2FnZ2VyLWFwaS9zd2FnZ2VyLWNvZGVnZW4uZ2l0XG4gKiBEbyBub3QgZWRpdCB0aGUgY2xhc3MgbWFudWFsbHkuXG4gKi8vKiB0c2xpbnQ6ZGlzYWJsZTpuby11bnVzZWQtdmFyaWFibGUgbWVtYmVyLW9yZGVyaW5nICovXG5cbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgT3B0aW9uYWwgfSAgICAgICAgICAgICAgICAgICAgICBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEh0dHBDbGllbnQsIEh0dHBIZWFkZXJzLCBIdHRwUGFyYW1zLFxuICAgICAgICAgSHR0cFJlc3BvbnNlLCBIdHRwRXZlbnQgfSAgICAgICAgICAgICAgICAgICAgICAgICAgIGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEN1c3RvbUh0dHBVcmxFbmNvZGluZ0NvZGVjIH0gICAgICAgICAgICAgICAgICAgICAgICBmcm9tICcuLi9lbmNvZGVyJztcblxuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBBZEFjY291bnRSZXNwb25zZSB9IGZyb20gJy4uL21vZGVsL2FkQWNjb3VudFJlc3BvbnNlJztcbmltcG9ydCB7IEFkdmVydGlzZXJNbXBDb252ZXJzaW9uRXZlbnRSZXNwb25zZSB9IGZyb20gJy4uL21vZGVsL2FkdmVydGlzZXJNbXBDb252ZXJzaW9uRXZlbnRSZXNwb25zZSc7XG5pbXBvcnQgeyBBZHZlcnRpc2VyUmVzcG9uc2UgfSBmcm9tICcuLi9tb2RlbC9hZHZlcnRpc2VyUmVzcG9uc2UnO1xuaW1wb3J0IHsgQWR2ZXJ0aXNlclNlYXJjaFJlc3BvbnNlIH0gZnJvbSAnLi4vbW9kZWwvYWR2ZXJ0aXNlclNlYXJjaFJlc3BvbnNlJztcbmltcG9ydCB7IEJsb2NrZWRFdmVudFJlc3BvbnNlIH0gZnJvbSAnLi4vbW9kZWwvYmxvY2tlZEV2ZW50UmVzcG9uc2UnO1xuaW1wb3J0IHsgR29hbFJlc3BvbnNlIH0gZnJvbSAnLi4vbW9kZWwvZ29hbFJlc3BvbnNlJztcbmltcG9ydCB7IFBhZ2VBZHZlcnRpc2VyUmVzcG9uc2UgfSBmcm9tICcuLi9tb2RlbC9wYWdlQWR2ZXJ0aXNlclJlc3BvbnNlJztcbmltcG9ydCB7IFByb2R1Y3RTZXRSZXF1ZXN0IH0gZnJvbSAnLi4vbW9kZWwvcHJvZHVjdFNldFJlcXVlc3QnO1xuaW1wb3J0IHsgUHJvZHVjdFNldFJlc3BvbnNlIH0gZnJvbSAnLi4vbW9kZWwvcHJvZHVjdFNldFJlc3BvbnNlJztcbmltcG9ydCB7IFN1cHBvcnRlZEdvYWxFdmVudHNSZXNwb25zZURUTyB9IGZyb20gJy4uL21vZGVsL3N1cHBvcnRlZEdvYWxFdmVudHNSZXNwb25zZURUTyc7XG5cbmltcG9ydCB7IEJBU0VfUEFUSCwgQ09MTEVDVElPTl9GT1JNQVRTIH0gICAgICAgICAgICAgICAgICAgICBmcm9tICcuLi92YXJpYWJsZXMnO1xuaW1wb3J0IHsgQ29uZmlndXJhdGlvbiB9ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZyb20gJy4uL2NvbmZpZ3VyYXRpb24nO1xuXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBBZHZlcnRpc2VyQ29udHJvbGxlclNlcnZpY2Uge1xuXG4gICAgcHJvdGVjdGVkIGJhc2VQYXRoID0gJ2h0dHA6Ly9kZXYxLWludGVsbGliaWQtc3ZjLnJldnguaW8nO1xuICAgIHB1YmxpYyBkZWZhdWx0SGVhZGVycyA9IG5ldyBIdHRwSGVhZGVycygpO1xuICAgIHB1YmxpYyBjb25maWd1cmF0aW9uID0gbmV3IENvbmZpZ3VyYXRpb24oKTtcblxuICAgIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBodHRwQ2xpZW50OiBIdHRwQ2xpZW50LCBAT3B0aW9uYWwoKUBJbmplY3QoQkFTRV9QQVRIKSBiYXNlUGF0aDogc3RyaW5nLCBAT3B0aW9uYWwoKSBjb25maWd1cmF0aW9uOiBDb25maWd1cmF0aW9uKSB7XG4gICAgICAgIGlmIChiYXNlUGF0aCkge1xuICAgICAgICAgICAgdGhpcy5iYXNlUGF0aCA9IGJhc2VQYXRoO1xuICAgICAgICB9XG4gICAgICAgIGlmIChjb25maWd1cmF0aW9uKSB7XG4gICAgICAgICAgICB0aGlzLmNvbmZpZ3VyYXRpb24gPSBjb25maWd1cmF0aW9uO1xuICAgICAgICAgICAgdGhpcy5iYXNlUGF0aCA9IGJhc2VQYXRoIHx8IGNvbmZpZ3VyYXRpb24uYmFzZVBhdGggfHwgdGhpcy5iYXNlUGF0aDtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBwYXJhbSBjb25zdW1lcyBzdHJpbmdbXSBtaW1lLXR5cGVzXG4gICAgICogQHJldHVybiB0cnVlOiBjb25zdW1lcyBjb250YWlucyAnbXVsdGlwYXJ0L2Zvcm0tZGF0YScsIGZhbHNlOiBvdGhlcndpc2VcbiAgICAgKi9cbiAgICBwcml2YXRlIGNhbkNvbnN1bWVGb3JtKGNvbnN1bWVzOiBzdHJpbmdbXSk6IGJvb2xlYW4ge1xuICAgICAgICBjb25zdCBmb3JtID0gJ211bHRpcGFydC9mb3JtLWRhdGEnO1xuICAgICAgICBmb3IgKGNvbnN0IGNvbnN1bWUgb2YgY29uc3VtZXMpIHtcbiAgICAgICAgICAgIGlmIChmb3JtID09PSBjb25zdW1lKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuXG4gICAgLyoqXG4gICAgICogQWRkIGEgcHJvZHVjdCBzZXQgZm9yIGFuIGFkdmVydGlzZXJcbiAgICAgKiBDcmVhdGVzIGEgbmV3IHByb2R1Y3Qgc2V0LiBSZWplY3RzIHdpdGggNDAwIGlmIGEgcm93IGFscmVhZHkgZXhpc3RzIGZvciAoYWR2ZXJ0aXNlcklkLCBhZEFjY291bnRJZCwgcHJvZHVjdFNldElkKSBvciAoYWR2ZXJ0aXNlcklkLCBhZEFjY291bnRJZCwgcHJvZHVjdFNldExhYmVsKSDigJQgdXBkYXRlcyBhcmUgbm90IHN1cHBvcnRlZC5cbiAgICAgKiBAcGFyYW0gYm9keSBcbiAgICAgKiBAcGFyYW0gaWQgXG4gICAgICogQHBhcmFtIG9ic2VydmUgc2V0IHdoZXRoZXIgb3Igbm90IHRvIHJldHVybiB0aGUgZGF0YSBPYnNlcnZhYmxlIGFzIHRoZSBib2R5LCByZXNwb25zZSBvciBldmVudHMuIGRlZmF1bHRzIHRvIHJldHVybmluZyB0aGUgYm9keS5cbiAgICAgKiBAcGFyYW0gcmVwb3J0UHJvZ3Jlc3MgZmxhZyB0byByZXBvcnQgcmVxdWVzdCBhbmQgcmVzcG9uc2UgcHJvZ3Jlc3MuXG4gICAgICovXG4gICAgcHVibGljIGFkZFByb2R1Y3RTZXQoYm9keTogUHJvZHVjdFNldFJlcXVlc3QsIGlkOiBudW1iZXIsIG9ic2VydmU/OiAnYm9keScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8UHJvZHVjdFNldFJlc3BvbnNlPjtcbiAgICBwdWJsaWMgYWRkUHJvZHVjdFNldChib2R5OiBQcm9kdWN0U2V0UmVxdWVzdCwgaWQ6IG51bWJlciwgb2JzZXJ2ZT86ICdyZXNwb25zZScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8SHR0cFJlc3BvbnNlPFByb2R1Y3RTZXRSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBhZGRQcm9kdWN0U2V0KGJvZHk6IFByb2R1Y3RTZXRSZXF1ZXN0LCBpZDogbnVtYmVyLCBvYnNlcnZlPzogJ2V2ZW50cycsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8SHR0cEV2ZW50PFByb2R1Y3RTZXRSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBhZGRQcm9kdWN0U2V0KGJvZHk6IFByb2R1Y3RTZXRSZXF1ZXN0LCBpZDogbnVtYmVyLCBvYnNlcnZlOiBhbnkgPSAnYm9keScsIHJlcG9ydFByb2dyZXNzOiBib29sZWFuID0gZmFsc2UgKTogT2JzZXJ2YWJsZTxhbnk+IHtcblxuICAgICAgICBpZiAoYm9keSA9PT0gbnVsbCB8fCBib2R5ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGJvZHkgd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBhZGRQcm9kdWN0U2V0LicpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGlkID09PSBudWxsIHx8IGlkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGlkIHdhcyBudWxsIG9yIHVuZGVmaW5lZCB3aGVuIGNhbGxpbmcgYWRkUHJvZHVjdFNldC4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICAgICAgJ2FwcGxpY2F0aW9uL2pzb24nXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBDb250ZW50VHlwZVNlbGVjdGVkOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0SGVhZGVyQ29udGVudFR5cGUoY29uc3VtZXMpO1xuICAgICAgICBpZiAoaHR0cENvbnRlbnRUeXBlU2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0NvbnRlbnQtVHlwZScsIGh0dHBDb250ZW50VHlwZVNlbGVjdGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxQcm9kdWN0U2V0UmVzcG9uc2U+KCdwb3N0JyxgJHt0aGlzLmJhc2VQYXRofS9hcGkvYWR2ZXJ0aXNlci8ke2VuY29kZVVSSUNvbXBvbmVudChTdHJpbmcoaWQpKX0vcHJvZHVjdC1zZXRzYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBib2R5OiBib2R5LFxuICAgICAgICAgICAgICAgIHdpdGhDcmVkZW50aWFsczogdGhpcy5jb25maWd1cmF0aW9uLndpdGhDcmVkZW50aWFscyxcbiAgICAgICAgICAgICAgICBoZWFkZXJzOiBoZWFkZXJzLFxuICAgICAgICAgICAgICAgIG9ic2VydmU6IG9ic2VydmUsXG4gICAgICAgICAgICAgICAgcmVwb3J0UHJvZ3Jlc3M6IHJlcG9ydFByb2dyZXNzXG4gICAgICAgICAgICB9XG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogR2V0IGFsbCBhZCBhY2NvdW50cyBmb3IgYW4gYWR2ZXJ0aXNlclxuICAgICAqIFJldHVybnMgYWxsIGFkIGFjY291bnRzIGFjcm9zcyBhbGwgcGxhdGZvcm1zIChNZXRhLCBUaWtUb2ssIFNuYXBjaGF0KSBmb3IgdGhlIHNwZWNpZmllZCBhZHZlcnRpc2VyXG4gICAgICogQHBhcmFtIGlkIFxuICAgICAqIEBwYXJhbSBvYnNlcnZlIHNldCB3aGV0aGVyIG9yIG5vdCB0byByZXR1cm4gdGhlIGRhdGEgT2JzZXJ2YWJsZSBhcyB0aGUgYm9keSwgcmVzcG9uc2Ugb3IgZXZlbnRzLiBkZWZhdWx0cyB0byByZXR1cm5pbmcgdGhlIGJvZHkuXG4gICAgICogQHBhcmFtIHJlcG9ydFByb2dyZXNzIGZsYWcgdG8gcmVwb3J0IHJlcXVlc3QgYW5kIHJlc3BvbnNlIHByb2dyZXNzLlxuICAgICAqL1xuICAgIHB1YmxpYyBnZXRBZEFjY291bnRzKGlkOiBudW1iZXIsIG9ic2VydmU/OiAnYm9keScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8QXJyYXk8QWRBY2NvdW50UmVzcG9uc2U+PjtcbiAgICBwdWJsaWMgZ2V0QWRBY2NvdW50cyhpZDogbnVtYmVyLCBvYnNlcnZlPzogJ3Jlc3BvbnNlJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwUmVzcG9uc2U8QXJyYXk8QWRBY2NvdW50UmVzcG9uc2U+Pj47XG4gICAgcHVibGljIGdldEFkQWNjb3VudHMoaWQ6IG51bWJlciwgb2JzZXJ2ZT86ICdldmVudHMnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxBcnJheTxBZEFjY291bnRSZXNwb25zZT4+PjtcbiAgICBwdWJsaWMgZ2V0QWRBY2NvdW50cyhpZDogbnVtYmVyLCBvYnNlcnZlOiBhbnkgPSAnYm9keScsIHJlcG9ydFByb2dyZXNzOiBib29sZWFuID0gZmFsc2UgKTogT2JzZXJ2YWJsZTxhbnk+IHtcblxuICAgICAgICBpZiAoaWQgPT09IG51bGwgfHwgaWQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgaWQgd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBnZXRBZEFjY291bnRzLicpO1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGhlYWRlcnMgPSB0aGlzLmRlZmF1bHRIZWFkZXJzO1xuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQWNjZXB0IGhlYWRlclxuICAgICAgICBsZXQgaHR0cEhlYWRlckFjY2VwdHM6IHN0cmluZ1tdID0gW1xuICAgICAgICAgICAgJyovKidcbiAgICAgICAgXTtcbiAgICAgICAgY29uc3QgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0SGVhZGVyQWNjZXB0KGh0dHBIZWFkZXJBY2NlcHRzKTtcbiAgICAgICAgaWYgKGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCAhPSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldCgnQWNjZXB0JywgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQ29udGVudC1UeXBlIGhlYWRlclxuICAgICAgICBjb25zdCBjb25zdW1lczogc3RyaW5nW10gPSBbXG4gICAgICAgIF07XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5yZXF1ZXN0PEFycmF5PEFkQWNjb3VudFJlc3BvbnNlPj4oJ2dldCcsYCR7dGhpcy5iYXNlUGF0aH0vYXBpL2FkdmVydGlzZXIvJHtlbmNvZGVVUklDb21wb25lbnQoU3RyaW5nKGlkKSl9L2FkLWFjY291bnRzYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IHRoaXMuY29uZmlndXJhdGlvbi53aXRoQ3JlZGVudGlhbHMsXG4gICAgICAgICAgICAgICAgaGVhZGVyczogaGVhZGVycyxcbiAgICAgICAgICAgICAgICBvYnNlcnZlOiBvYnNlcnZlLFxuICAgICAgICAgICAgICAgIHJlcG9ydFByb2dyZXNzOiByZXBvcnRQcm9ncmVzc1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFxuICAgICAqIFxuICAgICAqIEBwYXJhbSBpZCBcbiAgICAgKiBAcGFyYW0gb2JzZXJ2ZSBzZXQgd2hldGhlciBvciBub3QgdG8gcmV0dXJuIHRoZSBkYXRhIE9ic2VydmFibGUgYXMgdGhlIGJvZHksIHJlc3BvbnNlIG9yIGV2ZW50cy4gZGVmYXVsdHMgdG8gcmV0dXJuaW5nIHRoZSBib2R5LlxuICAgICAqIEBwYXJhbSByZXBvcnRQcm9ncmVzcyBmbGFnIHRvIHJlcG9ydCByZXF1ZXN0IGFuZCByZXNwb25zZSBwcm9ncmVzcy5cbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0QWR2ZXJ0aXNlcihpZDogbnVtYmVyLCBvYnNlcnZlPzogJ2JvZHknLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEFkdmVydGlzZXJSZXNwb25zZT47XG4gICAgcHVibGljIGdldEFkdmVydGlzZXIoaWQ6IG51bWJlciwgb2JzZXJ2ZT86ICdyZXNwb25zZScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8SHR0cFJlc3BvbnNlPEFkdmVydGlzZXJSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBnZXRBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8QWR2ZXJ0aXNlclJlc3BvbnNlPj47XG4gICAgcHVibGljIGdldEFkdmVydGlzZXIoaWQ6IG51bWJlciwgb2JzZXJ2ZTogYW55ID0gJ2JvZHknLCByZXBvcnRQcm9ncmVzczogYm9vbGVhbiA9IGZhbHNlICk6IE9ic2VydmFibGU8YW55PiB7XG5cbiAgICAgICAgaWYgKGlkID09PSBudWxsIHx8IGlkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGlkIHdhcyBudWxsIG9yIHVuZGVmaW5lZCB3aGVuIGNhbGxpbmcgZ2V0QWR2ZXJ0aXNlci4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICBdO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxBZHZlcnRpc2VyUmVzcG9uc2U+KCdnZXQnLGAke3RoaXMuYmFzZVBhdGh9L2FwaS9hZHZlcnRpc2VyLyR7ZW5jb2RlVVJJQ29tcG9uZW50KFN0cmluZyhpZCkpfWAsXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgd2l0aENyZWRlbnRpYWxzOiB0aGlzLmNvbmZpZ3VyYXRpb24ud2l0aENyZWRlbnRpYWxzLFxuICAgICAgICAgICAgICAgIGhlYWRlcnM6IGhlYWRlcnMsXG4gICAgICAgICAgICAgICAgb2JzZXJ2ZTogb2JzZXJ2ZSxcbiAgICAgICAgICAgICAgICByZXBvcnRQcm9ncmVzczogcmVwb3J0UHJvZ3Jlc3NcbiAgICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBcbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gbmFtZSBcbiAgICAgKiBAcGFyYW0gaXNBY3RpdmUgXG4gICAgICogQHBhcmFtIHBhZ2UgWmVyby1iYXNlZCBwYWdlIGluZGV4ICgwLi5OKVxuICAgICAqIEBwYXJhbSBzaXplIFRoZSBzaXplIG9mIHRoZSBwYWdlIHRvIGJlIHJldHVybmVkXG4gICAgICogQHBhcmFtIHNvcnQgU29ydGluZyBjcml0ZXJpYSBpbiB0aGUgZm9ybWF0OiBwcm9wZXJ0eSwoYXNjfGRlc2MpLiBEZWZhdWx0IHNvcnQgb3JkZXIgaXMgYXNjZW5kaW5nLiBNdWx0aXBsZSBzb3J0IGNyaXRlcmlhIGFyZSBzdXBwb3J0ZWQuXG4gICAgICogQHBhcmFtIG9ic2VydmUgc2V0IHdoZXRoZXIgb3Igbm90IHRvIHJldHVybiB0aGUgZGF0YSBPYnNlcnZhYmxlIGFzIHRoZSBib2R5LCByZXNwb25zZSBvciBldmVudHMuIGRlZmF1bHRzIHRvIHJldHVybmluZyB0aGUgYm9keS5cbiAgICAgKiBAcGFyYW0gcmVwb3J0UHJvZ3Jlc3MgZmxhZyB0byByZXBvcnQgcmVxdWVzdCBhbmQgcmVzcG9uc2UgcHJvZ3Jlc3MuXG4gICAgICovXG4gICAgcHVibGljIGdldEFsbEFkdmVydGlzZXJzKG5hbWU/OiBzdHJpbmcsIGlzQWN0aXZlPzogYm9vbGVhbiwgcGFnZT86IG51bWJlciwgc2l6ZT86IG51bWJlciwgc29ydD86IEFycmF5PHN0cmluZz4sIG9ic2VydmU/OiAnYm9keScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8UGFnZUFkdmVydGlzZXJSZXNwb25zZT47XG4gICAgcHVibGljIGdldEFsbEFkdmVydGlzZXJzKG5hbWU/OiBzdHJpbmcsIGlzQWN0aXZlPzogYm9vbGVhbiwgcGFnZT86IG51bWJlciwgc2l6ZT86IG51bWJlciwgc29ydD86IEFycmF5PHN0cmluZz4sIG9ic2VydmU/OiAncmVzcG9uc2UnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBSZXNwb25zZTxQYWdlQWR2ZXJ0aXNlclJlc3BvbnNlPj47XG4gICAgcHVibGljIGdldEFsbEFkdmVydGlzZXJzKG5hbWU/OiBzdHJpbmcsIGlzQWN0aXZlPzogYm9vbGVhbiwgcGFnZT86IG51bWJlciwgc2l6ZT86IG51bWJlciwgc29ydD86IEFycmF5PHN0cmluZz4sIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8UGFnZUFkdmVydGlzZXJSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBnZXRBbGxBZHZlcnRpc2VycyhuYW1lPzogc3RyaW5nLCBpc0FjdGl2ZT86IGJvb2xlYW4sIHBhZ2U/OiBudW1iZXIsIHNpemU/OiBudW1iZXIsIHNvcnQ/OiBBcnJheTxzdHJpbmc+LCBvYnNlcnZlOiBhbnkgPSAnYm9keScsIHJlcG9ydFByb2dyZXNzOiBib29sZWFuID0gZmFsc2UgKTogT2JzZXJ2YWJsZTxhbnk+IHtcblxuXG5cblxuXG5cbiAgICAgICAgbGV0IHF1ZXJ5UGFyYW1ldGVycyA9IG5ldyBIdHRwUGFyYW1zKHtlbmNvZGVyOiBuZXcgQ3VzdG9tSHR0cFVybEVuY29kaW5nQ29kZWMoKX0pO1xuICAgICAgICBpZiAobmFtZSAhPT0gdW5kZWZpbmVkICYmIG5hbWUgIT09IG51bGwpIHtcbiAgICAgICAgICAgIHF1ZXJ5UGFyYW1ldGVycyA9IHF1ZXJ5UGFyYW1ldGVycy5zZXQoJ25hbWUnLCA8YW55Pm5hbWUpO1xuICAgICAgICB9XG4gICAgICAgIGlmIChpc0FjdGl2ZSAhPT0gdW5kZWZpbmVkICYmIGlzQWN0aXZlICE9PSBudWxsKSB7XG4gICAgICAgICAgICBxdWVyeVBhcmFtZXRlcnMgPSBxdWVyeVBhcmFtZXRlcnMuc2V0KCdpc0FjdGl2ZScsIDxhbnk+aXNBY3RpdmUpO1xuICAgICAgICB9XG4gICAgICAgIGlmIChwYWdlICE9PSB1bmRlZmluZWQgJiYgcGFnZSAhPT0gbnVsbCkge1xuICAgICAgICAgICAgcXVlcnlQYXJhbWV0ZXJzID0gcXVlcnlQYXJhbWV0ZXJzLnNldCgncGFnZScsIDxhbnk+cGFnZSk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHNpemUgIT09IHVuZGVmaW5lZCAmJiBzaXplICE9PSBudWxsKSB7XG4gICAgICAgICAgICBxdWVyeVBhcmFtZXRlcnMgPSBxdWVyeVBhcmFtZXRlcnMuc2V0KCdzaXplJywgPGFueT5zaXplKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoc29ydCkge1xuICAgICAgICAgICAgc29ydC5mb3JFYWNoKChlbGVtZW50KSA9PiB7XG4gICAgICAgICAgICAgICAgcXVlcnlQYXJhbWV0ZXJzID0gcXVlcnlQYXJhbWV0ZXJzLmFwcGVuZCgnc29ydCcsIDxhbnk+ZWxlbWVudCk7XG4gICAgICAgICAgICB9KVxuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGhlYWRlcnMgPSB0aGlzLmRlZmF1bHRIZWFkZXJzO1xuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQWNjZXB0IGhlYWRlclxuICAgICAgICBsZXQgaHR0cEhlYWRlckFjY2VwdHM6IHN0cmluZ1tdID0gW1xuICAgICAgICAgICAgJyovKidcbiAgICAgICAgXTtcbiAgICAgICAgY29uc3QgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0SGVhZGVyQWNjZXB0KGh0dHBIZWFkZXJBY2NlcHRzKTtcbiAgICAgICAgaWYgKGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCAhPSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldCgnQWNjZXB0JywgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQ29udGVudC1UeXBlIGhlYWRlclxuICAgICAgICBjb25zdCBjb25zdW1lczogc3RyaW5nW10gPSBbXG4gICAgICAgIF07XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5yZXF1ZXN0PFBhZ2VBZHZlcnRpc2VyUmVzcG9uc2U+KCdnZXQnLGAke3RoaXMuYmFzZVBhdGh9L2FwaS9hZHZlcnRpc2VyYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBwYXJhbXM6IHF1ZXJ5UGFyYW1ldGVycyxcbiAgICAgICAgICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IHRoaXMuY29uZmlndXJhdGlvbi53aXRoQ3JlZGVudGlhbHMsXG4gICAgICAgICAgICAgICAgaGVhZGVyczogaGVhZGVycyxcbiAgICAgICAgICAgICAgICBvYnNlcnZlOiBvYnNlcnZlLFxuICAgICAgICAgICAgICAgIHJlcG9ydFByb2dyZXNzOiByZXBvcnRQcm9ncmVzc1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldCBhbGwgYmxvY2tlZCBldmVudHMgZm9yIGFuIGFkdmVydGlzZXJcbiAgICAgKiBSZXR1cm5zIGxpc3Qgb2YgYmxvY2tlZCBldmVudHMgd2l0aCBldmVudE5hbWUgYW5kIGJsb2NraW5nRGF5cyBmb3IgdGhlIHNwZWNpZmllZCBhZHZlcnRpc2VyXG4gICAgICogQHBhcmFtIGlkIFxuICAgICAqIEBwYXJhbSBvYnNlcnZlIHNldCB3aGV0aGVyIG9yIG5vdCB0byByZXR1cm4gdGhlIGRhdGEgT2JzZXJ2YWJsZSBhcyB0aGUgYm9keSwgcmVzcG9uc2Ugb3IgZXZlbnRzLiBkZWZhdWx0cyB0byByZXR1cm5pbmcgdGhlIGJvZHkuXG4gICAgICogQHBhcmFtIHJlcG9ydFByb2dyZXNzIGZsYWcgdG8gcmVwb3J0IHJlcXVlc3QgYW5kIHJlc3BvbnNlIHByb2dyZXNzLlxuICAgICAqL1xuICAgIHB1YmxpYyBnZXRCbG9ja2VkRXZlbnRzQnlBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAnYm9keScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8QXJyYXk8QmxvY2tlZEV2ZW50UmVzcG9uc2U+PjtcbiAgICBwdWJsaWMgZ2V0QmxvY2tlZEV2ZW50c0J5QWR2ZXJ0aXNlcihpZDogbnVtYmVyLCBvYnNlcnZlPzogJ3Jlc3BvbnNlJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwUmVzcG9uc2U8QXJyYXk8QmxvY2tlZEV2ZW50UmVzcG9uc2U+Pj47XG4gICAgcHVibGljIGdldEJsb2NrZWRFdmVudHNCeUFkdmVydGlzZXIoaWQ6IG51bWJlciwgb2JzZXJ2ZT86ICdldmVudHMnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxBcnJheTxCbG9ja2VkRXZlbnRSZXNwb25zZT4+PjtcbiAgICBwdWJsaWMgZ2V0QmxvY2tlZEV2ZW50c0J5QWR2ZXJ0aXNlcihpZDogbnVtYmVyLCBvYnNlcnZlOiBhbnkgPSAnYm9keScsIHJlcG9ydFByb2dyZXNzOiBib29sZWFuID0gZmFsc2UgKTogT2JzZXJ2YWJsZTxhbnk+IHtcblxuICAgICAgICBpZiAoaWQgPT09IG51bGwgfHwgaWQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgaWQgd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBnZXRCbG9ja2VkRXZlbnRzQnlBZHZlcnRpc2VyLicpO1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGhlYWRlcnMgPSB0aGlzLmRlZmF1bHRIZWFkZXJzO1xuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQWNjZXB0IGhlYWRlclxuICAgICAgICBsZXQgaHR0cEhlYWRlckFjY2VwdHM6IHN0cmluZ1tdID0gW1xuICAgICAgICAgICAgJyovKidcbiAgICAgICAgXTtcbiAgICAgICAgY29uc3QgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0SGVhZGVyQWNjZXB0KGh0dHBIZWFkZXJBY2NlcHRzKTtcbiAgICAgICAgaWYgKGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCAhPSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldCgnQWNjZXB0JywgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQ29udGVudC1UeXBlIGhlYWRlclxuICAgICAgICBjb25zdCBjb25zdW1lczogc3RyaW5nW10gPSBbXG4gICAgICAgIF07XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5yZXF1ZXN0PEFycmF5PEJsb2NrZWRFdmVudFJlc3BvbnNlPj4oJ2dldCcsYCR7dGhpcy5iYXNlUGF0aH0vYXBpL2FkdmVydGlzZXIvJHtlbmNvZGVVUklDb21wb25lbnQoU3RyaW5nKGlkKSl9L2Jsb2NrZWQtZXZlbnRzYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IHRoaXMuY29uZmlndXJhdGlvbi53aXRoQ3JlZGVudGlhbHMsXG4gICAgICAgICAgICAgICAgaGVhZGVyczogaGVhZGVycyxcbiAgICAgICAgICAgICAgICBvYnNlcnZlOiBvYnNlcnZlLFxuICAgICAgICAgICAgICAgIHJlcG9ydFByb2dyZXNzOiByZXBvcnRQcm9ncmVzc1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldCBhbGwgZ29hbHMgZm9yIGFuIGFkdmVydGlzZXJcbiAgICAgKiBSZXR1cm5zIGxpc3Qgb2YgZ29hbHMgZGVyaXZlZCBmcm9tIHRoZSBhZHZlcnRpc2VyJiN4Mjc7cyBhY3RpdmUgcG9zdGJhY2sgZXZlbnQgbWFwcGluZ3NcbiAgICAgKiBAcGFyYW0gaWQgXG4gICAgICogQHBhcmFtIG9ic2VydmUgc2V0IHdoZXRoZXIgb3Igbm90IHRvIHJldHVybiB0aGUgZGF0YSBPYnNlcnZhYmxlIGFzIHRoZSBib2R5LCByZXNwb25zZSBvciBldmVudHMuIGRlZmF1bHRzIHRvIHJldHVybmluZyB0aGUgYm9keS5cbiAgICAgKiBAcGFyYW0gcmVwb3J0UHJvZ3Jlc3MgZmxhZyB0byByZXBvcnQgcmVxdWVzdCBhbmQgcmVzcG9uc2UgcHJvZ3Jlc3MuXG4gICAgICovXG4gICAgcHVibGljIGdldEdvYWxzQnlBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAnYm9keScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8QXJyYXk8R29hbFJlc3BvbnNlPj47XG4gICAgcHVibGljIGdldEdvYWxzQnlBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAncmVzcG9uc2UnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBSZXNwb25zZTxBcnJheTxHb2FsUmVzcG9uc2U+Pj47XG4gICAgcHVibGljIGdldEdvYWxzQnlBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8QXJyYXk8R29hbFJlc3BvbnNlPj4+O1xuICAgIHB1YmxpYyBnZXRHb2Fsc0J5QWR2ZXJ0aXNlcihpZDogbnVtYmVyLCBvYnNlcnZlOiBhbnkgPSAnYm9keScsIHJlcG9ydFByb2dyZXNzOiBib29sZWFuID0gZmFsc2UgKTogT2JzZXJ2YWJsZTxhbnk+IHtcblxuICAgICAgICBpZiAoaWQgPT09IG51bGwgfHwgaWQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgaWQgd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBnZXRHb2Fsc0J5QWR2ZXJ0aXNlci4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICBdO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxBcnJheTxHb2FsUmVzcG9uc2U+PignZ2V0JyxgJHt0aGlzLmJhc2VQYXRofS9hcGkvYWR2ZXJ0aXNlci8ke2VuY29kZVVSSUNvbXBvbmVudChTdHJpbmcoaWQpKX0vZ29hbHNgLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIHdpdGhDcmVkZW50aWFsczogdGhpcy5jb25maWd1cmF0aW9uLndpdGhDcmVkZW50aWFscyxcbiAgICAgICAgICAgICAgICBoZWFkZXJzOiBoZWFkZXJzLFxuICAgICAgICAgICAgICAgIG9ic2VydmU6IG9ic2VydmUsXG4gICAgICAgICAgICAgICAgcmVwb3J0UHJvZ3Jlc3M6IHJlcG9ydFByb2dyZXNzXG4gICAgICAgICAgICB9XG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogR2V0IGFsbCBNTVAgY29udmVyc2lvbiBldmVudHMgZm9yIGFuIGFkdmVydGlzZXJcbiAgICAgKiBSZXR1cm5zIGxpc3Qgb2YgY29uZmlndXJlZCBNTVAgZXZlbnRzIHdpdGggaWQgYW5kIGV2ZW50TGFiZWwgZm9yIHRoZSBzcGVjaWZpZWQgYWR2ZXJ0aXNlclxuICAgICAqIEBwYXJhbSBpZCBcbiAgICAgKiBAcGFyYW0gb2JzZXJ2ZSBzZXQgd2hldGhlciBvciBub3QgdG8gcmV0dXJuIHRoZSBkYXRhIE9ic2VydmFibGUgYXMgdGhlIGJvZHksIHJlc3BvbnNlIG9yIGV2ZW50cy4gZGVmYXVsdHMgdG8gcmV0dXJuaW5nIHRoZSBib2R5LlxuICAgICAqIEBwYXJhbSByZXBvcnRQcm9ncmVzcyBmbGFnIHRvIHJlcG9ydCByZXF1ZXN0IGFuZCByZXNwb25zZSBwcm9ncmVzcy5cbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0TU1QQ29udmVyc2lvbkV2ZW50c0J5QWR2ZXJ0aXNlcihpZDogbnVtYmVyLCBvYnNlcnZlPzogJ2JvZHknLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEFycmF5PEFkdmVydGlzZXJNbXBDb252ZXJzaW9uRXZlbnRSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBnZXRNTVBDb252ZXJzaW9uRXZlbnRzQnlBZHZlcnRpc2VyKGlkOiBudW1iZXIsIG9ic2VydmU/OiAncmVzcG9uc2UnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBSZXNwb25zZTxBcnJheTxBZHZlcnRpc2VyTW1wQ29udmVyc2lvbkV2ZW50UmVzcG9uc2U+Pj47XG4gICAgcHVibGljIGdldE1NUENvbnZlcnNpb25FdmVudHNCeUFkdmVydGlzZXIoaWQ6IG51bWJlciwgb2JzZXJ2ZT86ICdldmVudHMnLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEh0dHBFdmVudDxBcnJheTxBZHZlcnRpc2VyTW1wQ29udmVyc2lvbkV2ZW50UmVzcG9uc2U+Pj47XG4gICAgcHVibGljIGdldE1NUENvbnZlcnNpb25FdmVudHNCeUFkdmVydGlzZXIoaWQ6IG51bWJlciwgb2JzZXJ2ZTogYW55ID0gJ2JvZHknLCByZXBvcnRQcm9ncmVzczogYm9vbGVhbiA9IGZhbHNlICk6IE9ic2VydmFibGU8YW55PiB7XG5cbiAgICAgICAgaWYgKGlkID09PSBudWxsIHx8IGlkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGlkIHdhcyBudWxsIG9yIHVuZGVmaW5lZCB3aGVuIGNhbGxpbmcgZ2V0TU1QQ29udmVyc2lvbkV2ZW50c0J5QWR2ZXJ0aXNlci4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICBdO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxBcnJheTxBZHZlcnRpc2VyTW1wQ29udmVyc2lvbkV2ZW50UmVzcG9uc2U+PignZ2V0JyxgJHt0aGlzLmJhc2VQYXRofS9hcGkvYWR2ZXJ0aXNlci8ke2VuY29kZVVSSUNvbXBvbmVudChTdHJpbmcoaWQpKX0vbW1wLWNvbnZlcnNpb24tZXZlbnRzYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IHRoaXMuY29uZmlndXJhdGlvbi53aXRoQ3JlZGVudGlhbHMsXG4gICAgICAgICAgICAgICAgaGVhZGVyczogaGVhZGVycyxcbiAgICAgICAgICAgICAgICBvYnNlcnZlOiBvYnNlcnZlLFxuICAgICAgICAgICAgICAgIHJlcG9ydFByb2dyZXNzOiByZXBvcnRQcm9ncmVzc1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEdldCBhbGwgcHJvZHVjdCBzZXRzIGZvciBhbiBhZHZlcnRpc2VyXG4gICAgICogUmV0dXJucyBhbGwgcHJvZHVjdCBzZXRzIGNvbmZpZ3VyZWQgZm9yIHRoZSBzcGVjaWZpZWQgYWR2ZXJ0aXNlci4gT3B0aW9uYWxseSBmaWx0ZXIgYnkgYWRBY2NvdW50SWQuXG4gICAgICogQHBhcmFtIGlkIFxuICAgICAqIEBwYXJhbSBzb3VyY2VQbGF0Zm9ybSBcbiAgICAgKiBAcGFyYW0gYWRBY2NvdW50SWQgXG4gICAgICogQHBhcmFtIG9ic2VydmUgc2V0IHdoZXRoZXIgb3Igbm90IHRvIHJldHVybiB0aGUgZGF0YSBPYnNlcnZhYmxlIGFzIHRoZSBib2R5LCByZXNwb25zZSBvciBldmVudHMuIGRlZmF1bHRzIHRvIHJldHVybmluZyB0aGUgYm9keS5cbiAgICAgKiBAcGFyYW0gcmVwb3J0UHJvZ3Jlc3MgZmxhZyB0byByZXBvcnQgcmVxdWVzdCBhbmQgcmVzcG9uc2UgcHJvZ3Jlc3MuXG4gICAgICovXG4gICAgcHVibGljIGdldFByb2R1Y3RTZXRzKGlkOiBudW1iZXIsIHNvdXJjZVBsYXRmb3JtOiBzdHJpbmcsIGFkQWNjb3VudElkPzogc3RyaW5nLCBvYnNlcnZlPzogJ2JvZHknLCByZXBvcnRQcm9ncmVzcz86IGJvb2xlYW4pOiBPYnNlcnZhYmxlPEFycmF5PFByb2R1Y3RTZXRSZXNwb25zZT4+O1xuICAgIHB1YmxpYyBnZXRQcm9kdWN0U2V0cyhpZDogbnVtYmVyLCBzb3VyY2VQbGF0Zm9ybTogc3RyaW5nLCBhZEFjY291bnRJZD86IHN0cmluZywgb2JzZXJ2ZT86ICdyZXNwb25zZScsIHJlcG9ydFByb2dyZXNzPzogYm9vbGVhbik6IE9ic2VydmFibGU8SHR0cFJlc3BvbnNlPEFycmF5PFByb2R1Y3RTZXRSZXNwb25zZT4+PjtcbiAgICBwdWJsaWMgZ2V0UHJvZHVjdFNldHMoaWQ6IG51bWJlciwgc291cmNlUGxhdGZvcm06IHN0cmluZywgYWRBY2NvdW50SWQ/OiBzdHJpbmcsIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8QXJyYXk8UHJvZHVjdFNldFJlc3BvbnNlPj4+O1xuICAgIHB1YmxpYyBnZXRQcm9kdWN0U2V0cyhpZDogbnVtYmVyLCBzb3VyY2VQbGF0Zm9ybTogc3RyaW5nLCBhZEFjY291bnRJZD86IHN0cmluZywgb2JzZXJ2ZTogYW55ID0gJ2JvZHknLCByZXBvcnRQcm9ncmVzczogYm9vbGVhbiA9IGZhbHNlICk6IE9ic2VydmFibGU8YW55PiB7XG5cbiAgICAgICAgaWYgKGlkID09PSBudWxsIHx8IGlkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGlkIHdhcyBudWxsIG9yIHVuZGVmaW5lZCB3aGVuIGNhbGxpbmcgZ2V0UHJvZHVjdFNldHMuJyk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoc291cmNlUGxhdGZvcm0gPT09IG51bGwgfHwgc291cmNlUGxhdGZvcm0gPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgc291cmNlUGxhdGZvcm0gd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBnZXRQcm9kdWN0U2V0cy4nKTtcbiAgICAgICAgfVxuXG5cbiAgICAgICAgbGV0IHF1ZXJ5UGFyYW1ldGVycyA9IG5ldyBIdHRwUGFyYW1zKHtlbmNvZGVyOiBuZXcgQ3VzdG9tSHR0cFVybEVuY29kaW5nQ29kZWMoKX0pO1xuICAgICAgICBpZiAoc291cmNlUGxhdGZvcm0gIT09IHVuZGVmaW5lZCAmJiBzb3VyY2VQbGF0Zm9ybSAhPT0gbnVsbCkge1xuICAgICAgICAgICAgcXVlcnlQYXJhbWV0ZXJzID0gcXVlcnlQYXJhbWV0ZXJzLnNldCgnc291cmNlUGxhdGZvcm0nLCA8YW55PnNvdXJjZVBsYXRmb3JtKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoYWRBY2NvdW50SWQgIT09IHVuZGVmaW5lZCAmJiBhZEFjY291bnRJZCAhPT0gbnVsbCkge1xuICAgICAgICAgICAgcXVlcnlQYXJhbWV0ZXJzID0gcXVlcnlQYXJhbWV0ZXJzLnNldCgnYWRBY2NvdW50SWQnLCA8YW55PmFkQWNjb3VudElkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICBdO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxBcnJheTxQcm9kdWN0U2V0UmVzcG9uc2U+PignZ2V0JyxgJHt0aGlzLmJhc2VQYXRofS9hcGkvYWR2ZXJ0aXNlci8ke2VuY29kZVVSSUNvbXBvbmVudChTdHJpbmcoaWQpKX0vcHJvZHVjdC1zZXRzYCxcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBwYXJhbXM6IHF1ZXJ5UGFyYW1ldGVycyxcbiAgICAgICAgICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IHRoaXMuY29uZmlndXJhdGlvbi53aXRoQ3JlZGVudGlhbHMsXG4gICAgICAgICAgICAgICAgaGVhZGVyczogaGVhZGVycyxcbiAgICAgICAgICAgICAgICBvYnNlcnZlOiBvYnNlcnZlLFxuICAgICAgICAgICAgICAgIHJlcG9ydFByb2dyZXNzOiByZXBvcnRQcm9ncmVzc1xuICAgICAgICAgICAgfVxuICAgICAgICApO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFxuICAgICAqIFxuICAgICAqIEBwYXJhbSBhZHZlcnRpc2VySWQgXG4gICAgICogQHBhcmFtIHBsYXRmb3JtIFxuICAgICAqIEBwYXJhbSBhZEFjY291bnRJZCBcbiAgICAgKiBAcGFyYW0gb2JzZXJ2ZSBzZXQgd2hldGhlciBvciBub3QgdG8gcmV0dXJuIHRoZSBkYXRhIE9ic2VydmFibGUgYXMgdGhlIGJvZHksIHJlc3BvbnNlIG9yIGV2ZW50cy4gZGVmYXVsdHMgdG8gcmV0dXJuaW5nIHRoZSBib2R5LlxuICAgICAqIEBwYXJhbSByZXBvcnRQcm9ncmVzcyBmbGFnIHRvIHJlcG9ydCByZXF1ZXN0IGFuZCByZXNwb25zZSBwcm9ncmVzcy5cbiAgICAgKi9cbiAgICBwdWJsaWMgZ2V0U3VwcG9ydGVkR29hbEV2ZW50cyhhZHZlcnRpc2VySWQ6IG51bWJlciwgcGxhdGZvcm06IHN0cmluZywgYWRBY2NvdW50SWQ6IHN0cmluZywgb2JzZXJ2ZT86ICdib2R5JywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxTdXBwb3J0ZWRHb2FsRXZlbnRzUmVzcG9uc2VEVE8+O1xuICAgIHB1YmxpYyBnZXRTdXBwb3J0ZWRHb2FsRXZlbnRzKGFkdmVydGlzZXJJZDogbnVtYmVyLCBwbGF0Zm9ybTogc3RyaW5nLCBhZEFjY291bnRJZDogc3RyaW5nLCBvYnNlcnZlPzogJ3Jlc3BvbnNlJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwUmVzcG9uc2U8U3VwcG9ydGVkR29hbEV2ZW50c1Jlc3BvbnNlRFRPPj47XG4gICAgcHVibGljIGdldFN1cHBvcnRlZEdvYWxFdmVudHMoYWR2ZXJ0aXNlcklkOiBudW1iZXIsIHBsYXRmb3JtOiBzdHJpbmcsIGFkQWNjb3VudElkOiBzdHJpbmcsIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8U3VwcG9ydGVkR29hbEV2ZW50c1Jlc3BvbnNlRFRPPj47XG4gICAgcHVibGljIGdldFN1cHBvcnRlZEdvYWxFdmVudHMoYWR2ZXJ0aXNlcklkOiBudW1iZXIsIHBsYXRmb3JtOiBzdHJpbmcsIGFkQWNjb3VudElkOiBzdHJpbmcsIG9ic2VydmU6IGFueSA9ICdib2R5JywgcmVwb3J0UHJvZ3Jlc3M6IGJvb2xlYW4gPSBmYWxzZSApOiBPYnNlcnZhYmxlPGFueT4ge1xuXG4gICAgICAgIGlmIChhZHZlcnRpc2VySWQgPT09IG51bGwgfHwgYWR2ZXJ0aXNlcklkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGFkdmVydGlzZXJJZCB3YXMgbnVsbCBvciB1bmRlZmluZWQgd2hlbiBjYWxsaW5nIGdldFN1cHBvcnRlZEdvYWxFdmVudHMuJyk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAocGxhdGZvcm0gPT09IG51bGwgfHwgcGxhdGZvcm0gPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgcGxhdGZvcm0gd2FzIG51bGwgb3IgdW5kZWZpbmVkIHdoZW4gY2FsbGluZyBnZXRTdXBwb3J0ZWRHb2FsRXZlbnRzLicpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGFkQWNjb3VudElkID09PSBudWxsIHx8IGFkQWNjb3VudElkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignUmVxdWlyZWQgcGFyYW1ldGVyIGFkQWNjb3VudElkIHdhcyBudWxsIG9yIHVuZGVmaW5lZCB3aGVuIGNhbGxpbmcgZ2V0U3VwcG9ydGVkR29hbEV2ZW50cy4nKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGxldCBoZWFkZXJzID0gdGhpcy5kZWZhdWx0SGVhZGVycztcblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIEFjY2VwdCBoZWFkZXJcbiAgICAgICAgbGV0IGh0dHBIZWFkZXJBY2NlcHRzOiBzdHJpbmdbXSA9IFtcbiAgICAgICAgICAgICcqLyonXG4gICAgICAgIF07XG4gICAgICAgIGNvbnN0IGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZDogc3RyaW5nIHwgdW5kZWZpbmVkID0gdGhpcy5jb25maWd1cmF0aW9uLnNlbGVjdEhlYWRlckFjY2VwdChodHRwSGVhZGVyQWNjZXB0cyk7XG4gICAgICAgIGlmIChodHRwSGVhZGVyQWNjZXB0U2VsZWN0ZWQgIT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICBoZWFkZXJzID0gaGVhZGVycy5zZXQoJ0FjY2VwdCcsIGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCk7XG4gICAgICAgIH1cblxuICAgICAgICAvLyB0byBkZXRlcm1pbmUgdGhlIENvbnRlbnQtVHlwZSBoZWFkZXJcbiAgICAgICAgY29uc3QgY29uc3VtZXM6IHN0cmluZ1tdID0gW1xuICAgICAgICBdO1xuXG4gICAgICAgIHJldHVybiB0aGlzLmh0dHBDbGllbnQucmVxdWVzdDxTdXBwb3J0ZWRHb2FsRXZlbnRzUmVzcG9uc2VEVE8+KCdnZXQnLGAke3RoaXMuYmFzZVBhdGh9L2FwaS9hZHZlcnRpc2VyL2FkdmVydGlzZXJzLyR7ZW5jb2RlVVJJQ29tcG9uZW50KFN0cmluZyhhZHZlcnRpc2VySWQpKX0vcGxhdGZvcm1zLyR7ZW5jb2RlVVJJQ29tcG9uZW50KFN0cmluZyhwbGF0Zm9ybSkpfS9hZC1hY2NvdW50cy8ke2VuY29kZVVSSUNvbXBvbmVudChTdHJpbmcoYWRBY2NvdW50SWQpKX0vZ29hbC1ldmVudHNgLFxuICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIHdpdGhDcmVkZW50aWFsczogdGhpcy5jb25maWd1cmF0aW9uLndpdGhDcmVkZW50aWFscyxcbiAgICAgICAgICAgICAgICBoZWFkZXJzOiBoZWFkZXJzLFxuICAgICAgICAgICAgICAgIG9ic2VydmU6IG9ic2VydmUsXG4gICAgICAgICAgICAgICAgcmVwb3J0UHJvZ3Jlc3M6IHJlcG9ydFByb2dyZXNzXG4gICAgICAgICAgICB9XG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogXG4gICAgICogXG4gICAgICogQHBhcmFtIHEgXG4gICAgICogQHBhcmFtIG9ic2VydmUgc2V0IHdoZXRoZXIgb3Igbm90IHRvIHJldHVybiB0aGUgZGF0YSBPYnNlcnZhYmxlIGFzIHRoZSBib2R5LCByZXNwb25zZSBvciBldmVudHMuIGRlZmF1bHRzIHRvIHJldHVybmluZyB0aGUgYm9keS5cbiAgICAgKiBAcGFyYW0gcmVwb3J0UHJvZ3Jlc3MgZmxhZyB0byByZXBvcnQgcmVxdWVzdCBhbmQgcmVzcG9uc2UgcHJvZ3Jlc3MuXG4gICAgICovXG4gICAgcHVibGljIHNlYXJjaEFkdmVydGlzZXJzKHE6IHN0cmluZywgb2JzZXJ2ZT86ICdib2R5JywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxBcnJheTxBZHZlcnRpc2VyU2VhcmNoUmVzcG9uc2U+PjtcbiAgICBwdWJsaWMgc2VhcmNoQWR2ZXJ0aXNlcnMocTogc3RyaW5nLCBvYnNlcnZlPzogJ3Jlc3BvbnNlJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwUmVzcG9uc2U8QXJyYXk8QWR2ZXJ0aXNlclNlYXJjaFJlc3BvbnNlPj4+O1xuICAgIHB1YmxpYyBzZWFyY2hBZHZlcnRpc2VycyhxOiBzdHJpbmcsIG9ic2VydmU/OiAnZXZlbnRzJywgcmVwb3J0UHJvZ3Jlc3M/OiBib29sZWFuKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8QXJyYXk8QWR2ZXJ0aXNlclNlYXJjaFJlc3BvbnNlPj4+O1xuICAgIHB1YmxpYyBzZWFyY2hBZHZlcnRpc2VycyhxOiBzdHJpbmcsIG9ic2VydmU6IGFueSA9ICdib2R5JywgcmVwb3J0UHJvZ3Jlc3M6IGJvb2xlYW4gPSBmYWxzZSApOiBPYnNlcnZhYmxlPGFueT4ge1xuXG4gICAgICAgIGlmIChxID09PSBudWxsIHx8IHEgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdSZXF1aXJlZCBwYXJhbWV0ZXIgcSB3YXMgbnVsbCBvciB1bmRlZmluZWQgd2hlbiBjYWxsaW5nIHNlYXJjaEFkdmVydGlzZXJzLicpO1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IHF1ZXJ5UGFyYW1ldGVycyA9IG5ldyBIdHRwUGFyYW1zKHtlbmNvZGVyOiBuZXcgQ3VzdG9tSHR0cFVybEVuY29kaW5nQ29kZWMoKX0pO1xuICAgICAgICBpZiAocSAhPT0gdW5kZWZpbmVkICYmIHEgIT09IG51bGwpIHtcbiAgICAgICAgICAgIHF1ZXJ5UGFyYW1ldGVycyA9IHF1ZXJ5UGFyYW1ldGVycy5zZXQoJ3EnLCA8YW55PnEpO1xuICAgICAgICB9XG5cbiAgICAgICAgbGV0IGhlYWRlcnMgPSB0aGlzLmRlZmF1bHRIZWFkZXJzO1xuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQWNjZXB0IGhlYWRlclxuICAgICAgICBsZXQgaHR0cEhlYWRlckFjY2VwdHM6IHN0cmluZ1tdID0gW1xuICAgICAgICAgICAgJyovKidcbiAgICAgICAgXTtcbiAgICAgICAgY29uc3QgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkOiBzdHJpbmcgfCB1bmRlZmluZWQgPSB0aGlzLmNvbmZpZ3VyYXRpb24uc2VsZWN0SGVhZGVyQWNjZXB0KGh0dHBIZWFkZXJBY2NlcHRzKTtcbiAgICAgICAgaWYgKGh0dHBIZWFkZXJBY2NlcHRTZWxlY3RlZCAhPSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIGhlYWRlcnMgPSBoZWFkZXJzLnNldCgnQWNjZXB0JywgaHR0cEhlYWRlckFjY2VwdFNlbGVjdGVkKTtcbiAgICAgICAgfVxuXG4gICAgICAgIC8vIHRvIGRldGVybWluZSB0aGUgQ29udGVudC1UeXBlIGhlYWRlclxuICAgICAgICBjb25zdCBjb25zdW1lczogc3RyaW5nW10gPSBbXG4gICAgICAgIF07XG5cbiAgICAgICAgcmV0dXJuIHRoaXMuaHR0cENsaWVudC5yZXF1ZXN0PEFycmF5PEFkdmVydGlzZXJTZWFyY2hSZXNwb25zZT4+KCdnZXQnLGAke3RoaXMuYmFzZVBhdGh9L2FwaS9hZHZlcnRpc2VyL3NlYXJjaGAsXG4gICAgICAgICAgICB7XG4gICAgICAgICAgICAgICAgcGFyYW1zOiBxdWVyeVBhcmFtZXRlcnMsXG4gICAgICAgICAgICAgICAgd2l0aENyZWRlbnRpYWxzOiB0aGlzLmNvbmZpZ3VyYXRpb24ud2l0aENyZWRlbnRpYWxzLFxuICAgICAgICAgICAgICAgIGhlYWRlcnM6IGhlYWRlcnMsXG4gICAgICAgICAgICAgICAgb2JzZXJ2ZTogb2JzZXJ2ZSxcbiAgICAgICAgICAgICAgICByZXBvcnRQcm9ncmVzczogcmVwb3J0UHJvZ3Jlc3NcbiAgICAgICAgICAgIH1cbiAgICAgICAgKTtcbiAgICB9XG5cbn1cbiJdfQ==