israeli-bank-scrapers 6.3.2 → 6.3.4

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.
@@ -18,6 +18,10 @@ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
18
18
  var _errors = require("./errors");
19
19
  var _browser = require("../helpers/browser");
20
20
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
21
+ const RATE_LIMIT = {
22
+ SLEEP_BETWEEN: 1000,
23
+ TRANSACTIONS_BATCH_SIZE: 10
24
+ };
21
25
  const COUNTRY_CODE = '212';
22
26
  const ID_TYPE = '1';
23
27
  const INSTALLMENTS_KEYWORD = 'תשלום';
@@ -34,6 +38,7 @@ function getAccountsUrl(servicesUrl, monthMoment) {
34
38
  }
35
39
  async function fetchAccounts(page, servicesUrl, monthMoment) {
36
40
  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);
41
+ debug(`fetching accounts from ${dataUrl}`);
37
42
  const dataResult = await (0, _fetch.fetchGetWithinPage)(page, dataUrl);
38
43
  if (dataResult && _lodash.default.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {
39
44
  const {
@@ -111,6 +116,8 @@ function convertTransactions(txns, processedDate) {
111
116
  async function fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment) {
112
117
  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);
113
118
  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);
119
+ await (0, _waiting.sleep)(RATE_LIMIT.SLEEP_BETWEEN);
120
+ debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);
114
121
  const dataResult = await (0, _fetch.fetchGetWithinPage)(page, dataUrl);
115
122
  if (dataResult && _lodash.default.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {
116
123
  const accountTxns = {};
@@ -145,18 +152,14 @@ async function fetchTransactions(page, options, companyServiceOptions, startMome
145
152
  }
146
153
  return {};
147
154
  }
148
- function getTransactionExtraDetails(servicesUrl, month, accountIndex, transaction) {
149
- const moedChiuv = month.format('MMYYYY');
150
- const url = new URL(servicesUrl);
155
+ async function getExtraScrapTransaction(page, options, month, accountIndex, transaction) {
156
+ const url = new URL(options.servicesUrl);
151
157
  url.searchParams.set('reqName', 'PirteyIska_204');
152
158
  url.searchParams.set('CardIndex', accountIndex.toString());
153
159
  url.searchParams.set('shovarRatz', transaction.identifier.toString());
154
- url.searchParams.set('moedChiuv', moedChiuv);
155
- return url.toString();
156
- }
157
- async function getExtraScrapTransaction(page, options, month, accountIndex, transaction) {
158
- const dataUrl = getTransactionExtraDetails(options.servicesUrl, month, accountIndex, transaction);
159
- const data = await (0, _fetch.fetchGetWithinPage)(page, dataUrl);
160
+ url.searchParams.set('moedChiuv', month.format('MMYYYY'));
161
+ debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);
162
+ const data = await (0, _fetch.fetchGetWithinPage)(page, url.toString());
160
163
  if (!data) {
161
164
  return transaction;
162
165
  }
@@ -166,32 +169,40 @@ async function getExtraScrapTransaction(page, options, month, accountIndex, tran
166
169
  category: rawCategory.trim()
167
170
  };
168
171
  }
169
- function getExtraScrapTransactions(accountWithIndex, page, options, month) {
170
- const promises = accountWithIndex.txns.map(t => getExtraScrapTransaction(page, options, month, accountWithIndex.index, t));
171
- return Promise.all(promises);
172
- }
173
172
  async function getExtraScrapAccount(page, options, accountMap, month) {
174
- const promises = Object.keys(accountMap).map(async a => ({
175
- ...accountMap[a],
176
- txns: await getExtraScrapTransactions(accountMap[a], page, options, month)
177
- }));
178
- const accounts = await Promise.all(promises);
173
+ const accounts = [];
174
+ for (const account of Object.values(accountMap)) {
175
+ debug(`get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`, month.format('YYYY-MM'));
176
+ const txns = [];
177
+ for (const txnsChunk of _lodash.default.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {
178
+ debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);
179
+ const updatedTxns = await Promise.all(txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)));
180
+ await (0, _waiting.sleep)(RATE_LIMIT.SLEEP_BETWEEN);
181
+ txns.push(...updatedTxns);
182
+ }
183
+ accounts.push({
184
+ ...account,
185
+ txns
186
+ });
187
+ }
179
188
  return accounts.reduce((m, x) => ({
180
189
  ...m,
181
190
  [x.accountNumber]: x
182
191
  }), {});
183
192
  }
184
- function getExtraScrap(accountsWithIndex, page, options, allMonths) {
185
- const actions = accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i]));
186
- return (0, _waiting.runSerial)(actions);
193
+ async function getAdditionalTransactionInformation(scraperOptions, accountsWithIndex, page, options, allMonths) {
194
+ if (!scraperOptions.additionalTransactionInformation || scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')) {
195
+ return accountsWithIndex;
196
+ }
197
+ return (0, _waiting.runSerial)(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));
187
198
  }
