israeli-bank-scrapers 6.4.2 → 6.5.1

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.
@@ -89,7 +89,7 @@ function getInstallmentsInfo(txn) {
89
89
  function getTransactionType(txn) {
90
90
  return getInstallmentsInfo(txn) ? _transactions2.TransactionTypes.Installments : _transactions2.TransactionTypes.Normal;
91
91
  }
92
- function convertTransactions(txns, processedDate) {
92
+ function convertTransactions(txns, processedDate, options) {
93
93
  const filteredTxns = txns.filter(txn => txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000');
94
94
  return filteredTxns.map(txn => {
95
95
  const isOutbound = txn.dealSumOutbound;
@@ -110,6 +110,9 @@ function convertTransactions(txns, processedDate) {
110
110
  installments: getInstallmentsInfo(txn) || undefined,
111
111
  status: _transactions2.TransactionStatuses.Completed
112
112
  };
113
+ if (options?.includeRawTransaction) {
114
+ result.rawTransaction = txn;
115
+ }
113
116
  return result;
114
117
  });
115
118
  }
@@ -127,11 +130,11 @@ async function fetchTransactions(page, options, companyServiceOptions, startMome
127
130
  let allTxns = [];
128
131
  txnGroups.forEach(txnGroup => {
129
132
  if (txnGroup.txnIsrael) {
130
- const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);
133
+ const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate, options);
131
134
  allTxns.push(...txns);
132
135
  }
133
136
  if (txnGroup.txnAbroad) {
134
- const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);
137
+ const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate, options);
135
138
  allTxns.push(...txns);
136
139
  }
137
140
  });
@@ -321,4 +324,4 @@ class IsracardAmexBaseScraper extends _baseScraperWithBrowser.BaseScraperWithBro
321
324
  }
322
325
  }
323
326
  var _default = exports.default = IsracardAmexBaseScraper;
324
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_constants","_definitions","_dates","_debug","_fetch","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_errors","_browser","e","__esModule","default","RATE_LIMIT","SLEEP_BETWEEN","TRANSACTIONS_BATCH_SIZE","COUNTRY_CODE","ID_TYPE","INSTALLMENTS_KEYWORD","DATE_FORMAT","debug","getDebug","getAccountsUrl","servicesUrl","monthMoment","billingDate","format","url","URL","searchParams","set","toString","fetchAccounts","page","dataUrl","dataResult","fetchGetWithinPage","_","get","DashboardMonthBean","cardsCharges","map","cardCharge","index","parseInt","cardIndex","accountNumber","cardNumber","processedDate","moment","toISOString","getTransactionsUrl","month","year","monthStr","convertCurrency","currencyStr","SHEKEL_CURRENCY_KEYWORD","ALT_SHEKEL_CURRENCY","SHEKEL_CURRENCY","getInstallmentsInfo","txn","moreInfo","includes","undefined","matches","match","length","number","total","getTransactionType","TransactionTypes","Installments","Normal","convertTransactions","txns","filteredTxns","filter","dealSumType","voucherNumberRatz","voucherNumberRatzOutbound","isOutbound","dealSumOutbound","txnDateStr","fullPurchaseDateOutbound","fullPurchaseDate","txnMoment","currentProcessedDate","fullPaymentDate","result","type","identifier","date","originalAmount","dealSum","originalCurrency","currentPaymentCurrency","currencyId","chargedAmount","paymentSumOutbound","paymentSum","chargedCurrency","description","fullSupplierNameOutbound","fullSupplierNameHeb","memo","installments","status","TransactionStatuses","Completed","fetchTransactions","options","companyServiceOptions","startMoment","accounts","sleep","CardsTransactionsListBean","accountTxns","forEach","account","txnGroups","allTxns","txnGroup","txnIsrael","push","txnAbroad","combineInstallments","fixInstallments","outputData","enableTransactionsFilterByDate","filterOldTransactions","getExtraScrapTransaction","accountIndex","transaction","data","rawCategory","category","trim","getExtraScrapAccount","accountMap","Object","values","txnsChunk","chunk","updatedTxns","Promise","all","t","reduce","m","x","getAdditionalTransactionInformation","scraperOptions","accountsWithIndex","allMonths","additionalTransactionInformation","optInFeatures","runSerial","a","i","fetchAllTransactions","futureMonthsToScrape","getAllMonthMoments","results","finalResult","combinedTxns","keys","txnsForAccount","toBeAddedTxns","success","IsracardAmexBaseScraper","BaseScraperWithBrowser","constructor","baseUrl","companyCode","login","credentials","setRequestInterception","on","request","abort","interceptionPriorities","continue","maskHeadlessUserAgent","navigateTo","emitProgress","ScraperProgressTypes","LoggingIn","validateUrl","validateRequest","id","cardSuffix","card6Digits","countryCode","idType","checkLevel","validateResult","fetchPostWithinPage","Header","Status","ValidateIdDataBean","Error","validateReturnCode","returnCode","userName","loginUrl","KodMishtamesh","MisparZihuy","Sisma","password","loginResult","LoginSuccess","ChangePassword","errorType","ScraperErrorTypes","LoginFailed","InvalidPassword","fetchData","defaultStartMoment","subtract","startDate","toDate","max","_default","exports"],"sources":["../../src/scrapers/base-isracard-amex.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer';\nimport { ALT_SHEKEL_CURRENCY, SHEKEL_CURRENCY, SHEKEL_CURRENCY_KEYWORD } from '../constants';\nimport { ScraperProgressTypes } from '../definitions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { getDebug } from '../helpers/debug';\nimport { fetchGetWithinPage, fetchPostWithinPage } from '../helpers/fetch';\nimport { filterOldTransactions, fixInstallments } from '../helpers/transactions';\nimport { runSerial, sleep } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionInstallments,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\nimport { interceptionPriorities, maskHeadlessUserAgent } from '../helpers/browser';\n\nconst RATE_LIMIT = {\n  SLEEP_BETWEEN: 1000,\n  TRANSACTIONS_BATCH_SIZE: 10,\n} as const;\n\nconst COUNTRY_CODE = '212';\nconst ID_TYPE = '1';\nconst INSTALLMENTS_KEYWORD = 'תשלום';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst debug = getDebug('base-isracard-amex');\n\ntype CompanyServiceOptions = {\n  servicesUrl: string;\n  companyCode: string;\n};\n\ntype ScrapedAccountsWithIndex = Record<string, TransactionsAccount & { index: number }>;\n\ninterface ScrapedTransaction {\n  dealSumType: string;\n  voucherNumberRatzOutbound: string;\n  voucherNumberRatz: string;\n  moreInfo?: string;\n  dealSumOutbound: boolean;\n  currencyId: string;\n  currentPaymentCurrency: string;\n  dealSum: number;\n  fullPaymentDate?: string;\n  fullPurchaseDate?: string;\n  fullPurchaseDateOutbound?: string;\n  fullSupplierNameHeb: string;\n  fullSupplierNameOutbound: string;\n  paymentSum: number;\n  paymentSumOutbound: number;\n}\n\ninterface ScrapedAccount {\n  index: number;\n  accountNumber: string;\n  processedDate: string;\n}\n\ninterface ScrapedLoginValidation {\n  Header: {\n    Status: string;\n  };\n  ValidateIdDataBean?: {\n    userName?: string;\n    returnCode: string;\n  };\n}\n\ninterface ScrapedAccountsWithinPageResponse {\n  Header: {\n    Status: string;\n  };\n  DashboardMonthBean?: {\n    cardsCharges: {\n      cardIndex: string;\n      cardNumber: string;\n      billingDate: string;\n    }[];\n  };\n}\n\ninterface ScrapedCurrentCardTransactions {\n  txnIsrael?: ScrapedTransaction[];\n  txnAbroad?: ScrapedTransaction[];\n}\n\ninterface ScrapedTransactionData {\n  Header?: {\n    Status: string;\n  };\n  PirteyIska_204Bean?: {\n    sector: string;\n  };\n\n  CardsTransactionsListBean?: Record<\n    string,\n    {\n      CurrentCardTransactions: ScrapedCurrentCardTransactions[];\n    }\n  >;\n}\n\nfunction getAccountsUrl(servicesUrl: string, monthMoment: Moment) {\n  const billingDate = monthMoment.format('YYYY-MM-DD');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'DashboardMonth');\n  url.searchParams.set('actionCode', '0');\n  url.searchParams.set('billingDate', billingDate);\n  url.searchParams.set('format', 'Json');\n  return url.toString();\n}\n\nasync function fetchAccounts(page: Page, servicesUrl: string, monthMoment: Moment): Promise<ScrapedAccount[]> {\n  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);\n  debug(`fetching accounts from ${dataUrl}`);\n  const dataResult = await fetchGetWithinPage<ScrapedAccountsWithinPageResponse>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {\n    const { cardsCharges } = dataResult.DashboardMonthBean;\n    if (cardsCharges) {\n      return cardsCharges.map(cardCharge => {\n        return {\n          index: parseInt(cardCharge.cardIndex, 10),\n          accountNumber: cardCharge.cardNumber,\n          processedDate: moment(cardCharge.billingDate, DATE_FORMAT).toISOString(),\n        };\n      });\n    }\n  }\n  return [];\n}\n\nfunction getTransactionsUrl(servicesUrl: string, monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const monthStr = month < 10 ? `0${month}` : month.toString();\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'CardsTransactionsList');\n  url.searchParams.set('month', monthStr);\n  url.searchParams.set('year', `${year}`);\n  url.searchParams.set('requiredDate', 'N');\n  return url.toString();\n}\n\nfunction convertCurrency(currencyStr: string) {\n  if (currencyStr === SHEKEL_CURRENCY_KEYWORD || currencyStr === ALT_SHEKEL_CURRENCY) {\n    return SHEKEL_CURRENCY;\n  }\n  return currencyStr;\n}\n\nfunction getInstallmentsInfo(txn: ScrapedTransaction): TransactionInstallments | undefined {\n  if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {\n    return undefined;\n  }\n  const matches = txn.moreInfo.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\n\nfunction getTransactionType(txn: ScrapedTransaction) {\n  return getInstallmentsInfo(txn) ? TransactionTypes.Installments : TransactionTypes.Normal;\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], processedDate: string): Transaction[] {\n  const filteredTxns = txns.filter(\n    txn =>\n      txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000',\n  );\n\n  return filteredTxns.map(txn => {\n    const isOutbound = txn.dealSumOutbound;\n    const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;\n    const txnMoment = moment(txnDateStr, DATE_FORMAT);\n\n    const currentProcessedDate = txn.fullPaymentDate\n      ? moment(txn.fullPaymentDate, DATE_FORMAT).toISOString()\n      : processedDate;\n    const result: Transaction = {\n      type: getTransactionType(txn),\n      identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),\n      date: txnMoment.toISOString(),\n      processedDate: currentProcessedDate,\n      originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,\n      originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),\n      chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,\n      chargedCurrency: convertCurrency(txn.currencyId),\n      description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,\n      memo: txn.moreInfo || '',\n      installments: getInstallmentsInfo(txn) || undefined,\n      status: TransactionStatuses.Completed,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n  monthMoment: Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);\n  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);\n  await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n  debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);\n  const dataResult = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {\n    const accountTxns: ScrapedAccountsWithIndex = {};\n    accounts.forEach(account => {\n      const txnGroups: ScrapedCurrentCardTransactions[] | undefined = _.get(\n        dataResult,\n        `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`,\n      );\n      if (txnGroups) {\n        let allTxns: Transaction[] = [];\n        txnGroups.forEach(txnGroup => {\n          if (txnGroup.txnIsrael) {\n            const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate);\n            allTxns.push(...txns);\n          }\n        });\n\n        if (!options.combineInstallments) {\n          allTxns = fixInstallments(allTxns);\n        }\n        if (options.outputData?.enableTransactionsFilterByDate ?? true) {\n          allTxns = filterOldTransactions(allTxns, startMoment, options.combineInstallments || false);\n        }\n        accountTxns[account.accountNumber] = {\n          accountNumber: account.accountNumber,\n          index: account.index,\n          txns: allTxns,\n        };\n      }\n    });\n    return accountTxns;\n  }\n\n  return {};\n}\n\nasync function getExtraScrapTransaction(\n  page: Page,\n  options: CompanyServiceOptions,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): Promise<Transaction> {\n  const url = new URL(options.servicesUrl);\n  url.searchParams.set('reqName', 'PirteyIska_204');\n  url.searchParams.set('CardIndex', accountIndex.toString());\n  url.searchParams.set('shovarRatz', transaction.identifier!.toString());\n  url.searchParams.set('moedChiuv', month.format('MMYYYY'));\n\n  debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);\n  const data = await fetchGetWithinPage<ScrapedTransactionData>(page, url.toString());\n  if (!data) {\n    return transaction;\n  }\n\n  const rawCategory = _.get(data, 'PirteyIska_204Bean.sector') ?? '';\n  return {\n    ...transaction,\n    category: rawCategory.trim(),\n  };\n}\n\nasync function getExtraScrapAccount(\n  page: Page,\n  options: CompanyServiceOptions,\n  accountMap: ScrapedAccountsWithIndex,\n  month: moment.Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts: ScrapedAccountsWithIndex[string][] = [];\n  for (const account of Object.values(accountMap)) {\n    debug(\n      `get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`,\n      month.format('YYYY-MM'),\n    );\n    const txns: Transaction[] = [];\n    for (const txnsChunk of _.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {\n      debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);\n      const updatedTxns = await Promise.all(\n        txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)),\n      );\n      await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n      txns.push(...updatedTxns);\n    }\n    accounts.push({ ...account, txns });\n  }\n\n  return accounts.reduce((m, x) => ({ ...m, [x.accountNumber]: x }), {});\n}\n\nasync function getAdditionalTransactionInformation(\n  scraperOptions: ScraperOptions,\n  accountsWithIndex: ScrapedAccountsWithIndex[],\n  page: Page,\n  options: CompanyServiceOptions,\n  allMonths: moment.Moment[],\n): Promise<ScrapedAccountsWithIndex[]> {\n  if (\n    !scraperOptions.additionalTransactionInformation ||\n    scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')\n  ) {\n    return accountsWithIndex;\n  }\n  return runSerial(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));\n}\n\nasync function fetchAllTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n  const results: ScrapedAccountsWithIndex[] = await runSerial(\n    allMonths.map(monthMoment => () => {\n      return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);\n    }),\n  );\n\n  const finalResult = await getAdditionalTransactionInformation(\n    options,\n    results,\n    page,\n    companyServiceOptions,\n    allMonths,\n  );\n  const combinedTxns: Record<string, Transaction[]> = {};\n\n  finalResult.forEach(result => {\n    Object.keys(result).forEach(accountNumber => {\n      let txnsForAccount = combinedTxns[accountNumber];\n      if (!txnsForAccount) {\n        txnsForAccount = [];\n        combinedTxns[accountNumber] = txnsForAccount;\n      }\n      const toBeAddedTxns = result[accountNumber].txns;\n      combinedTxns[accountNumber].push(...toBeAddedTxns);\n    });\n  });\n\n  const accounts = Object.keys(combinedTxns).map(accountNumber => {\n    return {\n      accountNumber,\n      txns: combinedTxns[accountNumber],\n    };\n  });\n\n  return {\n    success: true,\n    accounts,\n  };\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; card6Digits: string };\nclass IsracardAmexBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private baseUrl: string;\n\n  private companyCode: string;\n\n  private servicesUrl: string;\n\n  constructor(options: ScraperOptions, baseUrl: string, companyCode: string) {\n    super(options);\n\n    this.baseUrl = baseUrl;\n    this.companyCode = companyCode;\n    this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;\n  }\n\n  async login(credentials: ScraperSpecificCredentials): Promise<ScraperScrapingResult> {\n    await this.page.setRequestInterception(true);\n    this.page.on('request', request => {\n      if (request.url().includes('detector-dom.min.js')) {\n        debug('force abort for request do download detector-dom.min.js resource');\n        void request.abort(undefined, interceptionPriorities.abort);\n      } else {\n        void request.continue(undefined, interceptionPriorities.continue);\n      }\n    });\n\n    await maskHeadlessUserAgent(this.page);\n\n    await this.navigateTo(`${this.baseUrl}/personalarea/Login`);\n\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;\n    const validateRequest = {\n      id: credentials.id,\n      cardSuffix: credentials.card6Digits,\n      countryCode: COUNTRY_CODE,\n      idType: ID_TYPE,\n      checkLevel: '1',\n      companyCode: this.companyCode,\n    };\n    debug('logging in with validate request');\n    const validateResult = await fetchPostWithinPage<ScrapedLoginValidation>(this.page, validateUrl, validateRequest);\n    if (\n      !validateResult ||\n      !validateResult.Header ||\n      validateResult.Header.Status !== '1' ||\n      !validateResult.ValidateIdDataBean\n    ) {\n      throw new Error('unknown error during login');\n    }\n\n    const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;\n    debug(`user validate with return code '${validateReturnCode}'`);\n    if (validateReturnCode === '1') {\n      const { userName } = validateResult.ValidateIdDataBean;\n\n      const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;\n      const request = {\n        KodMishtamesh: userName,\n        MisparZihuy: credentials.id,\n        Sisma: credentials.password,\n        cardSuffix: credentials.card6Digits,\n        countryCode: COUNTRY_CODE,\n        idType: ID_TYPE,\n      };\n      debug('user login started');\n      const loginResult = await fetchPostWithinPage<{ status: string }>(this.page, loginUrl, request);\n      debug(`user login with status '${loginResult?.status}'`, loginResult);\n\n      if (loginResult && loginResult.status === '1') {\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      }\n\n      if (loginResult && loginResult.status === '3') {\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      }\n\n      this.emitProgress(ScraperProgressTypes.LoginFailed);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.InvalidPassword,\n      };\n    }\n\n    if (validateReturnCode === '4') {\n      this.emitProgress(ScraperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    }\n\n    this.emitProgress(ScraperProgressTypes.LoginFailed);\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.InvalidPassword,\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    return fetchAllTransactions(\n      this.page,\n      this.options,\n      {\n        servicesUrl: this.servicesUrl,\n        companyCode: this.companyCode,\n      },\n      startMoment,\n    );\n  }\n}\n\nexport default IsracardAmexBaseScraper;\n"],"mappings":"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","ignoreList":[]}
327
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_moment","_constants","_definitions","_dates","_debug","_fetch","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_errors","_browser","e","__esModule","default","RATE_LIMIT","SLEEP_BETWEEN","TRANSACTIONS_BATCH_SIZE","COUNTRY_CODE","ID_TYPE","INSTALLMENTS_KEYWORD","DATE_FORMAT","debug","getDebug","getAccountsUrl","servicesUrl","monthMoment","billingDate","format","url","URL","searchParams","set","toString","fetchAccounts","page","dataUrl","dataResult","fetchGetWithinPage","_","get","DashboardMonthBean","cardsCharges","map","cardCharge","index","parseInt","cardIndex","accountNumber","cardNumber","processedDate","moment","toISOString","getTransactionsUrl","month","year","monthStr","convertCurrency","currencyStr","SHEKEL_CURRENCY_KEYWORD","ALT_SHEKEL_CURRENCY","SHEKEL_CURRENCY","getInstallmentsInfo","txn","moreInfo","includes","undefined","matches","match","length","number","total","getTransactionType","TransactionTypes","Installments","Normal","convertTransactions","txns","options","filteredTxns","filter","dealSumType","voucherNumberRatz","voucherNumberRatzOutbound","isOutbound","dealSumOutbound","txnDateStr","fullPurchaseDateOutbound","fullPurchaseDate","txnMoment","currentProcessedDate","fullPaymentDate","result","type","identifier","date","originalAmount","dealSum","originalCurrency","currentPaymentCurrency","currencyId","chargedAmount","paymentSumOutbound","paymentSum","chargedCurrency","description","fullSupplierNameOutbound","fullSupplierNameHeb","memo","installments","status","TransactionStatuses","Completed","includeRawTransaction","rawTransaction","fetchTransactions","companyServiceOptions","startMoment","accounts","sleep","CardsTransactionsListBean","accountTxns","forEach","account","txnGroups","allTxns","txnGroup","txnIsrael","push","txnAbroad","combineInstallments","fixInstallments","outputData","enableTransactionsFilterByDate","filterOldTransactions","getExtraScrapTransaction","accountIndex","transaction","data","rawCategory","category","trim","getExtraScrapAccount","accountMap","Object","values","txnsChunk","chunk","updatedTxns","Promise","all","t","reduce","m","x","getAdditionalTransactionInformation","scraperOptions","accountsWithIndex","allMonths","additionalTransactionInformation","optInFeatures","runSerial","a","i","fetchAllTransactions","futureMonthsToScrape","getAllMonthMoments","results","finalResult","combinedTxns","keys","txnsForAccount","toBeAddedTxns","success","IsracardAmexBaseScraper","BaseScraperWithBrowser","constructor","baseUrl","companyCode","login","credentials","setRequestInterception","on","request","abort","interceptionPriorities","continue","maskHeadlessUserAgent","navigateTo","emitProgress","ScraperProgressTypes","LoggingIn","validateUrl","validateRequest","id","cardSuffix","card6Digits","countryCode","idType","checkLevel","validateResult","fetchPostWithinPage","Header","Status","ValidateIdDataBean","Error","validateReturnCode","returnCode","userName","loginUrl","KodMishtamesh","MisparZihuy","Sisma","password","loginResult","LoginSuccess","ChangePassword","errorType","ScraperErrorTypes","LoginFailed","InvalidPassword","fetchData","defaultStartMoment","subtract","startDate","toDate","max","_default","exports"],"sources":["../../src/scrapers/base-isracard-amex.ts"],"sourcesContent":["import _ from 'lodash';\nimport moment, { type Moment } from 'moment';\nimport { type Page } from 'puppeteer';\nimport { ALT_SHEKEL_CURRENCY, SHEKEL_CURRENCY, SHEKEL_CURRENCY_KEYWORD } from '../constants';\nimport { ScraperProgressTypes } from '../definitions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { getDebug } from '../helpers/debug';\nimport { fetchGetWithinPage, fetchPostWithinPage } from '../helpers/fetch';\nimport { filterOldTransactions, fixInstallments } from '../helpers/transactions';\nimport { runSerial, sleep } from '../helpers/waiting';\nimport {\n  TransactionStatuses,\n  TransactionTypes,\n  type Transaction,\n  type TransactionInstallments,\n  type TransactionsAccount,\n} from '../transactions';\nimport { BaseScraperWithBrowser } from './base-scraper-with-browser';\nimport { ScraperErrorTypes } from './errors';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\nimport { interceptionPriorities, maskHeadlessUserAgent } from '../helpers/browser';\n\nconst RATE_LIMIT = {\n  SLEEP_BETWEEN: 1000,\n  TRANSACTIONS_BATCH_SIZE: 10,\n} as const;\n\nconst COUNTRY_CODE = '212';\nconst ID_TYPE = '1';\nconst INSTALLMENTS_KEYWORD = 'תשלום';\n\nconst DATE_FORMAT = 'DD/MM/YYYY';\n\nconst debug = getDebug('base-isracard-amex');\n\ntype CompanyServiceOptions = {\n  servicesUrl: string;\n  companyCode: string;\n};\n\ntype ScrapedAccountsWithIndex = Record<string, TransactionsAccount & { index: number }>;\n\ninterface ScrapedTransaction {\n  dealSumType: string;\n  voucherNumberRatzOutbound: string;\n  voucherNumberRatz: string;\n  moreInfo?: string;\n  dealSumOutbound: boolean;\n  currencyId: string;\n  currentPaymentCurrency: string;\n  dealSum: number;\n  fullPaymentDate?: string;\n  fullPurchaseDate?: string;\n  fullPurchaseDateOutbound?: string;\n  fullSupplierNameHeb: string;\n  fullSupplierNameOutbound: string;\n  paymentSum: number;\n  paymentSumOutbound: number;\n}\n\ninterface ScrapedAccount {\n  index: number;\n  accountNumber: string;\n  processedDate: string;\n}\n\ninterface ScrapedLoginValidation {\n  Header: {\n    Status: string;\n  };\n  ValidateIdDataBean?: {\n    userName?: string;\n    returnCode: string;\n  };\n}\n\ninterface ScrapedAccountsWithinPageResponse {\n  Header: {\n    Status: string;\n  };\n  DashboardMonthBean?: {\n    cardsCharges: {\n      cardIndex: string;\n      cardNumber: string;\n      billingDate: string;\n    }[];\n  };\n}\n\ninterface ScrapedCurrentCardTransactions {\n  txnIsrael?: ScrapedTransaction[];\n  txnAbroad?: ScrapedTransaction[];\n}\n\ninterface ScrapedTransactionData {\n  Header?: {\n    Status: string;\n  };\n  PirteyIska_204Bean?: {\n    sector: string;\n  };\n\n  CardsTransactionsListBean?: Record<\n    string,\n    {\n      CurrentCardTransactions: ScrapedCurrentCardTransactions[];\n    }\n  >;\n}\n\nfunction getAccountsUrl(servicesUrl: string, monthMoment: Moment) {\n  const billingDate = monthMoment.format('YYYY-MM-DD');\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'DashboardMonth');\n  url.searchParams.set('actionCode', '0');\n  url.searchParams.set('billingDate', billingDate);\n  url.searchParams.set('format', 'Json');\n  return url.toString();\n}\n\nasync function fetchAccounts(page: Page, servicesUrl: string, monthMoment: Moment): Promise<ScrapedAccount[]> {\n  const dataUrl = getAccountsUrl(servicesUrl, monthMoment);\n  debug(`fetching accounts from ${dataUrl}`);\n  const dataResult = await fetchGetWithinPage<ScrapedAccountsWithinPageResponse>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.DashboardMonthBean) {\n    const { cardsCharges } = dataResult.DashboardMonthBean;\n    if (cardsCharges) {\n      return cardsCharges.map(cardCharge => {\n        return {\n          index: parseInt(cardCharge.cardIndex, 10),\n          accountNumber: cardCharge.cardNumber,\n          processedDate: moment(cardCharge.billingDate, DATE_FORMAT).toISOString(),\n        };\n      });\n    }\n  }\n  return [];\n}\n\nfunction getTransactionsUrl(servicesUrl: string, monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const monthStr = month < 10 ? `0${month}` : month.toString();\n  const url = new URL(servicesUrl);\n  url.searchParams.set('reqName', 'CardsTransactionsList');\n  url.searchParams.set('month', monthStr);\n  url.searchParams.set('year', `${year}`);\n  url.searchParams.set('requiredDate', 'N');\n  return url.toString();\n}\n\nfunction convertCurrency(currencyStr: string) {\n  if (currencyStr === SHEKEL_CURRENCY_KEYWORD || currencyStr === ALT_SHEKEL_CURRENCY) {\n    return SHEKEL_CURRENCY;\n  }\n  return currencyStr;\n}\n\nfunction getInstallmentsInfo(txn: ScrapedTransaction): TransactionInstallments | undefined {\n  if (!txn.moreInfo || !txn.moreInfo.includes(INSTALLMENTS_KEYWORD)) {\n    return undefined;\n  }\n  const matches = txn.moreInfo.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\n\nfunction getTransactionType(txn: ScrapedTransaction) {\n  return getInstallmentsInfo(txn) ? TransactionTypes.Installments : TransactionTypes.Normal;\n}\n\nfunction convertTransactions(\n  txns: ScrapedTransaction[],\n  processedDate: string,\n  options?: ScraperOptions,\n): Transaction[] {\n  const filteredTxns = txns.filter(\n    txn =>\n      txn.dealSumType !== '1' && txn.voucherNumberRatz !== '000000000' && txn.voucherNumberRatzOutbound !== '000000000',\n  );\n\n  return filteredTxns.map(txn => {\n    const isOutbound = txn.dealSumOutbound;\n    const txnDateStr = isOutbound ? txn.fullPurchaseDateOutbound : txn.fullPurchaseDate;\n    const txnMoment = moment(txnDateStr, DATE_FORMAT);\n\n    const currentProcessedDate = txn.fullPaymentDate\n      ? moment(txn.fullPaymentDate, DATE_FORMAT).toISOString()\n      : processedDate;\n    const result: Transaction = {\n      type: getTransactionType(txn),\n      identifier: parseInt(isOutbound ? txn.voucherNumberRatzOutbound : txn.voucherNumberRatz, 10),\n      date: txnMoment.toISOString(),\n      processedDate: currentProcessedDate,\n      originalAmount: isOutbound ? -txn.dealSumOutbound : -txn.dealSum,\n      originalCurrency: convertCurrency(txn.currentPaymentCurrency ?? txn.currencyId),\n      chargedAmount: isOutbound ? -txn.paymentSumOutbound : -txn.paymentSum,\n      chargedCurrency: convertCurrency(txn.currencyId),\n      description: isOutbound ? txn.fullSupplierNameOutbound : txn.fullSupplierNameHeb,\n      memo: txn.moreInfo || '',\n      installments: getInstallmentsInfo(txn) || undefined,\n      status: TransactionStatuses.Completed,\n    };\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = txn;\n    }\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n  monthMoment: Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts = await fetchAccounts(page, companyServiceOptions.servicesUrl, monthMoment);\n  const dataUrl = getTransactionsUrl(companyServiceOptions.servicesUrl, monthMoment);\n  await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n  debug(`fetching transactions from ${dataUrl} for month ${monthMoment.format('YYYY-MM')}`);\n  const dataResult = await fetchGetWithinPage<ScrapedTransactionData>(page, dataUrl);\n  if (dataResult && _.get(dataResult, 'Header.Status') === '1' && dataResult.CardsTransactionsListBean) {\n    const accountTxns: ScrapedAccountsWithIndex = {};\n    accounts.forEach(account => {\n      const txnGroups: ScrapedCurrentCardTransactions[] | undefined = _.get(\n        dataResult,\n        `CardsTransactionsListBean.Index${account.index}.CurrentCardTransactions`,\n      );\n      if (txnGroups) {\n        let allTxns: Transaction[] = [];\n        txnGroups.forEach(txnGroup => {\n          if (txnGroup.txnIsrael) {\n            const txns = convertTransactions(txnGroup.txnIsrael, account.processedDate, options);\n            allTxns.push(...txns);\n          }\n          if (txnGroup.txnAbroad) {\n            const txns = convertTransactions(txnGroup.txnAbroad, account.processedDate, options);\n            allTxns.push(...txns);\n          }\n        });\n\n        if (!options.combineInstallments) {\n          allTxns = fixInstallments(allTxns);\n        }\n        if (options.outputData?.enableTransactionsFilterByDate ?? true) {\n          allTxns = filterOldTransactions(allTxns, startMoment, options.combineInstallments || false);\n        }\n        accountTxns[account.accountNumber] = {\n          accountNumber: account.accountNumber,\n          index: account.index,\n          txns: allTxns,\n        };\n      }\n    });\n    return accountTxns;\n  }\n\n  return {};\n}\n\nasync function getExtraScrapTransaction(\n  page: Page,\n  options: CompanyServiceOptions,\n  month: Moment,\n  accountIndex: number,\n  transaction: Transaction,\n): Promise<Transaction> {\n  const url = new URL(options.servicesUrl);\n  url.searchParams.set('reqName', 'PirteyIska_204');\n  url.searchParams.set('CardIndex', accountIndex.toString());\n  url.searchParams.set('shovarRatz', transaction.identifier!.toString());\n  url.searchParams.set('moedChiuv', month.format('MMYYYY'));\n\n  debug(`fetching extra scrap for transaction ${transaction.identifier} for month ${month.format('YYYY-MM')}`);\n  const data = await fetchGetWithinPage<ScrapedTransactionData>(page, url.toString());\n  if (!data) {\n    return transaction;\n  }\n\n  const rawCategory = _.get(data, 'PirteyIska_204Bean.sector') ?? '';\n  return {\n    ...transaction,\n    category: rawCategory.trim(),\n  };\n}\n\nasync function getExtraScrapAccount(\n  page: Page,\n  options: CompanyServiceOptions,\n  accountMap: ScrapedAccountsWithIndex,\n  month: moment.Moment,\n): Promise<ScrapedAccountsWithIndex> {\n  const accounts: ScrapedAccountsWithIndex[string][] = [];\n  for (const account of Object.values(accountMap)) {\n    debug(\n      `get extra scrap for ${account.accountNumber} with ${account.txns.length} transactions`,\n      month.format('YYYY-MM'),\n    );\n    const txns: Transaction[] = [];\n    for (const txnsChunk of _.chunk(account.txns, RATE_LIMIT.TRANSACTIONS_BATCH_SIZE)) {\n      debug(`processing chunk of ${txnsChunk.length} transactions for account ${account.accountNumber}`);\n      const updatedTxns = await Promise.all(\n        txnsChunk.map(t => getExtraScrapTransaction(page, options, month, account.index, t)),\n      );\n      await sleep(RATE_LIMIT.SLEEP_BETWEEN);\n      txns.push(...updatedTxns);\n    }\n    accounts.push({ ...account, txns });\n  }\n\n  return accounts.reduce((m, x) => ({ ...m, [x.accountNumber]: x }), {});\n}\n\nasync function getAdditionalTransactionInformation(\n  scraperOptions: ScraperOptions,\n  accountsWithIndex: ScrapedAccountsWithIndex[],\n  page: Page,\n  options: CompanyServiceOptions,\n  allMonths: moment.Moment[],\n): Promise<ScrapedAccountsWithIndex[]> {\n  if (\n    !scraperOptions.additionalTransactionInformation ||\n    scraperOptions.optInFeatures?.includes('isracard-amex:skipAdditionalTransactionInformation')\n  ) {\n    return accountsWithIndex;\n  }\n  return runSerial(accountsWithIndex.map((a, i) => () => getExtraScrapAccount(page, options, a, allMonths[i])));\n}\n\nasync function fetchAllTransactions(\n  page: Page,\n  options: ScraperOptions,\n  companyServiceOptions: CompanyServiceOptions,\n  startMoment: Moment,\n) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n  const results: ScrapedAccountsWithIndex[] = await runSerial(\n    allMonths.map(monthMoment => () => {\n      return fetchTransactions(page, options, companyServiceOptions, startMoment, monthMoment);\n    }),\n  );\n\n  const finalResult = await getAdditionalTransactionInformation(\n    options,\n    results,\n    page,\n    companyServiceOptions,\n    allMonths,\n  );\n  const combinedTxns: Record<string, Transaction[]> = {};\n\n  finalResult.forEach(result => {\n    Object.keys(result).forEach(accountNumber => {\n      let txnsForAccount = combinedTxns[accountNumber];\n      if (!txnsForAccount) {\n        txnsForAccount = [];\n        combinedTxns[accountNumber] = txnsForAccount;\n      }\n      const toBeAddedTxns = result[accountNumber].txns;\n      combinedTxns[accountNumber].push(...toBeAddedTxns);\n    });\n  });\n\n  const accounts = Object.keys(combinedTxns).map(accountNumber => {\n    return {\n      accountNumber,\n      txns: combinedTxns[accountNumber],\n    };\n  });\n\n  return {\n    success: true,\n    accounts,\n  };\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string; card6Digits: string };\nclass IsracardAmexBaseScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private baseUrl: string;\n\n  private companyCode: string;\n\n  private servicesUrl: string;\n\n  constructor(options: ScraperOptions, baseUrl: string, companyCode: string) {\n    super(options);\n\n    this.baseUrl = baseUrl;\n    this.companyCode = companyCode;\n    this.servicesUrl = `${baseUrl}/services/ProxyRequestHandler.ashx`;\n  }\n\n  async login(credentials: ScraperSpecificCredentials): Promise<ScraperScrapingResult> {\n    await this.page.setRequestInterception(true);\n    this.page.on('request', request => {\n      if (request.url().includes('detector-dom.min.js')) {\n        debug('force abort for request do download detector-dom.min.js resource');\n        void request.abort(undefined, interceptionPriorities.abort);\n      } else {\n        void request.continue(undefined, interceptionPriorities.continue);\n      }\n    });\n\n    await maskHeadlessUserAgent(this.page);\n\n    await this.navigateTo(`${this.baseUrl}/personalarea/Login`);\n\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    const validateUrl = `${this.servicesUrl}?reqName=ValidateIdData`;\n    const validateRequest = {\n      id: credentials.id,\n      cardSuffix: credentials.card6Digits,\n      countryCode: COUNTRY_CODE,\n      idType: ID_TYPE,\n      checkLevel: '1',\n      companyCode: this.companyCode,\n    };\n    debug('logging in with validate request');\n    const validateResult = await fetchPostWithinPage<ScrapedLoginValidation>(this.page, validateUrl, validateRequest);\n    if (\n      !validateResult ||\n      !validateResult.Header ||\n      validateResult.Header.Status !== '1' ||\n      !validateResult.ValidateIdDataBean\n    ) {\n      throw new Error('unknown error during login');\n    }\n\n    const validateReturnCode = validateResult.ValidateIdDataBean.returnCode;\n    debug(`user validate with return code '${validateReturnCode}'`);\n    if (validateReturnCode === '1') {\n      const { userName } = validateResult.ValidateIdDataBean;\n\n      const loginUrl = `${this.servicesUrl}?reqName=performLogonI`;\n      const request = {\n        KodMishtamesh: userName,\n        MisparZihuy: credentials.id,\n        Sisma: credentials.password,\n        cardSuffix: credentials.card6Digits,\n        countryCode: COUNTRY_CODE,\n        idType: ID_TYPE,\n      };\n      debug('user login started');\n      const loginResult = await fetchPostWithinPage<{ status: string }>(this.page, loginUrl, request);\n      debug(`user login with status '${loginResult?.status}'`, loginResult);\n\n      if (loginResult && loginResult.status === '1') {\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      }\n\n      if (loginResult && loginResult.status === '3') {\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      }\n\n      this.emitProgress(ScraperProgressTypes.LoginFailed);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.InvalidPassword,\n      };\n    }\n\n    if (validateReturnCode === '4') {\n      this.emitProgress(ScraperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    }\n\n    this.emitProgress(ScraperProgressTypes.LoginFailed);\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.InvalidPassword,\n    };\n  }\n\n  async fetchData() {\n    const defaultStartMoment = moment().subtract(1, 'years');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    return fetchAllTransactions(\n      this.page,\n      this.options,\n      {\n        servicesUrl: this.servicesUrl,\n        companyCode: this.companyCode,\n      },\n      startMoment,\n    );\n  }\n}\n\nexport default IsracardAmexBaseScraper;\n"],"mappings":";;;;;;AAAA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,UAAA,GAAAF,OAAA;AACA,IAAAG,YAAA,GAAAH,OAAA;AACA,IAAAI,MAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,MAAA,GAAAL,OAAA;AACA,IAAAM,MAAA,GAAAN,OAAA;AACA,IAAAO,aAAA,GAAAP,OAAA;AACA,IAAAQ,QAAA,GAAAR,OAAA;AACA,IAAAS,cAAA,GAAAT,OAAA;AAOA,IAAAU,uBAAA,GAAAV,OAAA;AACA,IAAAW,OAAA,GAAAX,OAAA;AAEA,IAAAY,QAAA,GAAAZ,OAAA;AAAmF,SAAAD,uBAAAc,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAEnF,MAAMG,UAAU,GAAG;EACjBC,aAAa,EAAE,IAAI;EACnBC,uBAAuB,EAAE;AAC3B,CAAU;AAEV,MAAMC,YAAY,GAAG,KAAK;AAC1B,MAAMC,OAAO,GAAG,GAAG;AACnB,MAAMC,oBAAoB,GAAG,OAAO;AAEpC,MAAMC,WAAW,GAAG,YAAY;AAEhC,MAAMC,KAAK,GAAG,IAAAC,eAAQ,EAAC,oBAAoB,CAAC;AA6E5C,SAASC,cAAcA,CAACC,WAAmB,EAAEC,WAAmB,EAAE;EAChE,MAAMC,WAAW,GAAGD,WAAW,CAACE,MAAM,CAAC,YAAY,CAAC;EACpD,MAAMC,GAAG,GAAG,IAAIC,GAAG,CAACL,WAAW,CAAC;EAChCI,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,SAAS,EAAE,gBAAgB,CAAC;EACjDH,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,YAAY,EAAE,GAAG,CAAC;EACvCH,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,aAAa,EAAEL,WAAW,CAAC;EAChDE,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC;EACtC,OAAOH,GAAG,CAACI,QAAQ,CAAC,CAAC;AACvB;AAEA,eAAeC,aAAaA,CAACC,IAAU,EAAEV,WAAmB,EAAEC,WAAmB,EAA6B;EAC5G,MAAMU,OAAO,GAAGZ,cAAc,CAACC,WAAW,EAAEC,WAAW,CAAC;EACxDJ,KAAK,CAAC,0BAA0Bc,OAAO,EAAE,CAAC;EAC1C,MAAMC,UAAU,GAAG,MAAM,IAAAC,yBAAkB,EAAoCH,IAAI,EAAEC,OAAO,CAAC;EAC7F,IAAIC,UAAU,IAAIE,eAAC,CAACC,GAAG,CAACH,UAAU,EAAE,eAAe,CAAC,KAAK,GAAG,IAAIA,UAAU,CAACI,kBAAkB,EAAE;IAC7F,MAAM;MAAEC;IAAa,CAAC,GAAGL,UAAU,CAACI,kBAAkB;IACtD,IAAIC,YAAY,EAAE;MAChB,OAAOA,YAAY,CAACC,GAAG,CAACC,UAAU,IAAI;QACpC,OAAO;UACLC,KAAK,EAAEC,QAAQ,CAACF,UAAU,CAACG,SAAS,EAAE,EAAE,CAAC;UACzCC,aAAa,EAAEJ,UAAU,CAACK,UAAU;UACpCC,aAAa,EAAE,IAAAC,eAAM,EAACP,UAAU,CAACjB,WAAW,EAAEN,WAAW,CAAC,CAAC+B,WAAW,CAAC;QACzE,CAAC;MACH,CAAC,CAAC;IACJ;EACF;EACA,OAAO,EAAE;AACX;AAEA,SAASC,kBAAkBA,CAAC5B,WAAmB,EAAEC,WAAmB,EAAE;EACpE,MAAM4B,KAAK,GAAG5B,WAAW,CAAC4B,KAAK,CAAC,CAAC,GAAG,CAAC;EACrC,MAAMC,IAAI,GAAG7B,WAAW,CAAC6B,IAAI,CAAC,CAAC;EAC/B,MAAMC,QAAQ,GAAGF,KAAK,GAAG,EAAE,GAAG,IAAIA,KAAK,EAAE,GAAGA,KAAK,CAACrB,QAAQ,CAAC,CAAC;EAC5D,MAAMJ,GAAG,GAAG,IAAIC,GAAG,CAACL,WAAW,CAAC;EAChCI,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,SAAS,EAAE,uBAAuB,CAAC;EACxDH,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,OAAO,EAAEwB,QAAQ,CAAC;EACvC3B,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,MAAM,EAAE,GAAGuB,IAAI,EAAE,CAAC;EACvC1B,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,cAAc,EAAE,GAAG,CAAC;EACzC,OAAOH,GAAG,CAACI,QAAQ,CAAC,CAAC;AACvB;AAEA,SAASwB,eAAeA,CAACC,WAAmB,EAAE;EAC5C,IAAIA,WAAW,KAAKC,kCAAuB,IAAID,WAAW,KAAKE,8BAAmB,EAAE;IAClF,OAAOC,0BAAe;EACxB;EACA,OAAOH,WAAW;AACpB;AAEA,SAASI,mBAAmBA,CAACC,GAAuB,EAAuC;EACzF,IAAI,CAACA,GAAG,CAACC,QAAQ,IAAI,CAACD,GAAG,CAACC,QAAQ,CAACC,QAAQ,CAAC7C,oBAAoB,CAAC,EAAE;IACjE,OAAO8C,SAAS;EAClB;EACA,MAAMC,OAAO,GAAGJ,GAAG,CAACC,QAAQ,CAACI,KAAK,CAAC,MAAM,CAAC;EAC1C,IAAI,CAACD,OAAO,IAAIA,OAAO,CAACE,MAAM,GAAG,CAAC,EAAE;IAClC,OAAOH,SAAS;EAClB;EAEA,OAAO;IACLI,MAAM,EAAExB,QAAQ,CAACqB,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAChCI,KAAK,EAAEzB,QAAQ,CAACqB,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;EAChC,CAAC;AACH;AAEA,SAASK,kBAAkBA,CAACT,GAAuB,EAAE;EACnD,OAAOD,mBAAmB,CAACC,GAAG,CAAC,GAAGU,+BAAgB,CAACC,YAAY,GAAGD,+BAAgB,CAACE,MAAM;AAC3F;AAEA,SAASC,mBAAmBA,CAC1BC,IAA0B,EAC1B3B,aAAqB,EACrB4B,OAAwB,EACT;EACf,MAAMC,YAAY,GAAGF,IAAI,CAACG,MAAM,CAC9BjB,GAAG,IACDA,GAAG,CAACkB,WAAW,KAAK,GAAG,IAAIlB,GAAG,CAACmB,iBAAiB,KAAK,WAAW,IAAInB,GAAG,CAACoB,yBAAyB,KAAK,WAC1G,CAAC;EAED,OAAOJ,YAAY,CAACpC,GAAG,CAACoB,GAAG,IAAI;IAC7B,MAAMqB,UAAU,GAAGrB,GAAG,CAACsB,eAAe;IACtC,MAAMC,UAAU,GAAGF,UAAU,GAAGrB,GAAG,CAACwB,wBAAwB,GAAGxB,GAAG,CAACyB,gBAAgB;IACnF,MAAMC,SAAS,GAAG,IAAAtC,eAAM,EAACmC,UAAU,EAAEjE,WAAW,CAAC;IAEjD,MAAMqE,oBAAoB,GAAG3B,GAAG,CAAC4B,eAAe,GAC5C,IAAAxC,eAAM,EAACY,GAAG,CAAC4B,eAAe,EAAEtE,WAAW,CAAC,CAAC+B,WAAW,CAAC,CAAC,GACtDF,aAAa;IACjB,MAAM0C,MAAmB,GAAG;MAC1BC,IAAI,EAAErB,kBAAkB,CAACT,GAAG,CAAC;MAC7B+B,UAAU,EAAEhD,QAAQ,CAACsC,UAAU,GAAGrB,GAAG,CAACoB,yBAAyB,GAAGpB,GAAG,CAACmB,iBAAiB,EAAE,EAAE,CAAC;MAC5Fa,IAAI,EAAEN,SAAS,CAACrC,WAAW,CAAC,CAAC;MAC7BF,aAAa,EAAEwC,oBAAoB;MACnCM,cAAc,EAAEZ,UAAU,GAAG,CAACrB,GAAG,CAACsB,eAAe,GAAG,CAACtB,GAAG,CAACkC,OAAO;MAChEC,gBAAgB,EAAEzC,eAAe,CAACM,GAAG,CAACoC,sBAAsB,IAAIpC,GAAG,CAACqC,UAAU,CAAC;MAC/EC,aAAa,EAAEjB,UAAU,GAAG,CAACrB,GAAG,CAACuC,kBAAkB,GAAG,CAACvC,GAAG,CAACwC,UAAU;MACrEC,eAAe,EAAE/C,eAAe,CAACM,GAAG,CAACqC,UAAU,CAAC;MAChDK,WAAW,EAAErB,UAAU,GAAGrB,GAAG,CAAC2C,wBAAwB,GAAG3C,GAAG,CAAC4C,mBAAmB;MAChFC,IAAI,EAAE7C,GAAG,CAACC,QAAQ,IAAI,EAAE;MACxB6C,YAAY,EAAE/C,mBAAmB,CAACC,GAAG,CAAC,IAAIG,SAAS;MACnD4C,MAAM,EAAEC,kCAAmB,CAACC;IAC9B,CAAC;IAED,IAAIlC,OAAO,EAAEmC,qBAAqB,EAAE;MAClCrB,MAAM,CAACsB,cAAc,GAAGnD,GAAG;IAC7B;IAEA,OAAO6B,MAAM;EACf,CAAC,CAAC;AACJ;AAEA,eAAeuB,iBAAiBA,CAC9BhF,IAAU,EACV2C,OAAuB,EACvBsC,qBAA4C,EAC5CC,WAAmB,EACnB3F,WAAmB,EACgB;EACnC,MAAM4F,QAAQ,GAAG,MAAMpF,aAAa,CAACC,IAAI,EAAEiF,qBAAqB,CAAC3F,WAAW,EAAEC,WAAW,CAAC;EAC1F,MAAMU,OAAO,GAAGiB,kBAAkB,CAAC+D,qBAAqB,CAAC3F,WAAW,EAAEC,WAAW,CAAC;EAClF,MAAM,IAAA6F,cAAK,EAACxG,UAAU,CAACC,aAAa,CAAC;EACrCM,KAAK,CAAC,8BAA8Bc,OAAO,cAAcV,WAAW,CAACE,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;EACzF,MAAMS,UAAU,GAAG,MAAM,IAAAC,yBAAkB,EAAyBH,IAAI,EAAEC,OAAO,CAAC;EAClF,IAAIC,UAAU,IAAIE,eAAC,CAACC,GAAG,CAACH,UAAU,EAAE,eAAe,CAAC,KAAK,GAAG,IAAIA,UAAU,CAACmF,yBAAyB,EAAE;IACpG,MAAMC,WAAqC,GAAG,CAAC,CAAC;IAChDH,QAAQ,CAACI,OAAO,CAACC,OAAO,IAAI;MAC1B,MAAMC,SAAuD,GAAGrF,eAAC,CAACC,GAAG,CACnEH,UAAU,EACV,kCAAkCsF,OAAO,CAAC9E,KAAK,0BACjD,CAAC;MACD,IAAI+E,SAAS,EAAE;QACb,IAAIC,OAAsB,GAAG,EAAE;QAC/BD,SAAS,CAACF,OAAO,CAACI,QAAQ,IAAI;UAC5B,IAAIA,QAAQ,CAACC,SAAS,EAAE;YACtB,MAAMlD,IAAI,GAAGD,mBAAmB,CAACkD,QAAQ,CAACC,SAAS,EAAEJ,OAAO,CAACzE,aAAa,EAAE4B,OAAO,CAAC;YACpF+C,OAAO,CAACG,IAAI,CAAC,GAAGnD,IAAI,CAAC;UACvB;UACA,IAAIiD,QAAQ,CAACG,SAAS,EAAE;YACtB,MAAMpD,IAAI,GAAGD,mBAAmB,CAACkD,QAAQ,CAACG,SAAS,EAAEN,OAAO,CAACzE,aAAa,EAAE4B,OAAO,CAAC;YACpF+C,OAAO,CAACG,IAAI,CAAC,GAAGnD,IAAI,CAAC;UACvB;QACF,CAAC,CAAC;QAEF,IAAI,CAACC,OAAO,CAACoD,mBAAmB,EAAE;UAChCL,OAAO,GAAG,IAAAM,6BAAe,EAACN,OAAO,CAAC;QACpC;QACA,IAAI/C,OAAO,CAACsD,UAAU,EAAEC,8BAA8B,IAAI,IAAI,EAAE;UAC9DR,OAAO,GAAG,IAAAS,mCAAqB,EAACT,OAAO,EAAER,WAAW,EAAEvC,OAAO,CAACoD,mBAAmB,IAAI,KAAK,CAAC;QAC7F;QACAT,WAAW,CAACE,OAAO,CAAC3E,aAAa,CAAC,GAAG;UACnCA,aAAa,EAAE2E,OAAO,CAAC3E,aAAa;UACpCH,KAAK,EAAE8E,OAAO,CAAC9E,KAAK;UACpBgC,IAAI,EAAEgD;QACR,CAAC;MACH;IACF,CAAC,CAAC;IACF,OAAOJ,WAAW;EACpB;EAEA,OAAO,CAAC,CAAC;AACX;AAEA,eAAec,wBAAwBA,CACrCpG,IAAU,EACV2C,OAA8B,EAC9BxB,KAAa,EACbkF,YAAoB,EACpBC,WAAwB,EACF;EACtB,MAAM5G,GAAG,GAAG,IAAIC,GAAG,CAACgD,OAAO,CAACrD,WAAW,CAAC;EACxCI,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,SAAS,EAAE,gBAAgB,CAAC;EACjDH,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,WAAW,EAAEwG,YAAY,CAACvG,QAAQ,CAAC,CAAC,CAAC;EAC1DJ,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,YAAY,EAAEyG,WAAW,CAAC3C,UAAU,CAAE7D,QAAQ,CAAC,CAAC,CAAC;EACtEJ,GAAG,CAACE,YAAY,CAACC,GAAG,CAAC,WAAW,EAAEsB,KAAK,CAAC1B,MAAM,CAAC,QAAQ,CAAC,CAAC;EAEzDN,KAAK,CAAC,wCAAwCmH,WAAW,CAAC3C,UAAU,cAAcxC,KAAK,CAAC1B,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC;EAC5G,MAAM8G,IAAI,GAAG,MAAM,IAAApG,yBAAkB,EAAyBH,IAAI,EAAEN,GAAG,CAACI,QAAQ,CAAC,CAAC,CAAC;EACnF,IAAI,CAACyG,IAAI,EAAE;IACT,OAAOD,WAAW;EACpB;EAEA,MAAME,WAAW,GAAGpG,eAAC,CAACC,GAAG,CAACkG,IAAI,EAAE,2BAA2B,CAAC,IAAI,EAAE;EAClE,OAAO;IACL,GAAGD,WAAW;IACdG,QAAQ,EAAED,WAAW,CAACE,IAAI,CAAC;EAC7B,CAAC;AACH;AAEA,eAAeC,oBAAoBA,CACjC3G,IAAU,EACV2C,OAA8B,EAC9BiE,UAAoC,EACpCzF,KAAoB,EACe;EACnC,MAAMgE,QAA4C,GAAG,EAAE;EACvD,KAAK,MAAMK,OAAO,IAAIqB,MAAM,CAACC,MAAM,CAACF,UAAU,CAAC,EAAE;IAC/CzH,KAAK,CACH,uBAAuBqG,OAAO,CAAC3E,aAAa,SAAS2E,OAAO,CAAC9C,IAAI,CAACR,MAAM,eAAe,EACvFf,KAAK,CAAC1B,MAAM,CAAC,SAAS,CACxB,CAAC;IACD,MAAMiD,IAAmB,GAAG,EAAE;IAC9B,KAAK,MAAMqE,SAAS,IAAI3G,eAAC,CAAC4G,KAAK,CAACxB,OAAO,CAAC9C,IAAI,EAAE9D,UAAU,CAACE,uBAAuB,CAAC,EAAE;MACjFK,KAAK,CAAC,uBAAuB4H,SAAS,CAAC7E,MAAM,6BAA6BsD,OAAO,CAAC3E,aAAa,EAAE,CAAC;MAClG,MAAMoG,WAAW,GAAG,MAAMC,OAAO,CAACC,GAAG,CACnCJ,SAAS,CAACvG,GAAG,CAAC4G,CAAC,IAAIhB,wBAAwB,CAACpG,IAAI,EAAE2C,OAAO,EAAExB,KAAK,EAAEqE,OAAO,CAAC9E,KAAK,EAAE0G,CAAC,CAAC,CACrF,CAAC;MACD,MAAM,IAAAhC,cAAK,EAACxG,UAAU,CAACC,aAAa,CAAC;MACrC6D,IAAI,CAACmD,IAAI,CAAC,GAAGoB,WAAW,CAAC;IAC3B;IACA9B,QAAQ,CAACU,IAAI,CAAC;MAAE,GAAGL,OAAO;MAAE9C;IAAK,CAAC,CAAC;EACrC;EAEA,OAAOyC,QAAQ,CAACkC,MAAM,CAAC,CAACC,CAAC,EAAEC,CAAC,MAAM;IAAE,GAAGD,CAAC;IAAE,CAACC,CAAC,CAAC1G,aAAa,GAAG0G;EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AACxE;AAEA,eAAeC,mCAAmCA,CAChDC,cAA8B,EAC9BC,iBAA6C,EAC7C1H,IAAU,EACV2C,OAA8B,EAC9BgF,SAA0B,EACW;EACrC,IACE,CAACF,cAAc,CAACG,gCAAgC,IAChDH,cAAc,CAACI,aAAa,EAAE/F,QAAQ,CAAC,oDAAoD,CAAC,EAC5F;IACA,OAAO4F,iBAAiB;EAC1B;EACA,OAAO,IAAAI,kBAAS,EAACJ,iBAAiB,CAAClH,GAAG,CAAC,CAACuH,CAAC,EAAEC,CAAC,KAAK,MAAMrB,oBAAoB,CAAC3G,IAAI,EAAE2C,OAAO,EAAEoF,CAAC,EAAEJ,SAAS,CAACK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/G;AAEA,eAAeC,oBAAoBA,CACjCjI,IAAU,EACV2C,OAAuB,EACvBsC,qBAA4C,EAC5CC,WAAmB,EACnB;EACA,MAAMgD,oBAAoB,GAAGvF,OAAO,CAACuF,oBAAoB,IAAI,CAAC;EAC9D,MAAMP,SAAS,GAAG,IAAAQ,cAAkB,EAACjD,WAAW,EAAEgD,oBAAoB,CAAC;EACvE,MAAME,OAAmC,GAAG,MAAM,IAAAN,kBAAS,EACzDH,SAAS,CAACnH,GAAG,CAACjB,WAAW,IAAI,MAAM;IACjC,OAAOyF,iBAAiB,CAAChF,IAAI,EAAE2C,OAAO,EAAEsC,qBAAqB,EAAEC,WAAW,EAAE3F,WAAW,CAAC;EAC1F,CAAC,CACH,CAAC;EAED,MAAM8I,WAAW,GAAG,MAAMb,mCAAmC,CAC3D7E,OAAO,EACPyF,OAAO,EACPpI,IAAI,EACJiF,qBAAqB,EACrB0C,SACF,CAAC;EACD,MAAMW,YAA2C,GAAG,CAAC,CAAC;EAEtDD,WAAW,CAAC9C,OAAO,CAAC9B,MAAM,IAAI;IAC5BoD,MAAM,CAAC0B,IAAI,CAAC9E,MAAM,CAAC,CAAC8B,OAAO,CAAC1E,aAAa,IAAI;MAC3C,IAAI2H,cAAc,GAAGF,YAAY,CAACzH,aAAa,CAAC;MAChD,IAAI,CAAC2H,cAAc,EAAE;QACnBA,cAAc,GAAG,EAAE;QACnBF,YAAY,CAACzH,aAAa,CAAC,GAAG2H,cAAc;MAC9C;MACA,MAAMC,aAAa,GAAGhF,MAAM,CAAC5C,aAAa,CAAC,CAAC6B,IAAI;MAChD4F,YAAY,CAACzH,aAAa,CAAC,CAACgF,IAAI,CAAC,GAAG4C,aAAa,CAAC;IACpD,CAAC,CAAC;EACJ,CAAC,CAAC;EAEF,MAAMtD,QAAQ,GAAG0B,MAAM,CAAC0B,IAAI,CAACD,YAAY,CAAC,CAAC9H,GAAG,CAACK,aAAa,IAAI;IAC9D,OAAO;MACLA,aAAa;MACb6B,IAAI,EAAE4F,YAAY,CAACzH,aAAa;IAClC,CAAC;EACH,CAAC,CAAC;EAEF,OAAO;IACL6H,OAAO,EAAE,IAAI;IACbvD;EACF,CAAC;AACH;AAGA,MAAMwD,uBAAuB,SAASC,8CAAsB,CAA6B;EAOvFC,WAAWA,CAAClG,OAAuB,EAAEmG,OAAe,EAAEC,WAAmB,EAAE;IACzE,KAAK,CAACpG,OAAO,CAAC;IAEd,IAAI,CAACmG,OAAO,GAAGA,OAAO;IACtB,IAAI,CAACC,WAAW,GAAGA,WAAW;IAC9B,IAAI,CAACzJ,WAAW,GAAG,GAAGwJ,OAAO,oCAAoC;EACnE;EAEA,MAAME,KAAKA,CAACC,WAAuC,EAAkC;IACnF,MAAM,IAAI,CAACjJ,IAAI,CAACkJ,sBAAsB,CAAC,IAAI,CAAC;IAC5C,IAAI,CAAClJ,IAAI,CAACmJ,EAAE,CAAC,SAAS,EAAEC,OAAO,IAAI;MACjC,IAAIA,OAAO,CAAC1J,GAAG,CAAC,CAAC,CAACoC,QAAQ,CAAC,qBAAqB,CAAC,EAAE;QACjD3C,KAAK,CAAC,kEAAkE,CAAC;QACzE,KAAKiK,OAAO,CAACC,KAAK,CAACtH,SAAS,EAAEuH,+BAAsB,CAACD,KAAK,CAAC;MAC7D,CAAC,MAAM;QACL,KAAKD,OAAO,CAACG,QAAQ,CAACxH,SAAS,EAAEuH,+BAAsB,CAACC,QAAQ,CAAC;MACnE;IACF,CAAC,CAAC;IAEF,MAAM,IAAAC,8BAAqB,EAAC,IAAI,CAACxJ,IAAI,CAAC;IAEtC,MAAM,IAAI,CAACyJ,UAAU,CAAC,GAAG,IAAI,CAACX,OAAO,qBAAqB,CAAC;IAE3D,IAAI,CAACY,YAAY,CAACC,iCAAoB,CAACC,SAAS,CAAC;IAEjD,MAAMC,WAAW,GAAG,GAAG,IAAI,CAACvK,WAAW,yBAAyB;IAChE,MAAMwK,eAAe,GAAG;MACtBC,EAAE,EAAEd,WAAW,CAACc,EAAE;MAClBC,UAAU,EAAEf,WAAW,CAACgB,WAAW;MACnCC,WAAW,EAAEnL,YAAY;MACzBoL,MAAM,EAAEnL,OAAO;MACfoL,UAAU,EAAE,GAAG;MACfrB,WAAW,EAAE,IAAI,CAACA;IACpB,CAAC;IACD5J,KAAK,CAAC,kCAAkC,CAAC;IACzC,MAAMkL,cAAc,GAAG,MAAM,IAAAC,0BAAmB,EAAyB,IAAI,CAACtK,IAAI,EAAE6J,WAAW,EAAEC,eAAe,CAAC;IACjH,IACE,CAACO,cAAc,IACf,CAACA,cAAc,CAACE,MAAM,IACtBF,cAAc,CAACE,MAAM,CAACC,MAAM,KAAK,GAAG,IACpC,CAACH,cAAc,CAACI,kBAAkB,EAClC;MACA,MAAM,IAAIC,KAAK,CAAC,4BAA4B,CAAC;IAC/C;IAEA,MAAMC,kBAAkB,GAAGN,cAAc,CAACI,kBAAkB,CAACG,UAAU;IACvEzL,KAAK,CAAC,mCAAmCwL,kBAAkB,GAAG,CAAC;IAC/D,IAAIA,kBAAkB,KAAK,GAAG,EAAE;MAC9B,MAAM;QAAEE;MAAS,CAAC,GAAGR,cAAc,CAACI,kBAAkB;MAEtD,MAAMK,QAAQ,GAAG,GAAG,IAAI,CAACxL,WAAW,wBAAwB;MAC5D,MAAM8J,OAAO,GAAG;QACd2B,aAAa,EAAEF,QAAQ;QACvBG,WAAW,EAAE/B,WAAW,CAACc,EAAE;QAC3BkB,KAAK,EAAEhC,WAAW,CAACiC,QAAQ;QAC3BlB,UAAU,EAAEf,WAAW,CAACgB,WAAW;QACnCC,WAAW,EAAEnL,YAAY;QACzBoL,MAAM,EAAEnL;MACV,CAAC;MACDG,KAAK,CAAC,oBAAoB,CAAC;MAC3B,MAAMgM,WAAW,GAAG,MAAM,IAAAb,0BAAmB,EAAqB,IAAI,CAACtK,IAAI,EAAE8K,QAAQ,EAAE1B,OAAO,CAAC;MAC/FjK,KAAK,CAAC,2BAA2BgM,WAAW,EAAExG,MAAM,GAAG,EAAEwG,WAAW,CAAC;MAErE,IAAIA,WAAW,IAAIA,WAAW,CAACxG,MAAM,KAAK,GAAG,EAAE;QAC7C,IAAI,CAAC+E,YAAY,CAACC,iCAAoB,CAACyB,YAAY,CAAC;QACpD,OAAO;UAAE1C,OAAO,EAAE;QAAK,CAAC;MAC1B;MAEA,IAAIyC,WAAW,IAAIA,WAAW,CAACxG,MAAM,KAAK,GAAG,EAAE;QAC7C,IAAI,CAAC+E,YAAY,CAACC,iCAAoB,CAAC0B,cAAc,CAAC;QACtD,OAAO;UACL3C,OAAO,EAAE,KAAK;UACd4C,SAAS,EAAEC,yBAAiB,CAACF;QAC/B,CAAC;MACH;MAEA,IAAI,CAAC3B,YAAY,CAACC,iCAAoB,CAAC6B,WAAW,CAAC;MACnD,OAAO;QACL9C,OAAO,EAAE,KAAK;QACd4C,SAAS,EAAEC,yBAAiB,CAACE;MAC/B,CAAC;IACH;IAEA,IAAId,kBAAkB,KAAK,GAAG,EAAE;MAC9B,IAAI,CAACjB,YAAY,CAACC,iCAAoB,CAAC0B,cAAc,CAAC;MACtD,OAAO;QACL3C,OAAO,EAAE,KAAK;QACd4C,SAAS,EAAEC,yBAAiB,CAACF;MAC/B,CAAC;IACH;IAEA,IAAI,CAAC3B,YAAY,CAACC,iCAAoB,CAAC6B,WAAW,CAAC;IACnD,OAAO;MACL9C,OAAO,EAAE,KAAK;MACd4C,SAAS,EAAEC,yBAAiB,CAACE;IAC/B,CAAC;EACH;EAEA,MAAMC,SAASA,CAAA,EAAG;IAChB,MAAMC,kBAAkB,GAAG,IAAA3K,eAAM,EAAC,CAAC,CAAC4K,QAAQ,CAAC,CAAC,EAAE,OAAO,CAAC;IACxD,MAAMC,SAAS,GAAG,IAAI,CAAClJ,OAAO,CAACkJ,SAAS,IAAIF,kBAAkB,CAACG,MAAM,CAAC,CAAC;IACvE,MAAM5G,WAAW,GAAGlE,eAAM,CAAC+K,GAAG,CAACJ,kBAAkB,EAAE,IAAA3K,eAAM,EAAC6K,SAAS,CAAC,CAAC;IAErE,OAAO5D,oBAAoB,CACzB,IAAI,CAACjI,IAAI,EACT,IAAI,CAAC2C,OAAO,EACZ;MACErD,WAAW,EAAE,IAAI,CAACA,WAAW;MAC7ByJ,WAAW,EAAE,IAAI,CAACA;IACpB,CAAC,EACD7D,WACF,CAAC;EACH;AACF;AAAC,IAAA8G,QAAA,GAAAC,OAAA,CAAAtN,OAAA,GAEcgK,uBAAuB","ignoreList":[]}
@@ -39,7 +39,9 @@ declare class BaseScraperWithBrowser<TCredentials extends ScraperCredentials> ex
39
39
  private defaultViewportSize;
