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.
@@ -112,7 +112,7 @@ function createLoginFields(credentials) {
112
112
  value: credentials.password
113
113
  }];
114
114
  }
115
- function convertParsedDataToTransactions(data, pendingData) {
115
+ function convertParsedDataToTransactions(data, pendingData, options) {
116
116
  const pendingTransactions = pendingData?.result ? pendingData.result.cardsList.flatMap(card => card.authDetalisList) : [];
117
117
  const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);
118
118
  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);
@@ -145,6 +145,9 @@ function convertParsedDataToTransactions(data, pendingData) {
145
145
  if (installments) {
146
146
  result.installments = installments;
147
147
  }
148
+ if (options?.includeRawTransaction) {
149
+ result.rawTransaction = transaction;
150
+ }
148
151
  return result;
149
152
  });
150
153
  }
@@ -259,7 +262,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
259
262
  const finalMonthToFetchMoment = (0, _moment.default)().add(futureMonthsToScrape, 'month');
260
263
  const months = finalMonthToFetchMoment.diff(startMoment, 'months');
261
264
  const allMonthsData = [];
262
- const frame = _lodash.default.find(frames.result.bankIssuedCards.cardLevelFrames, {
265
+ const frame = _lodash.default.find(frames.result.bankIssuedCards?.cardLevelFrames, {
263
266
  cardUniqueId: card.cardUniqueId
264
267
  });
265
268
  debug(`fetch pending transactions for card ${card.cardUniqueId}`);
@@ -297,7 +300,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
297
300
  debug('pendingData is not of type CardTransactionDetails');
298
301
  pendingData = null;
299
302
  }
300
- const transactions = convertParsedDataToTransactions(allMonthsData, pendingData);
303
+ const transactions = convertParsedDataToTransactions(allMonthsData, pendingData, this.options);
301
304
  debug('filter out old transactions');
302
305
  const txns = this.options.outputData?.enableTransactionsFilterByDate ?? true ? (0, _transactions.filterOldTransactions)(transactions, (0, _moment.default)(startDate), this.options.combineInstallments || false) : transactions;
303
306
  return {
@@ -315,4 +318,4 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
315
318
  }
316
319
  }
317
320
  var _default = exports.default = VisaCalScraper;