188
199
  async function fetchAllTransactions(page, options, companyServiceOptions, startMoment) {
189
200
  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;
190
201
  const allMonths = (0, _dates.default)(startMoment, futureMonthsToScrape);
191
- const results = await Promise.all(allMonths.map(async monthMoment => {
202
+ const results = await (0, _waiting.runSerial)(allMonths.map(monthMoment => () => {
192
203
  return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);
193
204
  }));
194
- const finalResult = options.additionalTransactionInformation ? await getExtraScrap(results, page, companyServiceOptions, allMonths) : results;
205
+ const finalResult = await getAdditionalTransactionInformation(options, results, page, companyServiceOptions, allMonths);
195
206
  const combinedTxns = {};
196
207
  finalResult.forEach(result => {
197
208
  Object.keys(result).forEach(accountNumber => {
@@ -244,6 +255,7 @@ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBro
244
255
  checkLevel: '1',
245
256
  companyCode: this.companyCode
246
257
  };
258
+ debug('logging in with validate request');
247
259
  const validateResult = await (0, _fetch.fetchPostWithinPage)(this.page, validateUrl, validateRequest);
248
260
  if (!validateResult || !validateResult.Header || validateResult.Header.Status !== '1' || !validateResult.ValidateIdDataBean) {
249
261
  throw new Error('unknown error during login');
@@ -263,8 +275,9 @@ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBro
263
275
  countryCode: COUNTRY_CODE,
264
276
  idType: ID_TYPE
265
277
  };
278
+ debug('user login started');
266
279
  const loginResult = await (0, _fetch.fetchPostWithinPage)(this.page, loginUrl, request);
267
- debug(`user login with status '${loginResult?.status}'`);
280
+ debug(`user login with status '${loginResult?.status}'`, loginResult);
268
281
  if (loginResult && loginResult.status === '1') {
269
282
  this.emitProgress(_definitions.ScraperProgressTypes.LoginSuccess);
270
283
  return {
@@ -308,4 +321,4 @@ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBro
308
321
  }
309
322
  }
310
323
  var _default = exports.default = IsracardAmexBaseScraper;
311
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_constants","_definitions","_dates","_debug","_fetch","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_errors","_browser","e","__esModule","default","COUNTRY_CODE","ID_TYPE","INSTALLMENTS_KEYWORD","DATE_FORMAT","debug","getDebug","getAccountsUrl","servicesUrl","monthMoment","billingDate","format","url","URL","searchParams","set","toString","fetchAccounts","page","dataUrl","dataResult","fetchGetWithinPage","_","get","DashboardMonthBean","cardsCharges","map","cardCharge","index","parseInt","cardIndex","accountNumber","cardNumber","processedDate","moment","toISOString","getTransactionsUrl","month","year","monthStr","convertCurrency","currencyStr","SHEKEL_CURRENCY_KEYWORD","ALT_SHEKEL_CURRENCY","SHEKEL_CURRENCY","getInstallmentsInfo","txn","moreInfo","includes","undefined","matches","match","length","number","total","getTransactionType","TransactionTypes","Installments","Normal","convertTransactions","txns","filteredTxns","filter","dealSumType","voucherNumberRatz","voucherNumberRatzOutbound","isOutbound","dealSumOutbound","txnDateStr","fullPurchaseDateOutbound","fullPurchaseDate","txnMoment","currentProcessedDate","fullPaymentDate","result","type","identifier","date","originalAmount","dealSum","originalCurrency","currentPaymentCurrency","currencyId","chargedAmount","paymentSumOutbound","paymentSum","chargedCurrency","description","fullSupplierNameOutbound","fullSupplierNameHeb","memo","installments","status","TransactionStatuses","Completed","fetchTransactions","options","companyServiceOptions","startMoment","accounts","CardsTransactionsListBean","accountTxns","forEach","account","txnGroups","allTxns","txnGroup","txnIsrael","push","txnAbroad","combineInstallments","fixInstallments","outputData","enableTransactionsFilterByDate","filterOldTransactions","getTransactionExtraDetails","accountIndex","transaction","moedChiuv","getExtraScrapTransaction","data","rawCategory","category","trim","getExtraScrapTransactions","accountWithIndex","promises","t","Promise","all","getExtraScrapAccount","accountMap","Object","keys","a","reduce","m","x","getExtraScrap","accountsWithIndex","allMonths","actions","i","runSerial","fetchAllTransactions","futureMonthsToScrape","getAllMonthMoments","results","finalResult","additionalTransactionInformation","combinedTxns","txnsForAccount","toBeAddedTxns","success","IsracardAmexBaseScraper","BaseScraperWithBrowser","constructor","baseUrl","companyCode","login","credentials","setRequestInterception","on","request","abort","interceptionPriorities","continue","maskHeadlessUserAgent","navigateTo","emitProgress","ScraperProgressTypes","LoggingIn","validateUrl","validateRequest","id","cardSuffix","card6Digits","countryCode","idType","checkLevel","validateResult","fetchPostWithinPage","Header","Status","ValidateIdDataBean","Error","validateReturnCode","returnCode","userName","loginUrl","KodMishtamesh","MisparZihuy","Sisma","password","loginResult","LoginSuccess","ChangePassword","errorType","ScraperErrorTypes","LoginFailed","InvalidPassword","fetchData","defaultStartMoment","subtract","startDate","toDate","max","_default","exports"],"sources":["../../src/scrapers/base-isracard-amex.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer';\nimport { ALT_SHEKEL_CURRENCY, SHEKEL_CURRENCY, SHEKEL_CURRENCY_KEYWORD } from '../constants';\nimport { ScraperProgressTypes } from '../definitions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { getDebug } from '../helpers/debug';\nimport { fetchGetWithinPage, fetchPostWithinPage } from '../helpers/fetch';\nimport { filterOldTransactions, fixInstallments } from '../helpers/transactions';\nimport { runSerial } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionInstallments,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\nimport { interceptionPriorities, maskHeadlessUserAgent } from '../helpers/browser';\n\nconst COUNTRY_CODE = '212';\nconst ID_TYPE = '1';\nconst INSTALLMENTS_KEYWORD = 'תשלום';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst debug = getDebug('base-isracard-amex');\n\ntype CompanyServiceOptions = {\n  servicesUrl: string;\n  companyCode: string;\n};\n\ntype ScrapedAccountsWithIndex = Record<string, TransactionsAccount & { index: number }>;\n\ninterface ScrapedTransaction {\n  dealSumType: string;\n  voucherNumberRatzOutbound: string;\n  voucherNumberRatz: string;\n  moreInfo?: string;\n  dealSumOutbound: boolean;\n  currencyId: string;\n  currentPaymentCurrency: string;\n  dealSum: number;\n  fullPaymentDate?: string;\n  fullPurchaseDate?: string;\n  fullPurchaseDateOutbound?: string;\n  fullSupplierNameHeb: string;\n  fullSupplierNameOutbound: string;\n  paymentSum: number;\n  paymentSumOutbound: number;\n}\n\ninterface ScrapedAccount {\n  index: number;\n  accountNumber: string;\n  processedDate: string;\n}\n\ninterface ScrapedLoginValidation {\n  Header: {\n    Status: string;\n  };\n  ValidateIdDataBean?: {\n    userName?: string;\n    returnCode: string;\n  };\n}\n\ninterface ScrapedAccountsWithinPageResponse {\n  Header: {\n    Status: string;\n  };\n  DashboardMonthBean?: {\n    cardsCharges: {\n      cardIndex: string;\n      cardNumber: string;\n      billingDate: string;\n    }[];\n  };\n}\n\ninterface ScrapedCurrentCardTransactions {\n  txnIsrael?: ScrapedTransaction[];\n  txnAbroad?: ScrapedTransaction[];\n}\n\ninterface ScrapedTransactionData {\n  Header?: {\n    Status: string;\n  };\n  PirteyIska_204Bean?: {\n    sector: string;\n  };\n\n  CardsTransactionsListBean?: Record<\n    string,\n    {\n      CurrentCardTransactions: ScrapedCurrentCardTransactions[];\n    }\n  >;\n}\n\nfunction getAccountsUrl(servicesUrl: string, monthMoment: Moment) {\n  const billingDate = monthMoment.format('YYYY-MM-DD');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'DashboardMonth');\n  url.searchParams.set('actionCode', '0');\n  url.searchParams.set('billingDate', billingDate);\n  url.searchParams.set('format', 'Json');\n  return url.toString();\n}\n\nasync function fetchAccounts(page: Page, servicesUrl: string, monthMoment: Moment): Promise<ScrapedAccount[]> {\n  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);\n  const dataResult = await fetchGetWithinPage<ScrapedAccountsWithinPageResponse>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {\n    const { cardsCharges } = dataResult.DashboardMonthBean;\n    if (cardsCharges) {\n      return cardsCharges.map(cardCharge => {\n        return {\n          index: parseInt(cardCharge.cardIndex, 10),\n          accountNumber: cardCharge.cardNumber,\n          processedDate: moment(cardCharge.billingDate, DATE_FORMAT).toISOString(),\n        };\n      });\n    }\n  }\n  return [];\n}\n\nfunction getTransactionsUrl(servicesUrl: string, monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const monthStr = month < 10 ? `0${month}` : month.toString();\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'CardsTransactionsList');\n  url.searchParams.set('month', monthStr);\n  url.searchParams.set('year', `${year}`);\n  url.searchParams.set('requiredDate', 'N');\n  return url.toString();\n}\n\nfunction convertCurrency(currencyStr: string) {\n  if (currencyStr === SHEKEL_CURRENCY_KEYWORD || currencyStr === ALT_SHEKEL_CURRENCY) {\n    return SHEKEL_CURRENCY;\n  }\n  return currencyStr;\n}\n\nfunction getInstallmentsInfo(txn: ScrapedTransaction): TransactionInstallments | undefined {\n  if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {\n    return undefined;\n  }\n  const matches = txn.moreInfo.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\n\nfunction getTransactionType(txn: ScrapedTransaction) {\n  return getInstallmentsInfo(txn) ? TransactionTypes.Installments : TransactionTypes.Normal;\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], processedDate: string): Transaction[] {\n  const filteredTxns = txns.filter(\n    txn =>\n      txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000',\n  );\n\n  return filteredTxns.map(txn => {\n    const isOutbound = txn.dealSumOutbound;\n    const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;\n    const txnMoment = moment(txnDateStr, DATE_FORMAT);\n\n    const currentProcessedDate = txn.fullPaymentDate\n      ? moment(txn.fullPaymentDate, DATE_FORMAT).toISOString()\n      : processedDate;\n    const result: Transaction = {\n      type: getTransactionType(txn),\n      identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),\n      date: txnMoment.toISOString(),\n      processedDate: currentProcessedDate,\n      originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,\n      originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),\n      chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,\n      chargedCurrency: convertCurrency(txn.currencyId),\n      description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,\n      memo: txn.moreInfo || '',\n      installments: getInstallmentsInfo(txn) || undefined,\n      status: TransactionStatuses.Completed,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n  monthMoment: Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);\n  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);\n  const dataResult = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {\n    const accountTxns: ScrapedAccountsWithIndex = {};\n    accounts.forEach(account => {\n      const txnGroups: ScrapedCurrentCardTransactions[] | undefined = _.get(\n        dataResult,\n        `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`,\n      );\n      if (txnGroups) {\n        let allTxns: Transaction[] = [];\n        txnGroups.forEach(txnGroup => {\n          if (txnGroup.txnIsrael) {\n            const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);\n            allTxns.push(...txns);\n          }\n        });\n\n        if (!options.combineInstallments) {\n          allTxns = fixInstallments(allTxns);\n        }\n        if (options.outputData?.enableTransactionsFilterByDate ?? true) {\n          allTxns = filterOldTransactions(allTxns, startMoment, options.combineInstallments || false);\n        }\n        accountTxns[account.accountNumber] = {\n          accountNumber: account.accountNumber,\n          index: account.index,\n          txns: allTxns,\n        };\n      }\n    });\n    return accountTxns;\n  }\n\n  return {};\n}\n\nfunction getTransactionExtraDetails(\n  servicesUrl: string,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): string {\n  const moedChiuv = month.format('MMYYYY');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'PirteyIska_204');\n  url.searchParams.set('CardIndex', accountIndex.toString());\n  url.searchParams.set('shovarRatz', transaction.identifier!.toString());\n  url.searchParams.set('moedChiuv', moedChiuv);\n  return url.toString();\n}\nasync function getExtraScrapTransaction(\n  page: Page,\n  options: CompanyServiceOptions,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): Promise<Transaction> {\n  const dataUrl = getTransactionExtraDetails(options.servicesUrl, month, accountIndex, transaction);\n  const data = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n\n  if (!data) {\n    return transaction;\n  }\n\n  const rawCategory = _.get(data, 'PirteyIska_204Bean.sector') ?? '';\n  return {\n    ...transaction,\n    category: rawCategory.trim(),\n  };\n}\n\nfunction getExtraScrapTransactions(\n  accountWithIndex: TransactionsAccount & { index: number },\n  page: Page,\n  options: CompanyServiceOptions,\n  month: moment.Moment,\n): Promise<Transaction[]> {\n  const promises = accountWithIndex.txns.map(t =>\n    getExtraScrapTransaction(page, options, month, accountWithIndex.index, t),\n  );\n  return Promise.all(promises);\n}\n\nasync function getExtraScrapAccount(\n  page: Page,\n  options: CompanyServiceOptions,\n  accountMap: ScrapedAccountsWithIndex,\n  month: moment.Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const promises = Object.keys(accountMap).map(async a => ({\n    ...accountMap[a],\n    txns: await getExtraScrapTransactions(accountMap[a], page, options, month),\n  }));\n  const accounts = await Promise.all(promises);\n  return accounts.reduce((m, x) => ({ ...m, [x.accountNumber]: x }), {});\n}\n\nfunction getExtraScrap(\n  accountsWithIndex: ScrapedAccountsWithIndex[],\n  page: Page,\n  options: CompanyServiceOptions,\n  allMonths: moment.Moment[],\n): Promise<ScrapedAccountsWithIndex[]> {\n  const actions = accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i]));\n  return runSerial(actions);\n}\n\nasync function fetchAllTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n  const results: ScrapedAccountsWithIndex[] = await Promise.all(\n    allMonths.map(async monthMoment => {\n      return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);\n    }),\n  );\n\n  const finalResult = options.additionalTransactionInformation\n    ? await getExtraScrap(results, page, companyServiceOptions, allMonths)\n    : results;\n\n  const combinedTxns: Record<string, Transaction[]> = {};\n\n  finalResult.forEach(result => {\n    Object.keys(result).forEach(accountNumber => {\n      let txnsForAccount = combinedTxns[accountNumber];\n      if (!txnsForAccount) {\n        txnsForAccount = [];\n        combinedTxns[accountNumber] = txnsForAccount;\n      }\n      const toBeAddedTxns = result[accountNumber].txns;\n      combinedTxns[accountNumber].push(...toBeAddedTxns);\n    });\n  });\n\n  const accounts = Object.keys(combinedTxns).map(accountNumber => {\n    return {\n      accountNumber,\n      txns: combinedTxns[accountNumber],\n    };\n  });\n\n  return {\n    success: true,\n    accounts,\n  };\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; card6Digits: string };\nclass IsracardAmexBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private baseUrl: string;\n\n  private companyCode: string;\n\n  private servicesUrl: string;\n\n  constructor(options: ScraperOptions, baseUrl: string, companyCode: string) {\n    super(options);\n\n    this.baseUrl = baseUrl;\n    this.companyCode = companyCode;\n    this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;\n  }\n\n  async login(credentials: ScraperSpecificCredentials): Promise<ScraperScrapingResult> {\n    await this.page.setRequestInterception(true);\n    this.page.on('request', request => {\n      if (request.url().includes('detector-dom.min.js')) {\n        debug('force abort for request do download detector-dom.min.js resource');\n        void request.abort(undefined, interceptionPriorities.abort);\n      } else {\n        void request.continue(undefined, interceptionPriorities.continue);\n      }\n    });\n\n    await maskHeadlessUserAgent(this.page);\n\n    await this.navigateTo(`${this.baseUrl}/personalarea/Login`);\n\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;\n    const validateRequest = {\n      id: credentials.id,\n      cardSuffix: credentials.card6Digits,\n      countryCode: COUNTRY_CODE,\n      idType: ID_TYPE,\n      checkLevel: '1',\n      companyCode: this.companyCode,\n    };\n    const validateResult = await fetchPostWithinPage<ScrapedLoginValidation>(this.page, validateUrl, validateRequest);\n    if (\n      !validateResult ||\n      !validateResult.Header ||\n      validateResult.Header.Status !== '1' ||\n      !validateResult.ValidateIdDataBean\n    ) {\n      throw new Error('unknown error during login');\n    }\n\n    const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;\n    debug(`user validate with return code '${validateReturnCode}'`);\n    if (validateReturnCode === '1') {\n      const { userName } = validateResult.ValidateIdDataBean;\n\n      const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;\n      const request = {\n        KodMishtamesh: userName,\n        MisparZihuy: credentials.id,\n        Sisma: credentials.password,\n        cardSuffix: credentials.card6Digits,\n        countryCode: COUNTRY_CODE,\n        idType: ID_TYPE,\n      };\n      const loginResult = await fetchPostWithinPage<{ status: string }>(this.page, loginUrl, request);\n      debug(`user login with status '${loginResult?.status}'`);\n\n      if (loginResult && loginResult.status === '1') {\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      }\n\n      if (loginResult && loginResult.status === '3') {\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      }\n\n      this.emitProgress(ScraperProgressTypes.LoginFailed);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.InvalidPassword,\n      };\n    }\n\n    if (validateReturnCode === '4') {\n      this.emitProgress(ScraperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    }\n\n    this.emitProgress(ScraperProgressTypes.LoginFailed);\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.InvalidPassword,\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    return fetchAllTransactions(\n      this.page,\n      this.options,\n      {\n        servicesUrl: this.servicesUrl,\n        companyCode: this.companyCode,\n      },\n      startMoment,\n    );\n  }\n}\n\nexport default IsracardAmexBaseScraper;\n"],"mappings":"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","ignoreList":[]}
324
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_constants","_definitions","_dates","_debug","_fetch","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_errors","_browser","e","__esModule","default","RATE_LIMIT","SLEEP_BETWEEN","TRANSACTIONS_BATCH_SIZE","COUNTRY_CODE","ID_TYPE","INSTALLMENTS_KEYWORD","DATE_FORMAT","debug","getDebug","getAccountsUrl","servicesUrl","monthMoment","billingDate","format","url","URL","searchParams","set","toString","fetchAccounts","page","dataUrl","dataResult","fetchGetWithinPage","_","get","DashboardMonthBean","cardsCharges","map","cardCharge","index","parseInt","cardIndex","accountNumber","cardNumber","processedDate","moment","toISOString","getTransactionsUrl","month","year","monthStr","convertCurrency","currencyStr","SHEKEL_CURRENCY_KEYWORD","ALT_SHEKEL_CURRENCY","SHEKEL_CURRENCY","getInstallmentsInfo","txn","moreInfo","includes","undefined","matches","match","length","number","total","getTransactionType","TransactionTypes","Installments","Normal","convertTransactions","txns","filteredTxns","filter","dealSumType","voucherNumberRatz","voucherNumberRatzOutbound","isOutbound","dealSumOutbound","txnDateStr","fullPurchaseDateOutbound","fullPurchaseDate","txnMoment","currentProcessedDate","fullPaymentDate","result","type","identifier","date","originalAmount","dealSum","originalCurrency","currentPaymentCurrency","currencyId","chargedAmount","paymentSumOutbound","paymentSum","chargedCurrency","description","fullSupplierNameOutbound","fullSupplierNameHeb","memo","installments","status","TransactionStatuses","Completed","fetchTransactions","options","companyServiceOptions","startMoment","accounts","sleep","CardsTransactionsListBean","accountTxns","forEach","account","txnGroups","allTxns","txnGroup","txnIsrael","push","txnAbroad","combineInstallments","fixInstallments","outputData","enableTransactionsFilterByDate","filterOldTransactions","getExtraScrapTransaction","accountIndex","transaction","data","rawCategory","category","trim","getExtraScrapAccount","accountMap","Object","values","txnsChunk","chunk","updatedTxns","Promise","all","t","reduce","m","x","getAdditionalTransactionInformation","scraperOptions","accountsWithIndex","allMonths","additionalTransactionInformation","optInFeatures","runSerial","a","i","fetchAllTransactions","futureMonthsToScrape","getAllMonthMoments","results","finalResult","combinedTxns","keys","txnsForAccount","toBeAddedTxns","success","IsracardAmexBaseScraper","BaseScraperWithBrowser","constructor","baseUrl","companyCode","login","credentials","setRequestInterception","on","request","abort","interceptionPriorities","continue","maskHeadlessUserAgent","navigateTo","emitProgress","ScraperProgressTypes","LoggingIn","validateUrl","validateRequest","id","cardSuffix","card6Digits","countryCode","idType","checkLevel","validateResult","fetchPostWithinPage","Header","Status","ValidateIdDataBean","Error","validateReturnCode","returnCode","userName","loginUrl","KodMishtamesh","MisparZihuy","Sisma","password","loginResult","LoginSuccess","ChangePassword","errorType","ScraperErrorTypes","LoginFailed","InvalidPassword","fetchData","defaultStartMoment","subtract","startDate","toDate","max","_default","exports"],"sources":["../../src/scrapers/base-isracard-amex.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer';\nimport { ALT_SHEKEL_CURRENCY, SHEKEL_CURRENCY, SHEKEL_CURRENCY_KEYWORD } from '../constants';\nimport { ScraperProgressTypes } from '../definitions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { getDebug } from '../helpers/debug';\nimport { fetchGetWithinPage, fetchPostWithinPage } from '../helpers/fetch';\nimport { filterOldTransactions, fixInstallments } from '../helpers/transactions';\nimport { runSerial, sleep } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionInstallments,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\nimport { interceptionPriorities, maskHeadlessUserAgent } from '../helpers/browser';\n\nconst RATE_LIMIT = {\n  SLEEP_BETWEEN: 1000,\n  TRANSACTIONS_BATCH_SIZE: 10,\n} as const;\n\nconst COUNTRY_CODE = '212';\nconst ID_TYPE = '1';\nconst INSTALLMENTS_KEYWORD = 'תשלום';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst debug = getDebug('base-isracard-amex');\n\ntype CompanyServiceOptions = {\n  servicesUrl: string;\n  companyCode: string;\n};\n\ntype ScrapedAccountsWithIndex = Record<string, TransactionsAccount & { index: number }>;\n\ninterface ScrapedTransaction {\n  dealSumType: string;\n  voucherNumberRatzOutbound: string;\n  voucherNumberRatz: string;\n  moreInfo?: string;\n  dealSumOutbound: boolean;\n  currencyId: string;\n  currentPaymentCurrency: string;\n  dealSum: number;\n  fullPaymentDate?: string;\n  fullPurchaseDate?: string;\n  fullPurchaseDateOutbound?: string;\n  fullSupplierNameHeb: string;\n  fullSupplierNameOutbound: string;\n  paymentSum: number;\n  paymentSumOutbound: number;\n}\n\ninterface ScrapedAccount {\n  index: number;\n  accountNumber: string;\n  processedDate: string;\n}\n\ninterface ScrapedLoginValidation {\n  Header: {\n    Status: string;\n  };\n  ValidateIdDataBean?: {\n    userName?: string;\n    returnCode: string;\n  };\n}\n\ninterface ScrapedAccountsWithinPageResponse {\n  Header: {\n    Status: string;\n  };\n  DashboardMonthBean?: {\n    cardsCharges: {\n      cardIndex: string;\n      cardNumber: string;\n      billingDate: string;\n    }[];\n  };\n}\n\ninterface ScrapedCurrentCardTransactions {\n  txnIsrael?: ScrapedTransaction[];\n  txnAbroad?: ScrapedTransaction[];\n}\n\ninterface ScrapedTransactionData {\n  Header?: {\n    Status: string;\n  };\n  PirteyIska_204Bean?: {\n    sector: string;\n  };\n\n  CardsTransactionsListBean?: Record<\n    string,\n    {\n      CurrentCardTransactions: ScrapedCurrentCardTransactions[];\n    }\n  >;\n}\n\nfunction getAccountsUrl(servicesUrl: string, monthMoment: Moment) {\n  const billingDate = monthMoment.format('YYYY-MM-DD');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'DashboardMonth');\n  url.searchParams.set('actionCode', '0');\n  url.searchParams.set('billingDate', billingDate);\n  url.searchParams.set('format', 'Json');\n  return url.toString();\n}\n\nasync function fetchAccounts(page: Page, servicesUrl: string, monthMoment: Moment): Promise<ScrapedAccount[]> {\n  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);\n  debug(`fetching accounts from ${dataUrl}`);\n  const dataResult = await fetchGetWithinPage<ScrapedAccountsWithinPageResponse>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {\n    const { cardsCharges } = dataResult.DashboardMonthBean;\n    if (cardsCharges) {\n      return cardsCharges.map(cardCharge => {\n        return {\n          index: parseInt(cardCharge.cardIndex, 10),\n          accountNumber: cardCharge.cardNumber,\n          processedDate: moment(cardCharge.billingDate, DATE_FORMAT).toISOString(),\n        };\n      });\n    }\n  }\n  return [];\n}\n\nfunction getTransactionsUrl(servicesUrl: string, monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const monthStr = month < 10 ? `0${month}` : month.toString();\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'CardsTransactionsList');\n  url.searchParams.set('month', monthStr);\n  url.searchParams.set('year', `${year}`);\n  url.searchParams.set('requiredDate', 'N');\n  return url.toString();\n}\n\nfunction convertCurrency(currencyStr: string) {\n  if (currencyStr === SHEKEL_CURRENCY_KEYWORD || currencyStr === ALT_SHEKEL_CURRENCY) {\n    return SHEKEL_CURRENCY;\n  }\n  return currencyStr;\n}\n\nfunction getInstallmentsInfo(txn: ScrapedTransaction): TransactionInstallments | undefined {\n  if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {\n    return undefined;\n  }\n  const matches = txn.moreInfo.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\n\nfunction getTransactionType(txn: ScrapedTransaction) {\n  return getInstallmentsInfo(txn) ? TransactionTypes.Installments : TransactionTypes.Normal;\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], processedDate: string): Transaction[] {\n  const filteredTxns = txns.filter(\n    txn =>\n      txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000',\n  );\n\n  return filteredTxns.map(txn => {\n    const isOutbound = txn.dealSumOutbound;\n    const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;\n    const txnMoment = moment(txnDateStr, DATE_FORMAT);\n\n    const currentProcessedDate = txn.fullPaymentDate\n      ? moment(txn.fullPaymentDate, DATE_FORMAT).toISOString()\n      : processedDate;\n    const result: Transaction = {\n      type: getTransactionType(txn),\n      identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),\n      date: txnMoment.toISOString(),\n      processedDate: currentProcessedDate,\n      originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,\n      originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),\n      chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,\n      chargedCurrency: convertCurrency(txn.currencyId),\n      description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,\n      memo: txn.moreInfo || '',\n      installments: getInstallmentsInfo(txn) || undefined,\n      status: TransactionStatuses.Completed,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n  monthMoment: Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);\n  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);\n  await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n  debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);\n  const dataResult = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {\n    const accountTxns: ScrapedAccountsWithIndex = {};\n    accounts.forEach(account => {\n      const txnGroups: ScrapedCurrentCardTransactions[] | undefined = _.get(\n        dataResult,\n        `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`,\n      );\n      if (txnGroups) {\n        let allTxns: Transaction[] = [];\n        txnGroups.forEach(txnGroup => {\n          if (txnGroup.txnIsrael) {\n            const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);\n            allTxns.push(...txns);\n          }\n        });\n\n        if (!options.combineInstallments) {\n          allTxns = fixInstallments(allTxns);\n        }\n        if (options.outputData?.enableTransactionsFilterByDate ?? true) {\n          allTxns = filterOldTransactions(allTxns, startMoment, options.combineInstallments || false);\n        }\n        accountTxns[account.accountNumber] = {\n          accountNumber: account.accountNumber,\n          index: account.index,\n          txns: allTxns,\n        };\n      }\n    });\n    return accountTxns;\n  }\n\n  return {};\n}\n\nasync function getExtraScrapTransaction(\n  page: Page,\n  options: CompanyServiceOptions,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): Promise<Transaction> {\n  const url = new URL(options.servicesUrl);\n  url.searchParams.set('reqName', 'PirteyIska_204');\n  url.searchParams.set('CardIndex', accountIndex.toString());\n  url.searchParams.set('shovarRatz', transaction.identifier!.toString());\n  url.searchParams.set('moedChiuv', month.format('MMYYYY'));\n\n  debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);\n  const data = await fetchGetWithinPage<ScrapedTransactionData>(page, url.toString());\n  if (!data) {\n    return transaction;\n  }\n\n  const rawCategory = _.get(data, 'PirteyIska_204Bean.sector') ?? '';\n  return {\n    ...transaction,\n    category: rawCategory.trim(),\n  };\n}\n\nasync function getExtraScrapAccount(\n  page: Page,\n  options: CompanyServiceOptions,\n  accountMap: ScrapedAccountsWithIndex,\n  month: moment.Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts: ScrapedAccountsWithIndex[string][] = [];\n  for (const account of Object.values(accountMap)) {\n    debug(\n      `get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`,\n      month.format('YYYY-MM'),\n    );\n    const txns: Transaction[] = [];\n    for (const txnsChunk of _.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {\n      debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);\n      const updatedTxns = await Promise.all(\n        txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)),\n      );\n      await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n      txns.push(...updatedTxns);\n    }\n    accounts.push({ ...account, txns });\n  }\n\n  return accounts.reduce((m, x) => ({ ...m, [x.accountNumber]: x }), {});\n}\n\nasync function getAdditionalTransactionInformation(\n  scraperOptions: ScraperOptions,\n  accountsWithIndex: ScrapedAccountsWithIndex[],\n  page: Page,\n  options: CompanyServiceOptions,\n  allMonths: moment.Moment[],\n): Promise<ScrapedAccountsWithIndex[]> {\n  if (\n    !scraperOptions.additionalTransactionInformation ||\n    scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')\n  ) {\n    return accountsWithIndex;\n  }\n  return runSerial(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));\n}\n\nasync function fetchAllTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n  const results: ScrapedAccountsWithIndex[] = await runSerial(\n    allMonths.map(monthMoment => () => {\n      return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);\n    }),\n  );\n\n  const finalResult = await getAdditionalTransactionInformation(\n    options,\n    results,\n    page,\n    companyServiceOptions,\n    allMonths,\n  );\n  const combinedTxns: Record<string, Transaction[]> = {};\n\n  finalResult.forEach(result => {\n    Object.keys(result).forEach(accountNumber => {\n      let txnsForAccount = combinedTxns[accountNumber];\n      if (!txnsForAccount) {\n        txnsForAccount = [];\n        combinedTxns[accountNumber] = txnsForAccount;\n      }\n      const toBeAddedTxns = result[accountNumber].txns;\n      combinedTxns[accountNumber].push(...toBeAddedTxns);\n    });\n  });\n\n  const accounts = Object.keys(combinedTxns).map(accountNumber => {\n    return {\n      accountNumber,\n      txns: combinedTxns[accountNumber],\n    };\n  });\n\n  return {\n    success: true,\n    accounts,\n  };\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; card6Digits: string };\nclass IsracardAmexBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private baseUrl: string;\n\n  private companyCode: string;\n\n  private servicesUrl: string;\n\n  constructor(options: ScraperOptions, baseUrl: string, companyCode: string) {\n    super(options);\n\n    this.baseUrl = baseUrl;\n    this.companyCode = companyCode;\n    this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;\n  }\n\n  async login(credentials: ScraperSpecificCredentials): Promise<ScraperScrapingResult> {\n    await this.page.setRequestInterception(true);\n    this.page.on('request', request => {\n      if (request.url().includes('detector-dom.min.js')) {\n        debug('force abort for request do download detector-dom.min.js resource');\n        void request.abort(undefined, interceptionPriorities.abort);\n      } else {\n        void request.continue(undefined, interceptionPriorities.continue);\n      }\n    });\n\n    await maskHeadlessUserAgent(this.page);\n\n    await this.navigateTo(`${this.baseUrl}/personalarea/Login`);\n\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;\n    const validateRequest = {\n      id: credentials.id,\n      cardSuffix: credentials.card6Digits,\n      countryCode: COUNTRY_CODE,\n      idType: ID_TYPE,\n      checkLevel: '1',\n      companyCode: this.companyCode,\n    };\n    debug('logging in with validate request');\n    const validateResult = await fetchPostWithinPage<ScrapedLoginValidation>(this.page, validateUrl, validateRequest);\n    if (\n      !validateResult ||\n      !validateResult.Header ||\n      validateResult.Header.Status !== '1' ||\n      !validateResult.ValidateIdDataBean\n    ) {\n      throw new Error('unknown error during login');\n    }\n\n    const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;\n    debug(`user validate with return code '${validateReturnCode}'`);\n    if (validateReturnCode === '1') {\n      const { userName } = validateResult.ValidateIdDataBean;\n\n      const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;\n      const request = {\n        KodMishtamesh: userName,\n        MisparZihuy: credentials.id,\n        Sisma: credentials.password,\n        cardSuffix: credentials.card6Digits,\n        countryCode: COUNTRY_CODE,\n        idType: ID_TYPE,\n      };\n      debug('user login started');\n      const loginResult = await fetchPostWithinPage<{ status: string }>(this.page, loginUrl, request);\n      debug(`user login with status '${loginResult?.status}'`, loginResult);\n\n      if (loginResult && loginResult.status === '1') {\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      }\n\n      if (loginResult && loginResult.status === '3') {\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      }\n\n      this.emitProgress(ScraperProgressTypes.LoginFailed);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.InvalidPassword,\n      };\n    }\n\n    if (validateReturnCode === '4') {\n      this.emitProgress(ScraperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    }\n\n    this.emitProgress(ScraperProgressTypes.LoginFailed);\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.InvalidPassword,\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    return fetchAllTransactions(\n      this.page,\n      this.options,\n      {\n        servicesUrl: this.servicesUrl,\n        companyCode: this.companyCode,\n      },\n      startMoment,\n    );\n  }\n}\n\nexport default IsracardAmexBaseScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -44,30 +44,34 @@ async function fetchAccountData(page, options) {
44
44
  errorMessage: 'failed to get account data'
45
45
  };