40
40
  protected page: Page;
41
41
  protected getViewPort(): {
42
- width: number;
42
+ width: number; /**
43
+ * For backward compatibility, we will close the browser even if we didn't create it
44
+ */
43
45
  height: number;
44
46
  };
45
47
  initialize(): Promise<void>;
@@ -16,10 +16,10 @@ const BASE_URL = 'https://www.behatsdaa.org.il';
16
16
  const LOGIN_URL = `${BASE_URL}/login`;
17
17
  const PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';
18
18
  const debug = (0, _debug.getDebug)('behatsdaa');
19
- function variantToTransaction(variant) {
19
+ function variantToTransaction(variant, options) {
20
20
  // The price is positive, make it negative as it's an expense
21
21
  const originalAmount = -variant.customerPrice;
22
- return {
22
+ const result = {
23
23
  type: _transactions.TransactionTypes.Normal,
24
24
  identifier: variant.tTransactionID,
25
25
  date: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
@@ -32,6 +32,10 @@ function variantToTransaction(variant) {
32
32
  status: _transactions.TransactionStatuses.Completed,
33
33
  memo: variant.variantName
34
34
  };
35
+ if (options?.includeRawTransaction) {
36
+ result.rawTransaction = variant;
37
+ }
38
+ return result;
35
39
  }
36
40
  class BehatsdaaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
37
41
  getLoginOptions(credentials) {
@@ -104,10 +108,10 @@ class BehatsdaaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
104
108
  success: true,
105
109
  accounts: [{
106
110
  accountNumber: res.data.memberId,
107
- txns: res.data.variants.map(variantToTransaction)
111
+ txns: res.data.variants.map(variant => variantToTransaction(variant, this.options))
108
112
  }]
109
113
  };
110
114
  }
111
115
  }
112
116
  var _default = exports.default = BehatsdaaScraper;
113
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_waiting","_transactions","_baseScraperWithBrowser","e","__esModule","default","BASE_URL","LOGIN_URL","PURCHASE_HISTORY_URL","debug","getDebug","variantToTransaction","variant","originalAmount","customerPrice","type","TransactionTypes","Normal","identifier","tTransactionID","date","moment","orderDate","format","processedDate","originalCurrency","chargedAmount","chargedCurrency","description","name","status","TransactionStatuses","Completed","memo","variantName","BehatsdaaScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","selector","value","id","password","checkReadiness","Promise","all","waitUntilElementFound","page","possibleResults","LoginResults","Success","InvalidPassword","submitButtonSelector","sleep","button","$","click","fetchData","token","evaluate","window","localStorage","getItem","success","errorMessage","body","FromDate","options","startDate","ToDate","BenefitStatusId","res","fetchPostWithinPage","authorization","organizationid","errorDescription","data","accounts","accountNumber","memberId","txns","variants","map","_default","exports"],"sources":["../../src/scrapers/behatsdaa.ts"],"sourcesContent":["import moment from 'moment';\nimport { getDebug } from '../helpers/debug';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { sleep } from '../helpers/waiting';\nimport { type Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, type LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult } from './interface';\n\nconst BASE_URL = 'https://www.behatsdaa.org.il';\nconst LOGIN_URL = `${BASE_URL}/login`;\nconst PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';\n\nconst debug = getDebug('behatsdaa');\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\ntype Variant = {\n  name: string;\n  variantName: string;\n  customerPrice: number;\n  orderDate: string; // ISO timestamp with no timezone\n  tTransactionID: string;\n};\n\ntype PurchaseHistoryResponse = {\n  data?: {\n    errorDescription?: string;\n    memberId: string;\n    variants: Variant[];\n  };\n  errorDescription?: string;\n};\n\nfunction variantToTransaction(variant: Variant): Transaction {\n  // The price is positive, make it negative as it's an expense\n  const originalAmount = -variant.customerPrice;\n  return {\n    type: TransactionTypes.Normal,\n    identifier: variant.tTransactionID,\n    date: moment(variant.orderDate).format('YYYY-MM-DD'),\n    processedDate: moment(variant.orderDate).format('YYYY-MM-DD'),\n    originalAmount,\n    originalCurrency: 'ILS',\n    chargedAmount: originalAmount,\n    chargedCurrency: 'ILS',\n    description: variant.name,\n    status: TransactionStatuses.Completed,\n    memo: variant.variantName,\n  };\n}\n\nclass BehatsdaaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  public getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: [\n        { selector: '#loginId', value: credentials.id },\n        { selector: '#loginPassword', value: credentials.password },\n      ],\n      checkReadiness: async () => {\n        await Promise.all([\n          waitUntilElementFound(this.page, '#loginPassword'),\n          waitUntilElementFound(this.page, '#loginId'),\n        ]);\n      },\n      possibleResults: {\n        [LoginResults.Success]: [`${BASE_URL}/`],\n        [LoginResults.InvalidPassword]: ['.custom-input-error-label'],\n      },\n      submitButtonSelector: async () => {\n        await sleep(1000);\n        debug('Trying to find submit button');\n        const button = await this.page.$('xpath=//button[contains(., \"התחברות\")]');\n        if (button) {\n          debug('Submit button found');\n          await button.click();\n        } else {\n          debug('Submit button not found');\n        }\n      },\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));\n    if (!token) {\n      debug('Token not found in local storage');\n      return {\n        success: false,\n        errorMessage: 'TokenNotFound',\n      };\n    }\n\n    const body = {\n      FromDate: moment(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),\n      ToDate: moment().format('YYYY-MM-DDTHH:mm:ss'),\n      BenefitStatusId: null,\n    };\n\n    debug('Fetching data');\n\n    const res = await fetchPostWithinPage<PurchaseHistoryResponse>(this.page, PURCHASE_HISTORY_URL, body, {\n      authorization: `Bearer ${token}`,\n      'Content-Type': 'application/json',\n      organizationid: '20',\n    });\n\n    debug('Data fetched');\n\n    if (res?.errorDescription || res?.data?.errorDescription) {\n      debug('Error fetching data', res.errorDescription || res.data?.errorDescription);\n      return { success: false, errorMessage: res.errorDescription };\n    }\n\n    if (!res?.data) {\n      debug('No data found');\n      return { success: false, errorMessage: 'NoData' };\n    }\n\n    debug('Data fetched successfully');\n    return {\n      success: true,\n      accounts: [\n        {\n          accountNumber: res.data.memberId,\n          txns: res.data.variants.map(variantToTransaction),\n        },\n      ],\n    };\n  }\n}\n\nexport default BehatsdaaScraper;\n"],"mappings":"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","ignoreList":[]}
117
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_waiting","_transactions","_baseScraperWithBrowser","e","__esModule","default","BASE_URL","LOGIN_URL","PURCHASE_HISTORY_URL","debug","getDebug","variantToTransaction","variant","options","originalAmount","customerPrice","result","type","TransactionTypes","Normal","identifier","tTransactionID","date","moment","orderDate","format","processedDate","originalCurrency","chargedAmount","chargedCurrency","description","name","status","TransactionStatuses","Completed","memo","variantName","includeRawTransaction","rawTransaction","BehatsdaaScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","selector","value","id","password","checkReadiness","Promise","all","waitUntilElementFound","page","possibleResults","LoginResults","Success","InvalidPassword","submitButtonSelector","sleep","button","$","click","fetchData","token","evaluate","window","localStorage","getItem","success","errorMessage","body","FromDate","startDate","ToDate","BenefitStatusId","res","fetchPostWithinPage","authorization","organizationid","errorDescription","data","accounts","accountNumber","memberId","txns","variants","map","_default","exports"],"sources":["../../src/scrapers/behatsdaa.ts"],"sourcesContent":["import moment from 'moment';\nimport { getDebug } from '../helpers/debug';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { sleep } from '../helpers/waiting';\nimport { type Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, type LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions, type ScraperScrapingResult } from './interface';\n\nconst BASE_URL = 'https://www.behatsdaa.org.il';\nconst LOGIN_URL = `${BASE_URL}/login`;\nconst PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';\n\nconst debug = getDebug('behatsdaa');\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\ntype Variant = {\n  name: string;\n  variantName: string;\n  customerPrice: number;\n  orderDate: string; // ISO timestamp with no timezone\n  tTransactionID: string;\n};\n\ntype PurchaseHistoryResponse = {\n  data?: {\n    errorDescription?: string;\n    memberId: string;\n    variants: Variant[];\n  };\n  errorDescription?: string;\n};\n\nfunction variantToTransaction(variant: Variant, options?: ScraperOptions): Transaction {\n  // The price is positive, make it negative as it's an expense\n  const originalAmount = -variant.customerPrice;\n  const result: Transaction = {\n    type: TransactionTypes.Normal,\n    identifier: variant.tTransactionID,\n    date: moment(variant.orderDate).format('YYYY-MM-DD'),\n    processedDate: moment(variant.orderDate).format('YYYY-MM-DD'),\n    originalAmount,\n    originalCurrency: 'ILS',\n    chargedAmount: originalAmount,\n    chargedCurrency: 'ILS',\n    description: variant.name,\n    status: TransactionStatuses.Completed,\n    memo: variant.variantName,\n  };\n\n  if (options?.includeRawTransaction) {\n    result.rawTransaction = variant;\n  }\n\n  return result;\n}\n\nclass BehatsdaaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  public getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: [\n        { selector: '#loginId', value: credentials.id },\n        { selector: '#loginPassword', value: credentials.password },\n      ],\n      checkReadiness: async () => {\n        await Promise.all([\n          waitUntilElementFound(this.page, '#loginPassword'),\n          waitUntilElementFound(this.page, '#loginId'),\n        ]);\n      },\n      possibleResults: {\n        [LoginResults.Success]: [`${BASE_URL}/`],\n        [LoginResults.InvalidPassword]: ['.custom-input-error-label'],\n      },\n      submitButtonSelector: async () => {\n        await sleep(1000);\n        debug('Trying to find submit button');\n        const button = await this.page.$('xpath=//button[contains(., \"התחברות\")]');\n        if (button) {\n          debug('Submit button found');\n          await button.click();\n        } else {\n          debug('Submit button not found');\n        }\n      },\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));\n    if (!token) {\n      debug('Token not found in local storage');\n      return {\n        success: false,\n        errorMessage: 'TokenNotFound',\n      };\n    }\n\n    const body = {\n      FromDate: moment(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),\n      ToDate: moment().format('YYYY-MM-DDTHH:mm:ss'),\n      BenefitStatusId: null,\n    };\n\n    debug('Fetching data');\n\n    const res = await fetchPostWithinPage<PurchaseHistoryResponse>(this.page, PURCHASE_HISTORY_URL, body, {\n      authorization: `Bearer ${token}`,\n      'Content-Type': 'application/json',\n      organizationid: '20',\n    });\n\n    debug('Data fetched');\n\n    if (res?.errorDescription || res?.data?.errorDescription) {\n      debug('Error fetching data', res.errorDescription || res.data?.errorDescription);\n      return { success: false, errorMessage: res.errorDescription };\n    }\n\n    if (!res?.data) {\n      debug('No data found');\n      return { success: false, errorMessage: 'NoData' };\n    }\n\n    debug('Data fetched successfully');\n    return {\n      success: true,\n      accounts: [\n        {\n          accountNumber: res.data.memberId,\n          txns: res.data.variants.map(variant => variantToTransaction(variant, this.options)),\n        },\n      ],\n    };\n  }\n}\n\nexport default BehatsdaaScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -40,7 +40,7 @@ function getAmountData(amountStr) {
40
40
  currency
41
41
  };
42
42
  }
43
- function convertTransactions(txns) {
43
+ function convertTransactions(txns, options) {
44
44
  debug(`convert ${txns.length} raw transactions to official Transaction structure`);
45
45
  return txns.map(txn => {
46
46
  const chargedAmountTuple = getAmountData(txn.chargedAmount || '');
@@ -58,6 +58,9 @@ function convertTransactions(txns) {
58
58
  memo: '',
59
59
  identifier: txn.identifier
60
60
  };
61
+ if (options?.includeRawTransaction) {
62
+ result.rawTransaction = txn;
63
+ }
61
64
  return result;
62
65
  });
63
66
  }
@@ -90,7 +93,7 @@ async function fetchTransactions(page, options) {
90
93
  });
91
94
  });
92
95
  debug(`fetched ${rawTransactions.length} raw transactions from page`);
93
- const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item));
96
+ const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item), options);
94
97
  debug('filer out old transactions');
95
98
  const txns = options.outputData?.enableTransactionsFilterByDate ?? true ? (0, _transactions.filterOldTransactions)(accountTransactions, startMoment, false) : accountTransactions;
96
99
  debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);
@@ -146,4 +149,4 @@ class BeyahadBishvilhaScraper extends _baseScraperWithBrowser.BaseScraperWithBro
146
149
  }
