israeli-bank-scrapers 5.0.1 → 5.1.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.
@@ -1,93 +1,5 @@
1
1
  import { BaseScraperWithBrowser, type LoginOptions } from './base-scraper-with-browser';
2
2
  import { type ScraperScrapingResult } from './interface';
3
- declare enum TrnTypeCode {
4
- regular = "5",
5
- credit = "6",
6
- installments = "8",
7
- standingOrder = "9"
8
- }
9
- interface ScrapedTransaction {
10
- amtBeforeConvAndIndex: number;
11
- branchCodeDesc: string;
12
- cashAccManagerName: null;
13
- cashAccountManager: null;
14
- cashAccountTrnAmt: number;
15
- chargeExternalToCardComment: string;
16
- comments: [];
17
- curPaymentNum: number;
18
- debCrdCurrencySymbol: CurrencySymbol;
19
- debCrdDate: string;
20
- debitSpreadInd: boolean;
21
- discountAmount: unknown;
22
- discountReason: unknown;
23
- immediateComments: [];
24
- isImmediateCommentInd: boolean;
25
- isImmediateHHKInd: boolean;
26
- isMargarita: boolean;
27
- isSpreadPaymenstAbroad: boolean;
28
- linkedComments: [];
29
- merchantAddress: string;
30
- merchantName: string;
31
- merchantPhoneNo: string;
32
- numOfPayments: number;
33
- onGoingTransactionsComment: string;
34
- refundInd: boolean;
35
- roundingAmount: unknown;
36
- roundingReason: unknown;
37
- tokenInd: 0;
38
- tokenNumberPart4: '';
39
- transCardPresentInd: boolean;
40
- transTypeCommentDetails: [];
41
- trnAmt: number;
42
- trnCurrencySymbol: CurrencySymbol;
43
- trnExacWay: number;
44
- trnIntId: string;
45
- trnNumaretor: number;
46
- trnPurchaseDate: string;
47
- trnType: string;
48
- trnTypeCode: TrnTypeCode;
49
- walletProviderCode: 0;
50
- walletProviderDesc: '';
51
- }
52
- type CurrencySymbol = string;
53
- interface CardTransactionDetailsError {
54
- title: string;
55
- statusCode: number;
56
- }
57
- interface CardTransactionDetails extends CardTransactionDetailsError {
58
- result: {
59
- bankAccounts: {
60
- bankAccountNum: string;
61
- bankName: string;
62
- choiceExternalTransactions: any;
63
- currentBankAccountInd: boolean;
64
- debitDates: {
65
- basketAmountComment: unknown;
66
- choiceHHKDebit: number;
67
- date: string;
68
- debitReason: unknown;
69
- fixDebitAmount: number;
70
- fromPurchaseDate: string;
71
- isChoiceRepaiment: boolean;
72
- toPurchaseDate: string;
73
- totalBasketAmount: number;
74
- totalDebits: {
75
- currencySymbol: CurrencySymbol;
76
- amount: number;
77
- }[];
78
- transactions: ScrapedTransaction[];
79
- }[];
80
- immidiateDebits: {
81
- totalDebits: [];
82
- debitDays: [];
83
- };
84
- }[];
85
- blockedCardInd: boolean;
86
- };
87
- statusCode: 1;
88
- statusDescription: string;
89
- statusTitle: string;
90
- }
91
3
  type ScraperSpecificCredentials = {
92
4
  username: string;
93
5
  password: string;
@@ -101,7 +13,6 @@ declare class VisaCalScraper extends BaseScraperWithBrowser<ScraperSpecificCrede
101
13
  getAuthorizationHeader(): Promise<string>;
102
14
  getXSiteId(): Promise<string>;
103
15
  getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions;
104
- isCardTransactionDetails(result: CardTransactionDetails | CardTransactionDetailsError): result is CardTransactionDetails;
105
16
  fetchData(): Promise<ScraperScrapingResult>;
106
17
  }
107
18
  export default VisaCalScraper;