46
46
  }
47
- const accountNumber = accountInfo.UserAccountsData.DefaultAccountNumber;
48
47
  const defaultStartMoment = (0, _moment.default)().subtract(1, 'years').add(2, 'day');
49
48
  const startDate = options.startDate || defaultStartMoment.toDate();
50
49
  const startMoment = _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
51
50
  const startDateStr = startMoment.format(DATE_FORMAT);
52
- const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;
53
- const txnsResult = await (0, _fetch.fetchGetWithinPage)(page, txnsUrl);
54
- if (!txnsResult || txnsResult.Error || !txnsResult.CurrentAccountLastTransactions) {
55
- return {
56
- success: false,
57
- errorType: _errors.ScraperErrorTypes.Generic,
58
- errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error'
59
- };
51
+ const accounts = accountInfo.UserAccountsData.UserAccounts.map(acc => acc.NewAccountInfo.AccountID);
52
+ const accountsData = [];
53
+ for (const accountNumber of accounts) {
54
+ const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;
55
+ const txnsResult = await (0, _fetch.fetchGetWithinPage)(page, txnsUrl);
56
+ if (!txnsResult || txnsResult.Error || !txnsResult.CurrentAccountLastTransactions) {
57
+ return {
58
+ success: false,
59
+ errorType: _errors.ScraperErrorTypes.Generic,
60
+ errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error'
61
+ };
62
+ }
63
+ const accountCompletedTxns = convertTransactions(txnsResult.CurrentAccountLastTransactions.OperationEntry, _transactions.TransactionStatuses.Completed);
64
+ const rawFutureTxns = _lodash.default.get(txnsResult, 'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry');
65
+ const accountPendingTxns = convertTransactions(rawFutureTxns, _transactions.TransactionStatuses.Pending);
66
+ accountsData.push({
67
+ accountNumber,
68
+ balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,
69
+ txns: [...accountCompletedTxns, ...accountPendingTxns]
70
+ });
60
71
  }
61
- const completedTxns = convertTransactions(txnsResult.CurrentAccountLastTransactions.OperationEntry, _transactions.TransactionStatuses.Completed);
62
- const rawFutureTxns = _lodash.default.get(txnsResult, 'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry');
63
- const pendingTxns = convertTransactions(rawFutureTxns, _transactions.TransactionStatuses.Pending);
64
72
  const accountData = {
65
73
  success: true,
66
- accounts: [{
67
- accountNumber,
68
- balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,
69
- txns: [...completedTxns, ...pendingTxns]
70
- }]
74
+ accounts: accountsData
71
75
  };
72
76
  return accountData;
73
77
  }
