israeli-bank-scrapers-core 6.3.7 → 6.4.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.
package/README.md CHANGED
@@ -35,7 +35,7 @@ Currently only the following banks are supported:
35
35
  - Behatsdaa - [בהצדעה](behatsdaa.org.il) (thanks [@daniel-hauser](https://github.com/daniel-hauser))
36
36
 
37
37
  # Prerequisites
38
- To use this you will need to have [Node.js](https://nodejs.org) >= 16.x installed.
38
+ To use this you will need to have [Node.js](https://nodejs.org) >= 22.12.0 installed.
39
39
 
40
40
  # Getting started
41
41
  To use these scrapers you'll need to install the package from npm:
@@ -14,11 +14,12 @@ var _transactions = require("../helpers/transactions");
14
14
  var _waiting = require("../helpers/waiting");
15
15
  var _transactions2 = require("../transactions");
16
16
  var _baseScraperWithBrowser = require("./base-scraper-with-browser");
17
+ var _lodash = _interopRequireDefault(require("lodash"));
17
18
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
18
19
  const apiHeaders = {
19
20
  'User-Agent': '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',
20
- Origin: 'https://www.cal-online.co.il',
21
- Referer: 'https://www.cal-online.co.il/',
21
+ Origin: 'https://digital-web.cal-online.co.il',
22
+ Referer: 'https://digital-web.cal-online.co.il',
22
23
  'Accept-Language': 'he-IL,he;q=0.9,en-US;q=0.8,en;q=0.7',
23
24
  'Sec-Fetch-Site': 'same-site',
24
25
  'Sec-Fetch-Mode': 'cors',
@@ -26,6 +27,7 @@ const apiHeaders = {
26
27
  };
27
28
  const LOGIN_URL = 'https://www.cal-online.co.il/';
28
29
  const TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';
30
+ const FRAMES_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Frames/api/Frames/GetFrameStatus';
29
31
  const PENDING_TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';
30
32
  const SSO_AUTHORIZATION_REQUEST_ENDPOINT = 'https://connect.cal-online.co.il/col-rest/calconnect/authentication/SSO';
31
33
  const InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';
@@ -166,7 +168,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
166
168
  async getCards() {
167
169
  const initData = await (0, _waiting.waitUntil)(() => (0, _storage.getFromSessionStorage)(this.page, 'init'), 'get init data in session storage', 10000, 1000);
168
170
  if (!initData) {
169
- throw new Error("could not find 'init' data in session storage");
171
+ throw new Error('could not find "init" data in session storage');
170
172
  }
171
173
  return initData?.result.cards.map(({
172
174
  cardUniqueId,
@@ -240,10 +242,26 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
240
242
  debug(`fetch transactions starting ${startMoment.format()}`);
241
243
  const [cards, xSiteId, Authorization] = await Promise.all([this.getCards(), this.getXSiteId(), this.getAuthorizationHeader()]);
242
244
  const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;
245
+ debug('fetch frames (misgarot) of cards');
246
+ const frames = await (0, _fetch.fetchPost)(FRAMES_REQUEST_ENDPOINT, {
247
+ cardsForFrameData: cards.map(({
248
+ cardUniqueId
249
+ }) => ({
250
+ cardUniqueId
251
+ }))
252
+ }, {
253
+ Authorization,
254
+ 'X-Site-Id': xSiteId,
255
+ 'Content-Type': 'application/json',
256
+ ...apiHeaders
257
+ });
243
258
  const accounts = await Promise.all(cards.map(async card => {
244
259
  const finalMonthToFetchMoment = (0, _moment.default)().add(futureMonthsToScrape, 'month');
245
260
  const months = finalMonthToFetchMoment.diff(startMoment, 'months');
246
261
  const allMonthsData = [];
262
+ const frame = _lodash.default.find(frames.result.bankIssuedCards.cardLevelFrames, {
263
+ cardUniqueId: card.cardUniqueId
264
+ });
247
265
  debug(`fetch pending transactions for card ${card.cardUniqueId}`);
248
266
  let pendingData = await (0, _fetch.fetchPost)(PENDING_TRANSACTIONS_REQUEST_ENDPOINT, {
249
267
  cardUniqueIDArray: [card.cardUniqueId]
@@ -254,7 +272,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
254
272
  ...apiHeaders
255
273
  });
256
274
  debug(`fetch completed transactions for card ${card.cardUniqueId}`);
257
- for (let i = 0; i <= months; i += 1) {
275
+ for (let i = 0; i <= months; i++) {
258
276
  const month = finalMonthToFetchMoment.clone().subtract(i, 'months');
259
277
  const monthData = await (0, _fetch.fetchPost)(TRANSACTIONS_REQUEST_ENDPOINT, {
260
278
  cardUniqueId: card.cardUniqueId,
@@ -284,6 +302,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
284
302
  const txns = this.options.outputData?.enableTransactionsFilterByDate ?? true ? (0, _transactions.filterOldTransactions)(transactions, (0, _moment.default)(startDate), this.options.combineInstallments || false) : transactions;
285
303
  return {
286
304
  txns,
305
+ balance: -frame?.nextTotalDebit,
287
306
  accountNumber: card.last4Digits
288
307
  };
289
308
  }));
@@ -296,4 +315,4 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
296
315
  }
297
316
  }
298
317
  var _default = exports.default = VisaCalScraper;
299
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_navigation","_storage","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","e","__esModule","default","apiHeaders","Origin","Referer","LOGIN_URL","TRANSACTIONS_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","finalMonthToFetchMoment","months","diff","allMonthsData","fetchPost","cardUniqueIDArray","i","month","clone","year","statusCode","title","push","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","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';\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://www.cal-online.co.il',\n  Referer: 'https://www.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 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    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\n        const allMonthsData: CardTransactionDetails[] = [];\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 += 1) {\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          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":[]}
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":[]}
package/package.json CHANGED
@@ -1,10 +1,14 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers-core",
3
- "version": "6.3.7",
3
+ "version": "6.4.0",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {
7
- "node": ">= 18.19.0"
7
+ "node": ">= 22.12.0"
8
+ },
9
+ "publishConfig": {
10
+ "access": "public",
11
+ "provenance": true
8
12
  },
9
13
  "main": "lib/index.js",
10
14
  "types": "lib/index.d.ts",