@@ -24,6 +24,7 @@ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol"
24
24
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
25
25
  const LOGIN_URL = 'https://www.cal-online.co.il/';
26
26
  const TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';
27
+ const PENDING_TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';
27
28
  const InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';
28
29
  const debug = (0, _debug.getDebug)('visa-cal');
29
30
  var TrnTypeCode = /*#__PURE__*/function (TrnTypeCode) {
@@ -33,6 +34,15 @@ var TrnTypeCode = /*#__PURE__*/function (TrnTypeCode) {
33
34
  TrnTypeCode["standingOrder"] = "9";
34
35
  return TrnTypeCode;
35
36
  }(TrnTypeCode || {});
37
+ function isPending(transaction) {
38
+ return transaction.debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction
39
+ }
40
+ function isCardTransactionDetails(result) {
41
+ return result.result !== undefined;
42
+ }
43
+ function isCardPendingTransactionDetails(result) {
44
+ return result.result !== undefined;
45
+ }
36
46
  async function getLoginFrame(page) {
37
47
  let frame = null;
38
48
  debug('wait until login frame found');
@@ -91,28 +101,36 @@ function createLoginFields(credentials) {
91
101
  value: credentials.password
92
102
  }];
93
103
  }
94
- function convertParsedDataToTransactions(parsedData) {
95
- const bankAccounts = parsedData.flatMap(monthData => monthData.result.bankAccounts);
104
+ function convertParsedDataToTransactions(data, pendingData) {
105
+ const pendingTransactions = pendingData !== null && pendingData !== void 0 && pendingData.result ? pendingData.result.cardsList.flatMap(card => card.authDetalisList) : [];
106
+ const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);
96
107
  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);
97
108
  const immediateDebitDays = bankAccounts.flatMap(accounts => accounts.immidiateDebits.debitDays);