@@ -113,4 +117,4 @@ class DiscountScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
113
117
  }
114
118
  }
115
119
  var _default = exports.default = DiscountScraper;
116
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_elementsInteractions","_fetch","_navigation","_transactions","_baseScraperWithBrowser","_errors","e","__esModule","default","BASE_URL","DATE_FORMAT","convertTransactions","txns","txnStatus","map","txn","type","TransactionTypes","Normal","identifier","OperationNumber","date","moment","OperationDate","toISOString","processedDate","ValueDate","originalAmount","OperationAmount","originalCurrency","chargedAmount","description","OperationDescriptionToDisplay","status","fetchAccountData","page","options","apiSiteUrl","accountDataUrl","accountInfo","fetchGetWithinPage","success","errorType","ScraperErrorTypes","Generic","errorMessage","accountNumber","UserAccountsData","DefaultAccountNumber","defaultStartMoment","subtract","add","startDate","toDate","startMoment","max","startDateStr","format","txnsUrl","txnsResult","Error","CurrentAccountLastTransactions","MsgText","completedTxns","OperationEntry","TransactionStatuses","Completed","rawFutureTxns","_","get","pendingTxns","Pending","accountData","accounts","balance","CurrentAccountInfo","AccountBalance","navigateOrErrorLabel","waitForNavigation","waitUntilElementFound","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","ChangePassword","createLoginFields","credentials","selector","value","id","password","num","DiscountScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","checkReadiness","fields","submitButtonSelector","postAction","possibleResults","fetchData","_default","exports"],"sources":["../../src/scrapers/discount.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { type Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\n\nconst BASE_URL = 'https://start.telebank.co.il';\nconst DATE_FORMAT = 'YYYYMMDD';\n\ninterface ScrapedTransaction {\n  OperationNumber: number;\n  OperationDate: string;\n  ValueDate: string;\n  OperationAmount: number;\n  OperationDescriptionToDisplay: string;\n}\n\ninterface CurrentAccountInfo {\n  AccountBalance: number;\n}\n\ninterface ScrapedAccountData {\n  UserAccountsData: {\n    DefaultAccountNumber: string;\n  };\n}\n\ninterface ScrapedTransactionData {\n  Error?: { MsgText: string };\n  CurrentAccountLastTransactions?: {\n    OperationEntry: ScrapedTransaction[];\n    CurrentAccountInfo: CurrentAccountInfo;\n    FutureTransactionsBlock: {\n      FutureTransactionEntry: ScrapedTransaction[];\n    };\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], txnStatus: TransactionStatuses): Transaction[] {\n  if (!txns) {\n    return [];\n  }\n  return txns.map(txn => {\n    return {\n      type: TransactionTypes.Normal,\n      identifier: txn.OperationNumber,\n      date: moment(txn.OperationDate, DATE_FORMAT).toISOString(),\n      processedDate: moment(txn.ValueDate, DATE_FORMAT).toISOString(),\n      originalAmount: txn.OperationAmount,\n      originalCurrency: 'ILS',\n      chargedAmount: txn.OperationAmount,\n      description: txn.OperationDescriptionToDisplay,\n      status: txnStatus,\n    };\n  });\n}\n\nasync function fetchAccountData(page: Page, options: ScraperOptions): Promise<ScraperScrapingResult> {\n  const apiSiteUrl = `${BASE_URL}/Titan/gatewayAPI`;\n\n  const accountDataUrl = `${apiSiteUrl}/userAccountsData`;\n  const accountInfo = await fetchGetWithinPage<ScrapedAccountData>(page, accountDataUrl);\n\n  if (!accountInfo) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: 'failed to get account data',\n    };\n  }\n  const accountNumber = accountInfo.UserAccountsData.DefaultAccountNumber;\n\n  const defaultStartMoment = moment().subtract(1, 'years').add(2, 'day');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const startDateStr = startMoment.format(DATE_FORMAT);\n  const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;\n  const txnsResult = await fetchGetWithinPage<ScrapedTransactionData>(page, txnsUrl);\n  if (!txnsResult || txnsResult.Error || !txnsResult.CurrentAccountLastTransactions) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error',\n    };\n  }\n\n  const completedTxns = convertTransactions(\n    txnsResult.CurrentAccountLastTransactions.OperationEntry,\n    TransactionStatuses.Completed,\n  );\n  const rawFutureTxns = _.get(\n    txnsResult,\n    'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry',\n  ) as ScrapedTransaction[];\n  const pendingTxns = convertTransactions(rawFutureTxns, TransactionStatuses.Pending);\n\n  const accountData = {\n    success: true,\n    accounts: [\n      {\n        accountNumber,\n        balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,\n        txns: [...completedTxns, ...pendingTxns],\n      },\n    ],\n  };\n\n  return accountData;\n}\n\nasync function navigateOrErrorLabel(page: Page) {\n  try {\n    await waitForNavigation(page);\n  } catch (e) {\n    await waitUntilElementFound(page, '#general-error', false, 100);\n  }\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [\n    `${BASE_URL}/apollo/retail/#/MY_ACCOUNT_HOMEPAGE`,\n    `${BASE_URL}/apollo/retail2/#/MY_ACCOUNT_HOMEPAGE`,\n  ];\n  urls[LoginResults.InvalidPassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`];\n  urls[LoginResults.ChangePassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/PWD_RENEW`];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#tzId', value: credentials.id },\n    { selector: '#tzPassword', value: credentials.password },\n    { selector: '#aidnum', value: credentials.num },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; num: string };\n\nclass DiscountScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${BASE_URL}/login/#/LOGIN_PAGE`,\n      checkReadiness: async () => waitUntilElementFound(this.page, '#tzId'),\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '.sendBtn',\n      postAction: async () => navigateOrErrorLabel(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    return fetchAccountData(this.page, this.options);\n  }\n}\n\nexport default DiscountScraper;\n"],"mappings":"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","ignoreList":[]}
120
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_elementsInteractions","_fetch","_navigation","_transactions","_baseScraperWithBrowser","_errors","e","__esModule","default","BASE_URL","DATE_FORMAT","convertTransactions","txns","txnStatus","map","txn","type","TransactionTypes","Normal","identifier","OperationNumber","date","moment","OperationDate","toISOString","processedDate","ValueDate","originalAmount","OperationAmount","originalCurrency","chargedAmount","description","OperationDescriptionToDisplay","status","fetchAccountData","page","options","apiSiteUrl","accountDataUrl","accountInfo","fetchGetWithinPage","success","errorType","ScraperErrorTypes","Generic","errorMessage","defaultStartMoment","subtract","add","startDate","toDate","startMoment","max","startDateStr","format","accounts","UserAccountsData","UserAccounts","acc","NewAccountInfo","AccountID","accountsData","accountNumber","txnsUrl","txnsResult","Error","CurrentAccountLastTransactions","MsgText","accountCompletedTxns","OperationEntry","TransactionStatuses","Completed","rawFutureTxns","_","get","accountPendingTxns","Pending","push","balance","CurrentAccountInfo","AccountBalance","accountData","navigateOrErrorLabel","waitForNavigation","waitUntilElementFound","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","ChangePassword","createLoginFields","credentials","selector","value","id","password","num","DiscountScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","checkReadiness","fields","submitButtonSelector","postAction","possibleResults","fetchData","_default","exports"],"sources":["../../src/scrapers/discount.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { type Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\n\nconst BASE_URL = 'https://start.telebank.co.il';\nconst DATE_FORMAT = 'YYYYMMDD';\n\ninterface ScrapedTransaction {\n  OperationNumber: number;\n  OperationDate: string;\n  ValueDate: string;\n  OperationAmount: number;\n  OperationDescriptionToDisplay: string;\n}\n\ninterface CurrentAccountInfo {\n  AccountBalance: number;\n}\n\ninterface ScrapedAccountData {\n  UserAccountsData: {\n    DefaultAccountNumber: string;\n    UserAccounts: Array<{\n      NewAccountInfo: {\n        AccountID: string;\n      };\n    }>;\n  };\n}\n\ninterface ScrapedTransactionData {\n  Error?: { MsgText: string };\n  CurrentAccountLastTransactions?: {\n    OperationEntry: ScrapedTransaction[];\n    CurrentAccountInfo: CurrentAccountInfo;\n    FutureTransactionsBlock: {\n      FutureTransactionEntry: ScrapedTransaction[];\n    };\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], txnStatus: TransactionStatuses): Transaction[] {\n  if (!txns) {\n    return [];\n  }\n  return txns.map(txn => {\n    return {\n      type: TransactionTypes.Normal,\n      identifier: txn.OperationNumber,\n      date: moment(txn.OperationDate, DATE_FORMAT).toISOString(),\n      processedDate: moment(txn.ValueDate, DATE_FORMAT).toISOString(),\n      originalAmount: txn.OperationAmount,\n      originalCurrency: 'ILS',\n      chargedAmount: txn.OperationAmount,\n      description: txn.OperationDescriptionToDisplay,\n      status: txnStatus,\n    };\n  });\n}\n\nasync function fetchAccountData(page: Page, options: ScraperOptions): Promise<ScraperScrapingResult> {\n  const apiSiteUrl = `${BASE_URL}/Titan/gatewayAPI`;\n\n  const accountDataUrl = `${apiSiteUrl}/userAccountsData`;\n  const accountInfo = await fetchGetWithinPage<ScrapedAccountData>(page, accountDataUrl);\n\n  if (!accountInfo) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: 'failed to get account data',\n    };\n  }\n\n  const defaultStartMoment = moment().subtract(1, 'years').add(2, 'day');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const startDateStr = startMoment.format(DATE_FORMAT);\n\n  const accounts: string[] = accountInfo.UserAccountsData.UserAccounts.map(acc => acc.NewAccountInfo.AccountID);\n  const accountsData: Array<{ accountNumber: string; balance: number; txns: Transaction[] }> = [];\n\n  for (const accountNumber of accounts) {\n    const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;\n    const txnsResult = await fetchGetWithinPage<ScrapedTransactionData>(page, txnsUrl);\n    if (!txnsResult || txnsResult.Error || !txnsResult.CurrentAccountLastTransactions) {\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.Generic,\n        errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error',\n      };\n    }\n\n    const accountCompletedTxns = convertTransactions(\n      txnsResult.CurrentAccountLastTransactions.OperationEntry,\n      TransactionStatuses.Completed,\n    );\n    const rawFutureTxns = _.get(\n      txnsResult,\n      'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry',\n    ) as ScrapedTransaction[];\n    const accountPendingTxns = convertTransactions(rawFutureTxns, TransactionStatuses.Pending);\n\n    accountsData.push({\n      accountNumber,\n      balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,\n      txns: [...accountCompletedTxns, ...accountPendingTxns],\n    });\n  }\n\n  const accountData = {\n    success: true,\n    accounts: accountsData,\n  };\n\n  return accountData;\n}\n\nasync function navigateOrErrorLabel(page: Page) {\n  try {\n    await waitForNavigation(page);\n  } catch (e) {\n    await waitUntilElementFound(page, '#general-error', false, 100);\n  }\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [\n    `${BASE_URL}/apollo/retail/#/MY_ACCOUNT_HOMEPAGE`,\n    `${BASE_URL}/apollo/retail2/#/MY_ACCOUNT_HOMEPAGE`,\n  ];\n  urls[LoginResults.InvalidPassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`];\n  urls[LoginResults.ChangePassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/PWD_RENEW`];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#tzId', value: credentials.id },\n    { selector: '#tzPassword', value: credentials.password },\n    { selector: '#aidnum', value: credentials.num },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; num: string };\n\nclass DiscountScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: `${BASE_URL}/login/#/LOGIN_PAGE`,\n      checkReadiness: async () => waitUntilElementFound(this.page, '#tzId'),\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '.sendBtn',\n      postAction: async () => navigateOrErrorLabel(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    return fetchAccountData(this.page, this.options);\n  }\n}\n\nexport default DiscountScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -32,7 +32,7 @@ export type ScraperCredentials = {
32
32
  } | {
33
33
  otpLongTermToken: string;
34
34
  }));