318
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_navigation","_storage","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_lodash","e","__esModule","default","apiHeaders","Origin","Referer","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","FRAMES_REQUEST_ENDPOINT","PENDING_TRANSACTIONS_REQUEST_ENDPOINT","SSO_AUTHORIZATION_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","isAuthModule","result","Boolean","auth","calConnectToken","String","trim","authModuleOrUndefined","undefined","isPending","transaction","debCrdDate","isCardTransactionDetails","isCardPendingTransactionDetails","getLoginFrame","page","frame","waitUntil","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","elementPresentOnPage","errorMessage","pageEval","item","innerText","hasChangePasswordForm","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","ChangePassword","createLoginFields","credentials","selector","value","username","password","convertParsedDataToTransactions","data","pendingData","pendingTransactions","cardsList","flatMap","card","authDetalisList","bankAccounts","monthData","regularDebitDays","accounts","debitDates","immediateDebitDays","immidiateDebits","debitDays","completedTransactions","debitDate","transactions","all","map","numOfPayments","numberOfPayments","installments","number","curPaymentNum","total","date","moment","trnPurchaseDate","chargedAmount","trnAmt","amtBeforeConvAndIndex","originalAmount","trnTypeCode","credit","identifier","trnIntId","type","regular","standingOrder","TransactionTypes","Normal","Installments","status","TransactionStatuses","Pending","Completed","add","toISOString","processedDate","Date","originalCurrency","trnCurrencySymbol","chargedCurrency","debCrdCurrencySymbol","description","merchantName","memo","transTypeCommentDetails","toString","category","branchCodeDesc","VisaCalScraper","BaseScraperWithBrowser","authorization","openLoginPopup","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","getXSiteId","getLoginOptions","authRequestPromise","waitForRequest","timeout","catch","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","postAction","waitForNavigation","currentUrl","getCurrentUrl","endsWith","request","headers","requiresChangePassword","userAgent","fetchData","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","xSiteId","Authorization","futureMonthsToScrape","fetchPost","cardsForFrameData","finalMonthToFetchMoment","months","diff","allMonthsData","_","bankIssuedCards","cardLevelFrames","cardUniqueIDArray","i","month","clone","year","statusCode","title","push","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","balance","nextTotalDebit","accountNumber","JSON","stringify","success","_default","exports"],"sources":["../../src/scrapers/visa-cal.ts"],"sourcesContent":["import moment from 'moment';\nimport { type HTTPRequest, type Frame, type Page } from 'puppeteer-core';\nimport { getDebug } from '../helpers/debug';\nimport { clickButton, elementPresentOnPage, pageEval, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPost } from '../helpers/fetch';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult } from './interface';\nimport _ from 'lodash';\n\nconst apiHeaders = {\n  'User-Agent':\n    'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/142.0.0.0 Safari/537.36',\n  Origin: 'https://digital-web.cal-online.co.il',\n  Referer: 'https://digital-web.cal-online.co.il',\n  'Accept-Language': 'he-IL,he;q=0.9,en-US;q=0.8,en;q=0.7',\n  'Sec-Fetch-Site': 'same-site',\n  'Sec-Fetch-Mode': 'cors',\n  'Sec-Fetch-Dest': 'empty',\n};\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\nconst FRAMES_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Frames/api/Frames/GetFrameStatus';\nconst PENDING_TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';\nconst SSO_AUTHORIZATION_REQUEST_ENDPOINT = 'https://connect.cal-online.co.il/col-rest/calconnect/authentication/SSO';\n\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\nenum TrnTypeCode {\n  regular = '5',\n  credit = '6',\n  installments = '8',\n  standingOrder = '9',\n}\n\ninterface ScrapedTransaction {\n  amtBeforeConvAndIndex: number;\n  branchCodeDesc: string;\n  cashAccManagerName: null;\n  cashAccountManager: null;\n  cashAccountTrnAmt: number;\n  chargeExternalToCardComment: string;\n  comments: [];\n  curPaymentNum: number;\n  debCrdCurrencySymbol: CurrencySymbol;\n  debCrdDate: string;\n  debitSpreadInd: boolean;\n  discountAmount: unknown;\n  discountReason: unknown;\n  immediateComments: [];\n  isImmediateCommentInd: boolean;\n  isImmediateHHKInd: boolean;\n  isMargarita: boolean;\n  isSpreadPaymenstAbroad: boolean;\n  linkedComments: [];\n  merchantAddress: string;\n  merchantName: string;\n  merchantPhoneNo: string;\n  numOfPayments: number;\n  onGoingTransactionsComment: string;\n  refundInd: boolean;\n  roundingAmount: unknown;\n  roundingReason: unknown;\n  tokenInd: 0;\n  tokenNumberPart4: '';\n  transCardPresentInd: boolean;\n  transTypeCommentDetails: [];\n  trnAmt: number;\n  trnCurrencySymbol: CurrencySymbol;\n  trnExacWay: number;\n  trnIntId: string;\n  trnNumaretor: number;\n  trnPurchaseDate: string;\n  trnType: string;\n  trnTypeCode: TrnTypeCode;\n  walletProviderCode: 0;\n  walletProviderDesc: '';\n  earlyPaymentInd: boolean;\n}\ninterface ScrapedPendingTransaction {\n  merchantID: string;\n  merchantName: string;\n  trnPurchaseDate: string;\n  walletTranInd: number;\n  transactionsOrigin: number;\n  trnAmt: number;\n  tpaApprovalAmount: unknown;\n  trnCurrencySymbol: CurrencySymbol;\n  trnTypeCode: TrnTypeCode;\n  trnType: string;\n  branchCodeDesc: string;\n  transCardPresentInd: boolean;\n  j5Indicator: string;\n  numberOfPayments: number;\n  firstPaymentAmount: number;\n  transTypeCommentDetails: [];\n}\ninterface InitResponse {\n  result: {\n    cards: {\n      cardUniqueId: string;\n      last4Digits: string;\n      [key: string]: unknown;\n    }[];\n  };\n}\ntype CurrencySymbol = string;\ninterface CardTransactionDetailsError {\n  title: string;\n  statusCode: number;\n}\ninterface CardTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    bankAccounts: {\n      bankAccountNum: string;\n      bankName: string;\n      choiceExternalTransactions: any;\n      currentBankAccountInd: boolean;\n      debitDates: {\n        basketAmountComment: unknown;\n        choiceHHKDebit: number;\n        date: string;\n        debitReason: unknown;\n        fixDebitAmount: number;\n        fromPurchaseDate: string;\n        isChoiceRepaiment: boolean;\n        toPurchaseDate: string;\n        totalBasketAmount: number;\n        totalDebits: {\n          currencySymbol: CurrencySymbol;\n          amount: number;\n        }[];\n        transactions: ScrapedTransaction[];\n      }[];\n      immidiateDebits: { totalDebits: []; debitDays: [] };\n    }[];\n    blockedCardInd: boolean;\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\ninterface CardPendingTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    cardsList: {\n      cardUniqueID: string;\n      authDetalisList: ScrapedPendingTransaction[];\n    }[];\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\n\ninterface AuthModule {\n  auth: {\n    calConnectToken: string | null;\n  };\n}\n\nfunction isAuthModule(result: any): result is AuthModule {\n  return Boolean(result?.auth?.calConnectToken && String(result.auth.calConnectToken).trim());\n}\n\nfunction authModuleOrUndefined(result: any): AuthModule | undefined {\n  return isAuthModule(result) ? result : undefined;\n}\n\nfunction isPending(\n  transaction: ScrapedTransaction | ScrapedPendingTransaction,\n): transaction is ScrapedPendingTransaction {\n  return (transaction as ScrapedTransaction).debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction\n}\n\nfunction isCardTransactionDetails(\n  result: CardTransactionDetails | CardTransactionDetailsError,\n): result is CardTransactionDetails {\n  return (result as CardTransactionDetails).result !== undefined;\n}\n\nfunction isCardPendingTransactionDetails(\n  result: CardPendingTransactionDetails | CardTransactionDetailsError,\n): result is CardPendingTransactionDetails {\n  return (result as CardPendingTransactionDetails).result !== undefined;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(\n    () => {\n      frame = page.frames().find(f => f.url().includes('connect')) || null;\n      return Promise.resolve(!!frame);\n    },\n    'wait for iframe with login form',\n    10000,\n    1000,\n  );\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound\n    ? await pageEval(frame, 'div.general-error > div', '', item => {\n        return (item as HTMLDivElement).innerText;\n      })\n    : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nasync function hasChangePasswordForm(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, '.change-password-subtitle');\n  return errorFound;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/dashboard/i],\n    [LoginResults.InvalidPassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasInvalidPasswordError(page);\n      },\n    ],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasChangePasswordForm(page);\n      },\n    ],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\nfunction convertParsedDataToTransactions(\n  data: CardTransactionDetails[],\n  pendingData?: CardPendingTransactionDetails | null,\n): Transaction[] {\n  const pendingTransactions = pendingData?.result\n    ? pendingData.result.cardsList.flatMap(card => card.authDetalisList)\n    : [];\n\n  const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);\n  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);\n  const immediateDebitDays = bankAccounts.flatMap(accounts => accounts.immidiateDebits.debitDays);\n  const completedTransactions = [...regularDebitDays, ...immediateDebitDays].flatMap(\n    debitDate => debitDate.transactions,\n  );\n\n  const all: (ScrapedTransaction | ScrapedPendingTransaction)[] = [...pendingTransactions, ...completedTransactions];\n\n  return all.map(transaction => {\n    const numOfPayments = isPending(transaction) ? transaction.numberOfPayments : transaction.numOfPayments;\n    const installments = numOfPayments\n      ? {\n          number: isPending(transaction) ? 1 : transaction.curPaymentNum,\n          total: numOfPayments,\n        }\n      : undefined;\n\n    const date = moment(transaction.trnPurchaseDate);\n\n    const chargedAmount = (isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex) * -1;\n    const originalAmount = transaction.trnAmt * (transaction.trnTypeCode === TrnTypeCode.credit ? 1 : -1);\n\n    const result: Transaction = {\n      identifier: !isPending(transaction) ? transaction.trnIntId : undefined,\n      type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode)\n        ? TransactionTypes.Normal\n        : TransactionTypes.Installments,\n      status: isPending(transaction) ? TransactionStatuses.Pending : TransactionStatuses.Completed,\n      date: installments ? date.add(installments.number - 1, 'month').toISOString() : date.toISOString(),\n      processedDate: isPending(transaction) ? date.toISOString() : new Date(transaction.debCrdDate).toISOString(),\n      originalAmount,\n      originalCurrency: transaction.trnCurrencySymbol,\n      chargedAmount,\n      chargedCurrency: !isPending(transaction) ? transaction.debCrdCurrencySymbol : undefined,\n      description: transaction.merchantName,\n      memo: transaction.transTypeCommentDetails.toString(),\n      category: transaction.branchCodeDesc,\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    return result;\n  });\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass VisaCalScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private authorization: string | undefined = undefined;\n\n  private authRequestPromise: Promise<HTTPRequest | undefined> | undefined;\n\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  async getCards() {\n    const initData = await waitUntil(\n      () => getFromSessionStorage<InitResponse>(this.page, 'init'),\n      'get init data in session storage',\n      10000,\n      1000,\n    );\n    if (!initData) {\n      throw new Error('could not find \"init\" data in session storage');\n    }\n    return initData?.result.cards.map(({ cardUniqueId, last4Digits }) => ({ cardUniqueId, last4Digits }));\n  }\n\n  async getAuthorizationHeader() {\n    if (!this.authorization) {\n      debug('fetching authorization header');\n      const authModule = await waitUntil(\n        async () => authModuleOrUndefined(await getFromSessionStorage<AuthModule>(this.page, 'auth-module')),\n        'get authorization header with valid token in session storage',\n        10_000,\n        50,\n      );\n      return `CALAuthScheme ${authModule.auth.calConnectToken}`;\n    }\n    return this.authorization;\n  }\n\n  async getXSiteId() {\n    /*\n      I don't know if the constant below will change in the feature.\n      If so, use the next code:\n\n      return this.page.evaluate(() => new Ut().xSiteId);\n\n      To get the classname search for 'xSiteId' in the page source\n      class Ut {\n        constructor(_e, on, yn) {\n            this.store = _e,\n            this.config = on,\n            this.eventBusService = yn,\n            this.xSiteId = \"09031987-273E-2311-906C-8AF85B17C8D9\",\n    */\n    return Promise.resolve('09031987-273E-2311-906C-8AF85B17C8D9');\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    this.authRequestPromise = this.page\n      .waitForRequest(SSO_AUTHORIZATION_REQUEST_ENDPOINT, { timeout: 10_000 })\n      .catch(e => {\n        debug('error while waiting for the token request', e);\n        return undefined;\n      });\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      postAction: async () => {\n        try {\n          await waitForNavigation(this.page);\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\n          const request = await this.authRequestPromise;\n          this.authorization = String(request?.headers().authorization || '').trim();\n        } catch (e) {\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('dashboard')) return;\n          const requiresChangePassword = await hasChangePasswordForm(this.page);\n          if (requiresChangePassword) return;\n          throw e;\n        }\n      },\n      userAgent: apiHeaders['User-Agent'],\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').subtract(6, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    const [cards, xSiteId, Authorization] = await Promise.all([\n      this.getCards(),\n      this.getXSiteId(),\n      this.getAuthorizationHeader(),\n    ]);\n\n    const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;\n\n    debug('fetch frames (misgarot) of cards');\n    const frames = await fetchPost(\n      FRAMES_REQUEST_ENDPOINT,\n      { cardsForFrameData: cards.map(({ cardUniqueId }) => ({ cardUniqueId })) },\n      {\n        Authorization,\n        'X-Site-Id': xSiteId,\n        'Content-Type': 'application/json',\n        ...apiHeaders,\n      },\n    );\n\n    const accounts = await Promise.all(\n      cards.map(async card => {\n        const finalMonthToFetchMoment = moment().add(futureMonthsToScrape, 'month');\n        const months = finalMonthToFetchMoment.diff(startMoment, 'months');\n        const allMonthsData: CardTransactionDetails[] = [];\n        const frame = _.find(frames.result.bankIssuedCards.cardLevelFrames, { cardUniqueId: card.cardUniqueId });\n\n        debug(`fetch pending transactions for card ${card.cardUniqueId}`);\n        let pendingData = await fetchPost(\n          PENDING_TRANSACTIONS_REQUEST_ENDPOINT,\n          { cardUniqueIDArray: [card.cardUniqueId] },\n          {\n            Authorization,\n            'X-Site-Id': xSiteId,\n            'Content-Type': 'application/json',\n            ...apiHeaders,\n          },\n        );\n\n        debug(`fetch completed transactions for card ${card.cardUniqueId}`);\n        for (let i = 0; i <= months; i++) {\n          const month = finalMonthToFetchMoment.clone().subtract(i, 'months');\n          const monthData = await fetchPost(\n            TRANSACTIONS_REQUEST_ENDPOINT,\n            { cardUniqueId: card.cardUniqueId, month: month.format('M'), year: month.format('YYYY') },\n            {\n              Authorization,\n              'X-Site-Id': xSiteId,\n              'Content-Type': 'application/json',\n              ...apiHeaders,\n            },\n          );\n\n          if (monthData?.statusCode !== 1)\n            throw new Error(\n              `failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`,\n            );\n\n          if (!isCardTransactionDetails(monthData)) {\n            throw new Error('monthData is not of type CardTransactionDetails');\n          }\n\n          allMonthsData.push(monthData);\n        }\n\n        if (pendingData?.statusCode !== 1 && pendingData?.statusCode !== 96) {\n          debug(\n            `failed to fetch pending transactions for card ${card.last4Digits}. Message: ${pendingData?.title || ''}`,\n          );\n          pendingData = null;\n        } else if (!isCardPendingTransactionDetails(pendingData)) {\n          debug('pendingData is not of type CardTransactionDetails');\n          pendingData = null;\n        }\n\n        const transactions = convertParsedDataToTransactions(allMonthsData, pendingData);\n\n        debug('filter out old transactions');\n        const txns =\n          (this.options.outputData?.enableTransactionsFilterByDate ?? true)\n            ? filterOldTransactions(transactions, moment(startDate), this.options.combineInstallments || false)\n            : transactions;\n\n        return {\n          txns,\n          balance: -frame?.nextTotalDebit,\n          accountNumber: card.last4Digits,\n        } as TransactionsAccount;\n      }),\n    );\n\n    debug('return the scraped accounts');\n\n    debug(JSON.stringify(accounts, null, 2));\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"],"mappings":"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","ignoreList":[]}
321
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_navigation","_storage","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_lodash","e","__esModule","default","apiHeaders","Origin","Referer","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","FRAMES_REQUEST_ENDPOINT","PENDING_TRANSACTIONS_REQUEST_ENDPOINT","SSO_AUTHORIZATION_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","isAuthModule","result","Boolean","auth","calConnectToken","String","trim","authModuleOrUndefined","undefined","isPending","transaction","debCrdDate","isCardTransactionDetails","isCardPendingTransactionDetails","getLoginFrame","page","frame","waitUntil","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","elementPresentOnPage","errorMessage","pageEval","item","innerText","hasChangePasswordForm","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","ChangePassword","createLoginFields","credentials","selector","value","username","password","convertParsedDataToTransactions","data","pendingData","pendingTransactions","cardsList","flatMap","card","authDetalisList","bankAccounts","monthData","regularDebitDays","accounts","debitDates","immediateDebitDays","immidiateDebits","debitDays","completedTransactions","debitDate","transactions","all","map","numOfPayments","numberOfPayments","installments","number","curPaymentNum","total","date","moment","trnPurchaseDate","chargedAmount","trnAmt","amtBeforeConvAndIndex","originalAmount","trnTypeCode","credit","identifier","trnIntId","type","regular","standingOrder","TransactionTypes","Normal","Installments","status","TransactionStatuses","Pending","Completed","add","toISOString","processedDate","Date","originalCurrency","trnCurrencySymbol","chargedCurrency","debCrdCurrencySymbol","description","merchantName","memo","transTypeCommentDetails","toString","category","branchCodeDesc","includeRawTransaction","rawTransaction","VisaCalScraper","BaseScraperWithBrowser","authorization","openLoginPopup","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","getXSiteId","getLoginOptions","authRequestPromise","waitForRequest","timeout","catch","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","postAction","waitForNavigation","currentUrl","getCurrentUrl","endsWith","request","headers","requiresChangePassword","userAgent","fetchData","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","xSiteId","Authorization","futureMonthsToScrape","fetchPost","cardsForFrameData","finalMonthToFetchMoment","months","diff","allMonthsData","_","bankIssuedCards","cardLevelFrames","cardUniqueIDArray","i","month","clone","year","statusCode","title","push","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","balance","nextTotalDebit","accountNumber","JSON","stringify","success","_default","exports"],"sources":["../../src/scrapers/visa-cal.ts"],"sourcesContent":["import moment from 'moment';\nimport { type HTTPRequest, type Frame, type Page } from 'puppeteer-core';\nimport { getDebug } from '../helpers/debug';\nimport { clickButton, elementPresentOnPage, pageEval, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPost } from '../helpers/fetch';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult, type ScraperOptions } from './interface';\nimport _ from 'lodash';\n\nconst apiHeaders = {\n  'User-Agent':\n    'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/142.0.0.0 Safari/537.36',\n  Origin: 'https://digital-web.cal-online.co.il',\n  Referer: 'https://digital-web.cal-online.co.il',\n  'Accept-Language': 'he-IL,he;q=0.9,en-US;q=0.8,en;q=0.7',\n  'Sec-Fetch-Site': 'same-site',\n  'Sec-Fetch-Mode': 'cors',\n  'Sec-Fetch-Dest': 'empty',\n};\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\nconst FRAMES_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Frames/api/Frames/GetFrameStatus';\nconst PENDING_TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';\nconst SSO_AUTHORIZATION_REQUEST_ENDPOINT = 'https://connect.cal-online.co.il/col-rest/calconnect/authentication/SSO';\n\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\nenum TrnTypeCode {\n  regular = '5',\n  credit = '6',\n  installments = '8',\n  standingOrder = '9',\n}\n\ninterface ScrapedTransaction {\n  amtBeforeConvAndIndex: number;\n  branchCodeDesc: string;\n  cashAccManagerName: null;\n  cashAccountManager: null;\n  cashAccountTrnAmt: number;\n  chargeExternalToCardComment: string;\n  comments: [];\n  curPaymentNum: number;\n  debCrdCurrencySymbol: CurrencySymbol;\n  debCrdDate: string;\n  debitSpreadInd: boolean;\n  discountAmount: unknown;\n  discountReason: unknown;\n  immediateComments: [];\n  isImmediateCommentInd: boolean;\n  isImmediateHHKInd: boolean;\n  isMargarita: boolean;\n  isSpreadPaymenstAbroad: boolean;\n  linkedComments: [];\n  merchantAddress: string;\n  merchantName: string;\n  merchantPhoneNo: string;\n  numOfPayments: number;\n  onGoingTransactionsComment: string;\n  refundInd: boolean;\n  roundingAmount: unknown;\n  roundingReason: unknown;\n  tokenInd: 0;\n  tokenNumberPart4: '';\n  transCardPresentInd: boolean;\n  transTypeCommentDetails: [];\n  trnAmt: number;\n  trnCurrencySymbol: CurrencySymbol;\n  trnExacWay: number;\n  trnIntId: string;\n  trnNumaretor: number;\n  trnPurchaseDate: string;\n  trnType: string;\n  trnTypeCode: TrnTypeCode;\n  walletProviderCode: 0;\n  walletProviderDesc: '';\n  earlyPaymentInd: boolean;\n}\ninterface ScrapedPendingTransaction {\n  merchantID: string;\n  merchantName: string;\n  trnPurchaseDate: string;\n  walletTranInd: number;\n  transactionsOrigin: number;\n  trnAmt: number;\n  tpaApprovalAmount: unknown;\n  trnCurrencySymbol: CurrencySymbol;\n  trnTypeCode: TrnTypeCode;\n  trnType: string;\n  branchCodeDesc: string;\n  transCardPresentInd: boolean;\n  j5Indicator: string;\n  numberOfPayments: number;\n  firstPaymentAmount: number;\n  transTypeCommentDetails: [];\n}\ninterface InitResponse {\n  result: {\n    cards: {\n      cardUniqueId: string;\n      last4Digits: string;\n      [key: string]: unknown;\n    }[];\n  };\n}\ntype CurrencySymbol = string;\ninterface CardTransactionDetailsError {\n  title: string;\n  statusCode: number;\n}\ninterface CardTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    bankAccounts: {\n      bankAccountNum: string;\n      bankName: string;\n      choiceExternalTransactions: any;\n      currentBankAccountInd: boolean;\n      debitDates: {\n        basketAmountComment: unknown;\n        choiceHHKDebit: number;\n        date: string;\n        debitReason: unknown;\n        fixDebitAmount: number;\n        fromPurchaseDate: string;\n        isChoiceRepaiment: boolean;\n        toPurchaseDate: string;\n        totalBasketAmount: number;\n        totalDebits: {\n          currencySymbol: CurrencySymbol;\n          amount: number;\n        }[];\n        transactions: ScrapedTransaction[];\n      }[];\n      immidiateDebits: { totalDebits: []; debitDays: [] };\n    }[];\n    blockedCardInd: boolean;\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\ninterface CardPendingTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    cardsList: {\n      cardUniqueID: string;\n      authDetalisList: ScrapedPendingTransaction[];\n    }[];\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\n\ninterface AuthModule {\n  auth: {\n    calConnectToken: string | null;\n  };\n}\n\nfunction isAuthModule(result: any): result is AuthModule {\n  return Boolean(result?.auth?.calConnectToken && String(result.auth.calConnectToken).trim());\n}\n\nfunction authModuleOrUndefined(result: any): AuthModule | undefined {\n  return isAuthModule(result) ? result : undefined;\n}\n\nfunction isPending(\n  transaction: ScrapedTransaction | ScrapedPendingTransaction,\n): transaction is ScrapedPendingTransaction {\n  return (transaction as ScrapedTransaction).debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction\n}\n\nfunction isCardTransactionDetails(\n  result: CardTransactionDetails | CardTransactionDetailsError,\n): result is CardTransactionDetails {\n  return (result as CardTransactionDetails).result !== undefined;\n}\n\nfunction isCardPendingTransactionDetails(\n  result: CardPendingTransactionDetails | CardTransactionDetailsError,\n): result is CardPendingTransactionDetails {\n  return (result as CardPendingTransactionDetails).result !== undefined;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(\n    () => {\n      frame = page.frames().find(f => f.url().includes('connect')) || null;\n      return Promise.resolve(!!frame);\n    },\n    'wait for iframe with login form',\n    10000,\n    1000,\n  );\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound\n    ? await pageEval(frame, 'div.general-error > div', '', item => {\n        return (item as HTMLDivElement).innerText;\n      })\n    : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nasync function hasChangePasswordForm(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, '.change-password-subtitle');\n  return errorFound;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/dashboard/i],\n    [LoginResults.InvalidPassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasInvalidPasswordError(page);\n      },\n    ],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasChangePasswordForm(page);\n      },\n    ],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\nfunction convertParsedDataToTransactions(\n  data: CardTransactionDetails[],\n  pendingData?: CardPendingTransactionDetails | null,\n  options?: ScraperOptions,\n): Transaction[] {\n  const pendingTransactions = pendingData?.result\n    ? pendingData.result.cardsList.flatMap(card => card.authDetalisList)\n    : [];\n\n  const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);\n  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);\n  const immediateDebitDays = bankAccounts.flatMap(accounts => accounts.immidiateDebits.debitDays);\n  const completedTransactions = [...regularDebitDays, ...immediateDebitDays].flatMap(\n    debitDate => debitDate.transactions,\n  );\n\n  const all: (ScrapedTransaction | ScrapedPendingTransaction)[] = [...pendingTransactions, ...completedTransactions];\n\n  return all.map(transaction => {\n    const numOfPayments = isPending(transaction) ? transaction.numberOfPayments : transaction.numOfPayments;\n    const installments = numOfPayments\n      ? {\n          number: isPending(transaction) ? 1 : transaction.curPaymentNum,\n          total: numOfPayments,\n        }\n      : undefined;\n\n    const date = moment(transaction.trnPurchaseDate);\n\n    const chargedAmount = (isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex) * -1;\n    const originalAmount = transaction.trnAmt * (transaction.trnTypeCode === TrnTypeCode.credit ? 1 : -1);\n\n    const result: Transaction = {\n      identifier: !isPending(transaction) ? transaction.trnIntId : undefined,\n      type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode)\n        ? TransactionTypes.Normal\n        : TransactionTypes.Installments,\n      status: isPending(transaction) ? TransactionStatuses.Pending : TransactionStatuses.Completed,\n      date: installments ? date.add(installments.number - 1, 'month').toISOString() : date.toISOString(),\n      processedDate: isPending(transaction) ? date.toISOString() : new Date(transaction.debCrdDate).toISOString(),\n      originalAmount,\n      originalCurrency: transaction.trnCurrencySymbol,\n      chargedAmount,\n      chargedCurrency: !isPending(transaction) ? transaction.debCrdCurrencySymbol : undefined,\n      description: transaction.merchantName,\n      memo: transaction.transTypeCommentDetails.toString(),\n      category: transaction.branchCodeDesc,\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = transaction;\n    }\n\n    return result;\n  });\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass VisaCalScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private authorization: string | undefined = undefined;\n\n  private authRequestPromise: Promise<HTTPRequest | undefined> | undefined;\n\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  async getCards() {\n    const initData = await waitUntil(\n      () => getFromSessionStorage<InitResponse>(this.page, 'init'),\n      'get init data in session storage',\n      10000,\n      1000,\n    );\n    if (!initData) {\n      throw new Error('could not find \"init\" data in session storage');\n    }\n    return initData?.result.cards.map(({ cardUniqueId, last4Digits }) => ({ cardUniqueId, last4Digits }));\n  }\n\n  async getAuthorizationHeader() {\n    if (!this.authorization) {\n      debug('fetching authorization header');\n      const authModule = await waitUntil(\n        async () => authModuleOrUndefined(await getFromSessionStorage<AuthModule>(this.page, 'auth-module')),\n        'get authorization header with valid token in session storage',\n        10_000,\n        50,\n      );\n      return `CALAuthScheme ${authModule.auth.calConnectToken}`;\n    }\n    return this.authorization;\n  }\n\n  async getXSiteId() {\n    /*\n      I don't know if the constant below will change in the feature.\n      If so, use the next code:\n\n      return this.page.evaluate(() => new Ut().xSiteId);\n\n      To get the classname search for 'xSiteId' in the page source\n      class Ut {\n        constructor(_e, on, yn) {\n            this.store = _e,\n            this.config = on,\n            this.eventBusService = yn,\n            this.xSiteId = \"09031987-273E-2311-906C-8AF85B17C8D9\",\n    */\n    return Promise.resolve('09031987-273E-2311-906C-8AF85B17C8D9');\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    this.authRequestPromise = this.page\n      .waitForRequest(SSO_AUTHORIZATION_REQUEST_ENDPOINT, { timeout: 10_000 })\n      .catch(e => {\n        debug('error while waiting for the token request', e);\n        return undefined;\n      });\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      postAction: async () => {\n        try {\n          await waitForNavigation(this.page);\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\n          const request = await this.authRequestPromise;\n          this.authorization = String(request?.headers().authorization || '').trim();\n        } catch (e) {\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('dashboard')) return;\n          const requiresChangePassword = await hasChangePasswordForm(this.page);\n          if (requiresChangePassword) return;\n          throw e;\n        }\n      },\n      userAgent: apiHeaders['User-Agent'],\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').subtract(6, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    const [cards, xSiteId, Authorization] = await Promise.all([\n      this.getCards(),\n      this.getXSiteId(),\n      this.getAuthorizationHeader(),\n    ]);\n\n    const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;\n\n    debug('fetch frames (misgarot) of cards');\n    const frames = await fetchPost(\n      FRAMES_REQUEST_ENDPOINT,\n      { cardsForFrameData: cards.map(({ cardUniqueId }) => ({ cardUniqueId })) },\n      {\n        Authorization,\n        'X-Site-Id': xSiteId,\n        'Content-Type': 'application/json',\n        ...apiHeaders,\n      },\n    );\n\n    const accounts = await Promise.all(\n      cards.map(async card => {\n        const finalMonthToFetchMoment = moment().add(futureMonthsToScrape, 'month');\n        const months = finalMonthToFetchMoment.diff(startMoment, 'months');\n        const allMonthsData: CardTransactionDetails[] = [];\n        const frame = _.find(frames.result.bankIssuedCards?.cardLevelFrames, { cardUniqueId: card.cardUniqueId });\n\n        debug(`fetch pending transactions for card ${card.cardUniqueId}`);\n        let pendingData = await fetchPost(\n          PENDING_TRANSACTIONS_REQUEST_ENDPOINT,\n          { cardUniqueIDArray: [card.cardUniqueId] },\n          {\n            Authorization,\n            'X-Site-Id': xSiteId,\n            'Content-Type': 'application/json',\n            ...apiHeaders,\n          },\n        );\n\n        debug(`fetch completed transactions for card ${card.cardUniqueId}`);\n        for (let i = 0; i <= months; i++) {\n          const month = finalMonthToFetchMoment.clone().subtract(i, 'months');\n          const monthData = await fetchPost(\n            TRANSACTIONS_REQUEST_ENDPOINT,\n            { cardUniqueId: card.cardUniqueId, month: month.format('M'), year: month.format('YYYY') },\n            {\n              Authorization,\n              'X-Site-Id': xSiteId,\n              'Content-Type': 'application/json',\n              ...apiHeaders,\n            },\n          );\n\n          if (monthData?.statusCode !== 1)\n            throw new Error(\n              `failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`,\n            );\n\n          if (!isCardTransactionDetails(monthData)) {\n            throw new Error('monthData is not of type CardTransactionDetails');\n          }\n\n          allMonthsData.push(monthData);\n        }\n\n        if (pendingData?.statusCode !== 1 && pendingData?.statusCode !== 96) {\n          debug(\n            `failed to fetch pending transactions for card ${card.last4Digits}. Message: ${pendingData?.title || ''}`,\n          );\n          pendingData = null;\n        } else if (!isCardPendingTransactionDetails(pendingData)) {\n          debug('pendingData is not of type CardTransactionDetails');\n          pendingData = null;\n        }\n\n        const transactions = convertParsedDataToTransactions(allMonthsData, pendingData, this.options);\n\n        debug('filter out old transactions');\n        const txns =\n          (this.options.outputData?.enableTransactionsFilterByDate ?? true)\n            ? filterOldTransactions(transactions, moment(startDate), this.options.combineInstallments || false)\n            : transactions;\n\n        return {\n          txns,\n          balance: -frame?.nextTotalDebit,\n          accountNumber: card.last4Digits,\n        } as TransactionsAccount;\n      }),\n    );\n\n    debug('return the scraped accounts');\n\n    debug(JSON.stringify(accounts, null, 2));\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -55,11 +55,11 @@ function getTxnAmount(txn) {
55
55
  const debit = getAmountData(txn.debit);