147
150
  }
148
151
  var _default = exports.default = BeyahadBishvilhaScraper;
149
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_debug","_elementsInteractions","_transactions","_transactions2","_baseScraperWithBrowser","e","__esModule","default","debug","getDebug","DATE_FORMAT","LOGIN_URL","SUCCESS_URL","CARD_URL","getAmountData","amountStr","amountStrCln","replace","currency","amount","includes","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","convertTransactions","txns","length","map","txn","chargedAmountTuple","chargedAmount","txnProcessedDate","moment","date","result","type","TransactionTypes","Normal","status","TransactionStatuses","Completed","toISOString","processedDate","originalAmount","originalCurrency","chargedCurrency","description","memo","identifier","fetchTransactions","page","options","goto","waitUntilElementFound","defaultStartMoment","subtract","startDate","toDate","startMoment","max","accountNumber","pageEval","element","innerText","balance","rawTransactions","pageEvalAll","items","el","columns","querySelectorAll","accountTransactions","filter","item","outputData","enableTransactionsFilterByDate","filterOldTransactions","substring","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","id","password","BeyahadBishvilhaScraper","BaseScraperWithBrowser","getViewPort","width","height","getLoginOptions","loginUrl","fields","submitButtonSelector","button","$","click","possibleResults","fetchData","account","success","accounts","_default","exports"],"sources":["../../src/scrapers/beyahad-bishvilha.ts"],"sourcesContent":["import moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport {\n  DOLLAR_CURRENCY,\n  DOLLAR_CURRENCY_SYMBOL,\n  EURO_CURRENCY,\n  EURO_CURRENCY_SYMBOL,\n  SHEKEL_CURRENCY,\n  SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { getDebug } from '../helpers/debug';\nimport { pageEval, pageEvalAll, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { TransactionStatuses, TransactionTypes, type Transaction } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions } from './interface';\n\nconst debug = getDebug('beyahadBishvilha');\n\nconst DATE_FORMAT = 'DD/MM/YY';\nconst LOGIN_URL = 'https://www.hist.org.il/login';\nconst SUCCESS_URL = 'https://www.hist.org.il/';\nconst CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';\n\ninterface ScrapedTransaction {\n  date: string;\n  description: string;\n  type: string;\n  chargedAmount: string;\n  identifier: string;\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCln = amountStr.replace(',', '');\n  let currency: string | null = null;\n  let amount: number | null = null;\n  if (amountStrCln.includes(SHEKEL_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(SHEKEL_CURRENCY_SYMBOL, ''));\n    currency = SHEKEL_CURRENCY;\n  } else if (amountStrCln.includes(DOLLAR_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(DOLLAR_CURRENCY_SYMBOL, ''));\n    currency = DOLLAR_CURRENCY;\n  } else if (amountStrCln.includes(EURO_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(EURO_CURRENCY_SYMBOL, ''));\n    currency = EURO_CURRENCY;\n  } else {\n    const parts = amountStrCln.split(' ');\n    [currency] = parts;\n    amount = parseFloat(parts[1]);\n  }\n\n  return {\n    amount,\n    currency,\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  debug(`convert ${txns.length} raw transactions to official Transaction structure`);\n  return txns.map(txn => {\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n    const txnProcessedDate = moment(txn.date, DATE_FORMAT);\n\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: txnProcessedDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: chargedAmountTuple.amount,\n      originalCurrency: chargedAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: '',\n      identifier: txn.identifier,\n    };\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  await page.goto(CARD_URL);\n  await waitUntilElementFound(page, '.react-loading.hide', false);\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const accountNumber = await pageEval(page, '.wallet-details div:nth-of-type(2)', null, element => {\n    return (element as any).innerText.replace('מספר כרטיס ', '');\n  });\n\n  const balance = await pageEval(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {\n    return (element as any).innerText;\n  });\n\n  debug('fetch raw transactions from page');\n\n  const rawTransactions: (ScrapedTransaction | null)[] = await pageEvalAll<(ScrapedTransaction | null)[]>(\n    page,\n    '.transaction-container, .transaction-component-container',\n    [],\n    items => {\n      return items.map(el => {\n        const columns: NodeListOf<HTMLSpanElement> = el.querySelectorAll('.transaction-item > span');\n        if (columns.length === 7) {\n          return {\n            date: columns[0].innerText,\n            identifier: columns[1].innerText,\n            description: columns[3].innerText,\n            type: columns[5].innerText,\n            chargedAmount: columns[6].innerText,\n          };\n        }\n        return null;\n      });\n    },\n  );\n  debug(`fetched ${rawTransactions.length} raw transactions from page`);\n\n  const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item) as ScrapedTransaction[]);\n\n  debug('filer out old transactions');\n  const txns =\n    (options.outputData?.enableTransactionsFilterByDate ?? true)\n      ? filterOldTransactions(accountTransactions, startMoment, false)\n      : accountTransactions;\n  debug(\n    `found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`,\n  );\n\n  return {\n    accountNumber,\n    balance: getAmountData(balance).amount,\n    txns,\n  };\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = []; // TODO\n  urls[LoginResults.InvalidPassword] = []; // TODO\n  urls[LoginResults.UnknownError] = []; // TODO\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#loginId', value: credentials.id },\n    { selector: '#loginPassword', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\nclass BeyahadBishvilhaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  protected getViewPort(): { width: number; height: number } {\n    return {\n      width: 1500,\n      height: 800,\n    };\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: async () => {\n        const button = await this.page.$('xpath//button[contains(., \"התחבר\")]');\n        if (button) {\n          await button.click();\n        }\n      },\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    const account = await fetchTransactions(this.page, this.options);\n    return {\n      success: true,\n      accounts: [account],\n    };\n  }\n}\n\nexport default BeyahadBishvilhaScraper;\n"],"mappings":"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","ignoreList":[]}
152
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_constants","_debug","_elementsInteractions","_transactions","_transactions2","_baseScraperWithBrowser","e","__esModule","default","debug","getDebug","DATE_FORMAT","LOGIN_URL","SUCCESS_URL","CARD_URL","getAmountData","amountStr","amountStrCln","replace","currency","amount","includes","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","convertTransactions","txns","options","length","map","txn","chargedAmountTuple","chargedAmount","txnProcessedDate","moment","date","result","type","TransactionTypes","Normal","status","TransactionStatuses","Completed","toISOString","processedDate","originalAmount","originalCurrency","chargedCurrency","description","memo","identifier","includeRawTransaction","rawTransaction","fetchTransactions","page","goto","waitUntilElementFound","defaultStartMoment","subtract","startDate","toDate","startMoment","max","accountNumber","pageEval","element","innerText","balance","rawTransactions","pageEvalAll","items","el","columns","querySelectorAll","accountTransactions","filter","item","outputData","enableTransactionsFilterByDate","filterOldTransactions","substring","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","id","password","BeyahadBishvilhaScraper","BaseScraperWithBrowser","getViewPort","width","height","getLoginOptions","loginUrl","fields","submitButtonSelector","button","$","click","possibleResults","fetchData","account","success","accounts","_default","exports"],"sources":["../../src/scrapers/beyahad-bishvilha.ts"],"sourcesContent":["import moment from 'moment';\nimport { type Page } from 'puppeteer';\nimport {\n  DOLLAR_CURRENCY,\n  DOLLAR_CURRENCY_SYMBOL,\n  EURO_CURRENCY,\n  EURO_CURRENCY_SYMBOL,\n  SHEKEL_CURRENCY,\n  SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { getDebug } from '../helpers/debug';\nimport { pageEval, pageEvalAll, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { TransactionStatuses, TransactionTypes, type Transaction } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type PossibleLoginResults } from './base-scraper-with-browser';\nimport { type ScraperOptions } from './interface';\n\nconst debug = getDebug('beyahadBishvilha');\n\nconst DATE_FORMAT = 'DD/MM/YY';\nconst LOGIN_URL = 'https://www.hist.org.il/login';\nconst SUCCESS_URL = 'https://www.hist.org.il/';\nconst CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';\n\ninterface ScrapedTransaction {\n  date: string;\n  description: string;\n  type: string;\n  chargedAmount: string;\n  identifier: string;\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCln = amountStr.replace(',', '');\n  let currency: string | null = null;\n  let amount: number | null = null;\n  if (amountStrCln.includes(SHEKEL_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(SHEKEL_CURRENCY_SYMBOL, ''));\n    currency = SHEKEL_CURRENCY;\n  } else if (amountStrCln.includes(DOLLAR_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(DOLLAR_CURRENCY_SYMBOL, ''));\n    currency = DOLLAR_CURRENCY;\n  } else if (amountStrCln.includes(EURO_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(EURO_CURRENCY_SYMBOL, ''));\n    currency = EURO_CURRENCY;\n  } else {\n    const parts = amountStrCln.split(' ');\n    [currency] = parts;\n    amount = parseFloat(parts[1]);\n  }\n\n  return {\n    amount,\n    currency,\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], options?: ScraperOptions): Transaction[] {\n  debug(`convert ${txns.length} raw transactions to official Transaction structure`);\n  return txns.map(txn => {\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n    const txnProcessedDate = moment(txn.date, DATE_FORMAT);\n\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: txnProcessedDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: chargedAmountTuple.amount,\n      originalCurrency: chargedAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: '',\n      identifier: txn.identifier,\n    };\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = txn;\n    }\n\n    return result;\n  });\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  await page.goto(CARD_URL);\n  await waitUntilElementFound(page, '.react-loading.hide', false);\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const accountNumber = await pageEval(page, '.wallet-details div:nth-of-type(2)', null, element => {\n    return (element as any).innerText.replace('מספר כרטיס ', '');\n  });\n\n  const balance = await pageEval(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {\n    return (element as any).innerText;\n  });\n\n  debug('fetch raw transactions from page');\n\n  const rawTransactions: (ScrapedTransaction | null)[] = await pageEvalAll<(ScrapedTransaction | null)[]>(\n    page,\n    '.transaction-container, .transaction-component-container',\n    [],\n    items => {\n      return items.map(el => {\n        const columns: NodeListOf<HTMLSpanElement> = el.querySelectorAll('.transaction-item > span');\n        if (columns.length === 7) {\n          return {\n            date: columns[0].innerText,\n            identifier: columns[1].innerText,\n            description: columns[3].innerText,\n            type: columns[5].innerText,\n            chargedAmount: columns[6].innerText,\n          };\n        }\n        return null;\n      });\n    },\n  );\n  debug(`fetched ${rawTransactions.length} raw transactions from page`);\n\n  const accountTransactions = convertTransactions(\n    rawTransactions.filter(item => !!item) as ScrapedTransaction[],\n    options,\n  );\n\n  debug('filer out old transactions');\n  const txns =\n    (options.outputData?.enableTransactionsFilterByDate ?? true)\n      ? filterOldTransactions(accountTransactions, startMoment, false)\n      : accountTransactions;\n  debug(\n    `found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`,\n  );\n\n  return {\n    accountNumber,\n    balance: getAmountData(balance).amount,\n    txns,\n  };\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = []; // TODO\n  urls[LoginResults.InvalidPassword] = []; // TODO\n  urls[LoginResults.UnknownError] = []; // TODO\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#loginId', value: credentials.id },\n    { selector: '#loginPassword', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\nclass BeyahadBishvilhaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  protected getViewPort(): { width: number; height: number } {\n    return {\n      width: 1500,\n      height: 800,\n    };\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: async () => {\n        const button = await this.page.$('xpath//button[contains(., \"התחבר\")]');\n        if (button) {\n          await button.click();\n        }\n      },\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    const account = await fetchTransactions(this.page, this.options);\n    return {\n      success: true,\n      accounts: [account],\n    };\n  }\n}\n\nexport default BeyahadBishvilhaScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -15,12 +15,12 @@ var _errors = require("./errors");
15
15
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
16
16
  const BASE_URL = 'https://start.telebank.co.il';
17
17
  const DATE_FORMAT = 'YYYYMMDD';
18
- function convertTransactions(txns, txnStatus) {
18
+ function convertTransactions(txns, txnStatus, options) {
19
19
  if (!txns) {
20
20
  return [];
21
21
  }
22
22
  return txns.map(txn => {
23
- return {
23
+ const result = {
24
24
  type: _transactions.TransactionTypes.Normal,
25
25
  identifier: txn.OperationNumber,
26
26
  date: (0, _moment.default)(txn.OperationDate, DATE_FORMAT).toISOString(),
@@ -31,6 +31,10 @@ function convertTransactions(txns, txnStatus) {
31
31
  description: txn.OperationDescriptionToDisplay,
32
32
  status: txnStatus
33
33
  };
34
+ if (options?.includeRawTransaction) {
35
+ result.rawTransaction = txn;
36
+ }
37
+ return result;
34
38
  });
35
39
  }
36
40
  async function fetchAccountData(page, options) {
@@ -60,9 +64,9 @@ async function fetchAccountData(page, options) {
60
64
  errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error'
61
65
  };
62
66
  }
63
- const accountCompletedTxns = convertTransactions(txnsResult.CurrentAccountLastTransactions.OperationEntry, _transactions.TransactionStatuses.Completed);
67
+ const accountCompletedTxns = convertTransactions(txnsResult.CurrentAccountLastTransactions.OperationEntry, _transactions.TransactionStatuses.Completed, options);
64
68
  const rawFutureTxns = _lodash.default.get(txnsResult, 'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry');
65
- const accountPendingTxns = convertTransactions(rawFutureTxns, _transactions.TransactionStatuses.Pending);
69
+ const accountPendingTxns = convertTransactions(rawFutureTxns, _transactions.TransactionStatuses.Pending, options);
66
70
  accountsData.push({
67
71
  accountNumber,
68
72
  balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,
@@ -117,4 +121,4 @@ class DiscountScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
117
121
  }
118
122
  }
119
123
  var _default = exports.default = DiscountScraper;
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    `${BASE_URL}/apollo/retail2/`,\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":[]}
124
+ //# 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","options","map","txn","result","type","TransactionTypes","Normal","identifier","OperationNumber","date","moment","OperationDate","toISOString","processedDate","ValueDate","originalAmount","OperationAmount","originalCurrency","chargedAmount","description","OperationDescriptionToDisplay","status","includeRawTransaction","rawTransaction","fetchAccountData","page","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(\n  txns: ScrapedTransaction[],\n  txnStatus: TransactionStatuses,\n  options?: ScraperOptions,\n): Transaction[] {\n  if (!txns) {\n    return [];\n  }\n  return txns.map(txn => {\n    const result: Transaction = {\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    if (options?.includeRawTransaction) {\n      result.rawTransaction = txn;\n    }\n\n    return result;\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      options,\n    );\n    const rawFutureTxns = _.get(\n      txnsResult,\n      'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry',\n    ) as ScrapedTransaction[];\n    const accountPendingTxns = convertTransactions(rawFutureTxns, TransactionStatuses.Pending, options);\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    `${BASE_URL}/apollo/retail2/`,\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":[]}