35
- export type OptInFeatures = 'mizrahi:pendingIfNoIdentifier' | 'mizrahi:pendingIfHasGenericDescription' | 'mizrahi:pendingIfTodayTransaction';
35
+ export type OptInFeatures = 'isracard-amex:skipAdditionalTransactionInformation' | 'mizrahi:pendingIfNoIdentifier' | 'mizrahi:pendingIfHasGenericDescription' | 'mizrahi:pendingIfTodayTransaction';
36
36
  export interface FutureDebit {
37
37
  amount: number;
38
38
  amountCurrency: string;
@@ -3,4 +3,4 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/scrapers/interface.ts"],"sourcesContent":["import { type BrowserContext, type Browser, type Page } from 'puppeteer';\nimport { type CompanyTypes, type ScraperProgressTypes } from '../definitions';\nimport { type TransactionsAccount } from '../transactions';\nimport { type ErrorResult, type ScraperErrorTypes } from './errors';\n\n// TODO: Remove this type when the scraper 'factory' will return concrete scraper types\n// Instead of a generic interface (which in turn uses this type)\nexport type ScraperCredentials =\n  | { userCode: string; password: string }\n  | { username: string; password: string }\n  | { id: string; password: string }\n  | { id: string; password: string; num: string }\n  | { id: string; password: string; card6Digits: string }\n  | { username: string; nationalID: string; password: string }\n  | ({ email: string; password: string } & (\n      | {\n          otpCodeRetriever: () => Promise<string>;\n          phoneNumber: string;\n        }\n      | {\n          otpLongTermToken: string;\n        }\n    ));\n\nexport type OptInFeatures =\n  | 'mizrahi:pendingIfNoIdentifier'\n  | 'mizrahi:pendingIfHasGenericDescription'\n  | 'mizrahi:pendingIfTodayTransaction';\n\nexport interface FutureDebit {\n  amount: number;\n  amountCurrency: string;\n  chargeDate?: string;\n  bankAccountNumber?: string;\n}\n\ninterface ExternalBrowserOptions {\n  /**\n   * An externally created browser instance.\n   * you can get a browser directly from puppeteer via `puppeteer.launch()`\n   *\n   * Note: The browser will be closed by the library after the scraper finishes unless `skipCloseBrowser` is set to true\n   */\n  browser: Browser;\n\n  /**\n   * If true, the browser will not be closed by the library after the scraper finishes\n   */\n  skipCloseBrowser?: boolean;\n}\n\ninterface ExternalBrowserContextOptions {\n  /**\n   * An externally managed browser context. This is useful when you want to manage the browser\n   */\n  browserContext: BrowserContext;\n}\n\ninterface DefaultBrowserOptions {\n  /**\n   * shows the browser while scraping, good for debugging (default false)\n   */\n  showBrowser?: boolean;\n\n  /**\n   * provide a patch to local chromium to be used by puppeteer. Relevant when using\n   * `israeli-bank-scrapers-core` library\n   */\n  executablePath?: string;\n\n  /**\n   * additional arguments to pass to the browser instance. The list of flags can be found in\n   *\n   * https://developer.mozilla.org/en-US/docs/Mozilla/Command_Line_Options\n   * https://peter.sh/experiments/chromium-command-line-switches/\n   */\n  args?: string[];\n\n  /**\n   * Maximum navigation time in milliseconds, pass 0 to disable timeout.\n   * @default 30000\n   */\n  timeout?: number;\n\n  /**\n   * adjust the browser instance before it is being used\n   *\n   * @param browser\n   */\n  prepareBrowser?: (browser: Browser) => Promise<void>;\n}\n\ntype ScraperBrowserOptions = ExternalBrowserOptions | ExternalBrowserContextOptions | DefaultBrowserOptions;\n\nexport type ScraperOptions = ScraperBrowserOptions & {\n  /**\n   * The company you want to scrape\n   */\n  companyId: CompanyTypes;\n\n  /**\n   * include more debug info about in the output\n   */\n  verbose?: boolean;\n\n  /**\n   * the date to fetch transactions from (can't be before the minimum allowed time difference for the scraper)\n   */\n  startDate: Date;\n\n  /**\n   * scrape transactions to be processed X months in the future\n   */\n  futureMonthsToScrape?: number;\n\n  /**\n   * if set to true, all installment transactions will be combine into the first one\n   */\n  combineInstallments?: boolean;\n\n  /**\n   * adjust the page instance before it is being used.\n   *\n   * @param page\n   */\n  preparePage?: (page: Page) => Promise<void>;\n\n  /**\n   * if set, store a screenshot if failed to scrape. Used for debug purposes\n   */\n  storeFailureScreenShotPath?: string;\n\n  /**\n   * if set, will set the timeout in milliseconds of puppeteer's `page.setDefaultTimeout`.\n   */\n  defaultTimeout?: number;\n\n  /**\n   * Options for manipulation of output data\n   */\n  outputData?: OutputDataOptions;\n\n  /**\n   * Perform additional operation for each transaction to get more information (Like category) about it.\n   * Please note: It will take more time to finish the process.\n   */\n  additionalTransactionInformation?: boolean;\n\n  /**\n   * Adjust the viewport size of the browser page.\n   * If not set, the default viewport size of 1024x768 will be used.\n   */\n  viewportSize?: {\n    width: number;\n    height: number;\n  };\n\n  /**\n   * The number of times to retry the navigation in case of a failure (default 0)\n   */\n  navigationRetryCount?: number;\n\n  /**\n   * Opt-in features for the scrapers, allowing safe rollout of new breaking changes.\n   */\n  optInFeatures?: Array<OptInFeatures>;\n};\n\nexport interface OutputDataOptions {\n  /**\n   * if true, the result wouldn't be filtered out by date, and you will return unfiltered scrapped data.\n   */\n  enableTransactionsFilterByDate?: boolean;\n}\n\nexport interface ScraperScrapingResult {\n  success: boolean;\n  accounts?: TransactionsAccount[];\n  futureDebits?: FutureDebit[];\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport interface Scraper<TCredentials extends ScraperCredentials> {\n  scrape(credentials: TCredentials): Promise<ScraperScrapingResult>;\n  onProgress(func: (companyId: CompanyTypes, payload: { type: ScraperProgressTypes }) => void): void;\n  triggerTwoFactorAuth(phoneNumber: string): Promise<ScraperTwoFactorAuthTriggerResult>;\n  getLongTermTwoFactorToken(otpCode: string): Promise<ScraperGetLongTermTwoFactorTokenResult>;\n}\n\nexport type ScraperTwoFactorAuthTriggerResult =\n  | ErrorResult\n  | {\n      success: true;\n    };\n\nexport type ScraperGetLongTermTwoFactorTokenResult =\n  | ErrorResult\n  | {\n      success: true;\n      longTermTwoFactorAuthToken: string;\n    };\n\nexport interface ScraperLoginResult {\n  success: boolean;\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n  persistentOtpToken?: string;\n}\n"],"mappings":"","ignoreList":[]}
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":[],"sources":["../../src/scrapers/interface.ts"],"sourcesContent":["import { type BrowserContext, type Browser, type Page } from 'puppeteer';\nimport { type CompanyTypes, type ScraperProgressTypes } from '../definitions';\nimport { type TransactionsAccount } from '../transactions';\nimport { type ErrorResult, type ScraperErrorTypes } from './errors';\n\n// TODO: Remove this type when the scraper 'factory' will return concrete scraper types\n// Instead of a generic interface (which in turn uses this type)\nexport type ScraperCredentials =\n  | { userCode: string; password: string }\n  | { username: string; password: string }\n  | { id: string; password: string }\n  | { id: string; password: string; num: string }\n  | { id: string; password: string; card6Digits: string }\n  | { username: string; nationalID: string; password: string }\n  | ({ email: string; password: string } & (\n      | {\n          otpCodeRetriever: () => Promise<string>;\n          phoneNumber: string;\n        }\n      | {\n          otpLongTermToken: string;\n        }\n    ));\n\nexport type OptInFeatures =\n  | 'isracard-amex:skipAdditionalTransactionInformation'\n  | 'mizrahi:pendingIfNoIdentifier'\n  | 'mizrahi:pendingIfHasGenericDescription'\n  | 'mizrahi:pendingIfTodayTransaction';\n\nexport interface FutureDebit {\n  amount: number;\n  amountCurrency: string;\n  chargeDate?: string;\n  bankAccountNumber?: string;\n}\n\ninterface ExternalBrowserOptions {\n  /**\n   * An externally created browser instance.\n   * you can get a browser directly from puppeteer via `puppeteer.launch()`\n   *\n   * Note: The browser will be closed by the library after the scraper finishes unless `skipCloseBrowser` is set to true\n   */\n  browser: Browser;\n\n  /**\n   * If true, the browser will not be closed by the library after the scraper finishes\n   */\n  skipCloseBrowser?: boolean;\n}\n\ninterface ExternalBrowserContextOptions {\n  /**\n   * An externally managed browser context. This is useful when you want to manage the browser\n   */\n  browserContext: BrowserContext;\n}\n\ninterface DefaultBrowserOptions {\n  /**\n   * shows the browser while scraping, good for debugging (default false)\n   */\n  showBrowser?: boolean;\n\n  /**\n   * provide a patch to local chromium to be used by puppeteer. Relevant when using\n   * `israeli-bank-scrapers-core` library\n   */\n  executablePath?: string;\n\n  /**\n   * additional arguments to pass to the browser instance. The list of flags can be found in\n   *\n   * https://developer.mozilla.org/en-US/docs/Mozilla/Command_Line_Options\n   * https://peter.sh/experiments/chromium-command-line-switches/\n   */\n  args?: string[];\n\n  /**\n   * Maximum navigation time in milliseconds, pass 0 to disable timeout.\n   * @default 30000\n   */\n  timeout?: number;\n\n  /**\n   * adjust the browser instance before it is being used\n   *\n   * @param browser\n   */\n  prepareBrowser?: (browser: Browser) => Promise<void>;\n}\n\ntype ScraperBrowserOptions = ExternalBrowserOptions | ExternalBrowserContextOptions | DefaultBrowserOptions;\n\nexport type ScraperOptions = ScraperBrowserOptions & {\n  /**\n   * The company you want to scrape\n   */\n  companyId: CompanyTypes;\n\n  /**\n   * include more debug info about in the output\n   */\n  verbose?: boolean;\n\n  /**\n   * the date to fetch transactions from (can't be before the minimum allowed time difference for the scraper)\n   */\n  startDate: Date;\n\n  /**\n   * scrape transactions to be processed X months in the future\n   */\n  futureMonthsToScrape?: number;\n\n  /**\n   * if set to true, all installment transactions will be combine into the first one\n   */\n  combineInstallments?: boolean;\n\n  /**\n   * adjust the page instance before it is being used.\n   *\n   * @param page\n   */\n  preparePage?: (page: Page) => Promise<void>;\n\n  /**\n   * if set, store a screenshot if failed to scrape. Used for debug purposes\n   */\n  storeFailureScreenShotPath?: string;\n\n  /**\n   * if set, will set the timeout in milliseconds of puppeteer's `page.setDefaultTimeout`.\n   */\n  defaultTimeout?: number;\n\n  /**\n   * Options for manipulation of output data\n   */\n  outputData?: OutputDataOptions;\n\n  /**\n   * Perform additional operation for each transaction to get more information (Like category) about it.\n   * Please note: It will take more time to finish the process.\n   */\n  additionalTransactionInformation?: boolean;\n\n  /**\n   * Adjust the viewport size of the browser page.\n   * If not set, the default viewport size of 1024x768 will be used.\n   */\n  viewportSize?: {\n    width: number;\n    height: number;\n  };\n\n  /**\n   * The number of times to retry the navigation in case of a failure (default 0)\n   */\n  navigationRetryCount?: number;\n\n  /**\n   * Opt-in features for the scrapers, allowing safe rollout of new breaking changes.\n   */\n  optInFeatures?: Array<OptInFeatures>;\n};\n\nexport interface OutputDataOptions {\n  /**\n   * if true, the result wouldn't be filtered out by date, and you will return unfiltered scrapped data.\n   */\n  enableTransactionsFilterByDate?: boolean;\n}\n\nexport interface ScraperScrapingResult {\n  success: boolean;\n  accounts?: TransactionsAccount[];\n  futureDebits?: FutureDebit[];\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport interface Scraper<TCredentials extends ScraperCredentials> {\n  scrape(credentials: TCredentials): Promise<ScraperScrapingResult>;\n  onProgress(func: (companyId: CompanyTypes, payload: { type: ScraperProgressTypes }) => void): void;\n  triggerTwoFactorAuth(phoneNumber: string): Promise<ScraperTwoFactorAuthTriggerResult>;\n  getLongTermTwoFactorToken(otpCode: string): Promise<ScraperGetLongTermTwoFactorTokenResult>;\n}\n\nexport type ScraperTwoFactorAuthTriggerResult =\n  | ErrorResult\n  | {\n      success: true;\n    };\n\nexport type ScraperGetLongTermTwoFactorTokenResult =\n  | ErrorResult\n  | {\n      success: true;\n      longTermTwoFactorAuthToken: string;\n    };\n\nexport interface ScraperLoginResult {\n  success: boolean;\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n  persistentOtpToken?: string;\n}\n"],"mappings":"","ignoreList":[]}
@@ -4,14 +4,16 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = void 0;
7
+ var _debug = _interopRequireDefault(require("debug"));
7
8
  var _baseIsracardAmex = _interopRequireDefault(require("./base-isracard-amex"));
8
9
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
10
  const BASE_URL = 'https://digital.isracard.co.il';
10
11
  const COMPANY_CODE = '11';
12
+ _debug.default.enable('israeli-bank-scrapers:base-isracard-amex');
11
13
  class IsracardScraper extends _baseIsracardAmex.default {
12
14
  constructor(options) {
13
15
  super(options, BASE_URL, COMPANY_CODE);
14
16
  }
15
17
  }
16
18
  var _default = exports.default = IsracardScraper;
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYmFzZUlzcmFjYXJkQW1leCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiQkFTRV9VUkwiLCJDT01QQU5ZX0NPREUiLCJJc3JhY2FyZFNjcmFwZXIiLCJJc3JhY2FyZEFtZXhCYXNlU2NyYXBlciIsImNvbnN0cnVjdG9yIiwib3B0aW9ucyIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9pc3JhY2FyZC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgSXNyYWNhcmRBbWV4QmFzZVNjcmFwZXIgZnJvbSAnLi9iYXNlLWlzcmFjYXJkLWFtZXgnO1xuaW1wb3J0IHsgdHlwZSBTY3JhcGVyT3B0aW9ucyB9IGZyb20gJy4vaW50ZXJmYWNlJztcblxuY29uc3QgQkFTRV9VUkwgPSAnaHR0cHM6Ly9kaWdpdGFsLmlzcmFjYXJkLmNvLmlsJztcbmNvbnN0IENPTVBBTllfQ09ERSA9ICcxMSc7XG5cbmNsYXNzIElzcmFjYXJkU2NyYXBlciBleHRlbmRzIElzcmFjYXJkQW1leEJhc2VTY3JhcGVyIHtcbiAgY29uc3RydWN0b3Iob3B0aW9uczogU2NyYXBlck9wdGlvbnMpIHtcbiAgICBzdXBlcihvcHRpb25zLCBCQVNFX1VSTCwgQ09NUEFOWV9DT0RFKTtcbiAgfVxufVxuXG5leHBvcnQgZGVmYXVsdCBJc3JhY2FyZFNjcmFwZXI7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLGlCQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBMkQsU0FBQUQsdUJBQUFFLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFHM0QsTUFBTUcsUUFBUSxHQUFHLGdDQUFnQztBQUNqRCxNQUFNQyxZQUFZLEdBQUcsSUFBSTtBQUV6QixNQUFNQyxlQUFlLFNBQVNDLHlCQUF1QixDQUFDO0VBQ3BEQyxXQUFXQSxDQUFDQyxPQUF1QixFQUFFO0lBQ25DLEtBQUssQ0FBQ0EsT0FBTyxFQUFFTCxRQUFRLEVBQUVDLFlBQVksQ0FBQztFQUN4QztBQUNGO0FBQUMsSUFBQUssUUFBQSxHQUFBQyxPQUFBLENBQUFSLE9BQUEsR0FFY0csZUFBZSIsImlnbm9yZUxpc3QiOltdfQ==
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGVidWciLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9iYXNlSXNyYWNhcmRBbWV4IiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiQkFTRV9VUkwiLCJDT01QQU5ZX0NPREUiLCJkZWJ1ZyIsImVuYWJsZSIsIklzcmFjYXJkU2NyYXBlciIsIklzcmFjYXJkQW1leEJhc2VTY3JhcGVyIiwiY29uc3RydWN0b3IiLCJvcHRpb25zIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2lzcmFjYXJkLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5pbXBvcnQgSXNyYWNhcmRBbWV4QmFzZVNjcmFwZXIgZnJvbSAnLi9iYXNlLWlzcmFjYXJkLWFtZXgnO1xuaW1wb3J0IHsgdHlwZSBTY3JhcGVyT3B0aW9ucyB9IGZyb20gJy4vaW50ZXJmYWNlJztcblxuY29uc3QgQkFTRV9VUkwgPSAnaHR0cHM6Ly9kaWdpdGFsLmlzcmFjYXJkLmNvLmlsJztcbmNvbnN0IENPTVBBTllfQ09ERSA9ICcxMSc7XG5cbmRlYnVnLmVuYWJsZSgnaXNyYWVsaS1iYW5rLXNjcmFwZXJzOmJhc2UtaXNyYWNhcmQtYW1leCcpO1xuXG5jbGFzcyBJc3JhY2FyZFNjcmFwZXIgZXh0ZW5kcyBJc3JhY2FyZEFtZXhCYXNlU2NyYXBlciB7XG4gIGNvbnN0cnVjdG9yKG9wdGlvbnM6IFNjcmFwZXJPcHRpb25zKSB7XG4gICAgc3VwZXIob3B0aW9ucywgQkFTRV9VUkwsIENPTVBBTllfQ09ERSk7XG4gIH1cbn1cblxuZXhwb3J0IGRlZmF1bHQgSXNyYWNhcmRTY3JhcGVyO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxpQkFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQTJELFNBQUFELHVCQUFBRyxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRzNELE1BQU1HLFFBQVEsR0FBRyxnQ0FBZ0M7QUFDakQsTUFBTUMsWUFBWSxHQUFHLElBQUk7QUFFekJDLGNBQUssQ0FBQ0MsTUFBTSxDQUFDLDBDQUEwQyxDQUFDO0FBRXhELE1BQU1DLGVBQWUsU0FBU0MseUJBQXVCLENBQUM7RUFDcERDLFdBQVdBLENBQUNDLE9BQXVCLEVBQUU7SUFDbkMsS0FBSyxDQUFDQSxPQUFPLEVBQUVQLFFBQVEsRUFBRUMsWUFBWSxDQUFDO0VBQ3hDO0FBQ0Y7QUFBQyxJQUFBTyxRQUFBLEdBQUFDLE9BQUEsQ0FBQVYsT0FBQSxHQUVjSyxlQUFlIiwiaWdub3JlTGlzdCI6W119
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers",
3
- "version": "6.3.2",
3
+ "version": "6.3.4",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {