@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,324 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _lodash = _interopRequireDefault(require("lodash"));
8
+ var _moment = _interopRequireDefault(require("moment"));
9
+ var _constants = require("../constants");
10
+ var _definitions = require("../definitions");
11
+ var _dates = _interopRequireDefault(require("../helpers/dates"));
12
+ var _debug = require("../helpers/debug");
13
+ var _fetch = require("../helpers/fetch");
14
+ var _transactions = require("../helpers/transactions");
15
+ var _waiting = require("../helpers/waiting");
16
+ var _transactions2 = require("../transactions");
17
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
18
+ var _errors = require("./errors");
19
+ var _browser = require("../helpers/browser");
20
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
21
+ const RATE_LIMIT = {
22
+ SLEEP_BETWEEN: 1000,
23
+ TRANSACTIONS_BATCH_SIZE: 10
24
+ };
25
+ const COUNTRY_CODE = '212';
26
+ const ID_TYPE = '1';
27
+ const INSTALLMENTS_KEYWORD = 'תשלום';
28
+ const DATE_FORMAT = 'DD/MM/YYYY';
29
+ const debug = (0, _debug.getDebug)('base-isracard-amex');
30
+ function getAccountsUrl(servicesUrl, monthMoment) {
31
+ const billingDate = monthMoment.format('YYYY-MM-DD');
32
+ const url = new URL(servicesUrl);
33
+ url.searchParams.set('reqName', 'DashboardMonth');
34
+ url.searchParams.set('actionCode', '0');
35
+ url.searchParams.set('billingDate', billingDate);
36
+ url.searchParams.set('format', 'Json');
37
+ return url.toString();
38
+ }
39
+ async function fetchAccounts(page, servicesUrl, monthMoment) {
40
+ const dataUrl = getAccountsUrl(servicesUrl, monthMoment);
41
+ debug(`fetching accounts from ${dataUrl}`);
42
+ const dataResult = await (0, _fetch.fetchGetWithinPage)(page, dataUrl);
43
+ if (dataResult && _lodash.default.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {
44
+ const {
45
+ cardsCharges
46
+ } = dataResult.DashboardMonthBean;
47
+ if (cardsCharges) {
48
+ return cardsCharges.map(cardCharge => {
49
+ return {
50
+ index: parseInt(cardCharge.cardIndex, 10),
51
+ accountNumber: cardCharge.cardNumber,
52
+ processedDate: (0, _moment.default)(cardCharge.billingDate, DATE_FORMAT).toISOString()
53
+ };
54
+ });
55
+ }
56
+ }
57
+ return [];
58
+ }
59
+ function getTransactionsUrl(servicesUrl, monthMoment) {
60
+ const month = monthMoment.month() + 1;
61
+ const year = monthMoment.year();
62
+ const monthStr = month < 10 ? `0${month}` : month.toString();
63
+ const url = new URL(servicesUrl);
64
+ url.searchParams.set('reqName', 'CardsTransactionsList');
65
+ url.searchParams.set('month', monthStr);
66
+ url.searchParams.set('year', `${year}`);
67
+ url.searchParams.set('requiredDate', 'N');
68
+ return url.toString();
69
+ }
70
+ function convertCurrency(currencyStr) {
71
+ if (currencyStr === _constants.SHEKEL_CURRENCY_KEYWORD || currencyStr === _constants.ALT_SHEKEL_CURRENCY) {
72
+ return _constants.SHEKEL_CURRENCY;
73
+ }
74
+ return currencyStr;
75
+ }
76
+ function getInstallmentsInfo(txn) {
77
+ if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {
78
+ return undefined;
79
+ }
80
+ const matches = txn.moreInfo.match(/\d+/g);
81
+ if (!matches || matches.length < 2) {
82
+ return undefined;
83
+ }
84
+ return {
85
+ number: parseInt(matches[0], 10),
86
+ total: parseInt(matches[1], 10)
87
+ };
88
+ }
89
+ function getTransactionType(txn) {
90
+ return getInstallmentsInfo(txn) ? _transactions2.TransactionTypes.Installments : _transactions2.TransactionTypes.Normal;
91
+ }
92
+ function convertTransactions(txns, processedDate) {
93
+ const filteredTxns = txns.filter(txn => txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000');
94
+ return filteredTxns.map(txn => {
95
+ const isOutbound = txn.dealSumOutbound;
96
+ const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;
97
+ const txnMoment = (0, _moment.default)(txnDateStr, DATE_FORMAT);
98
+ const currentProcessedDate = txn.fullPaymentDate ? (0, _moment.default)(txn.fullPaymentDate, DATE_FORMAT).toISOString() : processedDate;
99
+ const result = {
100
+ type: getTransactionType(txn),
101
+ identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),
102
+ date: txnMoment.toISOString(),
103
+ processedDate: currentProcessedDate,
104
+ originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,
105
+ originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),
106
+ chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,
107
+ chargedCurrency: convertCurrency(txn.currencyId),
108
+ description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,
109
+ memo: txn.moreInfo || '',
110
+ installments: getInstallmentsInfo(txn) || undefined,
111
+ status: _transactions2.TransactionStatuses.Completed
112
+ };
113
+ return result;
114
+ });
115
+ }
116
+ async function fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment) {
117
+ const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);
118
+ const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);
119
+ await (0, _waiting.sleep)(RATE_LIMIT.SLEEP_BETWEEN);
120
+ debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);
121
+ const dataResult = await (0, _fetch.fetchGetWithinPage)(page, dataUrl);
122
+ if (dataResult && _lodash.default.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {
123
+ const accountTxns = {};
124
+ accounts.forEach(account => {
125
+ const txnGroups = _lodash.default.get(dataResult, `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`);
126
+ if (txnGroups) {
127
+ let allTxns = [];
128
+ txnGroups.forEach(txnGroup => {
129
+ if (txnGroup.txnIsrael) {
130
+ const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);
131
+ allTxns.push(...txns);
132
+ }
133
+ if (txnGroup.txnAbroad) {
134
+ const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);
135
+ allTxns.push(...txns);
136
+ }
137
+ });
138
+ if (!options.combineInstallments) {
139
+ allTxns = (0, _transactions.fixInstallments)(allTxns);
140
+ }
141
+ if (options.outputData?.enableTransactionsFilterByDate ?? true) {
142
+ allTxns = (0, _transactions.filterOldTransactions)(allTxns, startMoment, options.combineInstallments || false);
143
+ }
144
+ accountTxns[account.accountNumber] = {
145
+ accountNumber: account.accountNumber,
146
+ index: account.index,
147
+ txns: allTxns
148
+ };
149
+ }
150
+ });
151
+ return accountTxns;
152
+ }
153
+ return {};
154
+ }
155
+ async function getExtraScrapTransaction(page, options, month, accountIndex, transaction) {
156
+ const url = new URL(options.servicesUrl);
157
+ url.searchParams.set('reqName', 'PirteyIska_204');
158
+ url.searchParams.set('CardIndex', accountIndex.toString());
159
+ url.searchParams.set('shovarRatz', transaction.identifier.toString());
160
+ url.searchParams.set('moedChiuv', month.format('MMYYYY'));
161
+ debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);
162
+ const data = await (0, _fetch.fetchGetWithinPage)(page, url.toString());
163
+ if (!data) {
164
+ return transaction;
165
+ }
166
+ const rawCategory = _lodash.default.get(data, 'PirteyIska_204Bean.sector') ?? '';
167
+ return {
168
+ ...transaction,
169
+ category: rawCategory.trim()
170
+ };
171
+ }
172
+ async function getExtraScrapAccount(page, options, accountMap, month) {
173
+ const accounts = [];
174
+ for (const account of Object.values(accountMap)) {
175
+ debug(`get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`, month.format('YYYY-MM'));
176
+ const txns = [];
177
+ for (const txnsChunk of _lodash.default.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {
178
+ debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);
179
+ const updatedTxns = await Promise.all(txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)));
180
+ await (0, _waiting.sleep)(RATE_LIMIT.SLEEP_BETWEEN);
181
+ txns.push(...updatedTxns);
182
+ }
183
+ accounts.push({
184
+ ...account,
185
+ txns
186
+ });
187
+ }
188
+ return accounts.reduce((m, x) => ({
189
+ ...m,
190
+ [x.accountNumber]: x
191
+ }), {});
192
+ }
193
+ async function getAdditionalTransactionInformation(scraperOptions, accountsWithIndex, page, options, allMonths) {
194
+ if (!scraperOptions.additionalTransactionInformation || scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')) {
195
+ return accountsWithIndex;
196
+ }
197
+ return (0, _waiting.runSerial)(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));
198
+ }
199
+ async function fetchAllTransactions(page, options, companyServiceOptions, startMoment) {
200
+ const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;
201
+ const allMonths = (0, _dates.default)(startMoment, futureMonthsToScrape);
202
+ const results = await (0, _waiting.runSerial)(allMonths.map(monthMoment => () => {
203
+ return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);
204
+ }));
205
+ const finalResult = await getAdditionalTransactionInformation(options, results, page, companyServiceOptions, allMonths);
206
+ const combinedTxns = {};
207
+ finalResult.forEach(result => {
208
+ Object.keys(result).forEach(accountNumber => {
209
+ let txnsForAccount = combinedTxns[accountNumber];
210
+ if (!txnsForAccount) {
211
+ txnsForAccount = [];
212
+ combinedTxns[accountNumber] = txnsForAccount;
213
+ }
214
+ const toBeAddedTxns = result[accountNumber].txns;
215
+ combinedTxns[accountNumber].push(...toBeAddedTxns);
216
+ });
217
+ });
218
+ const accounts = Object.keys(combinedTxns).map(accountNumber => {
219
+ return {
220
+ accountNumber,
221
+ txns: combinedTxns[accountNumber]
222
+ };
223
+ });
224
+ return {
225
+ success: true,
226
+ accounts
227
+ };
228
+ }
229
+ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
230
+ constructor(options, baseUrl, companyCode) {
231
+ super(options);
232
+ this.baseUrl = baseUrl;
233
+ this.companyCode = companyCode;
234
+ this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;
235
+ }
236
+ async login(credentials) {
237
+ await this.page.setRequestInterception(true);
238
+ this.page.on('request', request => {
239
+ if (request.url().includes('detector-dom.min.js')) {
240
+ debug('force abort for request do download detector-dom.min.js resource');
241
+ void request.abort(undefined, _browser.interceptionPriorities.abort);
242
+ } else {
243
+ void request.continue(undefined, _browser.interceptionPriorities.continue);
244
+ }
245
+ });
246
+ await (0, _browser.maskHeadlessUserAgent)(this.page);
247
+ await this.navigateTo(`${this.baseUrl}/personalarea/Login`);
248
+ this.emitProgress(_definitions.ScraperProgressTypes.LoggingIn);
249
+ const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;
250
+ const validateRequest = {
251
+ id: credentials.id,
252
+ cardSuffix: credentials.card6Digits,
253
+ countryCode: COUNTRY_CODE,
254
+ idType: ID_TYPE,
255
+ checkLevel: '1',
256
+ companyCode: this.companyCode
257
+ };
258
+ debug('logging in with validate request');
259
+ const validateResult = await (0, _fetch.fetchPostWithinPage)(this.page, validateUrl, validateRequest);
260
+ if (!validateResult || !validateResult.Header || validateResult.Header.Status !== '1' || !validateResult.ValidateIdDataBean) {
261
+ throw new Error('unknown error during login');
262
+ }
263
+ const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;
264
+ debug(`user validate with return code '${validateReturnCode}'`);
265
+ if (validateReturnCode === '1') {
266
+ const {
267
+ userName
268
+ } = validateResult.ValidateIdDataBean;
269
+ const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;
270
+ const request = {
271
+ KodMishtamesh: userName,
272
+ MisparZihuy: credentials.id,
273
+ Sisma: credentials.password,
274
+ cardSuffix: credentials.card6Digits,
275
+ countryCode: COUNTRY_CODE,
276
+ idType: ID_TYPE
277
+ };
278
+ debug('user login started');
279
+ const loginResult = await (0, _fetch.fetchPostWithinPage)(this.page, loginUrl, request);
280
+ debug(`user login with status '${loginResult?.status}'`, loginResult);
281
+ if (loginResult && loginResult.status === '1') {
282
+ this.emitProgress(_definitions.ScraperProgressTypes.LoginSuccess);
283
+ return {
284
+ success: true
285
+ };
286
+ }
287
+ if (loginResult && loginResult.status === '3') {
288
+ this.emitProgress(_definitions.ScraperProgressTypes.ChangePassword);
289
+ return {
290
+ success: false,
291
+ errorType: _errors.ScraperErrorTypes.ChangePassword
292
+ };
293
+ }
294
+ this.emitProgress(_definitions.ScraperProgressTypes.LoginFailed);
295
+ return {
296
+ success: false,
297
+ errorType: _errors.ScraperErrorTypes.InvalidPassword
298
+ };
299
+ }
300
+ if (validateReturnCode === '4') {
301
+ this.emitProgress(_definitions.ScraperProgressTypes.ChangePassword);
302
+ return {
303
+ success: false,
304
+ errorType: _errors.ScraperErrorTypes.ChangePassword
305
+ };
306
+ }
307
+ this.emitProgress(_definitions.ScraperProgressTypes.LoginFailed);
308
+ return {
309
+ success: false,
310
+ errorType: _errors.ScraperErrorTypes.InvalidPassword
311
+ };
312
+ }
313
+ async fetchData() {
314
+ const defaultStartMoment = (0, _moment.default)().subtract(1, 'years');
315
+ const startDate = this.options.startDate || defaultStartMoment.toDate();
316
+ const startMoment = _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
317
+ return fetchAllTransactions(this.page, this.options, {
318
+ servicesUrl: this.servicesUrl,
319
+ companyCode: this.companyCode
320
+ }, startMoment);
321
+ }
322
+ }
323
+ var _default = exports.default = IsracardAmexBaseScraper;
324
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_constants","_definitions","_dates","_debug","_fetch","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_errors","_browser","e","__esModule","default","RATE_LIMIT","SLEEP_BETWEEN","TRANSACTIONS_BATCH_SIZE","COUNTRY_CODE","ID_TYPE","INSTALLMENTS_KEYWORD","DATE_FORMAT","debug","getDebug","getAccountsUrl","servicesUrl","monthMoment","billingDate","format","url","URL","searchParams","set","toString","fetchAccounts","page","dataUrl","dataResult","fetchGetWithinPage","_","get","DashboardMonthBean","cardsCharges","map","cardCharge","index","parseInt","cardIndex","accountNumber","cardNumber","processedDate","moment","toISOString","getTransactionsUrl","month","year","monthStr","convertCurrency","currencyStr","SHEKEL_CURRENCY_KEYWORD","ALT_SHEKEL_CURRENCY","SHEKEL_CURRENCY","getInstallmentsInfo","txn","moreInfo","includes","undefined","matches","match","length","number","total","getTransactionType","TransactionTypes","Installments","Normal","convertTransactions","txns","filteredTxns","filter","dealSumType","voucherNumberRatz","voucherNumberRatzOutbound","isOutbound","dealSumOutbound","txnDateStr","fullPurchaseDateOutbound","fullPurchaseDate","txnMoment","currentProcessedDate","fullPaymentDate","result","type","identifier","date","originalAmount","dealSum","originalCurrency","currentPaymentCurrency","currencyId","chargedAmount","paymentSumOutbound","paymentSum","chargedCurrency","description","fullSupplierNameOutbound","fullSupplierNameHeb","memo","installments","status","TransactionStatuses","Completed","fetchTransactions","options","companyServiceOptions","startMoment","accounts","sleep","CardsTransactionsListBean","accountTxns","forEach","account","txnGroups","allTxns","txnGroup","txnIsrael","push","txnAbroad","combineInstallments","fixInstallments","outputData","enableTransactionsFilterByDate","filterOldTransactions","getExtraScrapTransaction","accountIndex","transaction","data","rawCategory","category","trim","getExtraScrapAccount","accountMap","Object","values","txnsChunk","chunk","updatedTxns","Promise","all","t","reduce","m","x","getAdditionalTransactionInformation","scraperOptions","accountsWithIndex","allMonths","additionalTransactionInformation","optInFeatures","runSerial","a","i","fetchAllTransactions","futureMonthsToScrape","getAllMonthMoments","results","finalResult","combinedTxns","keys","txnsForAccount","toBeAddedTxns","success","IsracardAmexBaseScraper","BaseScraperWithBrowser","constructor","baseUrl","companyCode","login","credentials","setRequestInterception","on","request","abort","interceptionPriorities","continue","maskHeadlessUserAgent","navigateTo","emitProgress","ScraperProgressTypes","LoggingIn","validateUrl","validateRequest","id","cardSuffix","card6Digits","countryCode","idType","checkLevel","validateResult","fetchPostWithinPage","Header","Status","ValidateIdDataBean","Error","validateReturnCode","returnCode","userName","loginUrl","KodMishtamesh","MisparZihuy","Sisma","password","loginResult","LoginSuccess","ChangePassword","errorType","ScraperErrorTypes","LoginFailed","InvalidPassword","fetchData","defaultStartMoment","subtract","startDate","toDate","max","_default","exports"],"sources":["../../src/scrapers/base-isracard-amex.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer';\nimport { ALT_SHEKEL_CURRENCY, SHEKEL_CURRENCY, SHEKEL_CURRENCY_KEYWORD } from '../constants';\nimport { ScraperProgressTypes } from '../definitions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { getDebug } from '../helpers/debug';\nimport { fetchGetWithinPage, fetchPostWithinPage } from '../helpers/fetch';\nimport { filterOldTransactions, fixInstallments } from '../helpers/transactions';\nimport { runSerial, sleep } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionInstallments,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\nimport { interceptionPriorities, maskHeadlessUserAgent } from '../helpers/browser';\n\nconst RATE_LIMIT = {\n  SLEEP_BETWEEN: 1000,\n  TRANSACTIONS_BATCH_SIZE: 10,\n} as const;\n\nconst COUNTRY_CODE = '212';\nconst ID_TYPE = '1';\nconst INSTALLMENTS_KEYWORD = 'תשלום';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst debug = getDebug('base-isracard-amex');\n\ntype CompanyServiceOptions = {\n  servicesUrl: string;\n  companyCode: string;\n};\n\ntype ScrapedAccountsWithIndex = Record<string, TransactionsAccount & { index: number }>;\n\ninterface ScrapedTransaction {\n  dealSumType: string;\n  voucherNumberRatzOutbound: string;\n  voucherNumberRatz: string;\n  moreInfo?: string;\n  dealSumOutbound: boolean;\n  currencyId: string;\n  currentPaymentCurrency: string;\n  dealSum: number;\n  fullPaymentDate?: string;\n  fullPurchaseDate?: string;\n  fullPurchaseDateOutbound?: string;\n  fullSupplierNameHeb: string;\n  fullSupplierNameOutbound: string;\n  paymentSum: number;\n  paymentSumOutbound: number;\n}\n\ninterface ScrapedAccount {\n  index: number;\n  accountNumber: string;\n  processedDate: string;\n}\n\ninterface ScrapedLoginValidation {\n  Header: {\n    Status: string;\n  };\n  ValidateIdDataBean?: {\n    userName?: string;\n    returnCode: string;\n  };\n}\n\ninterface ScrapedAccountsWithinPageResponse {\n  Header: {\n    Status: string;\n  };\n  DashboardMonthBean?: {\n    cardsCharges: {\n      cardIndex: string;\n      cardNumber: string;\n      billingDate: string;\n    }[];\n  };\n}\n\ninterface ScrapedCurrentCardTransactions {\n  txnIsrael?: ScrapedTransaction[];\n  txnAbroad?: ScrapedTransaction[];\n}\n\ninterface ScrapedTransactionData {\n  Header?: {\n    Status: string;\n  };\n  PirteyIska_204Bean?: {\n    sector: string;\n  };\n\n  CardsTransactionsListBean?: Record<\n    string,\n    {\n      CurrentCardTransactions: ScrapedCurrentCardTransactions[];\n    }\n  >;\n}\n\nfunction getAccountsUrl(servicesUrl: string, monthMoment: Moment) {\n  const billingDate = monthMoment.format('YYYY-MM-DD');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'DashboardMonth');\n  url.searchParams.set('actionCode', '0');\n  url.searchParams.set('billingDate', billingDate);\n  url.searchParams.set('format', 'Json');\n  return url.toString();\n}\n\nasync function fetchAccounts(page: Page, servicesUrl: string, monthMoment: Moment): Promise<ScrapedAccount[]> {\n  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);\n  debug(`fetching accounts from ${dataUrl}`);\n  const dataResult = await fetchGetWithinPage<ScrapedAccountsWithinPageResponse>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {\n    const { cardsCharges } = dataResult.DashboardMonthBean;\n    if (cardsCharges) {\n      return cardsCharges.map(cardCharge => {\n        return {\n          index: parseInt(cardCharge.cardIndex, 10),\n          accountNumber: cardCharge.cardNumber,\n          processedDate: moment(cardCharge.billingDate, DATE_FORMAT).toISOString(),\n        };\n      });\n    }\n  }\n  return [];\n}\n\nfunction getTransactionsUrl(servicesUrl: string, monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const monthStr = month < 10 ? `0${month}` : month.toString();\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'CardsTransactionsList');\n  url.searchParams.set('month', monthStr);\n  url.searchParams.set('year', `${year}`);\n  url.searchParams.set('requiredDate', 'N');\n  return url.toString();\n}\n\nfunction convertCurrency(currencyStr: string) {\n  if (currencyStr === SHEKEL_CURRENCY_KEYWORD || currencyStr === ALT_SHEKEL_CURRENCY) {\n    return SHEKEL_CURRENCY;\n  }\n  return currencyStr;\n}\n\nfunction getInstallmentsInfo(txn: ScrapedTransaction): TransactionInstallments | undefined {\n  if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {\n    return undefined;\n  }\n  const matches = txn.moreInfo.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\n\nfunction getTransactionType(txn: ScrapedTransaction) {\n  return getInstallmentsInfo(txn) ? TransactionTypes.Installments : TransactionTypes.Normal;\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], processedDate: string): Transaction[] {\n  const filteredTxns = txns.filter(\n    txn =>\n      txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000',\n  );\n\n  return filteredTxns.map(txn => {\n    const isOutbound = txn.dealSumOutbound;\n    const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;\n    const txnMoment = moment(txnDateStr, DATE_FORMAT);\n\n    const currentProcessedDate = txn.fullPaymentDate\n      ? moment(txn.fullPaymentDate, DATE_FORMAT).toISOString()\n      : processedDate;\n    const result: Transaction = {\n      type: getTransactionType(txn),\n      identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),\n      date: txnMoment.toISOString(),\n      processedDate: currentProcessedDate,\n      originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,\n      originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),\n      chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,\n      chargedCurrency: convertCurrency(txn.currencyId),\n      description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,\n      memo: txn.moreInfo || '',\n      installments: getInstallmentsInfo(txn) || undefined,\n      status: TransactionStatuses.Completed,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n  monthMoment: Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);\n  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);\n  await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n  debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);\n  const dataResult = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {\n    const accountTxns: ScrapedAccountsWithIndex = {};\n    accounts.forEach(account => {\n      const txnGroups: ScrapedCurrentCardTransactions[] | undefined = _.get(\n        dataResult,\n        `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`,\n      );\n      if (txnGroups) {\n        let allTxns: Transaction[] = [];\n        txnGroups.forEach(txnGroup => {\n          if (txnGroup.txnIsrael) {\n            const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);\n            allTxns.push(...txns);\n          }\n        });\n\n        if (!options.combineInstallments) {\n          allTxns = fixInstallments(allTxns);\n        }\n        if (options.outputData?.enableTransactionsFilterByDate ?? true) {\n          allTxns = filterOldTransactions(allTxns, startMoment, options.combineInstallments || false);\n        }\n        accountTxns[account.accountNumber] = {\n          accountNumber: account.accountNumber,\n          index: account.index,\n          txns: allTxns,\n        };\n      }\n    });\n    return accountTxns;\n  }\n\n  return {};\n}\n\nasync function getExtraScrapTransaction(\n  page: Page,\n  options: CompanyServiceOptions,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): Promise<Transaction> {\n  const url = new URL(options.servicesUrl);\n  url.searchParams.set('reqName', 'PirteyIska_204');\n  url.searchParams.set('CardIndex', accountIndex.toString());\n  url.searchParams.set('shovarRatz', transaction.identifier!.toString());\n  url.searchParams.set('moedChiuv', month.format('MMYYYY'));\n\n  debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);\n  const data = await fetchGetWithinPage<ScrapedTransactionData>(page, url.toString());\n  if (!data) {\n    return transaction;\n  }\n\n  const rawCategory = _.get(data, 'PirteyIska_204Bean.sector') ?? '';\n  return {\n    ...transaction,\n    category: rawCategory.trim(),\n  };\n}\n\nasync function getExtraScrapAccount(\n  page: Page,\n  options: CompanyServiceOptions,\n  accountMap: ScrapedAccountsWithIndex,\n  month: moment.Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts: ScrapedAccountsWithIndex[string][] = [];\n  for (const account of Object.values(accountMap)) {\n    debug(\n      `get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`,\n      month.format('YYYY-MM'),\n    );\n    const txns: Transaction[] = [];\n    for (const txnsChunk of _.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {\n      debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);\n      const updatedTxns = await Promise.all(\n        txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)),\n      );\n      await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n      txns.push(...updatedTxns);\n    }\n    accounts.push({ ...account, txns });\n  }\n\n  return accounts.reduce((m, x) => ({ ...m, [x.accountNumber]: x }), {});\n}\n\nasync function getAdditionalTransactionInformation(\n  scraperOptions: ScraperOptions,\n  accountsWithIndex: ScrapedAccountsWithIndex[],\n  page: Page,\n  options: CompanyServiceOptions,\n  allMonths: moment.Moment[],\n): Promise<ScrapedAccountsWithIndex[]> {\n  if (\n    !scraperOptions.additionalTransactionInformation ||\n    scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')\n  ) {\n    return accountsWithIndex;\n  }\n  return runSerial(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));\n}\n\nasync function fetchAllTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n  const results: ScrapedAccountsWithIndex[] = await runSerial(\n    allMonths.map(monthMoment => () => {\n      return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);\n    }),\n  );\n\n  const finalResult = await getAdditionalTransactionInformation(\n    options,\n    results,\n    page,\n    companyServiceOptions,\n    allMonths,\n  );\n  const combinedTxns: Record<string, Transaction[]> = {};\n\n  finalResult.forEach(result => {\n    Object.keys(result).forEach(accountNumber => {\n      let txnsForAccount = combinedTxns[accountNumber];\n      if (!txnsForAccount) {\n        txnsForAccount = [];\n        combinedTxns[accountNumber] = txnsForAccount;\n      }\n      const toBeAddedTxns = result[accountNumber].txns;\n      combinedTxns[accountNumber].push(...toBeAddedTxns);\n    });\n  });\n\n  const accounts = Object.keys(combinedTxns).map(accountNumber => {\n    return {\n      accountNumber,\n      txns: combinedTxns[accountNumber],\n    };\n  });\n\n  return {\n    success: true,\n    accounts,\n  };\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; card6Digits: string };\nclass IsracardAmexBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private baseUrl: string;\n\n  private companyCode: string;\n\n  private servicesUrl: string;\n\n  constructor(options: ScraperOptions, baseUrl: string, companyCode: string) {\n    super(options);\n\n    this.baseUrl = baseUrl;\n    this.companyCode = companyCode;\n    this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;\n  }\n\n  async login(credentials: ScraperSpecificCredentials): Promise<ScraperScrapingResult> {\n    await this.page.setRequestInterception(true);\n    this.page.on('request', request => {\n      if (request.url().includes('detector-dom.min.js')) {\n        debug('force abort for request do download detector-dom.min.js resource');\n        void request.abort(undefined, interceptionPriorities.abort);\n      } else {\n        void request.continue(undefined, interceptionPriorities.continue);\n      }\n    });\n\n    await maskHeadlessUserAgent(this.page);\n\n    await this.navigateTo(`${this.baseUrl}/personalarea/Login`);\n\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;\n    const validateRequest = {\n      id: credentials.id,\n      cardSuffix: credentials.card6Digits,\n      countryCode: COUNTRY_CODE,\n      idType: ID_TYPE,\n      checkLevel: '1',\n      companyCode: this.companyCode,\n    };\n    debug('logging in with validate request');\n    const validateResult = await fetchPostWithinPage<ScrapedLoginValidation>(this.page, validateUrl, validateRequest);\n    if (\n      !validateResult ||\n      !validateResult.Header ||\n      validateResult.Header.Status !== '1' ||\n      !validateResult.ValidateIdDataBean\n    ) {\n      throw new Error('unknown error during login');\n    }\n\n    const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;\n    debug(`user validate with return code '${validateReturnCode}'`);\n    if (validateReturnCode === '1') {\n      const { userName } = validateResult.ValidateIdDataBean;\n\n      const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;\n      const request = {\n        KodMishtamesh: userName,\n        MisparZihuy: credentials.id,\n        Sisma: credentials.password,\n        cardSuffix: credentials.card6Digits,\n        countryCode: COUNTRY_CODE,\n        idType: ID_TYPE,\n      };\n      debug('user login started');\n      const loginResult = await fetchPostWithinPage<{ status: string }>(this.page, loginUrl, request);\n      debug(`user login with status '${loginResult?.status}'`, loginResult);\n\n      if (loginResult && loginResult.status === '1') {\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      }\n\n      if (loginResult && loginResult.status === '3') {\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      }\n\n      this.emitProgress(ScraperProgressTypes.LoginFailed);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.InvalidPassword,\n      };\n    }\n\n    if (validateReturnCode === '4') {\n      this.emitProgress(ScraperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    }\n\n    this.emitProgress(ScraperProgressTypes.LoginFailed);\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.InvalidPassword,\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    return fetchAllTransactions(\n      this.page,\n      this.options,\n      {\n        servicesUrl: this.servicesUrl,\n        companyCode: this.companyCode,\n      },\n      startMoment,\n    );\n  }\n}\n\nexport default IsracardAmexBaseScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,57 @@
1
+ import { type Frame, type Page, type PuppeteerLifeCycleEvent } from 'puppeteer';
2
+ import { BaseScraper } from './base-scraper';
3
+ import { ScraperErrorTypes } from './errors';
4
+ import { type ScraperCredentials, type ScraperScrapingResult } from './interface';
5
+ declare enum LoginBaseResults {
6
+ Success = "SUCCESS",
7
+ UnknownError = "UNKNOWN_ERROR"
8
+ }
9
+ export declare const LoginResults: {
10
+ Success: LoginBaseResults.Success;
11
+ UnknownError: LoginBaseResults.UnknownError;
12
+ TwoFactorRetrieverMissing: ScraperErrorTypes.TwoFactorRetrieverMissing;
13
+ InvalidPassword: ScraperErrorTypes.InvalidPassword;
14
+ ChangePassword: ScraperErrorTypes.ChangePassword;
15
+ AccountBlocked: ScraperErrorTypes.AccountBlocked;
16
+ };
17
+ export type LoginResults = Exclude<ScraperErrorTypes, ScraperErrorTypes.Timeout | ScraperErrorTypes.Generic | ScraperErrorTypes.General> | LoginBaseResults;
18
+ export type PossibleLoginResults = {
19
+ [key in LoginResults]?: (string | RegExp | ((options?: {
20
+ page?: Page;
21
+ }) => Promise<boolean>))[];
22
+ };
23
+ export interface LoginOptions {
24
+ loginUrl: string;
25
+ checkReadiness?: () => Promise<void>;
26
+ fields: {
27
+ selector: string;
28
+ value: string;
29
+ }[];
30
+ submitButtonSelector: string | (() => Promise<void>);
31
+ preAction?: () => Promise<Frame | void>;
32
+ postAction?: () => Promise<void>;
33
+ possibleResults: PossibleLoginResults;
34
+ userAgent?: string;
35
+ waitUntil?: PuppeteerLifeCycleEvent;
36
+ }
37
+ declare class BaseScraperWithBrowser<TCredentials extends ScraperCredentials> extends BaseScraper<TCredentials> {
38
+ private cleanups;
39
+ private defaultViewportSize;
40
+ protected page: Page;
41
+ protected getViewPort(): {
42
+ width: number;
43
+ height: number;
44
+ };
45
+ initialize(): Promise<void>;
46
+ private initializePage;
47
+ navigateTo(url: string, waitUntil?: PuppeteerLifeCycleEvent | undefined, retries?: number): Promise<void>;
48
+ getLoginOptions(_credentials: ScraperCredentials): LoginOptions;
49
+ fillInputs(pageOrFrame: Page | Frame, fields: {
50
+ selector: string;
51
+ value: string;
52
+ }[]): Promise<void>;
53
+ login(credentials: ScraperCredentials): Promise<ScraperScrapingResult>;
54
+ terminate(_success: boolean): Promise<void>;
55
+ private handleLoginResult;
56
+ }
57
+ export { BaseScraperWithBrowser };