@tomerh2001/israeli-bank-scrapers 6.3.11

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 (121) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +425 -0
  3. package/lib/assertNever.d.ts +1 -0
  4. package/lib/assertNever.js +10 -0
  5. package/lib/constants.d.ts +10 -0
  6. package/lib/constants.js +17 -0
  7. package/lib/definitions.d.ts +105 -0
  8. package/lib/definitions.js +116 -0
  9. package/lib/helpers/browser.d.ts +10 -0
  10. package/lib/helpers/browser.js +21 -0
  11. package/lib/helpers/dates.d.ts +2 -0
  12. package/lib/helpers/dates.js +22 -0
  13. package/lib/helpers/debug.d.ts +2 -0
  14. package/lib/helpers/debug.js +12 -0
  15. package/lib/helpers/elements-interactions.d.ts +17 -0
  16. package/lib/helpers/elements-interactions.js +111 -0
  17. package/lib/helpers/fetch.d.ts +6 -0
  18. package/lib/helpers/fetch.js +111 -0
  19. package/lib/helpers/navigation.d.ts +6 -0
  20. package/lib/helpers/navigation.js +39 -0
  21. package/lib/helpers/storage.d.ts +2 -0
  22. package/lib/helpers/storage.js +14 -0
  23. package/lib/helpers/transactions.d.ts +5 -0
  24. package/lib/helpers/transactions.js +47 -0
  25. package/lib/helpers/waiting.d.ts +13 -0
  26. package/lib/helpers/waiting.js +58 -0
  27. package/lib/index.d.ts +7 -0
  28. package/lib/index.js +85 -0
  29. package/lib/scrapers/amex.d.ts +6 -0
  30. package/lib/scrapers/amex.js +17 -0
  31. package/lib/scrapers/amex.test.d.ts +1 -0
  32. package/lib/scrapers/amex.test.js +49 -0
  33. package/lib/scrapers/base-beinleumi-group.d.ts +66 -0
  34. package/lib/scrapers/base-beinleumi-group.js +428 -0
  35. package/lib/scrapers/base-isracard-amex.d.ts +23 -0
  36. package/lib/scrapers/base-isracard-amex.js +324 -0
  37. package/lib/scrapers/base-scraper-with-browser.d.ts +57 -0
  38. package/lib/scrapers/base-scraper-with-browser.js +291 -0
  39. package/lib/scrapers/base-scraper-with-browser.test.d.ts +1 -0
  40. package/lib/scrapers/base-scraper-with-browser.test.js +53 -0
  41. package/lib/scrapers/base-scraper.d.ts +19 -0
  42. package/lib/scrapers/base-scraper.js +91 -0
  43. package/lib/scrapers/behatsdaa.d.ts +11 -0
  44. package/lib/scrapers/behatsdaa.js +113 -0
  45. package/lib/scrapers/behatsdaa.test.d.ts +1 -0
  46. package/lib/scrapers/behatsdaa.test.js +46 -0
  47. package/lib/scrapers/beinleumi.d.ts +7 -0
  48. package/lib/scrapers/beinleumi.js +15 -0
  49. package/lib/scrapers/beinleumi.test.d.ts +1 -0
  50. package/lib/scrapers/beinleumi.test.js +47 -0
  51. package/lib/scrapers/beyahad-bishvilha.d.ts +30 -0
  52. package/lib/scrapers/beyahad-bishvilha.js +149 -0
  53. package/lib/scrapers/beyahad-bishvilha.test.d.ts +1 -0
  54. package/lib/scrapers/beyahad-bishvilha.test.js +47 -0
  55. package/lib/scrapers/discount.d.ts +22 -0
  56. package/lib/scrapers/discount.js +120 -0
  57. package/lib/scrapers/discount.test.d.ts +1 -0
  58. package/lib/scrapers/discount.test.js +49 -0
  59. package/lib/scrapers/errors.d.ts +16 -0
  60. package/lib/scrapers/errors.js +32 -0
  61. package/lib/scrapers/factory.d.ts +2 -0
  62. package/lib/scrapers/factory.js +70 -0
  63. package/lib/scrapers/factory.test.d.ts +1 -0
  64. package/lib/scrapers/factory.test.js +19 -0
  65. package/lib/scrapers/hapoalim.d.ts +24 -0
  66. package/lib/scrapers/hapoalim.js +198 -0
  67. package/lib/scrapers/hapoalim.test.d.ts +1 -0
  68. package/lib/scrapers/hapoalim.test.js +47 -0
  69. package/lib/scrapers/interface.d.ts +186 -0
  70. package/lib/scrapers/interface.js +6 -0
  71. package/lib/scrapers/isracard.d.ts +6 -0
  72. package/lib/scrapers/isracard.js +17 -0
  73. package/lib/scrapers/isracard.test.d.ts +1 -0
  74. package/lib/scrapers/isracard.test.js +49 -0
  75. package/lib/scrapers/leumi.d.ts +21 -0
  76. package/lib/scrapers/leumi.js +200 -0
  77. package/lib/scrapers/leumi.test.d.ts +1 -0
  78. package/lib/scrapers/leumi.test.js +47 -0
  79. package/lib/scrapers/massad.d.ts +7 -0
  80. package/lib/scrapers/massad.js +15 -0
  81. package/lib/scrapers/max.d.ts +37 -0
  82. package/lib/scrapers/max.js +299 -0
  83. package/lib/scrapers/max.test.d.ts +1 -0
  84. package/lib/scrapers/max.test.js +64 -0
  85. package/lib/scrapers/mercantile.d.ts +20 -0
  86. package/lib/scrapers/mercantile.js +18 -0
  87. package/lib/scrapers/mercantile.test.d.ts +1 -0
  88. package/lib/scrapers/mercantile.test.js +45 -0
  89. package/lib/scrapers/mizrahi.d.ts +35 -0
  90. package/lib/scrapers/mizrahi.js +265 -0
  91. package/lib/scrapers/mizrahi.test.d.ts +1 -0
  92. package/lib/scrapers/mizrahi.test.js +56 -0
  93. package/lib/scrapers/one-zero-queries.d.ts +2 -0
  94. package/lib/scrapers/one-zero-queries.js +560 -0
  95. package/lib/scrapers/one-zero.d.ts +36 -0
  96. package/lib/scrapers/one-zero.js +238 -0
  97. package/lib/scrapers/one-zero.test.d.ts +1 -0
  98. package/lib/scrapers/one-zero.test.js +51 -0
  99. package/lib/scrapers/otsar-hahayal.d.ts +7 -0
  100. package/lib/scrapers/otsar-hahayal.js +15 -0
  101. package/lib/scrapers/otsar-hahayal.test.d.ts +1 -0
  102. package/lib/scrapers/otsar-hahayal.test.js +47 -0
  103. package/lib/scrapers/pagi.d.ts +7 -0
  104. package/lib/scrapers/pagi.js +15 -0
  105. package/lib/scrapers/pagi.test.d.ts +1 -0
  106. package/lib/scrapers/pagi.test.js +47 -0
  107. package/lib/scrapers/union-bank.d.ts +23 -0
  108. package/lib/scrapers/union-bank.js +242 -0
  109. package/lib/scrapers/union-bank.test.d.ts +1 -0
  110. package/lib/scrapers/union-bank.test.js +47 -0
  111. package/lib/scrapers/visa-cal.d.ts +20 -0
  112. package/lib/scrapers/visa-cal.js +318 -0
  113. package/lib/scrapers/visa-cal.test.d.ts +1 -0
  114. package/lib/scrapers/visa-cal.test.js +49 -0
  115. package/lib/scrapers/yahav.d.ts +25 -0
  116. package/lib/scrapers/yahav.js +247 -0
  117. package/lib/scrapers/yahav.test.d.ts +1 -0
  118. package/lib/scrapers/yahav.test.js +49 -0
  119. package/lib/transactions.d.ts +47 -0
  120. package/lib/transactions.js +17 -0
  121. package/package.json +91 -0
@@ -0,0 +1,265 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _moment = _interopRequireDefault(require("moment"));
8
+ var _constants = require("../constants");
9
+ var _elementsInteractions = require("../helpers/elements-interactions");
10
+ var _fetch = require("../helpers/fetch");
11
+ var _navigation = require("../helpers/navigation");
12
+ var _transactions = require("../transactions");
13
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
14
+ var _errors = require("./errors");
15
+ var _debug = require("../helpers/debug");
16
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
17
+ const debug = (0, _debug.getDebug)('mizrahi');
18
+ const BASE_WEBSITE_URL = 'https://www.mizrahi-tefahot.co.il';
19
+ const LOGIN_URL = `${BASE_WEBSITE_URL}/login/index.html#/auth-page-he`;
20
+ const BASE_APP_URL = 'https://mto.mizrahi-tefahot.co.il';
21
+ const AFTER_LOGIN_BASE_URL = /https:\/\/mto\.mizrahi-tefahot\.co\.il\/OnlineApp\/.*/;
22
+ const OSH_PAGE = '/osh/legacy/legacy-Osh-Main';
23
+ const TRANSACTIONS_PAGE = '/osh/legacy/root-main-osh-p428New';
24
+ const TRANSACTIONS_REQUEST_URLS = [`${BASE_APP_URL}/OnlinePilot/api/SkyOSH/get428Index`, `${BASE_APP_URL}/Online/api/SkyOSH/get428Index`];
25
+ const PENDING_TRANSACTIONS_PAGE = '/osh/legacy/legacy-Osh-p420';
26
+ const PENDING_TRANSACTIONS_IFRAME = 'p420.aspx';
27
+ const MORE_DETAILS_URL = `${BASE_APP_URL}/Online/api/OSH/getMaherBerurimSMF`;
28
+ const CHANGE_PASSWORD_URL = /https:\/\/www\.mizrahi-tefahot\.co\.il\/login\/index\.html#\/change-pass/;
29
+ const DATE_FORMAT = 'DD/MM/YYYY';
30
+ const MAX_ROWS_PER_REQUEST = 10000000000;
31
+ const usernameSelector = '#userNumberDesktopHeb';
32
+ const passwordSelector = '#passwordDesktopHeb';
33
+ const submitButtonSelector = 'button.btn.btn-primary';
34
+ const invalidPasswordSelector = 'a[href*="https://sc.mizrahi-tefahot.co.il/SCServices/SC/P010.aspx"]';
35
+ const afterLoginSelector = '#dropdownBasic';
36
+ const loginSpinnerSelector = 'div.ngx-overlay.loading-foreground';
37
+ const accountDropDownItemSelector = '#AccountPicker .item';
38
+ const pendingTrxIdentifierId = '#ctl00_ContentPlaceHolder2_panel1';
39
+ const checkingAccountTabHebrewName = 'עובר ושב';
40
+ const checkingAccountTabEnglishName = 'Checking Account';
41
+ const genericDescriptions = ['העברת יומן לבנק זר מסניף זר'];
42
+ function createLoginFields(credentials) {
43
+ return [{
44
+ selector: usernameSelector,
45
+ value: credentials.username
46
+ }, {
47
+ selector: passwordSelector,
48
+ value: credentials.password
49
+ }];
50
+ }
51
+ async function isLoggedIn(options) {
52
+ if (!options?.page) {
53
+ return false;
54
+ }
55
+ const oshXPath = `//a//span[contains(., "${checkingAccountTabHebrewName}") or contains(., "${checkingAccountTabEnglishName}")]`;
56
+ const oshTab = await options.page.$$(`xpath${oshXPath}`);
57
+ return oshTab.length > 0;
58
+ }
59
+ function getPossibleLoginResults(page) {
60
+ return {
61
+ [_baseScraperWithBrowser.LoginResults.Success]: [AFTER_LOGIN_BASE_URL, isLoggedIn],
62
+ [_baseScraperWithBrowser.LoginResults.InvalidPassword]: [async () => !!(await page.$(invalidPasswordSelector))],
63
+ [_baseScraperWithBrowser.LoginResults.ChangePassword]: [CHANGE_PASSWORD_URL]
64
+ };
65
+ }
66
+ function getStartMoment(optionsStartDate) {
67
+ const defaultStartMoment = (0, _moment.default)().subtract(1, 'years');
68
+ const startDate = optionsStartDate || defaultStartMoment.toDate();
69
+ return _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
70
+ }
71
+ async function getExtraTransactionDetails(page, item, apiHeaders) {
72
+ try {
73
+ debug('getExtraTransactionDetails for item:', item);
74
+ if (item.MC02ShowDetailsEZ === '1') {
75
+ const tarPeula = (0, _moment.default)(item.MC02PeulaTaaEZ);
76
+ const tarErech = (0, _moment.default)(item.MC02ErehTaaEZ);
77
+ const params = {
78
+ inKodGorem: item.MC02KodGoremEZ,
79
+ inAsmachta: item.MC02AsmahtaMekoritEZ,
80
+ inSchum: item.MC02SchumEZ,
81
+ inNakvanit: item.MC02KodGoremEZ,
82
+ inSugTnua: item.MC02SugTnuaKaspitEZ,
83
+ inAgid: item.MC02AgidEZ,
84
+ inTarPeulaFormatted: tarPeula.format(DATE_FORMAT),
85
+ inTarErechFormatted: (tarErech.year() > 2000 ? tarErech : tarPeula).format(DATE_FORMAT),
86
+ inKodNose: item.MC02SeifMaralEZ,
87
+ inKodTatNose: item.MC02NoseMaralEZ,
88
+ inTransactionNumber: item.TransactionNumber
89
+ };
90
+ const response = await (0, _fetch.fetchPostWithinPage)(page, MORE_DETAILS_URL, params, apiHeaders);
91
+ const details = response?.body.fields?.[0]?.[0]?.Records?.[0].Fields;
92
+ debug('fetch details for', params, 'details:', details);
93
+ if (Array.isArray(details) && details.length > 0) {
94
+ const entries = details.map(record => [record.Label.trim(), record.Value.trim()]);
95
+ return {
96
+ entries: Object.fromEntries(entries),
97
+ memo: entries.filter(([label]) => ['שם', 'מהות', 'חשבון'].some(key => label.startsWith(key))).map(([label, value]) => `${label} ${value}`).join(', ')
98
+ };
99
+ }
100
+ }
101
+ } catch (error) {
102
+ debug('Error fetching extra transaction details:', error);
103
+ }
104
+ return {
105
+ entries: {},
106
+ memo: undefined
107
+ };
108
+ }
109
+ function createDataFromRequest(request, optionsStartDate) {
110
+ const data = JSON.parse(request.postData() || '{}');
111
+ data.inFromDate = getStartMoment(optionsStartDate).format(DATE_FORMAT);
112
+ data.inToDate = (0, _moment.default)().format(DATE_FORMAT);
113
+ data.table.maxRow = MAX_ROWS_PER_REQUEST;
114
+ return data;
115
+ }
116
+ function createHeadersFromRequest(request) {
117
+ return {
118
+ mizrahixsrftoken: request.headers().mizrahixsrftoken,
119
+ 'Content-Type': request.headers()['content-type']
120
+ };
121
+ }
122
+ async function convertTransactions(txns, getMoreDetails, pendingIfTodayTransaction = false) {
123
+ return Promise.all(txns.map(async row => {
124
+ const moreDetails = await getMoreDetails(row);
125
+ const txnDate = (0, _moment.default)(row.MC02PeulaTaaEZ, _moment.default.HTML5_FMT.DATETIME_LOCAL_SECONDS).toISOString();
126
+ return {
127
+ type: _transactions.TransactionTypes.Normal,
128
+ identifier: row.MC02AsmahtaMekoritEZ ? parseInt(row.MC02AsmahtaMekoritEZ, 10) : undefined,
129
+ date: txnDate,
130
+ processedDate: txnDate,
131
+ originalAmount: row.MC02SchumEZ,
132
+ originalCurrency: _constants.SHEKEL_CURRENCY,
133
+ chargedAmount: row.MC02SchumEZ,
134
+ description: row.MC02TnuaTeurEZ,
135
+ memo: moreDetails?.memo,
136
+ status: pendingIfTodayTransaction && row.IsTodayTransaction ? _transactions.TransactionStatuses.Pending : _transactions.TransactionStatuses.Completed
137
+ };
138
+ }));
139
+ }
140
+ async function extractPendingTransactions(page) {
141
+ const pendingTxn = await (0, _elementsInteractions.pageEvalAll)(page, 'tr.rgRow, tr.rgAltRow', [], trs => {
142
+ return trs.map(tr => Array.from(tr.querySelectorAll('td'), td => td.textContent || ''));
143
+ });
144
+ return pendingTxn.map(([dateStr, description, incomeAmountStr, amountStr]) => ({
145
+ date: (0, _moment.default)(dateStr, 'DD/MM/YY').toISOString(),
146
+ amount: parseFloat(amountStr.replaceAll(',', '')),
147
+ description,
148
+ incomeAmountStr // TODO: handle incomeAmountStr once we know the sign of it
149
+ })).filter(txn => txn.date).map(({
150
+ date,
151
+ description,
152
+ amount
153
+ }) => ({
154
+ type: _transactions.TransactionTypes.Normal,
155
+ date,
156
+ processedDate: date,
157
+ originalAmount: amount,
158
+ originalCurrency: _constants.SHEKEL_CURRENCY,
159
+ chargedAmount: amount,
160
+ description,
161
+ status: _transactions.TransactionStatuses.Pending
162
+ }));
163
+ }
164
+ async function postLogin(page) {
165
+ await Promise.race([(0, _elementsInteractions.waitUntilElementFound)(page, afterLoginSelector), (0, _elementsInteractions.waitUntilElementFound)(page, invalidPasswordSelector), (0, _navigation.waitForUrl)(page, CHANGE_PASSWORD_URL)]);
166
+ }
167
+ class MizrahiScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
168
+ getLoginOptions(credentials) {
169
+ return {
170
+ loginUrl: LOGIN_URL,
171
+ fields: createLoginFields(credentials),
172
+ submitButtonSelector,
173
+ checkReadiness: async () => (0, _elementsInteractions.waitUntilElementDisappear)(this.page, loginSpinnerSelector),
174
+ postAction: async () => postLogin(this.page),
175
+ possibleResults: getPossibleLoginResults(this.page)
176
+ };
177
+ }
178
+ async fetchData() {
179
+ await this.page.$eval('#dropdownBasic, .item', el => el.click());
180
+ const numOfAccounts = (await this.page.$$(accountDropDownItemSelector)).length;
181
+ try {
182
+ const results = [];
183
+ for (let i = 0; i < numOfAccounts; i += 1) {
184
+ if (i > 0) {
185
+ await this.page.$eval('#dropdownBasic, .item', el => el.click());
186
+ }
187
+ await this.page.$eval(`${accountDropDownItemSelector}:nth-child(${i + 1})`, el => el.click());
188
+ results.push(await this.fetchAccount());
189
+ }
190
+ return {
191
+ success: true,
192
+ accounts: results
193
+ };
194
+ } catch (e) {
195
+ return {
196
+ success: false,
197
+ errorType: _errors.ScraperErrorTypes.Generic,
198
+ errorMessage: e.message
199
+ };
200
+ }
201
+ }
202
+ async getPendingTransactions() {
203
+ await this.page.$eval(`a[href*="${PENDING_TRANSACTIONS_PAGE}"]`, el => el.click());
204
+ const frame = await (0, _elementsInteractions.waitUntilIframeFound)(this.page, f => f.url().includes(PENDING_TRANSACTIONS_IFRAME));
205
+ const isPending = await (0, _elementsInteractions.waitUntilElementFound)(frame, pendingTrxIdentifierId).then(() => true).catch(() => false);
206
+ if (!isPending) {
207
+ return [];
208
+ }
209
+ const pendingTxn = await extractPendingTransactions(frame);
210
+ return pendingTxn;
211
+ }
212
+ async fetchAccount() {
213
+ await this.page.waitForSelector(`a[href*="${OSH_PAGE}"]`);
214
+ await this.page.$eval(`a[href*="${OSH_PAGE}"]`, el => el.click());
215
+ await (0, _elementsInteractions.waitUntilElementFound)(this.page, `a[href*="${TRANSACTIONS_PAGE}"]`);
216
+ await this.page.$eval(`a[href*="${TRANSACTIONS_PAGE}"]`, el => el.click());
217
+ const accountNumberElement = await this.page.$('#dropdownBasic b span');
218
+ const accountNumberHandle = await accountNumberElement?.getProperty('title');
219
+ const accountNumber = await accountNumberHandle?.jsonValue();
220
+ if (!accountNumber) {
221
+ throw new Error('Account number not found');
222
+ }
223
+ const [response, apiHeaders] = await Promise.any(TRANSACTIONS_REQUEST_URLS.map(async url => {
224
+ const request = await this.page.waitForRequest(url);
225
+ const data = createDataFromRequest(request, this.options.startDate);
226
+ const headers = createHeadersFromRequest(request);
227
+ return [await (0, _fetch.fetchPostWithinPage)(this.page, url, data, headers), headers];
228
+ }));
229
+ if (!response || response.header.success === false) {
230
+ throw new Error(`Error fetching transaction. Response message: ${response ? response.header.messages[0].text : ''}`);
231
+ }
232
+ const relevantRows = response.body.table.rows.filter(row => row.RecTypeSpecified);
233
+ const oshTxn = await convertTransactions(relevantRows, this.options.additionalTransactionInformation ? row => getExtraTransactionDetails(this.page, row, apiHeaders) : () => Promise.resolve({
234
+ entries: {},
235
+ memo: undefined
236
+ }), this.options.optInFeatures?.includes('mizrahi:pendingIfTodayTransaction'));
237
+ oshTxn.filter(txn => this.shouldMarkAsPending(txn)).forEach(txn => {
238
+ txn.status = _transactions.TransactionStatuses.Pending;
239
+ });
240
+
241
+ // workaround for a bug which the bank's API returns transactions before the requested start date
242
+ const startMoment = getStartMoment(this.options.startDate);
243
+ const oshTxnAfterStartDate = oshTxn.filter(txn => (0, _moment.default)(txn.date).isSameOrAfter(startMoment));
244
+ const pendingTxn = await this.getPendingTransactions();
245
+ const allTxn = oshTxnAfterStartDate.concat(pendingTxn);
246
+ return {
247
+ accountNumber,
248
+ txns: allTxn,
249
+ balance: +response.body.fields?.Yitra
250
+ };
251
+ }
252
+ shouldMarkAsPending(txn) {
253
+ if (this.options.optInFeatures?.includes('mizrahi:pendingIfNoIdentifier') && !txn.identifier) {
254
+ debug(`Marking transaction '${txn.description}' as pending due to no identifier.`);
255
+ return true;
256
+ }
257
+ if (this.options.optInFeatures?.includes('mizrahi:pendingIfHasGenericDescription') && genericDescriptions.includes(txn.description)) {
258
+ debug(`Marking transaction '${txn.description}' as pending due to generic description.`);
259
+ return true;
260
+ }
261
+ return false;
262
+ }
263
+ }
264
+ var _default = exports.default = MizrahiScraper;
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbW9tZW50IiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJfY29uc3RhbnRzIiwiX2VsZW1lbnRzSW50ZXJhY3Rpb25zIiwiX2ZldGNoIiwiX25hdmlnYXRpb24iLCJfdHJhbnNhY3Rpb25zIiwiX2Jhc2VTY3JhcGVyV2l0aEJyb3dzZXIiLCJfZXJyb3JzIiwiX2RlYnVnIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVidWciLCJnZXREZWJ1ZyIsIkJBU0VfV0VCU0lURV9VUkwiLCJMT0dJTl9VUkwiLCJCQVNFX0FQUF9VUkwiLCJBRlRFUl9MT0dJTl9CQVNFX1VSTCIsIk9TSF9QQUdFIiwiVFJBTlNBQ1RJT05TX1BBR0UiLCJUUkFOU0FDVElPTlNfUkVRVUVTVF9VUkxTIiwiUEVORElOR19UUkFOU0FDVElPTlNfUEFHRSIsIlBFTkRJTkdfVFJBTlNBQ1RJT05TX0lGUkFNRSIsIk1PUkVfREVUQUlMU19VUkwiLCJDSEFOR0VfUEFTU1dPUkRfVVJMIiwiREFURV9GT1JNQVQiLCJNQVhfUk9XU19QRVJfUkVRVUVTVCIsInVzZXJuYW1lU2VsZWN0b3IiLCJwYXNzd29yZFNlbGVjdG9yIiwic3VibWl0QnV0dG9uU2VsZWN0b3IiLCJpbnZhbGlkUGFzc3dvcmRTZWxlY3RvciIsImFmdGVyTG9naW5TZWxlY3RvciIsImxvZ2luU3Bpbm5lclNlbGVjdG9yIiwiYWNjb3VudERyb3BEb3duSXRlbVNlbGVjdG9yIiwicGVuZGluZ1RyeElkZW50aWZpZXJJZCIsImNoZWNraW5nQWNjb3VudFRhYkhlYnJld05hbWUiLCJjaGVja2luZ0FjY291bnRUYWJFbmdsaXNoTmFtZSIsImdlbmVyaWNEZXNjcmlwdGlvbnMiLCJjcmVhdGVMb2dpbkZpZWxkcyIsImNyZWRlbnRpYWxzIiwic2VsZWN0b3IiLCJ2YWx1ZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJpc0xvZ2dlZEluIiwib3B0aW9ucyIsInBhZ2UiLCJvc2hYUGF0aCIsIm9zaFRhYiIsIiQkIiwibGVuZ3RoIiwiZ2V0UG9zc2libGVMb2dpblJlc3VsdHMiLCJMb2dpblJlc3VsdHMiLCJTdWNjZXNzIiwiSW52YWxpZFBhc3N3b3JkIiwiJCIsIkNoYW5nZVBhc3N3b3JkIiwiZ2V0U3RhcnRNb21lbnQiLCJvcHRpb25zU3RhcnREYXRlIiwiZGVmYXVsdFN0YXJ0TW9tZW50IiwibW9tZW50Iiwic3VidHJhY3QiLCJzdGFydERhdGUiLCJ0b0RhdGUiLCJtYXgiLCJnZXRFeHRyYVRyYW5zYWN0aW9uRGV0YWlscyIsIml0ZW0iLCJhcGlIZWFkZXJzIiwiTUMwMlNob3dEZXRhaWxzRVoiLCJ0YXJQZXVsYSIsIk1DMDJQZXVsYVRhYUVaIiwidGFyRXJlY2giLCJNQzAyRXJlaFRhYUVaIiwicGFyYW1zIiwiaW5Lb2RHb3JlbSIsIk1DMDJLb2RHb3JlbUVaIiwiaW5Bc21hY2h0YSIsIk1DMDJBc21haHRhTWVrb3JpdEVaIiwiaW5TY2h1bSIsIk1DMDJTY2h1bUVaIiwiaW5OYWt2YW5pdCIsImluU3VnVG51YSIsIk1DMDJTdWdUbnVhS2FzcGl0RVoiLCJpbkFnaWQiLCJNQzAyQWdpZEVaIiwiaW5UYXJQZXVsYUZvcm1hdHRlZCIsImZvcm1hdCIsImluVGFyRXJlY2hGb3JtYXR0ZWQiLCJ5ZWFyIiwiaW5Lb2ROb3NlIiwiTUMwMlNlaWZNYXJhbEVaIiwiaW5Lb2RUYXROb3NlIiwiTUMwMk5vc2VNYXJhbEVaIiwiaW5UcmFuc2FjdGlvbk51bWJlciIsIlRyYW5zYWN0aW9uTnVtYmVyIiwicmVzcG9uc2UiLCJmZXRjaFBvc3RXaXRoaW5QYWdlIiwiZGV0YWlscyIsImJvZHkiLCJmaWVsZHMiLCJSZWNvcmRzIiwiRmllbGRzIiwiQXJyYXkiLCJpc0FycmF5IiwiZW50cmllcyIsIm1hcCIsInJlY29yZCIsIkxhYmVsIiwidHJpbSIsIlZhbHVlIiwiT2JqZWN0IiwiZnJvbUVudHJpZXMiLCJtZW1vIiwiZmlsdGVyIiwibGFiZWwiLCJzb21lIiwia2V5Iiwic3RhcnRzV2l0aCIsImpvaW4iLCJlcnJvciIsInVuZGVmaW5lZCIsImNyZWF0ZURhdGFGcm9tUmVxdWVzdCIsInJlcXVlc3QiLCJkYXRhIiwiSlNPTiIsInBhcnNlIiwicG9zdERhdGEiLCJpbkZyb21EYXRlIiwiaW5Ub0RhdGUiLCJ0YWJsZSIsIm1heFJvdyIsImNyZWF0ZUhlYWRlcnNGcm9tUmVxdWVzdCIsIm1penJhaGl4c3JmdG9rZW4iLCJoZWFkZXJzIiwiY29udmVydFRyYW5zYWN0aW9ucyIsInR4bnMiLCJnZXRNb3JlRGV0YWlscyIsInBlbmRpbmdJZlRvZGF5VHJhbnNhY3Rpb24iLCJQcm9taXNlIiwiYWxsIiwicm93IiwibW9yZURldGFpbHMiLCJ0eG5EYXRlIiwiSFRNTDVfRk1UIiwiREFURVRJTUVfTE9DQUxfU0VDT05EUyIsInRvSVNPU3RyaW5nIiwidHlwZSIsIlRyYW5zYWN0aW9uVHlwZXMiLCJOb3JtYWwiLCJpZGVudGlmaWVyIiwicGFyc2VJbnQiLCJkYXRlIiwicHJvY2Vzc2VkRGF0ZSIsIm9yaWdpbmFsQW1vdW50Iiwib3JpZ2luYWxDdXJyZW5jeSIsIlNIRUtFTF9DVVJSRU5DWSIsImNoYXJnZWRBbW91bnQiLCJkZXNjcmlwdGlvbiIsIk1DMDJUbnVhVGV1ckVaIiwic3RhdHVzIiwiSXNUb2RheVRyYW5zYWN0aW9uIiwiVHJhbnNhY3Rpb25TdGF0dXNlcyIsIlBlbmRpbmciLCJDb21wbGV0ZWQiLCJleHRyYWN0UGVuZGluZ1RyYW5zYWN0aW9ucyIsInBlbmRpbmdUeG4iLCJwYWdlRXZhbEFsbCIsInRycyIsInRyIiwiZnJvbSIsInF1ZXJ5U2VsZWN0b3JBbGwiLCJ0ZCIsInRleHRDb250ZW50IiwiZGF0ZVN0ciIsImluY29tZUFtb3VudFN0ciIsImFtb3VudFN0ciIsImFtb3VudCIsInBhcnNlRmxvYXQiLCJyZXBsYWNlQWxsIiwidHhuIiwicG9zdExvZ2luIiwicmFjZSIsIndhaXRVbnRpbEVsZW1lbnRGb3VuZCIsIndhaXRGb3JVcmwiLCJNaXpyYWhpU2NyYXBlciIsIkJhc2VTY3JhcGVyV2l0aEJyb3dzZXIiLCJnZXRMb2dpbk9wdGlvbnMiLCJsb2dpblVybCIsImNoZWNrUmVhZGluZXNzIiwid2FpdFVudGlsRWxlbWVudERpc2FwcGVhciIsInBvc3RBY3Rpb24iLCJwb3NzaWJsZVJlc3VsdHMiLCJmZXRjaERhdGEiLCIkZXZhbCIsImVsIiwiY2xpY2siLCJudW1PZkFjY291bnRzIiwicmVzdWx0cyIsImkiLCJwdXNoIiwiZmV0Y2hBY2NvdW50Iiwic3VjY2VzcyIsImFjY291bnRzIiwiZXJyb3JUeXBlIiwiU2NyYXBlckVycm9yVHlwZXMiLCJHZW5lcmljIiwiZXJyb3JNZXNzYWdlIiwibWVzc2FnZSIsImdldFBlbmRpbmdUcmFuc2FjdGlvbnMiLCJmcmFtZSIsIndhaXRVbnRpbElmcmFtZUZvdW5kIiwiZiIsInVybCIsImluY2x1ZGVzIiwiaXNQZW5kaW5nIiwidGhlbiIsImNhdGNoIiwid2FpdEZvclNlbGVjdG9yIiwiYWNjb3VudE51bWJlckVsZW1lbnQiLCJhY2NvdW50TnVtYmVySGFuZGxlIiwiZ2V0UHJvcGVydHkiLCJhY2NvdW50TnVtYmVyIiwianNvblZhbHVlIiwiRXJyb3IiLCJhbnkiLCJ3YWl0Rm9yUmVxdWVzdCIsImhlYWRlciIsIm1lc3NhZ2VzIiwidGV4dCIsInJlbGV2YW50Um93cyIsInJvd3MiLCJSZWNUeXBlU3BlY2lmaWVkIiwib3NoVHhuIiwiYWRkaXRpb25hbFRyYW5zYWN0aW9uSW5mb3JtYXRpb24iLCJyZXNvbHZlIiwib3B0SW5GZWF0dXJlcyIsInNob3VsZE1hcmtBc1BlbmRpbmciLCJmb3JFYWNoIiwic3RhcnRNb21lbnQiLCJvc2hUeG5BZnRlclN0YXJ0RGF0ZSIsImlzU2FtZU9yQWZ0ZXIiLCJhbGxUeG4iLCJjb25jYXQiLCJiYWxhbmNlIiwiWWl0cmEiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NyYXBlcnMvbWl6cmFoaS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbW9tZW50IGZyb20gJ21vbWVudCc7XG5pbXBvcnQgeyB0eXBlIEZyYW1lLCB0eXBlIEhUVFBSZXF1ZXN0LCB0eXBlIFBhZ2UgfSBmcm9tICdwdXBwZXRlZXInO1xuaW1wb3J0IHsgU0hFS0VMX0NVUlJFTkNZIH0gZnJvbSAnLi4vY29uc3RhbnRzJztcbmltcG9ydCB7XG4gIHBhZ2VFdmFsQWxsLFxuICB3YWl0VW50aWxFbGVtZW50RGlzYXBwZWFyLFxuICB3YWl0VW50aWxFbGVtZW50Rm91bmQsXG4gIHdhaXRVbnRpbElmcmFtZUZvdW5kLFxufSBmcm9tICcuLi9oZWxwZXJzL2VsZW1lbnRzLWludGVyYWN0aW9ucyc7XG5pbXBvcnQgeyBmZXRjaFBvc3RXaXRoaW5QYWdlIH0gZnJvbSAnLi4vaGVscGVycy9mZXRjaCc7XG5pbXBvcnQgeyB3YWl0Rm9yVXJsIH0gZnJvbSAnLi4vaGVscGVycy9uYXZpZ2F0aW9uJztcbmltcG9ydCB7IHR5cGUgVHJhbnNhY3Rpb24sIFRyYW5zYWN0aW9uU3RhdHVzZXMsIFRyYW5zYWN0aW9uVHlwZXMsIHR5cGUgVHJhbnNhY3Rpb25zQWNjb3VudCB9IGZyb20gJy4uL3RyYW5zYWN0aW9ucyc7XG5pbXBvcnQgeyBCYXNlU2NyYXBlcldpdGhCcm93c2VyLCBMb2dpblJlc3VsdHMsIHR5cGUgUG9zc2libGVMb2dpblJlc3VsdHMgfSBmcm9tICcuL2Jhc2Utc2NyYXBlci13aXRoLWJyb3dzZXInO1xuaW1wb3J0IHsgU2NyYXBlckVycm9yVHlwZXMgfSBmcm9tICcuL2Vycm9ycyc7XG5pbXBvcnQgeyBnZXREZWJ1ZyB9IGZyb20gJy4uL2hlbHBlcnMvZGVidWcnO1xuXG5jb25zdCBkZWJ1ZyA9IGdldERlYnVnKCdtaXpyYWhpJyk7XG5cbmludGVyZmFjZSBTY3JhcGVkVHJhbnNhY3Rpb24ge1xuICBSZWNUeXBlU3BlY2lmaWVkOiBib29sZWFuO1xuICBNQzAyUGV1bGFUYWFFWjogc3RyaW5nO1xuICBNQzAyU2NodW1FWjogbnVtYmVyO1xuICBNQzAyQXNtYWh0YU1la29yaXRFWjogc3RyaW5nO1xuICBNQzAyVG51YVRldXJFWjogc3RyaW5nO1xuICBJc1RvZGF5VHJhbnNhY3Rpb246IGJvb2xlYW47XG4gIE1DMDJFcmVoVGFhRVo6IHN0cmluZztcbiAgTUMwMlNob3dEZXRhaWxzRVo/OiBzdHJpbmc7XG4gIE1DMDJLb2RHb3JlbUVaOiBhbnk7XG4gIE1DMDJTdWdUbnVhS2FzcGl0RVo6IGFueTtcbiAgTUMwMkFnaWRFWjogYW55O1xuICBNQzAyU2VpZk1hcmFsRVo6IGFueTtcbiAgTUMwMk5vc2VNYXJhbEVaOiBhbnk7XG4gIFRyYW5zYWN0aW9uTnVtYmVyOiBhbnk7XG59XG5cbmludGVyZmFjZSBTY3JhcGVkVHJhbnNhY3Rpb25zUmVzdWx0IHtcbiAgaGVhZGVyOiB7XG4gICAgc3VjY2VzczogYm9vbGVhbjtcbiAgICBtZXNzYWdlczogeyB0ZXh0OiBzdHJpbmcgfVtdO1xuICB9O1xuICBib2R5OiB7XG4gICAgZmllbGRzOiB7XG4gICAgICBZaXRyYTogc3RyaW5nO1xuICAgIH07XG4gICAgdGFibGU6IHtcbiAgICAgIHJvd3M6IFNjcmFwZWRUcmFuc2FjdGlvbltdO1xuICAgIH07XG4gIH07XG59XG5cbnR5cGUgTW9yZURldGFpbHNSZXNwb25zZSA9IHtcbiAgYm9keToge1xuICAgIGZpZWxkczogW1xuICAgICAgW1xuICAgICAgICB7XG4gICAgICAgICAgUmVjb3JkczogW1xuICAgICAgICAgICAge1xuICAgICAgICAgICAgICBGaWVsZHM6IEFycmF5PHtcbiAgICAgICAgICAgICAgICBMYWJlbDogc3RyaW5nO1xuICAgICAgICAgICAgICAgIFZhbHVlOiBzdHJpbmc7XG4gICAgICAgICAgICAgIH0+O1xuICAgICAgICAgICAgfSxcbiAgICAgICAgICBdO1xuICAgICAgICB9LFxuICAgICAgXSxcbiAgICBdO1xuICB9O1xufTtcblxudHlwZSBNb3JlRGV0YWlscyA9IHtcbiAgZW50cmllczogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcbiAgbWVtbzogc3RyaW5nIHwgdW5kZWZpbmVkO1xufTtcblxuY29uc3QgQkFTRV9XRUJTSVRFX1VSTCA9ICdodHRwczovL3d3dy5taXpyYWhpLXRlZmFob3QuY28uaWwnO1xuY29uc3QgTE9HSU5fVVJMID0gYCR7QkFTRV9XRUJTSVRFX1VSTH0vbG9naW4vaW5kZXguaHRtbCMvYXV0aC1wYWdlLWhlYDtcbmNvbnN0IEJBU0VfQVBQX1VSTCA9ICdodHRwczovL210by5taXpyYWhpLXRlZmFob3QuY28uaWwnO1xuY29uc3QgQUZURVJfTE9HSU5fQkFTRV9VUkwgPSAvaHR0cHM6XFwvXFwvbXRvXFwubWl6cmFoaS10ZWZhaG90XFwuY29cXC5pbFxcL09ubGluZUFwcFxcLy4qLztcbmNvbnN0IE9TSF9QQUdFID0gJy9vc2gvbGVnYWN5L2xlZ2FjeS1Pc2gtTWFpbic7XG5jb25zdCBUUkFOU0FDVElPTlNfUEFHRSA9ICcvb3NoL2xlZ2FjeS9yb290LW1haW4tb3NoLXA0MjhOZXcnO1xuY29uc3QgVFJBTlNBQ1RJT05TX1JFUVVFU1RfVVJMUyA9IFtcbiAgYCR7QkFTRV9BUFBfVVJMfS9PbmxpbmVQaWxvdC9hcGkvU2t5T1NIL2dldDQyOEluZGV4YCxcbiAgYCR7QkFTRV9BUFBfVVJMfS9PbmxpbmUvYXBpL1NreU9TSC9nZXQ0MjhJbmRleGAsXG5dO1xuY29uc3QgUEVORElOR19UUkFOU0FDVElPTlNfUEFHRSA9ICcvb3NoL2xlZ2FjeS9sZWdhY3ktT3NoLXA0MjAnO1xuY29uc3QgUEVORElOR19UUkFOU0FDVElPTlNfSUZSQU1FID0gJ3A0MjAuYXNweCc7XG5jb25zdCBNT1JFX0RFVEFJTFNfVVJMID0gYCR7QkFTRV9BUFBfVVJMfS9PbmxpbmUvYXBpL09TSC9nZXRNYWhlckJlcnVyaW1TTUZgO1xuY29uc3QgQ0hBTkdFX1BBU1NXT1JEX1VSTCA9IC9odHRwczpcXC9cXC93d3dcXC5taXpyYWhpLXRlZmFob3RcXC5jb1xcLmlsXFwvbG9naW5cXC9pbmRleFxcLmh0bWwjXFwvY2hhbmdlLXBhc3MvO1xuY29uc3QgREFURV9GT1JNQVQgPSAnREQvTU0vWVlZWSc7XG5jb25zdCBNQVhfUk9XU19QRVJfUkVRVUVTVCA9IDEwMDAwMDAwMDAwO1xuXG5jb25zdCB1c2VybmFtZVNlbGVjdG9yID0gJyN1c2VyTnVtYmVyRGVza3RvcEhlYic7XG5jb25zdCBwYXNzd29yZFNlbGVjdG9yID0gJyNwYXNzd29yZERlc2t0b3BIZWInO1xuY29uc3Qgc3VibWl0QnV0dG9uU2VsZWN0b3IgPSAnYnV0dG9uLmJ0bi5idG4tcHJpbWFyeSc7XG5jb25zdCBpbnZhbGlkUGFzc3dvcmRTZWxlY3RvciA9ICdhW2hyZWYqPVwiaHR0cHM6Ly9zYy5taXpyYWhpLXRlZmFob3QuY28uaWwvU0NTZXJ2aWNlcy9TQy9QMDEwLmFzcHhcIl0nO1xuY29uc3QgYWZ0ZXJMb2dpblNlbGVjdG9yID0gJyNkcm9wZG93bkJhc2ljJztcbmNvbnN0IGxvZ2luU3Bpbm5lclNlbGVjdG9yID0gJ2Rpdi5uZ3gtb3ZlcmxheS5sb2FkaW5nLWZvcmVncm91bmQnO1xuY29uc3QgYWNjb3VudERyb3BEb3duSXRlbVNlbGVjdG9yID0gJyNBY2NvdW50UGlja2VyIC5pdGVtJztcbmNvbnN0IHBlbmRpbmdUcnhJZGVudGlmaWVySWQgPSAnI2N0bDAwX0NvbnRlbnRQbGFjZUhvbGRlcjJfcGFuZWwxJztcbmNvbnN0IGNoZWNraW5nQWNjb3VudFRhYkhlYnJld05hbWUgPSAn16LXldeR16gg15XXqdeRJztcbmNvbnN0IGNoZWNraW5nQWNjb3VudFRhYkVuZ2xpc2hOYW1lID0gJ0NoZWNraW5nIEFjY291bnQnO1xuY29uc3QgZ2VuZXJpY0Rlc2NyaXB0aW9ucyA9IFsn15TXoteR16jXqiDXmdeV157XnyDXnNeR16DXpyDXlteoINee16HXoNeZ16Mg15bXqCddO1xuXG5mdW5jdGlvbiBjcmVhdGVMb2dpbkZpZWxkcyhjcmVkZW50aWFsczogU2NyYXBlclNwZWNpZmljQ3JlZGVudGlhbHMpIHtcbiAgcmV0dXJuIFtcbiAgICB7IHNlbGVjdG9yOiB1c2VybmFtZVNlbGVjdG9yLCB2YWx1ZTogY3JlZGVudGlhbHMudXNlcm5hbWUgfSxcbiAgICB7IHNlbGVjdG9yOiBwYXNzd29yZFNlbGVjdG9yLCB2YWx1ZTogY3JlZGVudGlhbHMucGFzc3dvcmQgfSxcbiAgXTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gaXNMb2dnZWRJbihvcHRpb25zOiB7IHBhZ2U/OiBQYWdlIHwgdW5kZWZpbmVkIH0gfCB1bmRlZmluZWQpIHtcbiAgaWYgKCFvcHRpb25zPy5wYWdlKSB7XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG4gIGNvbnN0IG9zaFhQYXRoID0gYC8vYS8vc3Bhbltjb250YWlucyguLCBcIiR7Y2hlY2tpbmdBY2NvdW50VGFiSGVicmV3TmFtZX1cIikgb3IgY29udGFpbnMoLiwgXCIke2NoZWNraW5nQWNjb3VudFRhYkVuZ2xpc2hOYW1lfVwiKV1gO1xuICBjb25zdCBvc2hUYWIgPSBhd2FpdCBvcHRpb25zLnBhZ2UuJCQoYHhwYXRoJHtvc2hYUGF0aH1gKTtcbiAgcmV0dXJuIG9zaFRhYi5sZW5ndGggPiAwO1xufVxuXG5mdW5jdGlvbiBnZXRQb3NzaWJsZUxvZ2luUmVzdWx0cyhwYWdlOiBQYWdlKTogUG9zc2libGVMb2dpblJlc3VsdHMge1xuICByZXR1cm4ge1xuICAgIFtMb2dpblJlc3VsdHMuU3VjY2Vzc106IFtBRlRFUl9MT0dJTl9CQVNFX1VSTCwgaXNMb2dnZWRJbl0sXG4gICAgW0xvZ2luUmVzdWx0cy5JbnZhbGlkUGFzc3dvcmRdOiBbYXN5bmMgKCkgPT4gISEoYXdhaXQgcGFnZS4kKGludmFsaWRQYXNzd29yZFNlbGVjdG9yKSldLFxuICAgIFtMb2dpblJlc3VsdHMuQ2hhbmdlUGFzc3dvcmRdOiBbQ0hBTkdFX1BBU1NXT1JEX1VSTF0sXG4gIH07XG59XG5cbmZ1bmN0aW9uIGdldFN0YXJ0TW9tZW50KG9wdGlvbnNTdGFydERhdGU6IERhdGUpIHtcbiAgY29uc3QgZGVmYXVsdFN0YXJ0TW9tZW50ID0gbW9tZW50KCkuc3VidHJhY3QoMSwgJ3llYXJzJyk7XG4gIGNvbnN0IHN0YXJ0RGF0ZSA9IG9wdGlvbnNTdGFydERhdGUgfHwgZGVmYXVsdFN0YXJ0TW9tZW50LnRvRGF0ZSgpO1xuICByZXR1cm4gbW9tZW50Lm1heChkZWZhdWx0U3RhcnRNb21lbnQsIG1vbWVudChzdGFydERhdGUpKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZ2V0RXh0cmFUcmFuc2FjdGlvbkRldGFpbHMoXG4gIHBhZ2U6IFBhZ2UsXG4gIGl0ZW06IFNjcmFwZWRUcmFuc2FjdGlvbixcbiAgYXBpSGVhZGVyczogUmVjb3JkPHN0cmluZywgc3RyaW5nPixcbik6IFByb21pc2U8TW9yZURldGFpbHM+IHtcbiAgdHJ5IHtcbiAgICBkZWJ1ZygnZ2V0RXh0cmFUcmFuc2FjdGlvbkRldGFpbHMgZm9yIGl0ZW06JywgaXRlbSk7XG4gICAgaWYgKGl0ZW0uTUMwMlNob3dEZXRhaWxzRVogPT09ICcxJykge1xuICAgICAgY29uc3QgdGFyUGV1bGEgPSBtb21lbnQoaXRlbS5NQzAyUGV1bGFUYWFFWik7XG4gICAgICBjb25zdCB0YXJFcmVjaCA9IG1vbWVudChpdGVtLk1DMDJFcmVoVGFhRVopO1xuXG4gICAgICBjb25zdCBwYXJhbXMgPSB7XG4gICAgICAgIGluS29kR29yZW06IGl0ZW0uTUMwMktvZEdvcmVtRVosXG4gICAgICAgIGluQXNtYWNodGE6IGl0ZW0uTUMwMkFzbWFodGFNZWtvcml0RVosXG4gICAgICAgIGluU2NodW06IGl0ZW0uTUMwMlNjaHVtRVosXG4gICAgICAgIGluTmFrdmFuaXQ6IGl0ZW0uTUMwMktvZEdvcmVtRVosXG4gICAgICAgIGluU3VnVG51YTogaXRlbS5NQzAyU3VnVG51YUthc3BpdEVaLFxuICAgICAgICBpbkFnaWQ6IGl0ZW0uTUMwMkFnaWRFWixcbiAgICAgICAgaW5UYXJQZXVsYUZvcm1hdHRlZDogdGFyUGV1bGEuZm9ybWF0KERBVEVfRk9STUFUKSxcbiAgICAgICAgaW5UYXJFcmVjaEZvcm1hdHRlZDogKHRhckVyZWNoLnllYXIoKSA+IDIwMDAgPyB0YXJFcmVjaCA6IHRhclBldWxhKS5mb3JtYXQoREFURV9GT1JNQVQpLFxuICAgICAgICBpbktvZE5vc2U6IGl0ZW0uTUMwMlNlaWZNYXJhbEVaLFxuICAgICAgICBpbktvZFRhdE5vc2U6IGl0ZW0uTUMwMk5vc2VNYXJhbEVaLFxuICAgICAgICBpblRyYW5zYWN0aW9uTnVtYmVyOiBpdGVtLlRyYW5zYWN0aW9uTnVtYmVyLFxuICAgICAgfTtcblxuICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBmZXRjaFBvc3RXaXRoaW5QYWdlPE1vcmVEZXRhaWxzUmVzcG9uc2U+KHBhZ2UsIE1PUkVfREVUQUlMU19VUkwsIHBhcmFtcywgYXBpSGVhZGVycyk7XG4gICAgICBjb25zdCBkZXRhaWxzID0gcmVzcG9uc2U/LmJvZHkuZmllbGRzPy5bMF0/LlswXT8uUmVjb3Jkcz8uWzBdLkZpZWxkcztcbiAgICAgIGRlYnVnKCdmZXRjaCBkZXRhaWxzIGZvcicsIHBhcmFtcywgJ2RldGFpbHM6JywgZGV0YWlscyk7XG4gICAgICBpZiAoQXJyYXkuaXNBcnJheShkZXRhaWxzKSAmJiBkZXRhaWxzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgY29uc3QgZW50cmllcyA9IGRldGFpbHMubWFwKHJlY29yZCA9PiBbcmVjb3JkLkxhYmVsLnRyaW0oKSwgcmVjb3JkLlZhbHVlLnRyaW0oKV0pO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIGVudHJpZXM6IE9iamVjdC5mcm9tRW50cmllcyhlbnRyaWVzKSxcbiAgICAgICAgICBtZW1vOiBlbnRyaWVzXG4gICAgICAgICAgICAuZmlsdGVyKChbbGFiZWxdKSA9PiBbJ9ep150nLCAn157XlNeV16onLCAn15fXqdeR15XXnyddLnNvbWUoa2V5ID0+IGxhYmVsLnN0YXJ0c1dpdGgoa2V5KSkpXG4gICAgICAgICAgICAubWFwKChbbGFiZWwsIHZhbHVlXSkgPT4gYCR7bGFiZWx9ICR7dmFsdWV9YClcbiAgICAgICAgICAgIC5qb2luKCcsICcpLFxuICAgICAgICB9O1xuICAgICAgfVxuICAgIH1cbiAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICBkZWJ1ZygnRXJyb3IgZmV0Y2hpbmcgZXh0cmEgdHJhbnNhY3Rpb24gZGV0YWlsczonLCBlcnJvcik7XG4gIH1cblxuICByZXR1cm4ge1xuICAgIGVudHJpZXM6IHt9LFxuICAgIG1lbW86IHVuZGVmaW5lZCxcbiAgfTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlRGF0YUZyb21SZXF1ZXN0KHJlcXVlc3Q6IEhUVFBSZXF1ZXN0LCBvcHRpb25zU3RhcnREYXRlOiBEYXRlKSB7XG4gIGNvbnN0IGRhdGEgPSBKU09OLnBhcnNlKHJlcXVlc3QucG9zdERhdGEoKSB8fCAne30nKTtcblxuICBkYXRhLmluRnJvbURhdGUgPSBnZXRTdGFydE1vbWVudChvcHRpb25zU3RhcnREYXRlKS5mb3JtYXQoREFURV9GT1JNQVQpO1xuICBkYXRhLmluVG9EYXRlID0gbW9tZW50KCkuZm9ybWF0KERBVEVfRk9STUFUKTtcbiAgZGF0YS50YWJsZS5tYXhSb3cgPSBNQVhfUk9XU19QRVJfUkVRVUVTVDtcblxuICByZXR1cm4gZGF0YTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlSGVhZGVyc0Zyb21SZXF1ZXN0KHJlcXVlc3Q6IEhUVFBSZXF1ZXN0KSB7XG4gIHJldHVybiB7XG4gICAgbWl6cmFoaXhzcmZ0b2tlbjogcmVxdWVzdC5oZWFkZXJzKCkubWl6cmFoaXhzcmZ0b2tlbixcbiAgICAnQ29udGVudC1UeXBlJzogcmVxdWVzdC5oZWFkZXJzKClbJ2NvbnRlbnQtdHlwZSddLFxuICB9O1xufVxuXG5hc3luYyBmdW5jdGlvbiBjb252ZXJ0VHJhbnNhY3Rpb25zKFxuICB0eG5zOiBTY3JhcGVkVHJhbnNhY3Rpb25bXSxcbiAgZ2V0TW9yZURldGFpbHM6IChyb3c6IFNjcmFwZWRUcmFuc2FjdGlvbikgPT4gUHJvbWlzZTxNb3JlRGV0YWlscz4sXG4gIHBlbmRpbmdJZlRvZGF5VHJhbnNhY3Rpb246IGJvb2xlYW4gPSBmYWxzZSxcbik6IFByb21pc2U8VHJhbnNhY3Rpb25bXT4ge1xuICByZXR1cm4gUHJvbWlzZS5hbGwoXG4gICAgdHhucy5tYXAoYXN5bmMgcm93ID0+IHtcbiAgICAgIGNvbnN0IG1vcmVEZXRhaWxzID0gYXdhaXQgZ2V0TW9yZURldGFpbHMocm93KTtcblxuICAgICAgY29uc3QgdHhuRGF0ZSA9IG1vbWVudChyb3cuTUMwMlBldWxhVGFhRVosIG1vbWVudC5IVE1MNV9GTVQuREFURVRJTUVfTE9DQUxfU0VDT05EUykudG9JU09TdHJpbmcoKTtcblxuICAgICAgcmV0dXJuIHtcbiAgICAgICAgdHlwZTogVHJhbnNhY3Rpb25UeXBlcy5Ob3JtYWwsXG4gICAgICAgIGlkZW50aWZpZXI6IHJvdy5NQzAyQXNtYWh0YU1la29yaXRFWiA/IHBhcnNlSW50KHJvdy5NQzAyQXNtYWh0YU1la29yaXRFWiwgMTApIDogdW5kZWZpbmVkLFxuICAgICAgICBkYXRlOiB0eG5EYXRlLFxuICAgICAgICBwcm9jZXNzZWREYXRlOiB0eG5EYXRlLFxuICAgICAgICBvcmlnaW5hbEFtb3VudDogcm93Lk1DMDJTY2h1bUVaLFxuICAgICAgICBvcmlnaW5hbEN1cnJlbmN5OiBTSEVLRUxfQ1VSUkVOQ1ksXG4gICAgICAgIGNoYXJnZWRBbW91bnQ6IHJvdy5NQzAyU2NodW1FWixcbiAgICAgICAgZGVzY3JpcHRpb246IHJvdy5NQzAyVG51YVRldXJFWixcbiAgICAgICAgbWVtbzogbW9yZURldGFpbHM/Lm1lbW8sXG4gICAgICAgIHN0YXR1czpcbiAgICAgICAgICBwZW5kaW5nSWZUb2RheVRyYW5zYWN0aW9uICYmIHJvdy5Jc1RvZGF5VHJhbnNhY3Rpb25cbiAgICAgICAgICAgID8gVHJhbnNhY3Rpb25TdGF0dXNlcy5QZW5kaW5nXG4gICAgICAgICAgICA6IFRyYW5zYWN0aW9uU3RhdHVzZXMuQ29tcGxldGVkLFxuICAgICAgfTtcbiAgICB9KSxcbiAgKTtcbn1cblxuYXN5bmMgZnVuY3Rpb24gZXh0cmFjdFBlbmRpbmdUcmFuc2FjdGlvbnMocGFnZTogRnJhbWUpOiBQcm9taXNlPFRyYW5zYWN0aW9uW10+IHtcbiAgY29uc3QgcGVuZGluZ1R4biA9IGF3YWl0IHBhZ2VFdmFsQWxsKHBhZ2UsICd0ci5yZ1JvdywgdHIucmdBbHRSb3cnLCBbXSwgdHJzID0+IHtcbiAgICByZXR1cm4gdHJzLm1hcCh0ciA9PiBBcnJheS5mcm9tKHRyLnF1ZXJ5U2VsZWN0b3JBbGwoJ3RkJyksIHRkID0+IHRkLnRleHRDb250ZW50IHx8ICcnKSk7XG4gIH0pO1xuXG4gIHJldHVybiBwZW5kaW5nVHhuXG4gICAgLm1hcCgoW2RhdGVTdHIsIGRlc2NyaXB0aW9uLCBpbmNvbWVBbW91bnRTdHIsIGFtb3VudFN0cl0pID0+ICh7XG4gICAgICBkYXRlOiBtb21lbnQoZGF0ZVN0ciwgJ0REL01NL1lZJykudG9JU09TdHJpbmcoKSxcbiAgICAgIGFtb3VudDogcGFyc2VGbG9hdChhbW91bnRTdHIucmVwbGFjZUFsbCgnLCcsICcnKSksXG4gICAgICBkZXNjcmlwdGlvbixcbiAgICAgIGluY29tZUFtb3VudFN0ciwgLy8gVE9ETzogaGFuZGxlIGluY29tZUFtb3VudFN0ciBvbmNlIHdlIGtub3cgdGhlIHNpZ24gb2YgaXRcbiAgICB9KSlcbiAgICAuZmlsdGVyKHR4biA9PiB0eG4uZGF0ZSlcbiAgICAubWFwKCh7IGRhdGUsIGRlc2NyaXB0aW9uLCBhbW91bnQgfSkgPT4gKHtcbiAgICAgIHR5cGU6IFRyYW5zYWN0aW9uVHlwZXMuTm9ybWFsLFxuICAgICAgZGF0ZSxcbiAgICAgIHByb2Nlc3NlZERhdGU6IGRhdGUsXG4gICAgICBvcmlnaW5hbEFtb3VudDogYW1vdW50LFxuICAgICAgb3JpZ2luYWxDdXJyZW5jeTogU0hFS0VMX0NVUlJFTkNZLFxuICAgICAgY2hhcmdlZEFtb3VudDogYW1vdW50LFxuICAgICAgZGVzY3JpcHRpb24sXG4gICAgICBzdGF0dXM6IFRyYW5zYWN0aW9uU3RhdHVzZXMuUGVuZGluZyxcbiAgICB9KSk7XG59XG5cbmFzeW5jIGZ1bmN0aW9uIHBvc3RMb2dpbihwYWdlOiBQYWdlKSB7XG4gIGF3YWl0IFByb21pc2UucmFjZShbXG4gICAgd2FpdFVudGlsRWxlbWVudEZvdW5kKHBhZ2UsIGFmdGVyTG9naW5TZWxlY3RvciksXG4gICAgd2FpdFVudGlsRWxlbWVudEZvdW5kKHBhZ2UsIGludmFsaWRQYXNzd29yZFNlbGVjdG9yKSxcbiAgICB3YWl0Rm9yVXJsKHBhZ2UsIENIQU5HRV9QQVNTV09SRF9VUkwpLFxuICBdKTtcbn1cblxudHlwZSBTY3JhcGVyU3BlY2lmaWNDcmVkZW50aWFscyA9IHsgdXNlcm5hbWU6IHN0cmluZzsgcGFzc3dvcmQ6IHN0cmluZyB9O1xuXG5jbGFzcyBNaXpyYWhpU2NyYXBlciBleHRlbmRzIEJhc2VTY3JhcGVyV2l0aEJyb3dzZXI8U2NyYXBlclNwZWNpZmljQ3JlZGVudGlhbHM+IHtcbiAgZ2V0TG9naW5PcHRpb25zKGNyZWRlbnRpYWxzOiBTY3JhcGVyU3BlY2lmaWNDcmVkZW50aWFscykge1xuICAgIHJldHVybiB7XG4gICAgICBsb2dpblVybDogTE9HSU5fVVJMLFxuICAgICAgZmllbGRzOiBjcmVhdGVMb2dpbkZpZWxkcyhjcmVkZW50aWFscyksXG4gICAgICBzdWJtaXRCdXR0b25TZWxlY3RvcixcbiAgICAgIGNoZWNrUmVhZGluZXNzOiBhc3luYyAoKSA9PiB3YWl0VW50aWxFbGVtZW50RGlzYXBwZWFyKHRoaXMucGFnZSwgbG9naW5TcGlubmVyU2VsZWN0b3IpLFxuICAgICAgcG9zdEFjdGlvbjogYXN5bmMgKCkgPT4gcG9zdExvZ2luKHRoaXMucGFnZSksXG4gICAgICBwb3NzaWJsZVJlc3VsdHM6IGdldFBvc3NpYmxlTG9naW5SZXN1bHRzKHRoaXMucGFnZSksXG4gICAgfTtcbiAgfVxuXG4gIGFzeW5jIGZldGNoRGF0YSgpIHtcbiAgICBhd2FpdCB0aGlzLnBhZ2UuJGV2YWwoJyNkcm9wZG93bkJhc2ljLCAuaXRlbScsIGVsID0+IChlbCBhcyBIVE1MRWxlbWVudCkuY2xpY2soKSk7XG5cbiAgICBjb25zdCBudW1PZkFjY291bnRzID0gKGF3YWl0IHRoaXMucGFnZS4kJChhY2NvdW50RHJvcERvd25JdGVtU2VsZWN0b3IpKS5sZW5ndGg7XG5cbiAgICB0cnkge1xuICAgICAgY29uc3QgcmVzdWx0czogVHJhbnNhY3Rpb25zQWNjb3VudFtdID0gW107XG5cbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbnVtT2ZBY2NvdW50czsgaSArPSAxKSB7XG4gICAgICAgIGlmIChpID4gMCkge1xuICAgICAgICAgIGF3YWl0IHRoaXMucGFnZS4kZXZhbCgnI2Ryb3Bkb3duQmFzaWMsIC5pdGVtJywgZWwgPT4gKGVsIGFzIEhUTUxFbGVtZW50KS5jbGljaygpKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGF3YWl0IHRoaXMucGFnZS4kZXZhbChgJHthY2NvdW50RHJvcERvd25JdGVtU2VsZWN0b3J9Om50aC1jaGlsZCgke2kgKyAxfSlgLCBlbCA9PiAoZWwgYXMgSFRNTEVsZW1lbnQpLmNsaWNrKCkpO1xuICAgICAgICByZXN1bHRzLnB1c2goYXdhaXQgdGhpcy5mZXRjaEFjY291bnQoKSk7XG4gICAgICB9XG5cbiAgICAgIHJldHVybiB7XG4gICAgICAgIHN1Y2Nlc3M6IHRydWUsXG4gICAgICAgIGFjY291bnRzOiByZXN1bHRzLFxuICAgICAgfTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICByZXR1cm4ge1xuICAgICAgICBzdWNjZXNzOiBmYWxzZSxcbiAgICAgICAgZXJyb3JUeXBlOiBTY3JhcGVyRXJyb3JUeXBlcy5HZW5lcmljLFxuICAgICAgICBlcnJvck1lc3NhZ2U6IChlIGFzIEVycm9yKS5tZXNzYWdlLFxuICAgICAgfTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIGdldFBlbmRpbmdUcmFuc2FjdGlvbnMoKTogUHJvbWlzZTxUcmFuc2FjdGlvbltdPiB7XG4gICAgYXdhaXQgdGhpcy5wYWdlLiRldmFsKGBhW2hyZWYqPVwiJHtQRU5ESU5HX1RSQU5TQUNUSU9OU19QQUdFfVwiXWAsIGVsID0+IChlbCBhcyBIVE1MRWxlbWVudCkuY2xpY2soKSk7XG4gICAgY29uc3QgZnJhbWUgPSBhd2FpdCB3YWl0VW50aWxJZnJhbWVGb3VuZCh0aGlzLnBhZ2UsIGYgPT4gZi51cmwoKS5pbmNsdWRlcyhQRU5ESU5HX1RSQU5TQUNUSU9OU19JRlJBTUUpKTtcbiAgICBjb25zdCBpc1BlbmRpbmcgPSBhd2FpdCB3YWl0VW50aWxFbGVtZW50Rm91bmQoZnJhbWUsIHBlbmRpbmdUcnhJZGVudGlmaWVySWQpXG4gICAgICAudGhlbigoKSA9PiB0cnVlKVxuICAgICAgLmNhdGNoKCgpID0+IGZhbHNlKTtcbiAgICBpZiAoIWlzUGVuZGluZykge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cblxuICAgIGNvbnN0IHBlbmRpbmdUeG4gPSBhd2FpdCBleHRyYWN0UGVuZGluZ1RyYW5zYWN0aW9ucyhmcmFtZSk7XG4gICAgcmV0dXJuIHBlbmRpbmdUeG47XG4gIH1cblxuICBwcml2YXRlIGFzeW5jIGZldGNoQWNjb3VudCgpIHtcbiAgICBhd2FpdCB0aGlzLnBhZ2Uud2FpdEZvclNlbGVjdG9yKGBhW2hyZWYqPVwiJHtPU0hfUEFHRX1cIl1gKTtcbiAgICBhd2FpdCB0aGlzLnBhZ2UuJGV2YWwoYGFbaHJlZio9XCIke09TSF9QQUdFfVwiXWAsIGVsID0+IChlbCBhcyBIVE1MRWxlbWVudCkuY2xpY2soKSk7XG4gICAgYXdhaXQgd2FpdFVudGlsRWxlbWVudEZvdW5kKHRoaXMucGFnZSwgYGFbaHJlZio9XCIke1RSQU5TQUNUSU9OU19QQUdFfVwiXWApO1xuICAgIGF3YWl0IHRoaXMucGFnZS4kZXZhbChgYVtocmVmKj1cIiR7VFJBTlNBQ1RJT05TX1BBR0V9XCJdYCwgZWwgPT4gKGVsIGFzIEhUTUxFbGVtZW50KS5jbGljaygpKTtcblxuICAgIGNvbnN0IGFjY291bnROdW1iZXJFbGVtZW50ID0gYXdhaXQgdGhpcy5wYWdlLiQoJyNkcm9wZG93bkJhc2ljIGIgc3BhbicpO1xuICAgIGNvbnN0IGFjY291bnROdW1iZXJIYW5kbGUgPSBhd2FpdCBhY2NvdW50TnVtYmVyRWxlbWVudD8uZ2V0UHJvcGVydHkoJ3RpdGxlJyk7XG4gICAgY29uc3QgYWNjb3VudE51bWJlciA9IChhd2FpdCBhY2NvdW50TnVtYmVySGFuZGxlPy5qc29uVmFsdWUoKSkgYXMgc3RyaW5nO1xuICAgIGlmICghYWNjb3VudE51bWJlcikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdBY2NvdW50IG51bWJlciBub3QgZm91bmQnKTtcbiAgICB9XG5cbiAgICBjb25zdCBbcmVzcG9uc2UsIGFwaUhlYWRlcnNdID0gYXdhaXQgUHJvbWlzZS5hbnkoXG4gICAgICBUUkFOU0FDVElPTlNfUkVRVUVTVF9VUkxTLm1hcChhc3luYyB1cmwgPT4ge1xuICAgICAgICBjb25zdCByZXF1ZXN0ID0gYXdhaXQgdGhpcy5wYWdlLndhaXRGb3JSZXF1ZXN0KHVybCk7XG4gICAgICAgIGNvbnN0IGRhdGEgPSBjcmVhdGVEYXRhRnJvbVJlcXVlc3QocmVxdWVzdCwgdGhpcy5vcHRpb25zLnN0YXJ0RGF0ZSk7XG4gICAgICAgIGNvbnN0IGhlYWRlcnMgPSBjcmVhdGVIZWFkZXJzRnJvbVJlcXVlc3QocmVxdWVzdCk7XG5cbiAgICAgICAgcmV0dXJuIFthd2FpdCBmZXRjaFBvc3RXaXRoaW5QYWdlPFNjcmFwZWRUcmFuc2FjdGlvbnNSZXN1bHQ+KHRoaXMucGFnZSwgdXJsLCBkYXRhLCBoZWFkZXJzKSwgaGVhZGVyc10gYXMgY29uc3Q7XG4gICAgICB9KSxcbiAgICApO1xuXG4gICAgaWYgKCFyZXNwb25zZSB8fCByZXNwb25zZS5oZWFkZXIuc3VjY2VzcyA9PT0gZmFsc2UpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYEVycm9yIGZldGNoaW5nIHRyYW5zYWN0aW9uLiBSZXNwb25zZSBtZXNzYWdlOiAke3Jlc3BvbnNlID8gcmVzcG9uc2UuaGVhZGVyLm1lc3NhZ2VzWzBdLnRleHQgOiAnJ31gLFxuICAgICAgKTtcbiAgICB9XG5cbiAgICBjb25zdCByZWxldmFudFJvd3MgPSByZXNwb25zZS5ib2R5LnRhYmxlLnJvd3MuZmlsdGVyKHJvdyA9PiByb3cuUmVjVHlwZVNwZWNpZmllZCk7XG4gICAgY29uc3Qgb3NoVHhuID0gYXdhaXQgY29udmVydFRyYW5zYWN0aW9ucyhcbiAgICAgIHJlbGV2YW50Um93cyxcbiAgICAgIHRoaXMub3B0aW9ucy5hZGRpdGlvbmFsVHJhbnNhY3Rpb25JbmZvcm1hdGlvblxuICAgICAgICA/IHJvdyA9PiBnZXRFeHRyYVRyYW5zYWN0aW9uRGV0YWlscyh0aGlzLnBhZ2UsIHJvdywgYXBpSGVhZGVycylcbiAgICAgICAgOiAoKSA9PiBQcm9taXNlLnJlc29sdmUoeyBlbnRyaWVzOiB7fSwgbWVtbzogdW5kZWZpbmVkIH0pLFxuICAgICAgdGhpcy5vcHRpb25zLm9wdEluRmVhdHVyZXM/LmluY2x1ZGVzKCdtaXpyYWhpOnBlbmRpbmdJZlRvZGF5VHJhbnNhY3Rpb24nKSxcbiAgICApO1xuXG4gICAgb3NoVHhuXG4gICAgICAuZmlsdGVyKHR4biA9PiB0aGlzLnNob3VsZE1hcmtBc1BlbmRpbmcodHhuKSlcbiAgICAgIC5mb3JFYWNoKHR4biA9PiB7XG4gICAgICAgIHR4bi5zdGF0dXMgPSBUcmFuc2FjdGlvblN0YXR1c2VzLlBlbmRpbmc7XG4gICAgICB9KTtcblxuICAgIC8vIHdvcmthcm91bmQgZm9yIGEgYnVnIHdoaWNoIHRoZSBiYW5rJ3MgQVBJIHJldHVybnMgdHJhbnNhY3Rpb25zIGJlZm9yZSB0aGUgcmVxdWVzdGVkIHN0YXJ0IGRhdGVcbiAgICBjb25zdCBzdGFydE1vbWVudCA9IGdldFN0YXJ0TW9tZW50KHRoaXMub3B0aW9ucy5zdGFydERhdGUpO1xuICAgIGNvbnN0IG9zaFR4bkFmdGVyU3RhcnREYXRlID0gb3NoVHhuLmZpbHRlcih0eG4gPT4gbW9tZW50KHR4bi5kYXRlKS5pc1NhbWVPckFmdGVyKHN0YXJ0TW9tZW50KSk7XG5cbiAgICBjb25zdCBwZW5kaW5nVHhuID0gYXdhaXQgdGhpcy5nZXRQZW5kaW5nVHJhbnNhY3Rpb25zKCk7XG4gICAgY29uc3QgYWxsVHhuID0gb3NoVHhuQWZ0ZXJTdGFydERhdGUuY29uY2F0KHBlbmRpbmdUeG4pO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIGFjY291bnROdW1iZXIsXG4gICAgICB0eG5zOiBhbGxUeG4sXG4gICAgICBiYWxhbmNlOiArcmVzcG9uc2UuYm9keS5maWVsZHM/LllpdHJhLFxuICAgIH07XG4gIH1cblxuICBwcml2YXRlIHNob3VsZE1hcmtBc1BlbmRpbmcodHhuOiBUcmFuc2FjdGlvbik6IGJvb2xlYW4ge1xuICAgIGlmICh0aGlzLm9wdGlvbnMub3B0SW5GZWF0dXJlcz8uaW5jbHVkZXMoJ21penJhaGk6cGVuZGluZ0lmTm9JZGVudGlmaWVyJykgJiYgIXR4bi5pZGVudGlmaWVyKSB7XG4gICAgICBkZWJ1ZyhgTWFya2luZyB0cmFuc2FjdGlvbiAnJHt0eG4uZGVzY3JpcHRpb259JyBhcyBwZW5kaW5nIGR1ZSB0byBubyBpZGVudGlmaWVyLmApO1xuICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxuXG4gICAgaWYgKFxuICAgICAgdGhpcy5vcHRpb25zLm9wdEluRmVhdHVyZXM/LmluY2x1ZGVzKCdtaXpyYWhpOnBlbmRpbmdJZkhhc0dlbmVyaWNEZXNjcmlwdGlvbicpICYmXG4gICAgICBnZW5lcmljRGVzY3JpcHRpb25zLmluY2x1ZGVzKHR4bi5kZXNjcmlwdGlvbilcbiAgICApIHtcbiAgICAgIGRlYnVnKGBNYXJraW5nIHRyYW5zYWN0aW9uICcke3R4bi5kZXNjcmlwdGlvbn0nIGFzIHBlbmRpbmcgZHVlIHRvIGdlbmVyaWMgZGVzY3JpcHRpb24uYCk7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgTWl6cmFoaVNjcmFwZXI7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLE9BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBLElBQUFDLFVBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLHFCQUFBLEdBQUFGLE9BQUE7QUFNQSxJQUFBRyxNQUFBLEdBQUFILE9BQUE7QUFDQSxJQUFBSSxXQUFBLEdBQUFKLE9B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
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+
3
+ var _mizrahi = _interopRequireDefault(require("./mizrahi"));
4
+ var _testsUtils = require("../tests/tests-utils");
5
+ var _definitions = require("../definitions");
6
+ var _constants = require("../constants");
7
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
8
+ var _debug = _interopRequireDefault(require("debug"));
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
10
+ _debug.default.enable('israeli-bank-scrapers:mizrahi');
11
+ const COMPANY_ID = 'mizrahi'; // TODO this property should be hard-coded in the provider
12
+ const testsConfig = (0, _testsUtils.getTestsConfig)();
13
+ describe('Mizrahi scraper', () => {
14
+ beforeAll(() => {
15
+ (0, _testsUtils.extendAsyncTimeout)(); // The default timeout is 5 seconds per async test, this function extends the timeout value
16
+ });
17
+ test('should expose login fields in scrapers constant', () => {
18
+ expect(_definitions.SCRAPERS.mizrahi).toBeDefined();
19
+ expect(_definitions.SCRAPERS.mizrahi.loginFields).toContain('username');
20
+ expect(_definitions.SCRAPERS.mizrahi.loginFields).toContain('password');
21
+ });
22
+ (0, _testsUtils.maybeTestCompanyAPI)(COMPANY_ID, config => config.companyAPI.invalidPassword)('should fail on invalid user/password', async () => {
23
+ const options = {
24
+ ...testsConfig.options,
25
+ companyId: COMPANY_ID
26
+ };
27
+ const scraper = new _mizrahi.default(options);
28
+ const result = await scraper.scrape({
29
+ username: 'e10s12',
30
+ password: '3f3ss3d'
31
+ });
32
+ expect(result).toBeDefined();
33
+ expect(result.success).toBeFalsy();
34
+ expect(result.errorType).toBe(_baseScraperWithBrowser.LoginResults.InvalidPassword);
35
+ });
36
+ (0, _testsUtils.maybeTestCompanyAPI)(COMPANY_ID)('should scrape transactions', async () => {
37
+ const options = {
38
+ ...testsConfig.options,
39
+ optInFeatures: ['mizrahi:pendingIfHasGenericDescription', 'mizrahi:pendingIfHasGenericDescriptionWithDate', 'mizrahi:pendingIfTodayTransaction'],
40
+ companyId: COMPANY_ID
41
+ };
42
+ const scraper = new _mizrahi.default(options);
43
+ const result = await scraper.scrape(testsConfig.credentials.mizrahi);
44
+ expect(result).toBeDefined();
45
+ const error = `${result.errorType || ''} ${result.errorMessage || ''}`.trim();
46
+ expect(error).toBe('');
47
+ expect(result.success).toBeTruthy();
48
+ expect(result.accounts).toBeDefined();
49
+ expect(result.accounts.length).toBeGreaterThan(0);
50
+ const account = result.accounts[0];
51
+ expect(account.accountNumber).not.toBe('');
52
+ expect(account.txns[0].date).toMatch(_constants.ISO_DATE_REGEX);
53
+ (0, _testsUtils.exportTransactions)(COMPANY_ID, result.accounts || []);
54
+ });
55
+ });
56
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbWl6cmFoaSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX3Rlc3RzVXRpbHMiLCJfZGVmaW5pdGlvbnMiLCJfY29uc3RhbnRzIiwiX2Jhc2VTY3JhcGVyV2l0aEJyb3dzZXIiLCJfZGVidWciLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJkZWJ1ZyIsImVuYWJsZSIsIkNPTVBBTllfSUQiLCJ0ZXN0c0NvbmZpZyIsImdldFRlc3RzQ29uZmlnIiwiZGVzY3JpYmUiLCJiZWZvcmVBbGwiLCJleHRlbmRBc3luY1RpbWVvdXQiLCJ0ZXN0IiwiZXhwZWN0IiwiU0NSQVBFUlMiLCJtaXpyYWhpIiwidG9CZURlZmluZWQiLCJsb2dpbkZpZWxkcyIsInRvQ29udGFpbiIsIm1heWJlVGVzdENvbXBhbnlBUEkiLCJjb25maWciLCJjb21wYW55QVBJIiwiaW52YWxpZFBhc3N3b3JkIiwib3B0aW9ucyIsImNvbXBhbnlJZCIsInNjcmFwZXIiLCJNaXpyYWhpU2NyYXBlciIsInJlc3VsdCIsInNjcmFwZSIsInVzZXJuYW1lIiwicGFzc3dvcmQiLCJzdWNjZXNzIiwidG9CZUZhbHN5IiwiZXJyb3JUeXBlIiwidG9CZSIsIkxvZ2luUmVzdWx0cyIsIkludmFsaWRQYXNzd29yZCIsIm9wdEluRmVhdHVyZXMiLCJjcmVkZW50aWFscyIsImVycm9yIiwiZXJyb3JNZXNzYWdlIiwidHJpbSIsInRvQmVUcnV0aHkiLCJhY2NvdW50cyIsImxlbmd0aCIsInRvQmVHcmVhdGVyVGhhbiIsImFjY291bnQiLCJhY2NvdW50TnVtYmVyIiwibm90IiwidHhucyIsImRhdGUiLCJ0b01hdGNoIiwiSVNPX0RBVEVfUkVHRVgiLCJleHBvcnRUcmFuc2FjdGlvbnMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvc2NyYXBlcnMvbWl6cmFoaS50ZXN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBNaXpyYWhpU2NyYXBlciBmcm9tICcuL21penJhaGknO1xuaW1wb3J0IHsgbWF5YmVUZXN0Q29tcGFueUFQSSwgZXh0ZW5kQXN5bmNUaW1lb3V0LCBnZXRUZXN0c0NvbmZpZywgZXhwb3J0VHJhbnNhY3Rpb25zIH0gZnJvbSAnLi4vdGVzdHMvdGVzdHMtdXRpbHMnO1xuaW1wb3J0IHsgU0NSQVBFUlMgfSBmcm9tICcuLi9kZWZpbml0aW9ucyc7XG5pbXBvcnQgeyBJU09fREFURV9SRUdFWCB9IGZyb20gJy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBMb2dpblJlc3VsdHMgfSBmcm9tICcuL2Jhc2Utc2NyYXBlci13aXRoLWJyb3dzZXInO1xuaW1wb3J0IHsgdHlwZSBUcmFuc2FjdGlvbnNBY2NvdW50IH0gZnJvbSAnLi4vdHJhbnNhY3Rpb25zJztcbmltcG9ydCBkZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgeyB0eXBlIFNjcmFwZXJPcHRpb25zIH0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuXG5kZWJ1Zy5lbmFibGUoJ2lzcmFlbGktYmFuay1zY3JhcGVyczptaXpyYWhpJyk7XG5cbmNvbnN0IENPTVBBTllfSUQgPSAnbWl6cmFoaSc7IC8vIFRPRE8gdGhpcyBwcm9wZXJ0eSBzaG91bGQgYmUgaGFyZC1jb2RlZCBpbiB0aGUgcHJvdmlkZXJcbmNvbnN0IHRlc3RzQ29uZmlnID0gZ2V0VGVzdHNDb25maWcoKTtcblxuZGVzY3JpYmUoJ01penJhaGkgc2NyYXBlcicsICgpID0+IHtcbiAgYmVmb3JlQWxsKCgpID0+IHtcbiAgICBleHRlbmRBc3luY1RpbWVvdXQoKTsgLy8gVGhlIGRlZmF1bHQgdGltZW91dCBpcyA1IHNlY29uZHMgcGVyIGFzeW5jIHRlc3QsIHRoaXMgZnVuY3Rpb24gZXh0ZW5kcyB0aGUgdGltZW91dCB2YWx1ZVxuICB9KTtcblxuICB0ZXN0KCdzaG91bGQgZXhwb3NlIGxvZ2luIGZpZWxkcyBpbiBzY3JhcGVycyBjb25zdGFudCcsICgpID0+IHtcbiAgICBleHBlY3QoU0NSQVBFUlMubWl6cmFoaSkudG9CZURlZmluZWQoKTtcbiAgICBleHBlY3QoU0NSQVBFUlMubWl6cmFoaS5sb2dpbkZpZWxkcykudG9Db250YWluKCd1c2VybmFtZScpO1xuICAgIGV4cGVjdChTQ1JBUEVSUy5taXpyYWhpLmxvZ2luRmllbGRzKS50b0NvbnRhaW4oJ3Bhc3N3b3JkJyk7XG4gIH0pO1xuXG4gIG1heWJlVGVzdENvbXBhbnlBUEkoQ09NUEFOWV9JRCwgY29uZmlnID0+IGNvbmZpZy5jb21wYW55QVBJLmludmFsaWRQYXNzd29yZCkoXG4gICAgJ3Nob3VsZCBmYWlsIG9uIGludmFsaWQgdXNlci9wYXNzd29yZCcsXG4gICAgYXN5bmMgKCkgPT4ge1xuICAgICAgY29uc3Qgb3B0aW9ucyA9IHtcbiAgICAgICAgLi4udGVzdHNDb25maWcub3B0aW9ucyxcbiAgICAgICAgY29tcGFueUlkOiBDT01QQU5ZX0lELFxuICAgICAgfTtcblxuICAgICAgY29uc3Qgc2NyYXBlciA9IG5ldyBNaXpyYWhpU2NyYXBlcihvcHRpb25zKTtcblxuICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgc2NyYXBlci5zY3JhcGUoeyB1c2VybmFtZTogJ2UxMHMxMicsIHBhc3N3b3JkOiAnM2Yzc3MzZCcgfSk7XG5cbiAgICAgIGV4cGVjdChyZXN1bHQpLnRvQmVEZWZpbmVkKCk7XG4gICAgICBleHBlY3QocmVzdWx0LnN1Y2Nlc3MpLnRvQmVGYWxzeSgpO1xuICAgICAgZXhwZWN0KHJlc3VsdC5lcnJvclR5cGUpLnRvQmUoTG9naW5SZXN1bHRzLkludmFsaWRQYXNzd29yZCk7XG4gICAgfSxcbiAgKTtcblxuICBtYXliZVRlc3RDb21wYW55QVBJKENPTVBBTllfSUQpKCdzaG91bGQgc2NyYXBlIHRyYW5zYWN0aW9ucycsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBvcHRpb25zOiBTY3JhcGVyT3B0aW9ucyA9IHtcbiAgICAgIC4uLnRlc3RzQ29uZmlnLm9wdGlvbnMsXG4gICAgICBvcHRJbkZlYXR1cmVzOiBbXG4gICAgICAgICdtaXpyYWhpOnBlbmRpbmdJZkhhc0dlbmVyaWNEZXNjcmlwdGlvbicsXG4gICAgICAgICdtaXpyYWhpOnBlbmRpbmdJZkhhc0dlbmVyaWNEZXNjcmlwdGlvbldpdGhEYXRlJyxcbiAgICAgICAgJ21penJhaGk6cGVuZGluZ0lmVG9kYXlUcmFuc2FjdGlvbicsXG4gICAgICBdLFxuICAgICAgY29tcGFueUlkOiBDT01QQU5ZX0lELFxuICAgIH07XG5cbiAgICBjb25zdCBzY3JhcGVyID0gbmV3IE1penJhaGlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHNjcmFwZXIuc2NyYXBlKHRlc3RzQ29uZmlnLmNyZWRlbnRpYWxzLm1penJhaGkpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvQmVEZWZpbmVkKCk7XG4gICAgY29uc3QgZXJyb3IgPSBgJHtyZXN1bHQuZXJyb3JUeXBlIHx8ICcnfSAke3Jlc3VsdC5lcnJvck1lc3NhZ2UgfHwgJyd9YC50cmltKCk7XG4gICAgZXhwZWN0KGVycm9yKS50b0JlKCcnKTtcbiAgICBleHBlY3QocmVzdWx0LnN1Y2Nlc3MpLnRvQmVUcnV0aHkoKTtcbiAgICBleHBlY3QocmVzdWx0LmFjY291bnRzKS50b0JlRGVmaW5lZCgpO1xuICAgIGV4cGVjdCgocmVzdWx0LmFjY291bnRzIGFzIGFueSkubGVuZ3RoKS50b0JlR3JlYXRlclRoYW4oMCk7XG4gICAgY29uc3QgYWNjb3VudDogVHJhbnNhY3Rpb25zQWNjb3VudCA9IChyZXN1bHQgYXMgYW55KS5hY2NvdW50c1swXTtcbiAgICBleHBlY3QoYWNjb3VudC5hY2NvdW50TnVtYmVyKS5ub3QudG9CZSgnJyk7XG4gICAgZXhwZWN0KGFjY291bnQudHhuc1swXS5kYXRlKS50b01hdGNoKElTT19EQVRFX1JFR0VYKTtcblxuICAgIGV4cG9ydFRyYW5zYWN0aW9ucyhDT01QQU5ZX0lELCByZXN1bHQuYWNjb3VudHMgfHwgW10pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLElBQUFBLFFBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElB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
@@ -0,0 +1,2 @@
1
+ export declare const GET_CUSTOMER = "\nquery GetCustomer {\n customer {\n __typename\n customerId\n userId\n idType\n idNumber\n hebrewFirstName\n hebrewLastName\n latinFirstName\n latinLastName\n dateOfBirth\n lastLoginDate\n userEmail\n gender\n portfolioRelations {\n __typename\n customerId\n customerRole\n portfolioId\n initiator\n relationToInitiator\n status\n }\n portfolios {\n __typename\n ...Portfolio\n }\n status\n }\n}\nfragment Portfolio on Portfolio {\n __typename\n accounts {\n __typename\n accountId\n accountType\n closingDate\n currency\n openingDate\n status\n subType\n }\n activationDate\n bank\n baseCurrency\n branch\n club\n clubDescription\n iban\n imageURL\n isJointAccount\n partnerName {\n __typename\n partnerFirstName\n partnerLastName\n }\n portfolioId\n portfolioNum\n portfolioType\n status\n subType\n onboardingCompleted\n}\n";
2
+ export declare const GET_MOVEMENTS = "query GetMovements(\n $portfolioId: String!\n $accountId: String!\n $pagination: PaginationInput!\n $language: BffLanguage!\n) {\n movements(\n portfolioId: $portfolioId\n accountId: $accountId\n pagination: $pagination\n language: $language\n ) {\n __typename\n ...MovementsFragment\n }\n}\nfragment TransactionInstrumentAmountFragment on TransactionInstrumentAmount {\n __typename\n instrumentAmount\n instrumentSymbol\n instrumentType\n}\nfragment CounterPartyReferenceFragment on CounterPartyReference {\n __typename\n bankId\n bic\n branchCode\n id\n name\n type\n}\nfragment BaseTransactionFragment on BaseTransaction {\n __typename\n accountId\n betweenOwnAccounts\n bookDate\n calculatedStatus\n chargeAmount {\n __typename\n ...TransactionInstrumentAmountFragment\n }\n clearingSystem\n counterParty {\n __typename\n ...CounterPartyReferenceFragment\n }\n currentPaymentNumber\n direction\n domainType\n isReversal\n method\n originalAmount {\n __typename\n ...TransactionInstrumentAmountFragment\n }\n portfolioId\n totalPaymentsCount\n transactionId\n transactionType\n valueDate\n}\nfragment CategoryFragment on Category {\n __typename\n categoryId\n dataSource\n subCategoryId\n}\nfragment RecurrenceFragment on Recurrence {\n __typename\n dataSource\n isRecurrent\n}\nfragment TransactionEnrichmentFragment on TransactionEnrichment {\n __typename\n categories {\n __typename\n ...CategoryFragment\n }\n recurrences {\n __typename\n ...RecurrenceFragment\n }\n}\nfragment TransactionEventMetadataFragment on TransactionEventMetadata {\n __typename\n correlationId\n processingOrder\n}\nfragment CounterPartyTransferData on CounterPartyTransfer {\n __typename\n accountId\n bank_id\n branch_code\n counter_party_name\n}\nfragment BankTransferDetailsData on BankTransferDetails {\n __typename\n ... on CashBlockTransfer {\n counterParty {\n __typename\n ...CounterPartyTransferData\n }\n transferDescriptionKey\n }\n ... on RTGSReturnTransfer {\n transferDescriptionKey\n }\n ... on RTGSTransfer {\n transferDescriptionKey\n }\n ... on SwiftReturnTransfer {\n transferConversionRate\n transferDescriptionKey\n }\n ... on SwiftTransfer {\n transferConversionRate\n transferDescriptionKey\n }\n ... on Transfer {\n counterParty {\n __typename\n ...CounterPartyTransferData\n }\n transferDescriptionKey\n }\n}\nfragment CategoryData on Category {\n __typename\n categoryId\n dataSource\n subCategoryId\n}\nfragment RecurrenceData on Recurrence {\n __typename\n dataSource\n isRecurrent\n}\nfragment CardDetailsData on CardDetails {\n __typename\n ... on CardCharge {\n book_date\n cardDescriptionKey\n }\n ... on CardChargeFCY {\n book_date\n cardConversionRate\n cardDescriptionKey\n cardFCYAmount\n cardFCYCurrency\n }\n ... on CardMonthlySettlement {\n cardDescriptionKey\n }\n ... on CardRefund {\n cardDescriptionKey\n }\n ... on CashBlockCardCharge {\n cardDescriptionKey\n }\n}\nfragment CashDetailsData on CashDetails {\n __typename\n ... on CashWithdrawal {\n cashDescriptionKey\n }\n ... on CashWithdrawalFCY {\n FCYAmount\n FCYCurrency\n cashDescriptionKey\n conversionRate\n }\n}\nfragment ChequesDetailsData on ChequesDetails {\n __typename\n ... on CashBlockChequeDeposit {\n bookDate\n chequesDescriptionKey\n }\n ... on ChequeDeposit {\n bookDate\n chequesDescriptionKey\n }\n ... on ChequeReturn {\n bookDate\n chequeReturnReason\n chequesDescriptionKey\n }\n ... on ChequeWithdrawal {\n chequesDescriptionKey\n }\n}\nfragment DefaultDetailsData on DefaultDetails {\n __typename\n ... on DefaultWithTransaction {\n defaultDescriptionKey\n }\n ... on DefaultWithoutTransaction {\n categories {\n __typename\n ...CategoryData\n }\n defaultDescriptionKey\n }\n}\nfragment FeeDetailsData on FeeDetails {\n __typename\n ... on GeneralFee {\n feeDescriptionKey\n }\n}\nfragment LoanDetailsData on LoanDetails {\n __typename\n ... on FullPrePayment {\n loanDescriptionKey\n }\n ... on Initiate {\n loanDescriptionKey\n }\n ... on MonthlyPayment {\n loanDescriptionKey\n loanPaymentNumber\n loanTotalPaymentsCount\n }\n ... on PartialPrePayment {\n loanDescriptionKey\n }\n}\nfragment MandateDetailsData on MandateDetails {\n __typename\n ... on MandatePayment {\n mandateDescriptionKey\n }\n ... on MandateReturnPayment {\n mandateDescriptionKey\n }\n}\nfragment SavingsDetailsData on SavingsDetails {\n __typename\n ... on FullSavingsWithdrawal {\n savingsDescriptionKey\n }\n ... on MonthlySavingsDeposit {\n savingsDepositNumber\n savingsDescriptionKey\n savingsTotalDepositCount\n }\n ... on PartialSavingsWithdrawal {\n savingsDescriptionKey\n }\n ... on SavingsClosing {\n savingsDescriptionKey\n }\n ... on SavingsDeposit {\n savingsDescriptionKey\n }\n ... on SavingsInterest {\n savingsDescriptionKey\n }\n ... on SavingsPenalty {\n savingsDescriptionKey\n }\n ... on SavingsTax {\n savingsDescriptionKey\n }\n}\nfragment SubscriptionDetailsData on SubscriptionDetails {\n __typename\n ... on SubscriptionPayment {\n subscriptionDescriptionKey\n }\n ... on SubscriptionReturnPayment {\n subscriptionDescriptionKey\n }\n}\nfragment TransactionsDetailsData on TransactionDetails {\n __typename\n ... on BankTransfer {\n bank_transfer_details {\n __typename\n ...BankTransferDetailsData\n }\n book_date\n categories {\n __typename\n ...CategoryData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Card {\n card_details {\n __typename\n ...CardDetailsData\n }\n categories {\n __typename\n ...CategoryData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Cash {\n cash_details {\n __typename\n ...CashDetailsData\n }\n categories {\n __typename\n ...CategoryData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Cheques {\n categories {\n __typename\n ...CategoryData\n }\n chequesDetails {\n __typename\n ...ChequesDetailsData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n valueDate\n referenceNumber\n frontImageUrl\n backImageUrl\n }\n ... on Default {\n default_details {\n __typename\n ...DefaultDetailsData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Fee {\n categories {\n __typename\n ...CategoryData\n }\n fee_details {\n __typename\n ...FeeDetailsData\n }\n value_date\n }\n ... on Loans {\n categories {\n __typename\n ...CategoryData\n }\n loan_details {\n __typename\n ...LoanDetailsData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Mandate {\n categories {\n __typename\n ...CategoryData\n }\n mandate_details {\n __typename\n ...MandateDetailsData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n value_date\n }\n ... on Savings {\n categories {\n __typename\n ...CategoryData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n savings_details {\n __typename\n ...SavingsDetailsData\n }\n value_date\n }\n ... on SubscriptionTransaction {\n categories {\n __typename\n ...CategoryData\n }\n recurrences {\n __typename\n ...RecurrenceData\n }\n subscription_details {\n __typename\n ...SubscriptionDetailsData\n }\n value_date\n }\n}\nfragment TransactionFragment on Transaction {\n __typename\n baseTransaction {\n __typename\n ...BaseTransactionFragment\n }\n enrichment {\n __typename\n ...TransactionEnrichmentFragment\n }\n metadata {\n __typename\n ...TransactionEventMetadataFragment\n }\n referenceNumber\n transactionDetails {\n __typename\n ...TransactionsDetailsData\n }\n}\nfragment MovementFragment on Movement {\n __typename\n accountId\n bankCurrencyAmount\n bookingDate\n conversionRate\n creditDebit\n description\n isReversed\n linkTransaction {\n __typename\n ...TransactionFragment\n }\n movementAmount\n movementCurrency\n movementId\n movementReversedId\n movementTimestamp\n movementType\n portfolioId\n runningBalance\n transaction {\n __typename\n ...TransactionFragment\n }\n valueDate\n}\nfragment PaginationFragment on Pagination {\n __typename\n cursor\n hasMore\n}\nfragment MovementsFragment on Movements {\n __typename\n isRunningBalanceInSync\n movements {\n __typename\n ...MovementFragment\n }\n pagination {\n __typename\n ...PaginationFragment\n }\n}";