98
- return [...regularDebitDays, ...immediateDebitDays].flatMap(debitDate => debitDate.transactions).map(transaction => {
99
- const installments = transaction.curPaymentNum && transaction.numOfPayments && {
100
- number: transaction.curPaymentNum,
101
- total: transaction.numOfPayments
102
- } || undefined;
109
+ const completedTransactions = [...regularDebitDays, ...immediateDebitDays].flatMap(debitDate => debitDate.transactions);
110
+ const all = [...pendingTransactions, ...completedTransactions];
111
+ return all.map(transaction => {
112
+ const numOfPayments = isPending(transaction) ? transaction.numberOfPayments : transaction.numOfPayments;
113
+ const installments = numOfPayments ? {
114
+ number: isPending(transaction) ? 1 : transaction.curPaymentNum,
115
+ total: numOfPayments
116
+ } : undefined;
103
117
  const date = (0, _moment.default)(transaction.trnPurchaseDate);
104
- const chargedAmount = transaction.amtBeforeConvAndIndex * -1;
105
- const originalAmount = transaction.trnAmt * -1;
118
+ let chargedAmount = isPending(transaction) ? transaction.trnAmt * -1 : transaction.amtBeforeConvAndIndex * -1;
119
+ let originalAmount = transaction.trnAmt * -1;
120
+ if (transaction.trnTypeCode === TrnTypeCode.credit) {
121
+ chargedAmount = isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex;
122
+ originalAmount = transaction.trnAmt;
123
+ }
106
124
  const result = {
107
- identifier: transaction.trnIntId,
125
+ identifier: !isPending(transaction) ? transaction.trnIntId : undefined,
108
126
  type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode) ? _transactions2.TransactionTypes.Normal : _transactions2.TransactionTypes.Installments,
109
- status: _transactions2.TransactionStatuses.Completed,
127
+ status: isPending(transaction) ? _transactions2.TransactionStatuses.Pending : _transactions2.TransactionStatuses.Completed,
110
128
  date: installments ? date.add(installments.number - 1, 'month').toISOString() : date.toISOString(),
111
- processedDate: new Date(transaction.debCrdDate).toISOString(),
129
+ processedDate: isPending(transaction) ? date.toISOString() : new Date(transaction.debCrdDate).toISOString(),
112
130
  originalAmount,
113
131
  originalCurrency: transaction.trnCurrencySymbol,
114
132
  chargedAmount,
115
- chargedCurrency: transaction.debCrdCurrencySymbol,
133
+ chargedCurrency: !isPending(transaction) ? transaction.debCrdCurrencySymbol : undefined,
116
134
  description: transaction.merchantName,
117
135
  memo: transaction.transTypeCommentDetails.toString(),
118
136
  category: transaction.branchCodeDesc
@@ -203,9 +221,6 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
203
221
  userAgent: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36'
204
222
  };
205
223
  }
206
- isCardTransactionDetails(result) {
207
- return result.result !== undefined;
208
- }
209
224
  async fetchData() {
210
225
  var _this$options$futureM;
211
226
  const defaultStartMoment = (0, _moment.default)().subtract(1, 'years').subtract(6, 'months').add(1, 'day');
@@ -217,11 +232,19 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
217
232
  const xSiteId = await this.getXSiteId();
218
233
  const futureMonthsToScrape = (_this$options$futureM = this.options.futureMonthsToScrape) !== null && _this$options$futureM !== void 0 ? _this$options$futureM : 1;
219
234
  const accounts = await Promise.all(cards.map(async card => {
220
- var _this$options$outputD, _this$options$outputD2;
221
- debug(`fetch transactions for card ${card.cardUniqueId}`);
235
+ var _pendingData, _pendingData2, _this$options$outputD, _this$options$outputD2;
222
236
  const finalMonthToFetchMoment = (0, _moment.default)().add(futureMonthsToScrape, 'month');
223
237
  const months = finalMonthToFetchMoment.diff(startMoment, 'months');
224
238
  const allMonthsData = [];
239
+ debug(`fetch pending transactions for card ${card.cardUniqueId}`);
240
+ let pendingData = await (0, _fetch.fetchPostWithinPage)(this.page, PENDING_TRANSACTIONS_REQUEST_ENDPOINT, {
241
+ cardUniqueIDArray: [card.cardUniqueId]
242
+ }, {
243
+ Authorization,
244
+ 'X-Site-Id': xSiteId,
245
+ 'Content-Type': 'application/json'
246
+ });
247
+ debug(`fetch completed transactions for card ${card.cardUniqueId}`);
225
248
  for (let i = 0; i <= months; i += 1) {
226
249
  const month = finalMonthToFetchMoment.clone().subtract(i, 'months');
227
250
  const monthData = await (0, _fetch.fetchPostWithinPage)(this.page, TRANSACTIONS_REQUEST_ENDPOINT, {
@@ -234,12 +257,20 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
234
257
  'Content-Type': 'application/json'
235
258
  });
236
259
  if ((monthData === null || monthData === void 0 ? void 0 : monthData.statusCode) !== 1) throw new Error(`failed to fetch transactions for card ${card.last4Digits}. Message: ${(monthData === null || monthData === void 0 ? void 0 : monthData.title) || ''}`);
237
- if (!this.isCardTransactionDetails(monthData)) {
260
+ if (!isCardTransactionDetails(monthData)) {
238
261
  throw new Error('monthData is not of type CardTransactionDetails');
239
262
  }
240
263
  allMonthsData.push(monthData);
241
264
  }
242
- const transactions = convertParsedDataToTransactions(allMonthsData);
265
+ if (((_pendingData = pendingData) === null || _pendingData === void 0 ? void 0 : _pendingData.statusCode) !== 1 && ((_pendingData2 = pendingData) === null || _pendingData2 === void 0 ? void 0 : _pendingData2.statusCode) !== 96) {
266
+ var _pendingData3;
267
+ debug(`failed to fetch pending transactions for card ${card.last4Digits}. Message: ${((_pendingData3 = pendingData) === null || _pendingData3 === void 0 ? void 0 : _pendingData3.title) || ''}`);
268
+ pendingData = null;
269
+ } else if (!isCardPendingTransactionDetails(pendingData)) {
270
+ debug('pendingData is not of type CardTransactionDetails');
271
+ pendingData = null;
272
+ }
273
+ const transactions = convertParsedDataToTransactions(allMonthsData, pendingData);
243
274
  debug('filer out old transactions');
244
275
  const txns = ((_this$options$outputD = (_this$options$outputD2 = this.options.outputData) === null || _this$options$outputD2 === void 0 ? void 0 : _this$options$outputD2.enableTransactionsFilterByDate) !== null && _this$options$outputD !== void 0 ? _this$options$outputD : true) ? (0, _transactions.filterOldTransactions)(transactions, (0, _moment.default)(startDate), this.options.combineInstallments || false) : transactions;
245
276
  return {
@@ -256,4 +287,4 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
256
287
  }
257
288
  }
258
289
  var _default = exports.default = VisaCalScraper;
259
- //# 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","_defineProperty","r","t","_toPropertyKey","Object","defineProperty","value","enumerable","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","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","username","password","convertParsedDataToTransactions","parsedData","bankAccounts","flatMap","monthData","result","regularDebitDays","accounts","debitDates","immediateDebitDays","immidiateDebits","debitDays","debitDate","transactions","map","transaction","installments","curPaymentNum","numOfPayments","number","total","undefined","date","moment","trnPurchaseDate","chargedAmount","amtBeforeConvAndIndex","originalAmount","trnAmt","identifier","trnIntId","type","regular","standingOrder","trnTypeCode","TransactionTypes","Normal","Installments","status","TransactionStatuses","Completed","add","toISOString","processedDate","Date","debCrdDate","originalCurrency","trnCurrencySymbol","chargedCurrency","debCrdCurrencySymbol","description","merchantName","memo","transTypeCommentDetails","toString","category","branchCodeDesc","VisaCalScraper","BaseScraperWithBrowser","constructor","args","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","auth","calConnectToken","getXSiteId","getLoginOptions","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","openLoginPopup","postAction","currentUrl","getCurrentUrl","endsWith","requiresChangePassword","userAgent","isCardTransactionDetails","fetchData","_this$options$futureM","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","Authorization","xSiteId","futureMonthsToScrape","all","card","_this$options$outputD","_this$options$outputD2","finalMonthToFetchMoment","months","diff","allMonthsData","month","clone","fetchPostWithinPage","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 Frame, type Page } from 'puppeteer';\nimport { getDebug } from '../helpers/debug';\nimport {\n  clickButton, elementPresentOnPage, pageEval, waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { getCurrentUrl } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult } from './interface';\n\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\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}\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}\n\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(() => {\n    frame = page\n      .frames()\n      .find((f) => f.url().includes('connect')) || null;\n    return Promise.resolve(!!frame);\n  }, 'wait for iframe with login form', 10000, 1000);\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 ? await pageEval(frame, 'div.general-error > div', '', (item) => {\n    return (item as HTMLDivElement).innerText;\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]: [async (options?: { page?: Page }) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasInvalidPasswordError(page);\n    }],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [async (options?: { page?: Page }) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasChangePasswordForm(page);\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(parsedData: CardTransactionDetails[]): Transaction[] {\n  const bankAccounts = parsedData\n    .flatMap((monthData) => monthData.result.bankAccounts);\n\n  const regularDebitDays = bankAccounts\n    .flatMap((accounts) => accounts.debitDates);\n  const immediateDebitDays = bankAccounts\n    .flatMap((accounts) => accounts.immidiateDebits.debitDays);\n\n  return [...regularDebitDays, ...immediateDebitDays]\n    .flatMap((debitDate) => debitDate.transactions)\n    .map((transaction) => {\n      const installments = (transaction.curPaymentNum && transaction.numOfPayments &&\n      {\n        number: transaction.curPaymentNum,\n        total: transaction.numOfPayments,\n      }) ||\n        undefined;\n\n      const date = moment(transaction.trnPurchaseDate);\n\n      const chargedAmount = transaction.amtBeforeConvAndIndex * (-1);\n      const originalAmount = transaction.trnAmt * (-1);\n\n      const result: Transaction = {\n        identifier: transaction.trnIntId,\n        type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode) ?\n          TransactionTypes.Normal :\n          TransactionTypes.Installments,\n        status: TransactionStatuses.Completed,\n        date: installments ?\n          date.add(installments.number - 1, 'month').toISOString() :\n          date.toISOString(),\n        processedDate: new Date(transaction.debCrdDate).toISOString(),\n        originalAmount,\n        originalCurrency: transaction.trnCurrencySymbol,\n        chargedAmount,\n        chargedCurrency: transaction.debCrdCurrencySymbol,\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  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    const authModule = await getFromSessionStorage<{ auth: { calConnectToken: string } }>(this.page, 'auth-module');\n    if (!authModule) {\n      throw new Error('could not find \\'auth-module\\' in session storage');\n    }\n    return `CALAuthScheme ${authModule.auth.calConnectToken}`;\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    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 waitUntilElementFound(this.page, 'button.btn-close');\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\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: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36',\n    };\n  }\n\n  isCardTransactionDetails(result: CardTransactionDetails | CardTransactionDetailsError):\n    result is CardTransactionDetails {\n    return (result as CardTransactionDetails).result !== undefined;\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 Authorization = await this.getAuthorizationHeader();\n    const cards = await this.getCards();\n    const xSiteId = await this.getXSiteId();\n    const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;\n\n    const accounts = await Promise.all(\n      cards.map(async (card) => {\n        debug(`fetch transactions for card ${card.cardUniqueId}`);\n\n        const finalMonthToFetchMoment = moment().add(futureMonthsToScrape, 'month');\n        const months = finalMonthToFetchMoment.diff(startMoment, 'months');\n\n        const allMonthsData: (CardTransactionDetails)[] = [];\n        for (let i = 0; i <= months; i += 1) {\n          const month = finalMonthToFetchMoment.clone().subtract(i, 'months');\n          const monthData = await fetchPostWithinPage<CardTransactionDetails | CardTransactionDetailsError>(\n            this.page, 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            },\n          );\n\n          if (monthData?.statusCode !== 1) throw new Error(`failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`);\n\n          if (!this.isCardTransactionDetails(monthData)) {\n            throw new Error('monthData is not of type CardTransactionDetails');\n          }\n\n          allMonthsData.push(monthData);\n        }\n\n        const transactions = convertParsedDataToTransactions(allMonthsData);\n\n        debug('filer out old transactions');\n        const txns = (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":[]}
290
+ //# 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","_defineProperty","r","t","_toPropertyKey","Object","defineProperty","value","enumerable","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","PENDING_TRANSACTIONS_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","isPending","transaction","debCrdDate","undefined","isCardTransactionDetails","result","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","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","constructor","args","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","auth","calConnectToken","getXSiteId","getLoginOptions","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","openLoginPopup","postAction","currentUrl","getCurrentUrl","endsWith","requiresChangePassword","userAgent","fetchData","_this$options$futureM","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","Authorization","xSiteId","futureMonthsToScrape","_pendingData","_pendingData2","_this$options$outputD","_this$options$outputD2","finalMonthToFetchMoment","months","diff","allMonthsData","fetchPostWithinPage","cardUniqueIDArray","month","clone","year","statusCode","title","push","_pendingData3","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","accountNumber","JSON","stringify","success","_default","exports"],"sources":["../../src/scrapers/visa-cal.ts"],"sourcesContent":["import moment from 'moment';\nimport { type Frame, type Page } from 'puppeteer';\nimport { getDebug } from '../helpers/debug';\nimport {\n  clickButton, elementPresentOnPage, pageEval, waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { getCurrentUrl } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult } from './interface';\n\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\nconst PENDING_TRANSACTIONS_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';\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\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\nfunction isPending(transaction: ScrapedTransaction | ScrapedPendingTransaction): transaction is ScrapedPendingTransaction {\n  return (transaction as ScrapedTransaction).debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction\n}\n\nfunction isCardTransactionDetails(result: CardTransactionDetails | CardTransactionDetailsError):\nresult is CardTransactionDetails {\n  return (result as CardTransactionDetails).result !== undefined;\n}\n\nfunction isCardPendingTransactionDetails(result: CardPendingTransactionDetails | CardTransactionDetailsError):\nresult 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    frame = page\n      .frames()\n      .find((f) => f.url().includes('connect')) || null;\n    return Promise.resolve(!!frame);\n  }, 'wait for iframe with login form', 10000, 1000);\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 ? await pageEval(frame, 'div.general-error > div', '', (item) => {\n    return (item as HTMLDivElement).innerText;\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]: [async (options?: { page?: Page }) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasInvalidPasswordError(page);\n    }],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [async (options?: { page?: Page }) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasChangePasswordForm(page);\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(data: CardTransactionDetails[], pendingData?: CardPendingTransactionDetails | null): Transaction[] {\n  const pendingTransactions = pendingData?.result ?\n    pendingData.result.cardsList.flatMap((card) => card.authDetalisList) :\n    [];\n\n  const bankAccounts = data\n    .flatMap((monthData) => monthData.result.bankAccounts);\n  const regularDebitDays = bankAccounts\n    .flatMap((accounts) => accounts.debitDates);\n  const immediateDebitDays = bankAccounts\n    .flatMap((accounts) => accounts.immidiateDebits.debitDays);\n  const completedTransactions = [...regularDebitDays, ...immediateDebitDays]\n    .flatMap((debitDate) => debitDate.transactions);\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    let chargedAmount = isPending(transaction) ? transaction.trnAmt * (-1) : transaction.amtBeforeConvAndIndex * (-1);\n    let originalAmount = transaction.trnAmt * (-1);\n\n    if (transaction.trnTypeCode === TrnTypeCode.credit) {\n      chargedAmount = isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex;\n      originalAmount = transaction.trnAmt;\n    }\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 ?\n        date.add(installments.number - 1, 'month').toISOString() :\n        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  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    const authModule = await getFromSessionStorage<{ auth: { calConnectToken: string } }>(this.page, 'auth-module');\n    if (!authModule) {\n      throw new Error('could not find \\'auth-module\\' in session storage');\n    }\n    return `CALAuthScheme ${authModule.auth.calConnectToken}`;\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    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 waitUntilElementFound(this.page, 'button.btn-close');\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\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: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36',\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 Authorization = await this.getAuthorizationHeader();\n    const cards = await this.getCards();\n    const xSiteId = await this.getXSiteId();\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 fetchPostWithinPage<CardPendingTransactionDetails | CardTransactionDetailsError>(\n          this.page, PENDING_TRANSACTIONS_REQUEST_ENDPOINT,\n          { cardUniqueIDArray: [card.cardUniqueId] },\n          {\n            Authorization,\n            'X-Site-Id': xSiteId,\n            'Content-Type': 'application/json',\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 fetchPostWithinPage<CardTransactionDetails | CardTransactionDetailsError>(\n            this.page, 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            },\n          );\n\n          if (monthData?.statusCode !== 1) throw new Error(`failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`);\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(`failed to fetch pending transactions for card ${card.last4Digits}. Message: ${pendingData?.title || ''}`);\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('filer out old transactions');\n        const txns = (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":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers",
3
- "version": "5.0.1",
3
+ "version": "5.1.0",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {
@@ -80,7 +80,7 @@
80
80
  "moment": "^2.22.2",
81
81
  "moment-timezone": "^0.5.37",
82
82
  "node-fetch": "^2.2.0",
83
- "puppeteer": "22.5.0",
83
+ "puppeteer": "22.12.1",
84
84
  "uuid": "^9.0.1"
85
85
  },
86
86
  "files": [