56
56
  return (Number.isNaN(credit) ? 0 : credit) - (Number.isNaN(debit) ? 0 : debit);
57
57
  }
58
- function convertTransactions(txns) {
58
+ function convertTransactions(txns, options) {
59
59
  return txns.map(txn => {
60
60
  const convertedDate = (0, _moment.default)(txn.date, DATE_FORMAT).toISOString();
61
61
  const convertedAmount = getTxnAmount(txn);
62
- return {
62
+ const result = {
63
63
  type: _transactions.TransactionTypes.Normal,
64
64
  identifier: txn.reference ? parseInt(txn.reference, 10) : undefined,
65
65
  date: convertedDate,
@@ -71,6 +71,10 @@ function convertTransactions(txns) {
71
71
  description: txn.description,
72
72
  memo: txn.memo
73
73
  };
74
+ if (options?.includeRawTransaction) {
75
+ result.rawTransaction = txn;
76
+ }
77
+ return result;
74
78
  });
75
79
  }
76
80
  function handleTransactionRow(txns, txnRow) {
@@ -89,7 +93,7 @@ function handleTransactionRow(txns, txnRow) {
89
93
  };
90
94
  txns.push(tx);
91
95
  }
92
- async function getAccountTransactions(page) {
96
+ async function getAccountTransactions(page, options) {
93
97
  // Wait for transactions.
94
98
  await (0, _elementsInteractions.waitUntilElementFound)(page, '.under-line-txn-table-header', true);
95
99
  const txns = [];
@@ -102,7 +106,7 @@ async function getAccountTransactions(page) {
102
106
  for (const txnRow of transactionsDivs) {
103
107
  handleTransactionRow(txns, txnRow);
104
108
  }
105
- return convertTransactions(txns);
109
+ return convertTransactions(txns, options);
106
110
  }
107
111
 
108
112
  // Manipulate the calendar drop down to choose the txs start date.
@@ -165,22 +169,22 @@ async function searchByDates(page, startDate) {
165
169
  }
166
170
  }
167
171
  }
168
- async function fetchAccountData(page, startDate, accountID) {
172
+ async function fetchAccountData(page, startDate, accountID, options) {
169
173
  await (0, _elementsInteractions.waitUntilElementDisappear)(page, '.loading-bar-spinner');
170
174
  await searchByDates(page, startDate);
171
175
  await (0, _elementsInteractions.waitUntilElementDisappear)(page, '.loading-bar-spinner');
172
- const txns = await getAccountTransactions(page);
176
+ const txns = await getAccountTransactions(page, options);
173
177
  return {
174
178
  accountNumber: accountID,
175
179
  txns
176
180
  };
177
181
  }
178
- async function fetchAccounts(page, startDate) {
182
+ async function fetchAccounts(page, startDate, options) {
179
183
  const accounts = [];
180
184
 
181
185
  // TODO: get more accounts. Not sure is supported.
182
186
  const accountID = await getAccountID(page);
183
- const accountData = await fetchAccountData(page, startDate, accountID);
187
+ const accountData = await fetchAccountData(page, startDate, accountID, options);
184
188
  accounts.push(accountData);
185
189
  return accounts;
186
190
  }
@@ -236,7 +240,7 @@ class YahavScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
236
240
  const defaultStartMoment = (0, _moment.default)().subtract(3, 'months').add(1, 'day');
237
241
  const startDate = this.options.startDate || defaultStartMoment.toDate();
238
242
  const startMoment = _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
239
- const accounts = await fetchAccounts(this.page, startMoment);
243
+ const accounts = await fetchAccounts(this.page, startMoment, this.options);
240
244
  return {
241
245
  success: true,
242
246
  accounts
@@ -244,4 +248,4 @@ class YahavScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
244
248
  }
245
249
  }
246
250
  var _default = exports.default = YahavScraper;
247
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_elementsInteractions","_navigation","_transactions","_baseScraperWithBrowser","e","__esModule","default","LOGIN_URL","BASE_URL","INVALID_DETAILS_SELECTOR","CHANGE_PASSWORD_OLD_PASS","BASE_WELCOME_URL","ACCOUNT_ID_SELECTOR","ACCOUNT_DETAILS_SELECTOR","DATE_FORMAT","USER_ELEM","PASSWD_ELEM","NATIONALID_ELEM","SUBMIT_LOGIN_SELECTOR","getPossibleLoginResults","page","urls","LoginResults","Success","InvalidPassword","elementPresentOnPage","ChangePassword","getAccountID","selectedSnifAccount","$eval","element","textContent","error","errorMessage","Error","message","String","getAmountData","amountStr","amountStrCopy","replace","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","handleTransactionRow","txnRow","div","innerDivs","regex","tx","TransactionStatuses","Completed","push","getAccountTransactions","waitUntilElementFound","transactionsDivs","pageEvalAll","divs","id","getAttribute","Array","from","getElementsByTagName","el","innerText","searchByDates","startDate","startDateDay","format","startDateMonth","startDateYear","dateFromPick","clickButton","monthFromPick","i","selector","year","y","monthSelector","day","d","fetchAccountData","accountID","waitUntilElementDisappear","accountNumber","fetchAccounts","accounts","accountData","waitReadinessForAll","redirectOrDialog","waitForNavigation","hasMessage","promise1","waitForSelector","timeout","promise2","promises","Promise","race","YahavScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","value","username","password","nationalID","submitButtonSelector","checkReadiness","postAction","possibleResults","fetchData","defaultStartMoment","subtract","add","options","toDate","startMoment","max","success","_default","exports"],"sources":["../../src/scrapers/yahav.ts"],"sourcesContent":["import moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer-core';\nimport { SHEKEL_CURRENCY } from '../constants';\nimport {\n  clickButton,\n  elementPresentOnPage,\n  pageEvalAll,\n  waitUntilElementDisappear,\n  waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\n\nconst LOGIN_URL = 'https://login.yahav.co.il/login/';\nconst BASE_URL = 'https://digital.yahav.co.il/BaNCSDigitalUI/app/index.html#/';\nconst INVALID_DETAILS_SELECTOR = '.ui-dialog-buttons';\nconst CHANGE_PASSWORD_OLD_PASS = 'input#ef_req_parameter_old_credential';\nconst BASE_WELCOME_URL = `${BASE_URL}main/home`;\n\nconst ACCOUNT_ID_SELECTOR = 'span.portfolio-value[ng-if=\"mainController.data.portfolioList.length === 1\"]';\nconst ACCOUNT_DETAILS_SELECTOR = '.account-details';\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst USER_ELEM = '#username';\nconst PASSWD_ELEM = '#password';\nconst NATIONALID_ELEM = '#pinno';\nconst SUBMIT_LOGIN_SELECTOR = '.btn';\n\ninterface ScrapedTransaction {\n  credit: string;\n  debit: string;\n  date: string;\n  reference?: string;\n  description: string;\n  memo: string;\n  status: TransactionStatuses;\n}\n\nfunction getPossibleLoginResults(page: Page): PossibleLoginResults {\n  // checkout file `base-scraper-with-browser.ts` for available result types\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [`${BASE_WELCOME_URL}`];\n  urls[LoginResults.InvalidPassword] = [\n    async () => {\n      return elementPresentOnPage(page, `${INVALID_DETAILS_SELECTOR}`);\n    },\n  ];\n\n  urls[LoginResults.ChangePassword] = [\n    async () => {\n      return elementPresentOnPage(page, `${CHANGE_PASSWORD_OLD_PASS}`);\n    },\n  ];\n\n  return urls;\n}\n\nasync function getAccountID(page: Page): Promise<string> {\n  try {\n    const selectedSnifAccount = await page.$eval(ACCOUNT_ID_SELECTOR, (element: Element) => {\n      return element.textContent as string;\n    });\n\n    return selectedSnifAccount;\n  } catch (error) {\n    const errorMessage = error instanceof Error ? error.message : String(error);\n    throw new Error(\n      `Failed to retrieve account ID. Possible outdated selector '${ACCOUNT_ID_SELECTOR}: ${errorMessage}`,\n    );\n  }\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCopy = amountStr.replace(',', '');\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\ntype TransactionsTr = { id: string; innerDivs: string[] };\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  return txns.map(txn => {\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 handleTransactionRow(txns: ScrapedTransaction[], txnRow: TransactionsTr) {\n  const div = txnRow.innerDivs;\n\n  // Remove anything except digits.\n  const regex = /\\D+/gm;\n\n  const tx: ScrapedTransaction = {\n    date: div[1],\n    reference: div[2].replace(regex, ''),\n    memo: '',\n    description: div[3],\n    debit: div[4],\n    credit: div[5],\n    status: TransactionStatuses.Completed,\n  };\n\n  txns.push(tx);\n}\n\nasync function getAccountTransactions(page: Page): Promise<Transaction[]> {\n  // Wait for transactions.\n  await waitUntilElementFound(page, '.under-line-txn-table-header', true);\n\n  const txns: ScrapedTransaction[] = [];\n  const transactionsDivs = await pageEvalAll<TransactionsTr[]>(\n    page,\n    '.list-item-holder .entire-content-ctr',\n    [],\n    divs => {\n      return (divs as HTMLElement[]).map(div => ({\n        id: div.getAttribute('id') || '',\n        innerDivs: Array.from(div.getElementsByTagName('div')).map(el => (el as HTMLElement).innerText),\n      }));\n    },\n  );\n\n  for (const txnRow of transactionsDivs) {\n    handleTransactionRow(txns, txnRow);\n  }\n\n  return convertTransactions(txns);\n}\n\n// Manipulate the calendar drop down to choose the txs start date.\nasync function searchByDates(page: Page, startDate: Moment) {\n  // Get the day number from startDate. 1-31 (usually 1)\n  const startDateDay = startDate.format('D');\n  const startDateMonth = startDate.format('M');\n  const startDateYear = startDate.format('Y');\n\n  // Open the calendar date picker\n  const dateFromPick =\n    'div.date-options-cell:nth-child(7) > date-picker:nth-child(1) > div:nth-child(1) > span:nth-child(2)';\n  await waitUntilElementFound(page, dateFromPick, true);\n  await clickButton(page, dateFromPick);\n\n  // Wait until first day appear.\n  await waitUntilElementFound(page, '.pmu-days > div:nth-child(1)', true);\n\n  // Open Months options.\n  const monthFromPick = '.pmu-month';\n  await waitUntilElementFound(page, monthFromPick, true);\n  await clickButton(page, monthFromPick);\n  await waitUntilElementFound(page, '.pmu-months > div:nth-child(1)', true);\n\n  // Open Year options.\n  // Use same selector... Yahav knows why...\n  await waitUntilElementFound(page, monthFromPick, true);\n  await clickButton(page, monthFromPick);\n  await waitUntilElementFound(page, '.pmu-years > div:nth-child(1)', true);\n\n  // Select year from a 12 year grid.\n  for (let i = 1; i < 13; i += 1) {\n    const selector = `.pmu-years > div:nth-child(${i})`;\n    const year = await page.$eval(selector, y => {\n      return (y as HTMLElement).innerText;\n    });\n    if (startDateYear === year) {\n      await clickButton(page, selector);\n      break;\n    }\n  }\n\n  // Select Month.\n  await waitUntilElementFound(page, '.pmu-months > div:nth-child(1)', true);\n  // The first element (1) is January.\n  const monthSelector = `.pmu-months > div:nth-child(${startDateMonth})`;\n  await clickButton(page, monthSelector);\n\n  // Select Day.\n  // The calendar grid shows 7 days and 6 weeks = 42 days.\n  // In theory, the first day of the month will be in the first row.\n  // Let's check everything just in case...\n  for (let i = 1; i < 42; i += 1) {\n    const selector = `.pmu-days > div:nth-child(${i})`;\n    const day = await page.$eval(selector, d => {\n      return (d as HTMLElement).innerText;\n    });\n\n    if (startDateDay === day) {\n      await clickButton(page, selector);\n      break;\n    }\n  }\n}\n\nasync function fetchAccountData(page: Page, startDate: Moment, accountID: string): Promise<TransactionsAccount> {\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  await searchByDates(page, startDate);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  const txns = await getAccountTransactions(page);\n\n  return {\n    accountNumber: accountID,\n    txns,\n  };\n}\n\nasync function fetchAccounts(page: Page, startDate: Moment): Promise<TransactionsAccount[]> {\n  const accounts: TransactionsAccount[] = [];\n\n  // TODO: get more accounts. Not sure is supported.\n  const accountID = await getAccountID(page);\n  const accountData = await fetchAccountData(page, startDate, accountID);\n  accounts.push(accountData);\n\n  return accounts;\n}\n\nasync function waitReadinessForAll(page: Page) {\n  await waitUntilElementFound(page, `${USER_ELEM}`, true);\n  await waitUntilElementFound(page, `${PASSWD_ELEM}`, true);\n  await waitUntilElementFound(page, `${NATIONALID_ELEM}`, true);\n  await waitUntilElementFound(page, `${SUBMIT_LOGIN_SELECTOR}`, true);\n}\n\nasync function redirectOrDialog(page: Page) {\n  // Click on bank messages if any.\n  await waitForNavigation(page);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  const hasMessage = await elementPresentOnPage(page, '.messaging-links-container');\n  if (hasMessage) {\n    await clickButton(page, '.link-1');\n  }\n\n  const promise1 = page.waitForSelector(ACCOUNT_DETAILS_SELECTOR, { timeout: 30000 });\n  const promise2 = page.waitForSelector(CHANGE_PASSWORD_OLD_PASS, { timeout: 30000 });\n  const promises = [promise1, promise2];\n\n  await Promise.race(promises);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string; nationalID: string };\n\nclass YahavScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: [\n        { selector: `${USER_ELEM}`, value: credentials.username },\n        { selector: `${PASSWD_ELEM}`, value: credentials.password },\n        { selector: `${NATIONALID_ELEM}`, value: credentials.nationalID },\n      ],\n      submitButtonSelector: `${SUBMIT_LOGIN_SELECTOR}`,\n      checkReadiness: async () => waitReadinessForAll(this.page),\n      postAction: async () => redirectOrDialog(this.page),\n      possibleResults: getPossibleLoginResults(this.page),\n    };\n  }\n\n  async fetchData() {\n    // Goto statements page\n    await waitUntilElementFound(this.page, ACCOUNT_DETAILS_SELECTOR, true);\n    await clickButton(this.page, ACCOUNT_DETAILS_SELECTOR);\n    await waitUntilElementFound(this.page, '.statement-options .selected-item-top', true);\n\n    const defaultStartMoment = moment().subtract(3, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    const accounts = await fetchAccounts(this.page, startMoment);\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default YahavScraper;\n"],"mappings":"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","ignoreList":[]}
251
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_elementsInteractions","_navigation","_transactions","_baseScraperWithBrowser","e","__esModule","default","LOGIN_URL","BASE_URL","INVALID_DETAILS_SELECTOR","CHANGE_PASSWORD_OLD_PASS","BASE_WELCOME_URL","ACCOUNT_ID_SELECTOR","ACCOUNT_DETAILS_SELECTOR","DATE_FORMAT","USER_ELEM","PASSWD_ELEM","NATIONALID_ELEM","SUBMIT_LOGIN_SELECTOR","getPossibleLoginResults","page","urls","LoginResults","Success","InvalidPassword","elementPresentOnPage","ChangePassword","getAccountID","selectedSnifAccount","$eval","element","textContent","error","errorMessage","Error","message","String","getAmountData","amountStr","amountStrCopy","replace","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","handleTransactionRow","txnRow","div","innerDivs","regex","tx","TransactionStatuses","Completed","push","getAccountTransactions","waitUntilElementFound","transactionsDivs","pageEvalAll","divs","id","getAttribute","Array","from","getElementsByTagName","el","innerText","searchByDates","startDate","startDateDay","format","startDateMonth","startDateYear","dateFromPick","clickButton","monthFromPick","i","selector","year","y","monthSelector","day","d","fetchAccountData","accountID","waitUntilElementDisappear","accountNumber","fetchAccounts","accounts","accountData","waitReadinessForAll","redirectOrDialog","waitForNavigation","hasMessage","promise1","waitForSelector","timeout","promise2","promises","Promise","race","YahavScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","value","username","password","nationalID","submitButtonSelector","checkReadiness","postAction","possibleResults","fetchData","defaultStartMoment","subtract","add","toDate","startMoment","max","success","_default","exports"],"sources":["../../src/scrapers/yahav.ts"],"sourcesContent":["import moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer-core';\nimport { SHEKEL_CURRENCY } from '../constants';\nimport {\n  clickButton,\n  elementPresentOnPage,\n  pageEvalAll,\n  waitUntilElementDisappear,\n  waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\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 LOGIN_URL = 'https://login.yahav.co.il/login/';\nconst BASE_URL = 'https://digital.yahav.co.il/BaNCSDigitalUI/app/index.html#/';\nconst INVALID_DETAILS_SELECTOR = '.ui-dialog-buttons';\nconst CHANGE_PASSWORD_OLD_PASS = 'input#ef_req_parameter_old_credential';\nconst BASE_WELCOME_URL = `${BASE_URL}main/home`;\n\nconst ACCOUNT_ID_SELECTOR = 'span.portfolio-value[ng-if=\"mainController.data.portfolioList.length === 1\"]';\nconst ACCOUNT_DETAILS_SELECTOR = '.account-details';\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst USER_ELEM = '#username';\nconst PASSWD_ELEM = '#password';\nconst NATIONALID_ELEM = '#pinno';\nconst SUBMIT_LOGIN_SELECTOR = '.btn';\n\ninterface ScrapedTransaction {\n  credit: string;\n  debit: string;\n  date: string;\n  reference?: string;\n  description: string;\n  memo: string;\n  status: TransactionStatuses;\n}\n\nfunction getPossibleLoginResults(page: Page): PossibleLoginResults {\n  // checkout file `base-scraper-with-browser.ts` for available result types\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [`${BASE_WELCOME_URL}`];\n  urls[LoginResults.InvalidPassword] = [\n    async () => {\n      return elementPresentOnPage(page, `${INVALID_DETAILS_SELECTOR}`);\n    },\n  ];\n\n  urls[LoginResults.ChangePassword] = [\n    async () => {\n      return elementPresentOnPage(page, `${CHANGE_PASSWORD_OLD_PASS}`);\n    },\n  ];\n\n  return urls;\n}\n\nasync function getAccountID(page: Page): Promise<string> {\n  try {\n    const selectedSnifAccount = await page.$eval(ACCOUNT_ID_SELECTOR, (element: Element) => {\n      return element.textContent as string;\n    });\n\n    return selectedSnifAccount;\n  } catch (error) {\n    const errorMessage = error instanceof Error ? error.message : String(error);\n    throw new Error(\n      `Failed to retrieve account ID. Possible outdated selector '${ACCOUNT_ID_SELECTOR}: ${errorMessage}`,\n    );\n  }\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCopy = amountStr.replace(',', '');\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\ntype TransactionsTr = { id: string; innerDivs: string[] };\n\nfunction convertTransactions(txns: ScrapedTransaction[], options?: ScraperOptions): Transaction[] {\n  return txns.map(txn => {\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 handleTransactionRow(txns: ScrapedTransaction[], txnRow: TransactionsTr) {\n  const div = txnRow.innerDivs;\n\n  // Remove anything except digits.\n  const regex = /\\D+/gm;\n\n  const tx: ScrapedTransaction = {\n    date: div[1],\n    reference: div[2].replace(regex, ''),\n    memo: '',\n    description: div[3],\n    debit: div[4],\n    credit: div[5],\n    status: TransactionStatuses.Completed,\n  };\n\n  txns.push(tx);\n}\n\nasync function getAccountTransactions(page: Page, options?: ScraperOptions): Promise<Transaction[]> {\n  // Wait for transactions.\n  await waitUntilElementFound(page, '.under-line-txn-table-header', true);\n\n  const txns: ScrapedTransaction[] = [];\n  const transactionsDivs = await pageEvalAll<TransactionsTr[]>(\n    page,\n    '.list-item-holder .entire-content-ctr',\n    [],\n    divs => {\n      return (divs as HTMLElement[]).map(div => ({\n        id: div.getAttribute('id') || '',\n        innerDivs: Array.from(div.getElementsByTagName('div')).map(el => (el as HTMLElement).innerText),\n      }));\n    },\n  );\n\n  for (const txnRow of transactionsDivs) {\n    handleTransactionRow(txns, txnRow);\n  }\n\n  return convertTransactions(txns, options);\n}\n\n// Manipulate the calendar drop down to choose the txs start date.\nasync function searchByDates(page: Page, startDate: Moment) {\n  // Get the day number from startDate. 1-31 (usually 1)\n  const startDateDay = startDate.format('D');\n  const startDateMonth = startDate.format('M');\n  const startDateYear = startDate.format('Y');\n\n  // Open the calendar date picker\n  const dateFromPick =\n    'div.date-options-cell:nth-child(7) > date-picker:nth-child(1) > div:nth-child(1) > span:nth-child(2)';\n  await waitUntilElementFound(page, dateFromPick, true);\n  await clickButton(page, dateFromPick);\n\n  // Wait until first day appear.\n  await waitUntilElementFound(page, '.pmu-days > div:nth-child(1)', true);\n\n  // Open Months options.\n  const monthFromPick = '.pmu-month';\n  await waitUntilElementFound(page, monthFromPick, true);\n  await clickButton(page, monthFromPick);\n  await waitUntilElementFound(page, '.pmu-months > div:nth-child(1)', true);\n\n  // Open Year options.\n  // Use same selector... Yahav knows why...\n  await waitUntilElementFound(page, monthFromPick, true);\n  await clickButton(page, monthFromPick);\n  await waitUntilElementFound(page, '.pmu-years > div:nth-child(1)', true);\n\n  // Select year from a 12 year grid.\n  for (let i = 1; i < 13; i += 1) {\n    const selector = `.pmu-years > div:nth-child(${i})`;\n    const year = await page.$eval(selector, y => {\n      return (y as HTMLElement).innerText;\n    });\n    if (startDateYear === year) {\n      await clickButton(page, selector);\n      break;\n    }\n  }\n\n  // Select Month.\n  await waitUntilElementFound(page, '.pmu-months > div:nth-child(1)', true);\n  // The first element (1) is January.\n  const monthSelector = `.pmu-months > div:nth-child(${startDateMonth})`;\n  await clickButton(page, monthSelector);\n\n  // Select Day.\n  // The calendar grid shows 7 days and 6 weeks = 42 days.\n  // In theory, the first day of the month will be in the first row.\n  // Let's check everything just in case...\n  for (let i = 1; i < 42; i += 1) {\n    const selector = `.pmu-days > div:nth-child(${i})`;\n    const day = await page.$eval(selector, d => {\n      return (d as HTMLElement).innerText;\n    });\n\n    if (startDateDay === day) {\n      await clickButton(page, selector);\n      break;\n    }\n  }\n}\n\nasync function fetchAccountData(\n  page: Page,\n  startDate: Moment,\n  accountID: string,\n  options?: ScraperOptions,\n): Promise<TransactionsAccount> {\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  await searchByDates(page, startDate);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  const txns = await getAccountTransactions(page, options);\n\n  return {\n    accountNumber: accountID,\n    txns,\n  };\n}\n\nasync function fetchAccounts(page: Page, startDate: Moment, options?: ScraperOptions): Promise<TransactionsAccount[]> {\n  const accounts: TransactionsAccount[] = [];\n\n  // TODO: get more accounts. Not sure is supported.\n  const accountID = await getAccountID(page);\n  const accountData = await fetchAccountData(page, startDate, accountID, options);\n  accounts.push(accountData);\n\n  return accounts;\n}\n\nasync function waitReadinessForAll(page: Page) {\n  await waitUntilElementFound(page, `${USER_ELEM}`, true);\n  await waitUntilElementFound(page, `${PASSWD_ELEM}`, true);\n  await waitUntilElementFound(page, `${NATIONALID_ELEM}`, true);\n  await waitUntilElementFound(page, `${SUBMIT_LOGIN_SELECTOR}`, true);\n}\n\nasync function redirectOrDialog(page: Page) {\n  // Click on bank messages if any.\n  await waitForNavigation(page);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n  const hasMessage = await elementPresentOnPage(page, '.messaging-links-container');\n  if (hasMessage) {\n    await clickButton(page, '.link-1');\n  }\n\n  const promise1 = page.waitForSelector(ACCOUNT_DETAILS_SELECTOR, { timeout: 30000 });\n  const promise2 = page.waitForSelector(CHANGE_PASSWORD_OLD_PASS, { timeout: 30000 });\n  const promises = [promise1, promise2];\n\n  await Promise.race(promises);\n  await waitUntilElementDisappear(page, '.loading-bar-spinner');\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string; nationalID: string };\n\nclass YahavScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: [\n        { selector: `${USER_ELEM}`, value: credentials.username },\n        { selector: `${PASSWD_ELEM}`, value: credentials.password },\n        { selector: `${NATIONALID_ELEM}`, value: credentials.nationalID },\n      ],\n      submitButtonSelector: `${SUBMIT_LOGIN_SELECTOR}`,\n      checkReadiness: async () => waitReadinessForAll(this.page),\n      postAction: async () => redirectOrDialog(this.page),\n      possibleResults: getPossibleLoginResults(this.page),\n    };\n  }\n\n  async fetchData() {\n    // Goto statements page\n    await waitUntilElementFound(this.page, ACCOUNT_DETAILS_SELECTOR, true);\n    await clickButton(this.page, ACCOUNT_DETAILS_SELECTOR);\n    await waitUntilElementFound(this.page, '.statement-options .selected-item-top', true);\n\n    const defaultStartMoment = moment().subtract(3, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\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 YahavScraper;\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AAEA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,qBAAA,GAAAF,OAAA;AAOA,IAAAG,WAAA,GAAAH,OAAA;AACA,IAAAI,aAAA,GAAAJ,OAAA;AACA,IAAAK,uBAAA,GAAAL,OAAA;AAA8G,SAAAD,uBAAAO,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAG9G,MAAMG,SAAS,GAAG,kCAAkC;AACpD,MAAMC,QAAQ,GAAG,6DAA6D;AAC9E,MAAMC,wBAAwB,GAAG,oBAAoB;AACrD,MAAMC,wBAAwB,GAAG,uCAAuC;AACxE,MAAMC,gBAAgB,GAAG,GAAGH,QAAQ,WAAW;AAE/C,MAAMI,mBAAmB,GAAG,8EAA8E;AAC1G,MAAMC,wBAAwB,GAAG,kBAAkB;AACnD,MAAMC,WAAW,GAAG,YAAY;AAEhC,MAAMC,SAAS,GAAG,WAAW;AAC7B,MAAMC,WAAW,GAAG,WAAW;AAC/B,MAAMC,eAAe,GAAG,QAAQ;AAChC,MAAMC,qBAAqB,GAAG,MAAM;AAYpC,SAASC,uBAAuBA,CAACC,IAAU,EAAwB;EACjE;EACA,MAAMC,IAA0B,GAAG,CAAC,CAAC;EACrCA,IAAI,CAACC,oCAAY,CAACC,OAAO,CAAC,GAAG,CAAC,GAAGZ,gBAAgB,EAAE,CAAC;EACpDU,IAAI,CAACC,oCAAY,CAACE,eAAe,CAAC,GAAG,CACnC,YAAY;IACV,OAAO,IAAAC,0CAAoB,EAACL,IAAI,EAAE,GAAGX,wBAAwB,EAAE,CAAC;EAClE,CAAC,CACF;EAEDY,IAAI,CAACC,oCAAY,CAACI,cAAc,CAAC,GAAG,CAClC,YAAY;IACV,OAAO,IAAAD,0CAAoB,EAACL,IAAI,EAAE,GAAGV,wBAAwB,EAAE,CAAC;EAClE,CAAC,CACF;EAED,OAAOW,IAAI;AACb;AAEA,eAAeM,YAAYA,CAACP,IAAU,EAAmB;EACvD,IAAI;IACF,MAAMQ,mBAAmB,GAAG,MAAMR,IAAI,CAACS,KAAK,CAACjB,mBAAmB,EAAGkB,OAAgB,IAAK;MACtF,OAAOA,OAAO,CAACC,WAAW;IAC5B,CAAC,CAAC;IAEF,OAAOH,mBAAmB;EAC5B,CAAC,CAAC,OAAOI,KAAK,EAAE;IACd,MAAMC,YAAY,GAAGD,KAAK,YAAYE,KAAK,GAAGF,KAAK,CAACG,OAAO,GAAGC,MAAM,CAACJ,KAAK,CAAC;IAC3E,MAAM,IAAIE,KAAK,CACb,8DAA8DtB,mBAAmB,KAAKqB,YAAY,EACpG,CAAC;EACH;AACF;AAEA,SAASI,aAAaA,CAACC,SAAiB,EAAE;EACxC,MAAMC,aAAa,GAAGD,SAAS,CAACE,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC;EAChD,OAAOC,UAAU,CAACF,aAAa,CAAC;AAClC;AAEA,SAASG,YAAYA,CAACC,GAAuB,EAAE;EAC7C,MAAMC,MAAM,GAAGP,aAAa,CAACM,GAAG,CAACC,MAAM,CAAC;EACxC,MAAMC,KAAK,GAAGR,aAAa,CAACM,GAAG,CAACE,KAAK,CAAC;EACtC,OAAO,CAACC,MAAM,CAACC,KAAK,CAACH,MAAM,CAAC,GAAG,CAAC,GAAGA,MAAM,KAAKE,MAAM,CAACC,KAAK,CAACF,KAAK,CAAC,GAAG,CAAC,GAAGA,KAAK,CAAC;AAChF;AAIA,SAASG,mBAAmBA,CAACC,IAA0B,EAAEC,OAAwB,EAAiB;EAChG,OAAOD,IAAI,CAACE,GAAG,CAACR,GAAG,IAAI;IACrB,MAAMS,aAAa,GAAG,IAAAC,eAAM,EAACV,GAAG,CAACW,IAAI,EAAExC,WAAW,CAAC,CAACyC,WAAW,CAAC,CAAC;IACjE,MAAMC,eAAe,GAAGd,YAAY,CAACC,GAAG,CAAC;IACzC,MAAMc,MAAmB,GAAG;MAC1BC,IAAI,EAAEC,8BAAgB,CAACC,MAAM;MAC7BC,UAAU,EAAElB,GAAG,CAACmB,SAAS,GAAGC,QAAQ,CAACpB,GAAG,CAACmB,SAAS,EAAE,EAAE,CAAC,GAAGE,SAAS;MACnEV,IAAI,EAAEF,aAAa;MACnBa,aAAa,EAAEb,aAAa;MAC5Bc,cAAc,EAAEV,eAAe;MAC/BW,gBAAgB,EAAEC,0BAAe;MACjCC,aAAa,EAAEb,eAAe;MAC9Bc,MAAM,EAAE3B,GAAG,CAAC2B,MAAM;MAClBC,WAAW,EAAE5B,GAAG,CAAC4B,WAAW;MAC5BC,IAAI,EAAE7B,GAAG,CAAC6B;IACZ,CAAC;IAED,IAAItB,OAAO,EAAEuB,qBAAqB,EAAE;MAClChB,MAAM,CAACiB,cAAc,GAAG/B,GAAG;IAC7B;IAEA,OAAOc,MAAM;EACf,CAAC,CAAC;AACJ;AAEA,SAASkB,oBAAoBA,CAAC1B,IAA0B,EAAE2B,MAAsB,EAAE;EAChF,MAAMC,GAAG,GAAGD,MAAM,CAACE,SAAS;;EAE5B;EACA,MAAMC,KAAK,GAAG,OAAO;EAErB,MAAMC,EAAsB,GAAG;IAC7B1B,IAAI,EAAEuB,GAAG,CAAC,CAAC,CAAC;IACZf,SAAS,EAAEe,GAAG,CAAC,CAAC,CAAC,CAACrC,OAAO,CAACuC,KAAK,EAAE,EAAE,CAAC;IACpCP,IAAI,EAAE,EAAE;IACRD,WAAW,EAAEM,GAAG,CAAC,CAAC,CAAC;IACnBhC,KAAK,EAAEgC,GAAG,CAAC,CAAC,CAAC;IACbjC,MAAM,EAAEiC,GAAG,CAAC,CAAC,CAAC;IACdP,MAAM,EAAEW,iCAAmB,CAACC;EAC9B,CAAC;EAEDjC,IAAI,CAACkC,IAAI,CAACH,EAAE,CAAC;AACf;AAEA,eAAeI,sBAAsBA,CAAChE,IAAU,EAAE8B,OAAwB,EAA0B;EAClG;EACA,MAAM,IAAAmC,2CAAqB,EAACjE,IAAI,EAAE,8BAA8B,EAAE,IAAI,CAAC;EAEvE,MAAM6B,IAA0B,GAAG,EAAE;EACrC,MAAMqC,gBAAgB,GAAG,MAAM,IAAAC,iCAAW,EACxCnE,IAAI,EACJ,uCAAuC,EACvC,EAAE,EACFoE,IAAI,IAAI;IACN,OAAQA,IAAI,CAAmBrC,GAAG,CAAC0B,GAAG,KAAK;MACzCY,EAAE,EAAEZ,GAAG,CAACa,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE;MAChCZ,SAAS,EAAEa,KAAK,CAACC,IAAI,CAACf,GAAG,CAACgB,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC1C,GAAG,CAAC2C,EAAE,IAAKA,EAAE,CAAiBC,SAAS;IAChG,CAAC,CAAC,CAAC;EACL,CACF,CAAC;EAED,KAAK,MAAMnB,MAAM,IAAIU,gBAAgB,EAAE;IACrCX,oBAAoB,CAAC1B,IAAI,EAAE2B,MAAM,CAAC;EACpC;EAEA,OAAO5B,mBAAmB,CAACC,IAAI,EAAEC,OAAO,CAAC;AAC3C;;AAEA;AACA,eAAe8C,aAAaA,CAAC5E,IAAU,EAAE6E,SAAiB,EAAE;EAC1D;EACA,MAAMC,YAAY,GAAGD,SAAS,CAACE,MAAM,CAAC,GAAG,CAAC;EAC1C,MAAMC,cAAc,GAAGH,SAAS,CAACE,MAAM,CAAC,GAAG,CAAC;EAC5C,MAAME,aAAa,GAAGJ,SAAS,CAACE,MAAM,CAAC,GAAG,CAAC;;EAE3C;EACA,MAAMG,YAAY,GAChB,sGAAsG;EACxG,MAAM,IAAAjB,2CAAqB,EAACjE,IAAI,EAAEkF,YAAY,EAAE,IAAI,CAAC;EACrD,MAAM,IAAAC,iCAAW,EAACnF,IAAI,EAAEkF,YAAY,CAAC;;EAErC;EACA,MAAM,IAAAjB,2CAAqB,EAACjE,IAAI,EAAE,8BAA8B,EAAE,IAAI,CAAC;;EAEvE;EACA,MAAMoF,aAAa,GAAG,YAAY;EAClC,MAAM,IAAAnB,2CAAqB,EAACjE,IAAI,EAAEoF,aAAa,EAAE,IAAI,CAAC;EACtD,MAAM,IAAAD,iCAAW,EAACnF,IAAI,EAAEoF,aAAa,CAAC;EACtC,MAAM,IAAAnB,2CAAqB,EAACjE,IAAI,EAAE,gCAAgC,EAAE,IAAI,CAAC;;EAEzE;EACA;EACA,MAAM,IAAAiE,2CAAqB,EAACjE,IAAI,EAAEoF,aAAa,EAAE,IAAI,CAAC;EACtD,MAAM,IAAAD,iCAAW,EAACnF,IAAI,EAAEoF,aAAa,CAAC;EACtC,MAAM,IAAAnB,2CAAqB,EAACjE,IAAI,EAAE,+BAA+B,EAAE,IAAI,CAAC;;EAExE;EACA,KAAK,IAAIqF,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG,EAAE,EAAEA,CAAC,IAAI,CAAC,EAAE;IAC9B,MAAMC,QAAQ,GAAG,8BAA8BD,CAAC,GAAG;IACnD,MAAME,IAAI,GAAG,MAAMvF,IAAI,CAACS,KAAK,CAAC6E,QAAQ,EAAEE,CAAC,IAAI;MAC3C,OAAQA,CAAC,CAAiBb,SAAS;IACrC,CAAC,CAAC;IACF,IAAIM,aAAa,KAAKM,IAAI,EAAE;MAC1B,MAAM,IAAAJ,iCAAW,EAACnF,IAAI,EAAEsF,QAAQ,CAAC;MACjC;IACF;EACF;;EAEA;EACA,MAAM,IAAArB,2CAAqB,EAACjE,IAAI,EAAE,gCAAgC,EAAE,IAAI,CAAC;EACzE;EACA,MAAMyF,aAAa,GAAG,+BAA+BT,cAAc,GAAG;EACtE,MAAM,IAAAG,iCAAW,EAACnF,IAAI,EAAEyF,aAAa,CAAC;;EAEtC;EACA;EACA;EACA;EACA,KAAK,IAAIJ,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAG,EAAE,EAAEA,CAAC,IAAI,CAAC,EAAE;IAC9B,MAAMC,QAAQ,GAAG,6BAA6BD,CAAC,GAAG;IAClD,MAAMK,GAAG,GAAG,MAAM1F,IAAI,CAACS,KAAK,CAAC6E,QAAQ,EAAEK,CAAC,IAAI;MAC1C,OAAQA,CAAC,CAAiBhB,SAAS;IACrC,CAAC,CAAC;IAEF,IAAIG,YAAY,KAAKY,GAAG,EAAE;MACxB,MAAM,IAAAP,iCAAW,EAACnF,IAAI,EAAEsF,QAAQ,CAAC;MACjC;IACF;EACF;AACF;AAEA,eAAeM,gBAAgBA,CAC7B5F,IAAU,EACV6E,SAAiB,EACjBgB,SAAiB,EACjB/D,OAAwB,EACM;EAC9B,MAAM,IAAAgE,+CAAyB,EAAC9F,IAAI,EAAE,sBAAsB,CAAC;EAC7D,MAAM4E,aAAa,CAAC5E,IAAI,EAAE6E,SAAS,CAAC;EACpC,MAAM,IAAAiB,+CAAyB,EAAC9F,IAAI,EAAE,sBAAsB,CAAC;EAC7D,MAAM6B,IAAI,GAAG,MAAMmC,sBAAsB,CAAChE,IAAI,EAAE8B,OAAO,CAAC;EAExD,OAAO;IACLiE,aAAa,EAAEF,SAAS;IACxBhE;EACF,CAAC;AACH;AAEA,eAAemE,aAAaA,CAAChG,IAAU,EAAE6E,SAAiB,EAAE/C,OAAwB,EAAkC;EACpH,MAAMmE,QAA+B,GAAG,EAAE;;EAE1C;EACA,MAAMJ,SAAS,GAAG,MAAMtF,YAAY,CAACP,IAAI,CAAC;EAC1C,MAAMkG,WAAW,GAAG,MAAMN,gBAAgB,CAAC5F,IAAI,EAAE6E,SAAS,EAAEgB,SAAS,EAAE/D,OAAO,CAAC;EAC/EmE,QAAQ,CAAClC,IAAI,CAACmC,WAAW,CAAC;EAE1B,OAAOD,QAAQ;AACjB;AAEA,eAAeE,mBAAmBA,CAACnG,IAAU,EAAE;EAC7C,MAAM,IAAAiE,2CAAqB,EAACjE,IAAI,EAAE,GAAGL,SAAS,EAAE,EAAE,IAAI,CAAC;EACvD,MAAM,IAAAsE,2CAAqB,EAACjE,IAAI,EAAE,GAAGJ,WAAW,EAAE,EAAE,IAAI,CAAC;EACzD,MAAM,IAAAqE,2CAAqB,EAACjE,IAAI,EAAE,GAAGH,eAAe,EAAE,EAAE,IAAI,CAAC;EAC7D,MAAM,IAAAoE,2CAAqB,EAACjE,IAAI,EAAE,GAAGF,qBAAqB,EAAE,EAAE,IAAI,CAAC;AACrE;AAEA,eAAesG,gBAAgBA,CAACpG,IAAU,EAAE;EAC1C;EACA,MAAM,IAAAqG,6BAAiB,EAACrG,IAAI,CAAC;EAC7B,MAAM,IAAA8F,+CAAyB,EAAC9F,IAAI,EAAE,sBAAsB,CAAC;EAC7D,MAAMsG,UAAU,GAAG,MAAM,IAAAjG,0CAAoB,EAACL,IAAI,EAAE,4BAA4B,CAAC;EACjF,IAAIsG,UAAU,EAAE;IACd,MAAM,IAAAnB,iCAAW,EAACnF,IAAI,EAAE,SAAS,CAAC;EACpC;EAEA,MAAMuG,QAAQ,GAAGvG,IAAI,CAACwG,eAAe,CAAC/G,wBAAwB,EAAE;IAAEgH,OAAO,EAAE;EAAM,CAAC,CAAC;EACnF,MAAMC,QAAQ,GAAG1G,IAAI,CAACwG,eAAe,CAAClH,wBAAwB,EAAE;IAAEmH,OAAO,EAAE;EAAM,CAAC,CAAC;EACnF,MAAME,QAAQ,GAAG,CAACJ,QAAQ,EAAEG,QAAQ,CAAC;EAErC,MAAME,OAAO,CAACC,IAAI,CAACF,QAAQ,CAAC;EAC5B,MAAM,IAAAb,+CAAyB,EAAC9F,IAAI,EAAE,sBAAsB,CAAC;AAC/D;AAIA,MAAM8G,YAAY,SAASC,8CAAsB,CAA6B;EAC5EC,eAAeA,CAACC,WAAuC,EAAE;IACvD,OAAO;MACLC,QAAQ,EAAE,GAAG/H,SAAS,EAAE;MACxBgI,MAAM,EAAE,CACN;QAAE7B,QAAQ,EAAE,GAAG3F,SAAS,EAAE;QAAEyH,KAAK,EAAEH,WAAW,CAACI;MAAS,CAAC,EACzD;QAAE/B,QAAQ,EAAE,GAAG1F,WAAW,EAAE;QAAEwH,KAAK,EAAEH,WAAW,CAACK;MAAS,CAAC,EAC3D;QAAEhC,QAAQ,EAAE,GAAGzF,eAAe,EAAE;QAAEuH,KAAK,EAAEH,WAAW,CAACM;MAAW,CAAC,CAClE;MACDC,oBAAoB,EAAE,GAAG1H,qBAAqB,EAAE;MAChD2H,cAAc,EAAE,MAAAA,CAAA,KAAYtB,mBAAmB,CAAC,IAAI,CAACnG,IAAI,CAAC;MAC1D0H,UAAU,EAAE,MAAAA,CAAA,KAAYtB,gBAAgB,CAAC,IAAI,CAACpG,IAAI,CAAC;MACnD2H,eAAe,EAAE5H,uBAAuB,CAAC,IAAI,CAACC,IAAI;IACpD,CAAC;EACH;EAEA,MAAM4H,SAASA,CAAA,EAAG;IAChB;IACA,MAAM,IAAA3D,2CAAqB,EAAC,IAAI,CAACjE,IAAI,EAAEP,wBAAwB,EAAE,IAAI,CAAC;IACtE,MAAM,IAAA0F,iCAAW,EAAC,IAAI,CAACnF,IAAI,EAAEP,wBAAwB,CAAC;IACtD,MAAM,IAAAwE,2CAAqB,EAAC,IAAI,CAACjE,IAAI,EAAE,uCAAuC,EAAE,IAAI,CAAC;IAErF,MAAM6H,kBAAkB,GAAG,IAAA5F,eAAM,EAAC,CAAC,CAAC6F,QAAQ,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC;IACvE,MAAMlD,SAAS,GAAG,IAAI,CAAC/C,OAAO,CAAC+C,SAAS,IAAIgD,kBAAkB,CAACG,MAAM,CAAC,CAAC;IACvE,MAAMC,WAAW,GAAGhG,eAAM,CAACiG,GAAG,CAACL,kBAAkB,EAAE,IAAA5F,eAAM,EAAC4C,SAAS,CAAC,CAAC;IAErE,MAAMoB,QAAQ,GAAG,MAAMD,aAAa,CAAC,IAAI,CAAChG,IAAI,EAAEiI,WAAW,EAAE,IAAI,CAACnG,OAAO,CAAC;IAE1E,OAAO;MACLqG,OAAO,EAAE,IAAI;MACblC;IACF,CAAC;EACH;AACF;AAAC,IAAAmC,QAAA,GAAAC,OAAA,CAAAnJ,OAAA,GAEc4H,YAAY","ignoreList":[]}
@@ -44,4 +44,5 @@ export interface Transaction {
44
44
  status: TransactionStatuses;
45
45
  installments?: TransactionInstallments;
46
46
  category?: string;
47
+ rawTransaction?: unknown;
47
48
  }
@@ -14,4 +14,4 @@ let TransactionStatuses = exports.TransactionStatuses = /*#__PURE__*/function (T
14
14
  TransactionStatuses["Pending"] = "pending";
15
15
  return TransactionStatuses;
16
16
  }({});
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJUcmFuc2FjdGlvblR5cGVzIiwiZXhwb3J0cyIsIlRyYW5zYWN0aW9uU3RhdHVzZXMiXSwic291cmNlcyI6WyIuLi9zcmMvdHJhbnNhY3Rpb25zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25zQWNjb3VudCB7XG4gIGFjY291bnROdW1iZXI6IHN0cmluZztcbiAgYmFsYW5jZT86IG51bWJlcjtcbiAgdHhuczogVHJhbnNhY3Rpb25bXTtcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25UeXBlcyB7XG4gIE5vcm1hbCA9ICdub3JtYWwnLFxuICBJbnN0YWxsbWVudHMgPSAnaW5zdGFsbG1lbnRzJyxcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25TdGF0dXNlcyB7XG4gIENvbXBsZXRlZCA9ICdjb21wbGV0ZWQnLFxuICBQZW5kaW5nID0gJ3BlbmRpbmcnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uSW5zdGFsbG1lbnRzIHtcbiAgLyoqXG4gICAqIHRoZSBjdXJyZW50IGluc3RhbGxtZW50IG51bWJlclxuICAgKi9cbiAgbnVtYmVyOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIHRoZSB0b3RhbCBudW1iZXIgb2YgaW5zdGFsbG1lbnRzXG4gICAqL1xuICB0b3RhbDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uIHtcbiAgdHlwZTogVHJhbnNhY3Rpb25UeXBlcztcbiAgLyoqXG4gICAqIHNvbWV0aW1lcyBjYWxsZWQgQXNtYWNodGFcbiAgICovXG4gIGlkZW50aWZpZXI/OiBzdHJpbmcgfCBudW1iZXI7XG4gIC8qKlxuICAgKiBJU08gZGF0ZSBzdHJpbmdcbiAgICovXG4gIGRhdGU6IHN0cmluZztcbiAgLyoqXG4gICAqIElTTyBkYXRlIHN0cmluZ1xuICAgKi9cbiAgcHJvY2Vzc2VkRGF0ZTogc3RyaW5nO1xuICBvcmlnaW5hbEFtb3VudDogbnVtYmVyO1xuICBvcmlnaW5hbEN1cnJlbmN5OiBzdHJpbmc7XG4gIGNoYXJnZWRBbW91bnQ6IG51bWJlcjtcbiAgY2hhcmdlZEN1cnJlbmN5Pzogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBtZW1vPzogc3RyaW5nO1xuICBzdGF0dXM6IFRyYW5zYWN0aW9uU3RhdHVzZXM7XG4gIGluc3RhbGxtZW50cz86IFRyYW5zYWN0aW9uSW5zdGFsbG1lbnRzO1xuICBjYXRlZ29yeT86IHN0cmluZztcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0lBTVlBLGdCQUFnQixHQUFBQyxPQUFBLENBQUFELGdCQUFBLDBCQUFoQkEsZ0JBQWdCO0VBQWhCQSxnQkFBZ0I7RUFBaEJBLGdCQUFnQjtFQUFBLE9BQWhCQSxnQkFBZ0I7QUFBQTtBQUFBLElBS2hCRSxtQkFBbUIsR0FBQUQsT0FBQSxDQUFBQyxtQkFBQSwwQkFBbkJBLG1CQUFtQjtFQUFuQkEsbUJBQW1CO0VBQW5CQSxtQkFBbUI7RUFBQSxPQUFuQkEsbUJBQW1CO0FBQUEiLCJpZ25vcmVMaXN0IjpbXX0=
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJUcmFuc2FjdGlvblR5cGVzIiwiZXhwb3J0cyIsIlRyYW5zYWN0aW9uU3RhdHVzZXMiXSwic291cmNlcyI6WyIuLi9zcmMvdHJhbnNhY3Rpb25zLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25zQWNjb3VudCB7XG4gIGFjY291bnROdW1iZXI6IHN0cmluZztcbiAgYmFsYW5jZT86IG51bWJlcjtcbiAgdHhuczogVHJhbnNhY3Rpb25bXTtcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25UeXBlcyB7XG4gIE5vcm1hbCA9ICdub3JtYWwnLFxuICBJbnN0YWxsbWVudHMgPSAnaW5zdGFsbG1lbnRzJyxcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25TdGF0dXNlcyB7XG4gIENvbXBsZXRlZCA9ICdjb21wbGV0ZWQnLFxuICBQZW5kaW5nID0gJ3BlbmRpbmcnLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uSW5zdGFsbG1lbnRzIHtcbiAgLyoqXG4gICAqIHRoZSBjdXJyZW50IGluc3RhbGxtZW50IG51bWJlclxuICAgKi9cbiAgbnVtYmVyOiBudW1iZXI7XG5cbiAgLyoqXG4gICAqIHRoZSB0b3RhbCBudW1iZXIgb2YgaW5zdGFsbG1lbnRzXG4gICAqL1xuICB0b3RhbDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFRyYW5zYWN0aW9uIHtcbiAgdHlwZTogVHJhbnNhY3Rpb25UeXBlcztcbiAgLyoqXG4gICAqIHNvbWV0aW1lcyBjYWxsZWQgQXNtYWNodGFcbiAgICovXG4gIGlkZW50aWZpZXI/OiBzdHJpbmcgfCBudW1iZXI7XG4gIC8qKlxuICAgKiBJU08gZGF0ZSBzdHJpbmdcbiAgICovXG4gIGRhdGU6IHN0cmluZztcbiAgLyoqXG4gICAqIElTTyBkYXRlIHN0cmluZ1xuICAgKi9cbiAgcHJvY2Vzc2VkRGF0ZTogc3RyaW5nO1xuICBvcmlnaW5hbEFtb3VudDogbnVtYmVyO1xuICBvcmlnaW5hbEN1cnJlbmN5OiBzdHJpbmc7XG4gIGNoYXJnZWRBbW91bnQ6IG51bWJlcjtcbiAgY2hhcmdlZEN1cnJlbmN5Pzogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBtZW1vPzogc3RyaW5nO1xuICBzdGF0dXM6IFRyYW5zYWN0aW9uU3RhdHVzZXM7XG4gIGluc3RhbGxtZW50cz86IFRyYW5zYWN0aW9uSW5zdGFsbG1lbnRzO1xuICBjYXRlZ29yeT86IHN0cmluZztcbiAgcmF3VHJhbnNhY3Rpb24/OiB1bmtub3duO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7SUFNWUEsZ0JBQWdCLEdBQUFDLE9BQUEsQ0FBQUQsZ0JBQUEsMEJBQWhCQSxnQkFBZ0I7RUFBaEJBLGdCQUFnQjtFQUFoQkEsZ0JBQWdCO0VBQUEsT0FBaEJBLGdCQUFnQjtBQUFBO0FBQUEsSUFLaEJFLG1CQUFtQixHQUFBRCxPQUFBLENBQUFDLG1CQUFBLDBCQUFuQkEsbUJBQW1CO0VBQW5CQSxtQkFBbUI7RUFBbkJBLG1CQUFtQjtFQUFBLE9BQW5CQSxtQkFBbUI7QUFBQSIsImlnbm9yZUxpc3QiOltdfQ==
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers-core",
3
- "version": "6.4.1",
3
+ "version": "6.5.0",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {