israeli-bank-scrapers-core 6.4.1 → 6.5.0

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.
@@ -66,11 +66,11 @@ function getTxnAmount(txn) {
66
66
  const debit = getAmountData(txn.debit);
67
67
  return (Number.isNaN(credit) ? 0 : credit) - (Number.isNaN(debit) ? 0 : debit);
68
68
  }
69
- function convertTransactions(txns) {
69
+ function convertTransactions(txns, options) {
70
70
  return txns.map(txn => {
71
71
  const convertedDate = (0, _moment.default)(txn.date, DATE_FORMAT).toISOString();
72
72
  const convertedAmount = getTxnAmount(txn);
73
- return {
73
+ const result = {
74
74
  type: _transactions.TransactionTypes.Normal,
75
75
  identifier: txn.reference ? parseInt(txn.reference, 10) : undefined,
76
76
  date: convertedDate,
@@ -82,6 +82,10 @@ function convertTransactions(txns) {
82
82
  description: txn.description,
83
83
  memo: txn.memo
84
84
  };
85
+ if (options?.includeRawTransaction) {
86
+ result.rawTransaction = txn;
87
+ }
88
+ return result;
85
89
  });
86
90
  }
87
91
  function getTransactionDate(tds, transactionType, transactionsColsTypes) {
@@ -187,7 +191,7 @@ async function navigateToNextPage(page) {
187
191
 
188
192
  /* Couldn't reproduce scenario with multiple pages of pending transactions - Should support if exists such case.
189
193
  needToPaginate is false if scraping pending transactions */
190
- async function scrapeTransactions(page, tableLocator, transactionStatus, needToPaginate) {
194
+ async function scrapeTransactions(page, tableLocator, transactionStatus, needToPaginate, options) {
191
195
  const txns = [];
192
196
  let hasNextPage = false;
193
197
  do {
@@ -200,16 +204,16 @@ async function scrapeTransactions(page, tableLocator, transactionStatus, needToP
200
204
  }
201
205
  }
202
206
  } while (hasNextPage);
203
- return convertTransactions(txns);
207
+ return convertTransactions(txns, options);
204
208
  }
205
- async function getAccountTransactions(page) {
209
+ async function getAccountTransactions(page, options) {
206
210
  await Promise.race([(0, _elementsInteractions.waitUntilElementFound)(page, "div[id*='divTable']", false), (0, _elementsInteractions.waitUntilElementFound)(page, `.${ERROR_MESSAGE_CLASS}`, false)]);
207
211
  const noTransactionInRangeError = await isNoTransactionInDateRangeError(page);
208
212
  if (noTransactionInRangeError) {
209
213
  return [];
210
214
  }
211
- const pendingTxns = await scrapeTransactions(page, PENDING_TRANSACTIONS_TABLE, _transactions.TransactionStatuses.Pending, false);
212
- const completedTxns = await scrapeTransactions(page, COMPLETED_TRANSACTIONS_TABLE, _transactions.TransactionStatuses.Completed, true);
215
+ const pendingTxns = await scrapeTransactions(page, PENDING_TRANSACTIONS_TABLE, _transactions.TransactionStatuses.Pending, false, options);
216
+ const completedTxns = await scrapeTransactions(page, COMPLETED_TRANSACTIONS_TABLE, _transactions.TransactionStatuses.Completed, true, options);
213
217
  const txns = [...pendingTxns, ...completedTxns];
214
218
  return txns;
215
219
  }
@@ -233,11 +237,11 @@ async function waitForPostLogin(page) {
233
237
  (0, _elementsInteractions.waitUntilElementFound)(page, '#validationMsg', true) // Old UI
234
238
  ]);
235
239
  }
236
- async function fetchAccountData(page, startDate) {
240
+ async function fetchAccountData(page, startDate, options) {
237
241
  const accountNumber = await getAccountNumber(page);
238
242
  const balance = await getCurrentBalance(page);
239
243
  await searchByDates(page, startDate);
240
- const txns = await getAccountTransactions(page);
244
+ const txns = await getAccountTransactions(page, options);
241
245
  return {
242
246
  accountNumber,
243
247
  txns,
@@ -368,25 +372,25 @@ async function selectAccountBothUIs(page, accountId) {
368
372
  await (0, _elementsInteractions.waitUntilElementFound)(page, '#account_num_select', true);
369
373
  }
370
374
  }
371
- async function fetchAccountDataBothUIs(page, startDate) {
375
+ async function fetchAccountDataBothUIs(page, startDate, options) {
372
376
  // Try to get the iframe for the new UI
373
377
  const frame = await getTransactionsFrame(page);
374
378
 
375
379
  // Use the frame if available (new UI), otherwise use the page directly (old UI)
376
380
  const targetPage = frame || page;
377
- return fetchAccountData(targetPage, startDate);
381
+ return fetchAccountData(targetPage, startDate, options);
378
382
  }
379
- async function fetchAccounts(page, startDate) {
383
+ async function fetchAccounts(page, startDate, options) {
380
384
  const accountsIds = await getAccountIdsBothUIs(page);
381
385
  if (accountsIds.length === 0) {
382
386
  // In case accountsIds could no be parsed just return the transactions of the currently selected account
383
- const accountData = await fetchAccountDataBothUIs(page, startDate);
387
+ const accountData = await fetchAccountDataBothUIs(page, startDate, options);
384
388
  return [accountData];
385
389
  }
386
390
  const accounts = [];
387
391
  for (const accountId of accountsIds) {
388
392
  await selectAccountBothUIs(page, accountId);
389
- const accountData = await fetchAccountDataBothUIs(page, startDate);
393
+ const accountData = await fetchAccountDataBothUIs(page, startDate, options);
390
394
  accounts.push(accountData);
391
395
  }
392
396
  return accounts;
@@ -417,7 +421,7 @@ class BeinleumiGroupBaseScraper extends _baseScraperWithBrowser.BaseScraperWithB
417
421
  const startDate = this.options.startDate || defaultStartMoment.toDate();
418
422
  const startMoment = _moment.default.max(startMomentLimit, (0, _moment.default)(startDate));
419
423
  await this.navigateTo(this.TRANSACTIONS_URL);
420
- const accounts = await fetchAccounts(this.page, startMoment);
424
+ const accounts = await fetchAccounts(this.page, startMoment, this.options);
421
425
  return {
422
426
  success: true,
423
427
  accounts
@@ -425,4 +429,4 @@ class BeinleumiGroupBaseScraper extends _baseScraperWithBrowser.BaseScraperWithB
425
429
  }
426
430
  }
427
431
  var _default = exports.default = BeinleumiGroupBaseScraper;
428
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_elementsInteractions","_navigation","_waiting","_transactions","_baseScraperWithBrowser","e","__esModule","default","DATE_FORMAT","NO_TRANSACTION_IN_DATE_RANGE_TEXT","DATE_COLUMN_CLASS_COMPLETED","DATE_COLUMN_CLASS_PENDING","DESCRIPTION_COLUMN_CLASS_COMPLETED","DESCRIPTION_COLUMN_CLASS_PENDING","REFERENCE_COLUMN_CLASS","DEBIT_COLUMN_CLASS","CREDIT_COLUMN_CLASS","ERROR_MESSAGE_CLASS","ACCOUNTS_NUMBER","CLOSE_SEARCH_BY_DATES_BUTTON_CLASS","SHOW_SEARCH_BY_DATES_BUTTON_VALUE","COMPLETED_TRANSACTIONS_TABLE","PENDING_TRANSACTIONS_TABLE","NEXT_PAGE_LINK","CURRENT_BALANCE","IFRAME_NAME","ELEMENT_RENDER_TIMEOUT_MS","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","createLoginFields","credentials","selector","value","username","password","getAmountData","amountStr","amountStrCopy","replace","SHEKEL_CURRENCY_SYMBOL","replaceAll","parseFloat","getTxnAmount","txn","credit","debit","Number","isNaN","convertTransactions","txns","map","convertedDate","moment","date","toISOString","convertedAmount","type","TransactionTypes","Normal","identifier","reference","parseInt","undefined","processedDate","originalAmount","originalCurrency","SHEKEL_CURRENCY","chargedAmount","status","description","memo","getTransactionDate","tds","transactionType","transactionsColsTypes","trim","getTransactionDescription","getTransactionReference","getTransactionDebit","getTransactionCredit","extractTransactionDetails","txnRow","transactionStatus","innerTds","item","getTransactionsColsTypeClasses","page","tableLocator","result","typeClassesObjs","pageEvalAll","td","index","colClass","getAttribute","typeClassObj","extractTransaction","push","extractTransactions","transactionsRows","trs","tr","Array","from","getElementsByTagName","innerText","isNoTransactionInDateRangeError","hasErrorInfoElement","elementPresentOnPage","errorText","$eval","errorElement","searchByDates","startDate","clickButton","waitUntilElementFound","fillInput","format","waitForNavigation","getAccountNumber","selectedSnifAccount","option","checkIfHasNextPage","navigateToNextPage","scrapeTransactions","needToPaginate","hasNextPage","currentPageTxns","getAccountTransactions","Promise","race","noTransactionInRangeError","pendingTxns","TransactionStatuses","Pending","completedTxns","Completed","getCurrentBalance","balanceStr","el","waitForPostLogin","fetchAccountData","accountNumber","balance","getAccountIdsOldUI","evaluate","selectElement","document","getElementById","options","querySelectorAll","clickAccountSelectorGetAccountIds","accountSelector","dropdownPanelSelector","optionSelector","dropdownVisible","window","getComputedStyle","display","offsetParent","catch","accountLabels","$$eval","textContent","filter","label","error","getAccountIdsBothUIs","accountsIds","length","selectAccountFromDropdown","accountLabel","availableAccounts","includes","accountOptions","$$","text","optionHandle","evaluateHandle","click","getTransactionsFrame","attempt","sleep","frames","targetFrame","find","f","name","selectAccountBothUIs","accountId","accountSelected","select","fetchAccountDataBothUIs","frame","targetPage","fetchAccounts","accountData","accounts","BeinleumiGroupBaseScraper","BaseScraperWithBrowser","BASE_URL","LOGIN_URL","TRANSACTIONS_URL","getLoginOptions","loginUrl","fields","submitButtonSelector","postAction","possibleResults","preAction","fetchData","defaultStartMoment","subtract","add","startMomentLimit","year","toDate","startMoment","max","navigateTo","success","_default","exports"],"sources":["../../src/scrapers/base-beinleumi-group.ts"],"sourcesContent":["import moment, { type Moment } from 'moment';\nimport { type Frame, type Page } from 'puppeteer-core';\nimport { SHEKEL_CURRENCY, SHEKEL_CURRENCY_SYMBOL } from '../constants';\nimport {\n  clickButton,\n  elementPresentOnPage,\n  fillInput,\n  pageEvalAll,\n  waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { sleep } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\nconst NO_TRANSACTION_IN_DATE_RANGE_TEXT = 'לא נמצאו נתונים בנושא המבוקש';\nconst DATE_COLUMN_CLASS_COMPLETED = 'date first';\nconst DATE_COLUMN_CLASS_PENDING = 'first date';\nconst DESCRIPTION_COLUMN_CLASS_COMPLETED = 'reference wrap_normal';\nconst DESCRIPTION_COLUMN_CLASS_PENDING = 'details wrap_normal';\nconst REFERENCE_COLUMN_CLASS = 'details';\nconst DEBIT_COLUMN_CLASS = 'debit';\nconst CREDIT_COLUMN_CLASS = 'credit';\nconst ERROR_MESSAGE_CLASS = 'NO_DATA';\nconst ACCOUNTS_NUMBER = 'div.fibi_account span.acc_num';\nconst CLOSE_SEARCH_BY_DATES_BUTTON_CLASS = 'ui-datepicker-close';\nconst SHOW_SEARCH_BY_DATES_BUTTON_VALUE = 'הצג';\nconst COMPLETED_TRANSACTIONS_TABLE = 'table#dataTable077';\nconst PENDING_TRANSACTIONS_TABLE = 'table#dataTable023';\nconst NEXT_PAGE_LINK = 'a#Npage.paging';\nconst CURRENT_BALANCE = '.main_balance';\nconst IFRAME_NAME = 'iframe-old-pages';\nconst ELEMENT_RENDER_TIMEOUT_MS = 10000;\n\ntype TransactionsColsTypes = Record<string, number>;\ntype TransactionsTrTds = string[];\ntype TransactionsTr = { innerTds: TransactionsTrTds };\n\ninterface ScrapedTransaction {\n  reference: string;\n  date: string;\n  credit: string;\n  debit: string;\n  memo?: string;\n  description: string;\n  status: TransactionStatuses;\n}\n\nexport function getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [\n    /fibi.*accountSummary/, // New UI pattern\n    /Resources\\/PortalNG\\/shell/, // New UI pattern\n    /FibiMenu\\/Online/, // Old UI pattern\n  ];\n  urls[LoginResults.InvalidPassword] = [/FibiMenu\\/Marketing\\/Private\\/Home/];\n  return urls;\n}\n\nexport function createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#username', value: credentials.username },\n    { selector: '#password', value: credentials.password },\n  ];\n}\n\nfunction getAmountData(amountStr: string) {\n  let amountStrCopy = amountStr.replace(SHEKEL_CURRENCY_SYMBOL, '');\n  amountStrCopy = amountStrCopy.replaceAll(',', '');\n  return parseFloat(amountStrCopy);\n}\n\nfunction getTxnAmount(txn: ScrapedTransaction) {\n  const credit = getAmountData(txn.credit);\n  const debit = getAmountData(txn.debit);\n  return (Number.isNaN(credit) ? 0 : credit) - (Number.isNaN(debit) ? 0 : debit);\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  return txns.map((txn): Transaction => {\n    const convertedDate = moment(txn.date, DATE_FORMAT).toISOString();\n    const convertedAmount = getTxnAmount(txn);\n    return {\n      type: TransactionTypes.Normal,\n      identifier: txn.reference ? parseInt(txn.reference, 10) : undefined,\n      date: convertedDate,\n      processedDate: convertedDate,\n      originalAmount: convertedAmount,\n      originalCurrency: SHEKEL_CURRENCY,\n      chargedAmount: convertedAmount,\n      status: txn.status,\n      description: txn.description,\n      memo: txn.memo,\n    };\n  });\n}\n\nfunction getTransactionDate(\n  tds: TransactionsTrTds,\n  transactionType: string,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  if (transactionType === 'completed') {\n    return (tds[transactionsColsTypes[DATE_COLUMN_CLASS_COMPLETED]] || '').trim();\n  }\n  return (tds[transactionsColsTypes[DATE_COLUMN_CLASS_PENDING]] || '').trim();\n}\n\nfunction getTransactionDescription(\n  tds: TransactionsTrTds,\n  transactionType: string,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  if (transactionType === 'completed') {\n    return (tds[transactionsColsTypes[DESCRIPTION_COLUMN_CLASS_COMPLETED]] || '').trim();\n  }\n  return (tds[transactionsColsTypes[DESCRIPTION_COLUMN_CLASS_PENDING]] || '').trim();\n}\n\nfunction getTransactionReference(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[REFERENCE_COLUMN_CLASS]] || '').trim();\n}\n\nfunction getTransactionDebit(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[DEBIT_COLUMN_CLASS]] || '').trim();\n}\n\nfunction getTransactionCredit(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[CREDIT_COLUMN_CLASS]] || '').trim();\n}\n\nfunction extractTransactionDetails(\n  txnRow: TransactionsTr,\n  transactionStatus: TransactionStatuses,\n  transactionsColsTypes: TransactionsColsTypes,\n): ScrapedTransaction {\n  const tds = txnRow.innerTds;\n  const item = {\n    status: transactionStatus,\n    date: getTransactionDate(tds, transactionStatus, transactionsColsTypes),\n    description: getTransactionDescription(tds, transactionStatus, transactionsColsTypes),\n    reference: getTransactionReference(tds, transactionsColsTypes),\n    debit: getTransactionDebit(tds, transactionsColsTypes),\n    credit: getTransactionCredit(tds, transactionsColsTypes),\n  };\n\n  return item;\n}\n\nasync function getTransactionsColsTypeClasses(\n  page: Page | Frame,\n  tableLocator: string,\n): Promise<TransactionsColsTypes> {\n  const result: TransactionsColsTypes = {};\n  const typeClassesObjs = await pageEvalAll(page, `${tableLocator} tbody tr:first-of-type td`, null, tds => {\n    return tds.map((td, index) => ({\n      colClass: td.getAttribute('class'),\n      index,\n    }));\n  });\n\n  for (const typeClassObj of typeClassesObjs) {\n    if (typeClassObj.colClass) {\n      result[typeClassObj.colClass] = typeClassObj.index;\n    }\n  }\n  return result;\n}\n\nfunction extractTransaction(\n  txns: ScrapedTransaction[],\n  transactionStatus: TransactionStatuses,\n  txnRow: TransactionsTr,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  const txn = extractTransactionDetails(txnRow, transactionStatus, transactionsColsTypes);\n  if (txn.date !== '') {\n    txns.push(txn);\n  }\n}\n\nasync function extractTransactions(page: Page | Frame, tableLocator: string, transactionStatus: TransactionStatuses) {\n  const txns: ScrapedTransaction[] = [];\n  const transactionsColsTypes = await getTransactionsColsTypeClasses(page, tableLocator);\n\n  const transactionsRows = await pageEvalAll<TransactionsTr[]>(page, `${tableLocator} tbody tr`, [], trs => {\n    return trs.map(tr => ({\n      innerTds: Array.from(tr.getElementsByTagName('td')).map(td => td.innerText),\n    }));\n  });\n\n  for (const txnRow of transactionsRows) {\n    extractTransaction(txns, transactionStatus, txnRow, transactionsColsTypes);\n  }\n  return txns;\n}\n\nasync function isNoTransactionInDateRangeError(page: Page | Frame) {\n  const hasErrorInfoElement = await elementPresentOnPage(page, `.${ERROR_MESSAGE_CLASS}`);\n  if (hasErrorInfoElement) {\n    const errorText = await page.$eval(`.${ERROR_MESSAGE_CLASS}`, errorElement => {\n      return (errorElement as HTMLElement).innerText;\n    });\n    return errorText.trim() === NO_TRANSACTION_IN_DATE_RANGE_TEXT;\n  }\n  return false;\n}\n\nasync function searchByDates(page: Page | Frame, startDate: Moment) {\n  await clickButton(page, 'a#tabHeader4');\n  await waitUntilElementFound(page, 'div#fibi_dates');\n  await fillInput(page, 'input#fromDate', startDate.format(DATE_FORMAT));\n  await clickButton(page, `button[class*=${CLOSE_SEARCH_BY_DATES_BUTTON_CLASS}]`);\n  await clickButton(page, `input[value=${SHOW_SEARCH_BY_DATES_BUTTON_VALUE}]`);\n  await waitForNavigation(page);\n}\n\nasync function getAccountNumber(page: Page | Frame): Promise<string> {\n  // Wait until the account number element is present in the DOM\n  await waitUntilElementFound(page, ACCOUNTS_NUMBER, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  const selectedSnifAccount = await page.$eval(ACCOUNTS_NUMBER, option => {\n    return (option as HTMLElement).innerText;\n  });\n\n  return selectedSnifAccount.replace('/', '_').trim();\n}\n\nasync function checkIfHasNextPage(page: Page | Frame) {\n  return elementPresentOnPage(page, NEXT_PAGE_LINK);\n}\n\nasync function navigateToNextPage(page: Page | Frame) {\n  await clickButton(page, NEXT_PAGE_LINK);\n  await waitForNavigation(page);\n}\n\n/* Couldn't reproduce scenario with multiple pages of pending transactions - Should support if exists such case.\n   needToPaginate is false if scraping pending transactions */\nasync function scrapeTransactions(\n  page: Page | Frame,\n  tableLocator: string,\n  transactionStatus: TransactionStatuses,\n  needToPaginate: boolean,\n) {\n  const txns = [];\n  let hasNextPage = false;\n\n  do {\n    const currentPageTxns = await extractTransactions(page, tableLocator, transactionStatus);\n    txns.push(...currentPageTxns);\n    if (needToPaginate) {\n      hasNextPage = await checkIfHasNextPage(page);\n      if (hasNextPage) {\n        await navigateToNextPage(page);\n      }\n    }\n  } while (hasNextPage);\n\n  return convertTransactions(txns);\n}\n\nasync function getAccountTransactions(page: Page | Frame) {\n  await Promise.race([\n    waitUntilElementFound(page, \"div[id*='divTable']\", false),\n    waitUntilElementFound(page, `.${ERROR_MESSAGE_CLASS}`, false),\n  ]);\n\n  const noTransactionInRangeError = await isNoTransactionInDateRangeError(page);\n  if (noTransactionInRangeError) {\n    return [];\n  }\n\n  const pendingTxns = await scrapeTransactions(page, PENDING_TRANSACTIONS_TABLE, TransactionStatuses.Pending, false);\n  const completedTxns = await scrapeTransactions(\n    page,\n    COMPLETED_TRANSACTIONS_TABLE,\n    TransactionStatuses.Completed,\n    true,\n  );\n  const txns = [...pendingTxns, ...completedTxns];\n  return txns;\n}\n\nasync function getCurrentBalance(page: Page | Frame): Promise<number> {\n  // Wait for the balance element to appear and be visible\n  await waitUntilElementFound(page, CURRENT_BALANCE, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  // Extract text content\n  const balanceStr = await page.$eval(CURRENT_BALANCE, el => {\n    return (el as HTMLElement).innerText;\n  });\n\n  return getAmountData(balanceStr);\n}\n\nexport async function waitForPostLogin(page: Page) {\n  return Promise.race([\n    waitUntilElementFound(page, '#card-header', false), // New UI\n    waitUntilElementFound(page, '#account_num', true), // New UI\n    waitUntilElementFound(page, '#matafLogoutLink', true), // Old UI\n    waitUntilElementFound(page, '#validationMsg', true), // Old UI\n  ]);\n}\n\nasync function fetchAccountData(page: Page | Frame, startDate: Moment) {\n  const accountNumber = await getAccountNumber(page);\n  const balance = await getCurrentBalance(page);\n  await searchByDates(page, startDate);\n  const txns = await getAccountTransactions(page);\n\n  return {\n    accountNumber,\n    txns,\n    balance,\n  };\n}\n\nasync function getAccountIdsOldUI(page: Page): Promise<string[]> {\n  return page.evaluate(() => {\n    const selectElement = document.getElementById('account_num_select');\n    const options = selectElement ? selectElement.querySelectorAll('option') : [];\n    if (!options) return [];\n    return Array.from(options, option => option.value);\n  });\n}\n\n/**\n * Ensures the account dropdown is open, then returns the available account labels.\n *\n * This method:\n * - Checks if the dropdown is already open.\n * - If not open, clicks the account selector to open it.\n * - Waits for the dropdown to render.\n * - Extracts and returns the list of available account labels.\n *\n * Graceful handling:\n * - If any error occurs (e.g., selectors not found, timing issues, UI version changes),\n *   the function returns an empty list.\n *\n * @param page Puppeteer Page object.\n * @returns An array of available account labels (e.g., [\"127 | XXXX1\", \"127 | XXXX2\"]),\n *          or an empty array if something goes wrong.\n */\nexport async function clickAccountSelectorGetAccountIds(page: Page): Promise<string[]> {\n  try {\n    const accountSelector = 'div.current-account'; // Direct selector to clickable element\n    const dropdownPanelSelector = 'div.mat-mdc-autocomplete-panel.account-select-dd'; // The dropdown list box\n    const optionSelector = 'mat-option .mdc-list-item__primary-text'; // Account option labels\n\n    // Check if dropdown is already open\n    const dropdownVisible = await page\n      .$eval(dropdownPanelSelector, el => {\n        return el && window.getComputedStyle(el).display !== 'none' && el.offsetParent !== null;\n      })\n      .catch(() => false); // catch if dropdown is not in the DOM yet\n\n    if (!dropdownVisible) {\n      await waitUntilElementFound(page, accountSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n      // Click the account selector to open the dropdown\n      await clickButton(page, accountSelector);\n\n      // Wait for the dropdown to open\n      await waitUntilElementFound(page, dropdownPanelSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n    }\n\n    // Extract account labels from the dropdown options\n    const accountLabels = await page.$$eval(optionSelector, options => {\n      return options.map(option => option.textContent?.trim() || '').filter(label => label !== '');\n    });\n\n    return accountLabels;\n  } catch (error) {\n    return []; // Graceful fallback\n  }\n}\n\nasync function getAccountIdsBothUIs(page: Page): Promise<string[]> {\n  let accountsIds: string[] = await clickAccountSelectorGetAccountIds(page);\n  if (accountsIds.length === 0) {\n    accountsIds = await getAccountIdsOldUI(page);\n  }\n  return accountsIds;\n}\n\n/**\n * Selects an account from the dropdown based on the provided account label.\n *\n * This method:\n * - Clicks the account selector button to open the dropdown.\n * - Retrieves the list of available account labels.\n * - Checks if the provided account label exists in the list.\n * - Finds and clicks the matching account option if found.\n *\n * @param page Puppeteer Page object.\n * @param accountLabel The text of the account to select (e.g., \"127 | XXXXX\").\n * @returns True if the account option was found and clicked; false otherwise.\n */\nexport async function selectAccountFromDropdown(page: Page, accountLabel: string): Promise<boolean> {\n  // Call clickAccountSelector to get the available accounts and open the dropdown\n  const availableAccounts = await clickAccountSelectorGetAccountIds(page);\n\n  // Check if the account label exists in the available accounts\n  if (!availableAccounts.includes(accountLabel)) {\n    return false;\n  }\n\n  // Wait for the dropdown options to be rendered\n  const optionSelector = 'mat-option .mdc-list-item__primary-text';\n  await waitUntilElementFound(page, optionSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  // Query all matching options\n  const accountOptions = await page.$$(optionSelector);\n\n  // Find and click the option matching the accountLabel\n  for (const option of accountOptions) {\n    const text = await page.evaluate(el => el.textContent?.trim(), option);\n\n    if (text === accountLabel) {\n      const optionHandle = await option.evaluateHandle(el => el as HTMLElement);\n      await page.evaluate((el: HTMLElement) => el.click(), optionHandle);\n      return true;\n    }\n  }\n\n  return false;\n}\n\nasync function getTransactionsFrame(page: Page): Promise<Frame | null> {\n  // Try a few times to find the iframe, as it might not be immediately available\n  for (let attempt = 0; attempt < 3; attempt++) {\n    await sleep(2000);\n    const frames = page.frames();\n    const targetFrame = frames.find(f => f.name() === IFRAME_NAME);\n\n    if (targetFrame) {\n      return targetFrame;\n    }\n  }\n\n  return null;\n}\n\nasync function selectAccountBothUIs(page: Page, accountId: string): Promise<void> {\n  const accountSelected = await selectAccountFromDropdown(page, accountId);\n  if (!accountSelected) {\n    // Old UI format\n    await page.select('#account_num_select', accountId);\n    await waitUntilElementFound(page, '#account_num_select', true);\n  }\n}\n\nasync function fetchAccountDataBothUIs(page: Page, startDate: Moment) {\n  // Try to get the iframe for the new UI\n  const frame = await getTransactionsFrame(page);\n\n  // Use the frame if available (new UI), otherwise use the page directly (old UI)\n  const targetPage = frame || page;\n  return fetchAccountData(targetPage, startDate);\n}\n\nasync function fetchAccounts(page: Page, startDate: Moment): Promise<TransactionsAccount[]> {\n  const accountsIds = await getAccountIdsBothUIs(page);\n\n  if (accountsIds.length === 0) {\n    // In case accountsIds could no be parsed just return the transactions of the currently selected account\n    const accountData = await fetchAccountDataBothUIs(page, startDate);\n    return [accountData];\n  }\n\n  const accounts: TransactionsAccount[] = [];\n  for (const accountId of accountsIds) {\n    await selectAccountBothUIs(page, accountId);\n    const accountData = await fetchAccountDataBothUIs(page, startDate);\n    accounts.push(accountData);\n  }\n\n  return accounts;\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass BeinleumiGroupBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  BASE_URL = '';\n\n  LOGIN_URL = '';\n\n  TRANSACTIONS_URL = '';\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${this.LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#continueBtn',\n      postAction: async () => waitForPostLogin(this.page),\n      possibleResults: getPossibleLoginResults(),\n      // HACK: For some reason, though the login button (#continueBtn) is present and visible, the click action does not perform.\n      // Adding this delay fixes the issue.\n      preAction: async () => {\n        await sleep(1000);\n      },\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startMomentLimit = moment({ year: 1600 });\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(startMomentLimit, moment(startDate));\n\n    await this.navigateTo(this.TRANSACTIONS_URL);\n\n    const accounts = await fetchAccounts(this.page, startMoment);\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default BeinleumiGroupBaseScraper;\n"],"mappings":"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","ignoreList":[]}
432
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_elementsInteractions","_navigation","_waiting","_transactions","_baseScraperWithBrowser","e","__esModule","default","DATE_FORMAT","NO_TRANSACTION_IN_DATE_RANGE_TEXT","DATE_COLUMN_CLASS_COMPLETED","DATE_COLUMN_CLASS_PENDING","DESCRIPTION_COLUMN_CLASS_COMPLETED","DESCRIPTION_COLUMN_CLASS_PENDING","REFERENCE_COLUMN_CLASS","DEBIT_COLUMN_CLASS","CREDIT_COLUMN_CLASS","ERROR_MESSAGE_CLASS","ACCOUNTS_NUMBER","CLOSE_SEARCH_BY_DATES_BUTTON_CLASS","SHOW_SEARCH_BY_DATES_BUTTON_VALUE","COMPLETED_TRANSACTIONS_TABLE","PENDING_TRANSACTIONS_TABLE","NEXT_PAGE_LINK","CURRENT_BALANCE","IFRAME_NAME","ELEMENT_RENDER_TIMEOUT_MS","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","createLoginFields","credentials","selector","value","username","password","getAmountData","amountStr","amountStrCopy","replace","SHEKEL_CURRENCY_SYMBOL","replaceAll","parseFloat","getTxnAmount","txn","credit","debit","Number","isNaN","convertTransactions","txns","options","map","convertedDate","moment","date","toISOString","convertedAmount","result","type","TransactionTypes","Normal","identifier","reference","parseInt","undefined","processedDate","originalAmount","originalCurrency","SHEKEL_CURRENCY","chargedAmount","status","description","memo","includeRawTransaction","rawTransaction","getTransactionDate","tds","transactionType","transactionsColsTypes","trim","getTransactionDescription","getTransactionReference","getTransactionDebit","getTransactionCredit","extractTransactionDetails","txnRow","transactionStatus","innerTds","item","getTransactionsColsTypeClasses","page","tableLocator","typeClassesObjs","pageEvalAll","td","index","colClass","getAttribute","typeClassObj","extractTransaction","push","extractTransactions","transactionsRows","trs","tr","Array","from","getElementsByTagName","innerText","isNoTransactionInDateRangeError","hasErrorInfoElement","elementPresentOnPage","errorText","$eval","errorElement","searchByDates","startDate","clickButton","waitUntilElementFound","fillInput","format","waitForNavigation","getAccountNumber","selectedSnifAccount","option","checkIfHasNextPage","navigateToNextPage","scrapeTransactions","needToPaginate","hasNextPage","currentPageTxns","getAccountTransactions","Promise","race","noTransactionInRangeError","pendingTxns","TransactionStatuses","Pending","completedTxns","Completed","getCurrentBalance","balanceStr","el","waitForPostLogin","fetchAccountData","accountNumber","balance","getAccountIdsOldUI","evaluate","selectElement","document","getElementById","querySelectorAll","clickAccountSelectorGetAccountIds","accountSelector","dropdownPanelSelector","optionSelector","dropdownVisible","window","getComputedStyle","display","offsetParent","catch","accountLabels","$$eval","textContent","filter","label","error","getAccountIdsBothUIs","accountsIds","length","selectAccountFromDropdown","accountLabel","availableAccounts","includes","accountOptions","$$","text","optionHandle","evaluateHandle","click","getTransactionsFrame","attempt","sleep","frames","targetFrame","find","f","name","selectAccountBothUIs","accountId","accountSelected","select","fetchAccountDataBothUIs","frame","targetPage","fetchAccounts","accountData","accounts","BeinleumiGroupBaseScraper","BaseScraperWithBrowser","BASE_URL","LOGIN_URL","TRANSACTIONS_URL","getLoginOptions","loginUrl","fields","submitButtonSelector","postAction","possibleResults","preAction","fetchData","defaultStartMoment","subtract","add","startMomentLimit","year","toDate","startMoment","max","navigateTo","success","_default","exports"],"sources":["../../src/scrapers/base-beinleumi-group.ts"],"sourcesContent":["import moment, { type Moment } from 'moment';\nimport { type Frame, type Page } from 'puppeteer-core';\nimport { SHEKEL_CURRENCY, SHEKEL_CURRENCY_SYMBOL } from '../constants';\nimport {\n  clickButton,\n  elementPresentOnPage,\n  fillInput,\n  pageEvalAll,\n  waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { sleep } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions } from './interface';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\nconst NO_TRANSACTION_IN_DATE_RANGE_TEXT = 'לא נמצאו נתונים בנושא המבוקש';\nconst DATE_COLUMN_CLASS_COMPLETED = 'date first';\nconst DATE_COLUMN_CLASS_PENDING = 'first date';\nconst DESCRIPTION_COLUMN_CLASS_COMPLETED = 'reference wrap_normal';\nconst DESCRIPTION_COLUMN_CLASS_PENDING = 'details wrap_normal';\nconst REFERENCE_COLUMN_CLASS = 'details';\nconst DEBIT_COLUMN_CLASS = 'debit';\nconst CREDIT_COLUMN_CLASS = 'credit';\nconst ERROR_MESSAGE_CLASS = 'NO_DATA';\nconst ACCOUNTS_NUMBER = 'div.fibi_account span.acc_num';\nconst CLOSE_SEARCH_BY_DATES_BUTTON_CLASS = 'ui-datepicker-close';\nconst SHOW_SEARCH_BY_DATES_BUTTON_VALUE = 'הצג';\nconst COMPLETED_TRANSACTIONS_TABLE = 'table#dataTable077';\nconst PENDING_TRANSACTIONS_TABLE = 'table#dataTable023';\nconst NEXT_PAGE_LINK = 'a#Npage.paging';\nconst CURRENT_BALANCE = '.main_balance';\nconst IFRAME_NAME = 'iframe-old-pages';\nconst ELEMENT_RENDER_TIMEOUT_MS = 10000;\n\ntype TransactionsColsTypes = Record<string, number>;\ntype TransactionsTrTds = string[];\ntype TransactionsTr = { innerTds: TransactionsTrTds };\n\ninterface ScrapedTransaction {\n  reference: string;\n  date: string;\n  credit: string;\n  debit: string;\n  memo?: string;\n  description: string;\n  status: TransactionStatuses;\n}\n\nexport function getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [\n    /fibi.*accountSummary/, // New UI pattern\n    /Resources\\/PortalNG\\/shell/, // New UI pattern\n    /FibiMenu\\/Online/, // Old UI pattern\n  ];\n  urls[LoginResults.InvalidPassword] = [/FibiMenu\\/Marketing\\/Private\\/Home/];\n  return urls;\n}\n\nexport function createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#username', value: credentials.username },\n    { selector: '#password', value: credentials.password },\n  ];\n}\n\nfunction getAmountData(amountStr: string) {\n  let amountStrCopy = amountStr.replace(SHEKEL_CURRENCY_SYMBOL, '');\n  amountStrCopy = amountStrCopy.replaceAll(',', '');\n  return parseFloat(amountStrCopy);\n}\n\nfunction getTxnAmount(txn: ScrapedTransaction) {\n  const credit = getAmountData(txn.credit);\n  const debit = getAmountData(txn.debit);\n  return (Number.isNaN(credit) ? 0 : credit) - (Number.isNaN(debit) ? 0 : debit);\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], options?: ScraperOptions): Transaction[] {\n  return txns.map((txn): Transaction => {\n    const convertedDate = moment(txn.date, DATE_FORMAT).toISOString();\n    const convertedAmount = getTxnAmount(txn);\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      identifier: txn.reference ? parseInt(txn.reference, 10) : undefined,\n      date: convertedDate,\n      processedDate: convertedDate,\n      originalAmount: convertedAmount,\n      originalCurrency: SHEKEL_CURRENCY,\n      chargedAmount: convertedAmount,\n      status: txn.status,\n      description: txn.description,\n      memo: txn.memo,\n    };\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = txn;\n    }\n\n    return result;\n  });\n}\n\nfunction getTransactionDate(\n  tds: TransactionsTrTds,\n  transactionType: string,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  if (transactionType === 'completed') {\n    return (tds[transactionsColsTypes[DATE_COLUMN_CLASS_COMPLETED]] || '').trim();\n  }\n  return (tds[transactionsColsTypes[DATE_COLUMN_CLASS_PENDING]] || '').trim();\n}\n\nfunction getTransactionDescription(\n  tds: TransactionsTrTds,\n  transactionType: string,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  if (transactionType === 'completed') {\n    return (tds[transactionsColsTypes[DESCRIPTION_COLUMN_CLASS_COMPLETED]] || '').trim();\n  }\n  return (tds[transactionsColsTypes[DESCRIPTION_COLUMN_CLASS_PENDING]] || '').trim();\n}\n\nfunction getTransactionReference(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[REFERENCE_COLUMN_CLASS]] || '').trim();\n}\n\nfunction getTransactionDebit(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[DEBIT_COLUMN_CLASS]] || '').trim();\n}\n\nfunction getTransactionCredit(tds: TransactionsTrTds, transactionsColsTypes: TransactionsColsTypes) {\n  return (tds[transactionsColsTypes[CREDIT_COLUMN_CLASS]] || '').trim();\n}\n\nfunction extractTransactionDetails(\n  txnRow: TransactionsTr,\n  transactionStatus: TransactionStatuses,\n  transactionsColsTypes: TransactionsColsTypes,\n): ScrapedTransaction {\n  const tds = txnRow.innerTds;\n  const item = {\n    status: transactionStatus,\n    date: getTransactionDate(tds, transactionStatus, transactionsColsTypes),\n    description: getTransactionDescription(tds, transactionStatus, transactionsColsTypes),\n    reference: getTransactionReference(tds, transactionsColsTypes),\n    debit: getTransactionDebit(tds, transactionsColsTypes),\n    credit: getTransactionCredit(tds, transactionsColsTypes),\n  };\n\n  return item;\n}\n\nasync function getTransactionsColsTypeClasses(\n  page: Page | Frame,\n  tableLocator: string,\n): Promise<TransactionsColsTypes> {\n  const result: TransactionsColsTypes = {};\n  const typeClassesObjs = await pageEvalAll(page, `${tableLocator} tbody tr:first-of-type td`, null, tds => {\n    return tds.map((td, index) => ({\n      colClass: td.getAttribute('class'),\n      index,\n    }));\n  });\n\n  for (const typeClassObj of typeClassesObjs) {\n    if (typeClassObj.colClass) {\n      result[typeClassObj.colClass] = typeClassObj.index;\n    }\n  }\n  return result;\n}\n\nfunction extractTransaction(\n  txns: ScrapedTransaction[],\n  transactionStatus: TransactionStatuses,\n  txnRow: TransactionsTr,\n  transactionsColsTypes: TransactionsColsTypes,\n) {\n  const txn = extractTransactionDetails(txnRow, transactionStatus, transactionsColsTypes);\n  if (txn.date !== '') {\n    txns.push(txn);\n  }\n}\n\nasync function extractTransactions(page: Page | Frame, tableLocator: string, transactionStatus: TransactionStatuses) {\n  const txns: ScrapedTransaction[] = [];\n  const transactionsColsTypes = await getTransactionsColsTypeClasses(page, tableLocator);\n\n  const transactionsRows = await pageEvalAll<TransactionsTr[]>(page, `${tableLocator} tbody tr`, [], trs => {\n    return trs.map(tr => ({\n      innerTds: Array.from(tr.getElementsByTagName('td')).map(td => td.innerText),\n    }));\n  });\n\n  for (const txnRow of transactionsRows) {\n    extractTransaction(txns, transactionStatus, txnRow, transactionsColsTypes);\n  }\n  return txns;\n}\n\nasync function isNoTransactionInDateRangeError(page: Page | Frame) {\n  const hasErrorInfoElement = await elementPresentOnPage(page, `.${ERROR_MESSAGE_CLASS}`);\n  if (hasErrorInfoElement) {\n    const errorText = await page.$eval(`.${ERROR_MESSAGE_CLASS}`, errorElement => {\n      return (errorElement as HTMLElement).innerText;\n    });\n    return errorText.trim() === NO_TRANSACTION_IN_DATE_RANGE_TEXT;\n  }\n  return false;\n}\n\nasync function searchByDates(page: Page | Frame, startDate: Moment) {\n  await clickButton(page, 'a#tabHeader4');\n  await waitUntilElementFound(page, 'div#fibi_dates');\n  await fillInput(page, 'input#fromDate', startDate.format(DATE_FORMAT));\n  await clickButton(page, `button[class*=${CLOSE_SEARCH_BY_DATES_BUTTON_CLASS}]`);\n  await clickButton(page, `input[value=${SHOW_SEARCH_BY_DATES_BUTTON_VALUE}]`);\n  await waitForNavigation(page);\n}\n\nasync function getAccountNumber(page: Page | Frame): Promise<string> {\n  // Wait until the account number element is present in the DOM\n  await waitUntilElementFound(page, ACCOUNTS_NUMBER, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  const selectedSnifAccount = await page.$eval(ACCOUNTS_NUMBER, option => {\n    return (option as HTMLElement).innerText;\n  });\n\n  return selectedSnifAccount.replace('/', '_').trim();\n}\n\nasync function checkIfHasNextPage(page: Page | Frame) {\n  return elementPresentOnPage(page, NEXT_PAGE_LINK);\n}\n\nasync function navigateToNextPage(page: Page | Frame) {\n  await clickButton(page, NEXT_PAGE_LINK);\n  await waitForNavigation(page);\n}\n\n/* Couldn't reproduce scenario with multiple pages of pending transactions - Should support if exists such case.\n   needToPaginate is false if scraping pending transactions */\nasync function scrapeTransactions(\n  page: Page | Frame,\n  tableLocator: string,\n  transactionStatus: TransactionStatuses,\n  needToPaginate: boolean,\n  options?: ScraperOptions,\n) {\n  const txns = [];\n  let hasNextPage = false;\n\n  do {\n    const currentPageTxns = await extractTransactions(page, tableLocator, transactionStatus);\n    txns.push(...currentPageTxns);\n    if (needToPaginate) {\n      hasNextPage = await checkIfHasNextPage(page);\n      if (hasNextPage) {\n        await navigateToNextPage(page);\n      }\n    }\n  } while (hasNextPage);\n\n  return convertTransactions(txns, options);\n}\n\nasync function getAccountTransactions(page: Page | Frame, options?: ScraperOptions) {\n  await Promise.race([\n    waitUntilElementFound(page, \"div[id*='divTable']\", false),\n    waitUntilElementFound(page, `.${ERROR_MESSAGE_CLASS}`, false),\n  ]);\n\n  const noTransactionInRangeError = await isNoTransactionInDateRangeError(page);\n  if (noTransactionInRangeError) {\n    return [];\n  }\n\n  const pendingTxns = await scrapeTransactions(\n    page,\n    PENDING_TRANSACTIONS_TABLE,\n    TransactionStatuses.Pending,\n    false,\n    options,\n  );\n  const completedTxns = await scrapeTransactions(\n    page,\n    COMPLETED_TRANSACTIONS_TABLE,\n    TransactionStatuses.Completed,\n    true,\n    options,\n  );\n  const txns = [...pendingTxns, ...completedTxns];\n  return txns;\n}\n\nasync function getCurrentBalance(page: Page | Frame): Promise<number> {\n  // Wait for the balance element to appear and be visible\n  await waitUntilElementFound(page, CURRENT_BALANCE, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  // Extract text content\n  const balanceStr = await page.$eval(CURRENT_BALANCE, el => {\n    return (el as HTMLElement).innerText;\n  });\n\n  return getAmountData(balanceStr);\n}\n\nexport async function waitForPostLogin(page: Page) {\n  return Promise.race([\n    waitUntilElementFound(page, '#card-header', false), // New UI\n    waitUntilElementFound(page, '#account_num', true), // New UI\n    waitUntilElementFound(page, '#matafLogoutLink', true), // Old UI\n    waitUntilElementFound(page, '#validationMsg', true), // Old UI\n  ]);\n}\n\nasync function fetchAccountData(page: Page | Frame, startDate: Moment, options?: ScraperOptions) {\n  const accountNumber = await getAccountNumber(page);\n  const balance = await getCurrentBalance(page);\n  await searchByDates(page, startDate);\n  const txns = await getAccountTransactions(page, options);\n\n  return {\n    accountNumber,\n    txns,\n    balance,\n  };\n}\n\nasync function getAccountIdsOldUI(page: Page): Promise<string[]> {\n  return page.evaluate(() => {\n    const selectElement = document.getElementById('account_num_select');\n    const options = selectElement ? selectElement.querySelectorAll('option') : [];\n    if (!options) return [];\n    return Array.from(options, option => option.value);\n  });\n}\n\n/**\n * Ensures the account dropdown is open, then returns the available account labels.\n *\n * This method:\n * - Checks if the dropdown is already open.\n * - If not open, clicks the account selector to open it.\n * - Waits for the dropdown to render.\n * - Extracts and returns the list of available account labels.\n *\n * Graceful handling:\n * - If any error occurs (e.g., selectors not found, timing issues, UI version changes),\n *   the function returns an empty list.\n *\n * @param page Puppeteer Page object.\n * @returns An array of available account labels (e.g., [\"127 | XXXX1\", \"127 | XXXX2\"]),\n *          or an empty array if something goes wrong.\n */\nexport async function clickAccountSelectorGetAccountIds(page: Page): Promise<string[]> {\n  try {\n    const accountSelector = 'div.current-account'; // Direct selector to clickable element\n    const dropdownPanelSelector = 'div.mat-mdc-autocomplete-panel.account-select-dd'; // The dropdown list box\n    const optionSelector = 'mat-option .mdc-list-item__primary-text'; // Account option labels\n\n    // Check if dropdown is already open\n    const dropdownVisible = await page\n      .$eval(dropdownPanelSelector, el => {\n        return el && window.getComputedStyle(el).display !== 'none' && el.offsetParent !== null;\n      })\n      .catch(() => false); // catch if dropdown is not in the DOM yet\n\n    if (!dropdownVisible) {\n      await waitUntilElementFound(page, accountSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n      // Click the account selector to open the dropdown\n      await clickButton(page, accountSelector);\n\n      // Wait for the dropdown to open\n      await waitUntilElementFound(page, dropdownPanelSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n    }\n\n    // Extract account labels from the dropdown options\n    const accountLabels = await page.$$eval(optionSelector, options => {\n      return options.map(option => option.textContent?.trim() || '').filter(label => label !== '');\n    });\n\n    return accountLabels;\n  } catch (error) {\n    return []; // Graceful fallback\n  }\n}\n\nasync function getAccountIdsBothUIs(page: Page): Promise<string[]> {\n  let accountsIds: string[] = await clickAccountSelectorGetAccountIds(page);\n  if (accountsIds.length === 0) {\n    accountsIds = await getAccountIdsOldUI(page);\n  }\n  return accountsIds;\n}\n\n/**\n * Selects an account from the dropdown based on the provided account label.\n *\n * This method:\n * - Clicks the account selector button to open the dropdown.\n * - Retrieves the list of available account labels.\n * - Checks if the provided account label exists in the list.\n * - Finds and clicks the matching account option if found.\n *\n * @param page Puppeteer Page object.\n * @param accountLabel The text of the account to select (e.g., \"127 | XXXXX\").\n * @returns True if the account option was found and clicked; false otherwise.\n */\nexport async function selectAccountFromDropdown(page: Page, accountLabel: string): Promise<boolean> {\n  // Call clickAccountSelector to get the available accounts and open the dropdown\n  const availableAccounts = await clickAccountSelectorGetAccountIds(page);\n\n  // Check if the account label exists in the available accounts\n  if (!availableAccounts.includes(accountLabel)) {\n    return false;\n  }\n\n  // Wait for the dropdown options to be rendered\n  const optionSelector = 'mat-option .mdc-list-item__primary-text';\n  await waitUntilElementFound(page, optionSelector, true, ELEMENT_RENDER_TIMEOUT_MS);\n\n  // Query all matching options\n  const accountOptions = await page.$$(optionSelector);\n\n  // Find and click the option matching the accountLabel\n  for (const option of accountOptions) {\n    const text = await page.evaluate(el => el.textContent?.trim(), option);\n\n    if (text === accountLabel) {\n      const optionHandle = await option.evaluateHandle(el => el as HTMLElement);\n      await page.evaluate((el: HTMLElement) => el.click(), optionHandle);\n      return true;\n    }\n  }\n\n  return false;\n}\n\nasync function getTransactionsFrame(page: Page): Promise<Frame | null> {\n  // Try a few times to find the iframe, as it might not be immediately available\n  for (let attempt = 0; attempt < 3; attempt++) {\n    await sleep(2000);\n    const frames = page.frames();\n    const targetFrame = frames.find(f => f.name() === IFRAME_NAME);\n\n    if (targetFrame) {\n      return targetFrame;\n    }\n  }\n\n  return null;\n}\n\nasync function selectAccountBothUIs(page: Page, accountId: string): Promise<void> {\n  const accountSelected = await selectAccountFromDropdown(page, accountId);\n  if (!accountSelected) {\n    // Old UI format\n    await page.select('#account_num_select', accountId);\n    await waitUntilElementFound(page, '#account_num_select', true);\n  }\n}\n\nasync function fetchAccountDataBothUIs(\n  page: Page,\n  startDate: Moment,\n  options?: ScraperOptions,\n): Promise<TransactionsAccount> {\n  // Try to get the iframe for the new UI\n  const frame = await getTransactionsFrame(page);\n\n  // Use the frame if available (new UI), otherwise use the page directly (old UI)\n  const targetPage = frame || page;\n  return fetchAccountData(targetPage, startDate, options);\n}\n\nasync function fetchAccounts(page: Page, startDate: Moment, options?: ScraperOptions): Promise<TransactionsAccount[]> {\n  const accountsIds = await getAccountIdsBothUIs(page);\n\n  if (accountsIds.length === 0) {\n    // In case accountsIds could no be parsed just return the transactions of the currently selected account\n    const accountData = await fetchAccountDataBothUIs(page, startDate, options);\n    return [accountData];\n  }\n\n  const accounts: TransactionsAccount[] = [];\n  for (const accountId of accountsIds) {\n    await selectAccountBothUIs(page, accountId);\n    const accountData = await fetchAccountDataBothUIs(page, startDate, options);\n    accounts.push(accountData);\n  }\n\n  return accounts;\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass BeinleumiGroupBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  BASE_URL = '';\n\n  LOGIN_URL = '';\n\n  TRANSACTIONS_URL = '';\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${this.LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#continueBtn',\n      postAction: async () => waitForPostLogin(this.page),\n      possibleResults: getPossibleLoginResults(),\n      // HACK: For some reason, though the login button (#continueBtn) is present and visible, the click action does not perform.\n      // Adding this delay fixes the issue.\n      preAction: async () => {\n        await sleep(1000);\n      },\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startMomentLimit = moment({ year: 1600 });\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(startMomentLimit, moment(startDate));\n\n    await this.navigateTo(this.TRANSACTIONS_URL);\n\n    const accounts = await fetchAccounts(this.page, startMoment, this.options);\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default BeinleumiGroupBaseScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -89,7 +89,7 @@ function getInstallmentsInfo(txn) {
89
89
  function getTransactionType(txn) {
90
90
  return getInstallmentsInfo(txn) ? _transactions2.TransactionTypes.Installments : _transactions2.TransactionTypes.Normal;
91
91
  }
92
- function convertTransactions(txns, processedDate) {
92
+ function convertTransactions(txns, processedDate, options) {
93
93
  const filteredTxns = txns.filter(txn => txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000');
94
94
  return filteredTxns.map(txn => {
95
95
  const isOutbound = txn.dealSumOutbound;
@@ -110,6 +110,9 @@ function convertTransactions(txns, processedDate) {
110
110
  installments: getInstallmentsInfo(txn) || undefined,
111
111
  status: _transactions2.TransactionStatuses.Completed
112
112
  };
113
+ if (options?.includeRawTransaction) {
114
+ result.rawTransaction = txn;
115
+ }
113
116
  return result;
114
117
  });
115
118
  }
@@ -127,11 +130,11 @@ async function fetchTransactions(page, options, companyServiceOptions, startMome
127
130
  let allTxns = [];
128
131
  txnGroups.forEach(txnGroup => {
129
132
  if (txnGroup.txnIsrael) {
130
- const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);
133
+ const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate, options);
131
134
  allTxns.push(...txns);
132
135
  }
133
136
  if (txnGroup.txnAbroad) {
134
- const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);
137
+ const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate, options);
135
138
  allTxns.push(...txns);
136
139
  }
137
140
  });
@@ -321,4 +324,4 @@ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBro
321
324
  }
322
325
  }
323
326
  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-core';\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":[]}
327
+ //# 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","options","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","includeRawTransaction","rawTransaction","fetchTransactions","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-core';\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(\n  txns: ScrapedTransaction[],\n  processedDate: string,\n  options?: ScraperOptions,\n): 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    if (options?.includeRawTransaction) {\n      result.rawTransaction = txn;\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, options);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate, options);\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":[]}
@@ -39,7 +39,9 @@ declare class BaseScraperWithBrowser<TCredentials extends ScraperCredentials> ex
39
39
  private defaultViewportSize;
40
40
  protected page: Page;
41
41
  protected getViewPort(): {
42
- width: number;
42
+ width: number; /**
43
+ * For backward compatibility, we will close the browser even if we didn't create it
44
+ */
43
45
  height: number;
44
46
  };
45
47
  initialize(): Promise<void>;