israeli-bank-scrapers 6.5.0 → 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.
package/lib/helpers/fetch.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { type Page } from 'puppeteer';
|
|
2
2
|
export declare function fetchGet<TResult>(url: string, extraHeaders: Record<string, any>): Promise<TResult>;
|
|
3
|
-
export declare function fetchPost(url: string, data: Record<string, any>, extraHeaders?: Record<string, any>): Promise<
|
|
3
|
+
export declare function fetchPost<TResult = any>(url: string, data: Record<string, any>, extraHeaders?: Record<string, any>): Promise<TResult>;
|
|
4
4
|
export declare function fetchGraphql<TResult>(url: string, query: string, variables?: Record<string, unknown>, extraHeaders?: Record<string, any>): Promise<TResult>;
|
|
5
5
|
export declare function fetchGetWithinPage<TResult>(page: Page, url: string, ignoreErrors?: boolean): Promise<TResult | null>;
|
|
6
6
|
export declare function fetchPostWithinPage<TResult>(page: Page, url: string, data: Record<string, any>, extraHeaders?: Record<string, any>, ignoreErrors?: boolean): Promise<TResult | null>;
|
package/lib/helpers/fetch.js
CHANGED
|
@@ -108,4 +108,4 @@ async function fetchPostWithinPage(page, url, data, extraHeaders = {}, ignoreErr
|
|
|
108
108
|
}
|
|
109
109
|
return null;
|
|
110
110
|
}
|
|
111
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_nodeFetch","_interopRequireDefault","require","e","__esModule","default","JSON_CONTENT_TYPE","getJsonHeaders","Accept","fetchGet","url","extraHeaders","headers","Object","assign","request","method","fetchResult","nodeFetch","status","Error","json","fetchPost","data","body","JSON","stringify","result","fetchGraphql","query","variables","operationName","errors","length","message","fetchGetWithinPage","page","ignoreErrors","evaluate","innerUrl","response","fetch","credentials","text","stack","String","parse","fetchPostWithinPage","innerData","innerExtraHeaders"],"sources":["../../src/helpers/fetch.ts"],"sourcesContent":["import nodeFetch from 'node-fetch';\nimport { type Page } from 'puppeteer';\n\nconst JSON_CONTENT_TYPE = 'application/json';\n\nfunction getJsonHeaders() {\n  return {\n    Accept: JSON_CONTENT_TYPE,\n    'Content-Type': JSON_CONTENT_TYPE,\n  };\n}\n\nexport async function fetchGet<TResult>(url: string, extraHeaders: Record<string, any>): Promise<TResult> {\n  let headers = getJsonHeaders();\n  if (extraHeaders) {\n    headers = Object.assign(headers, extraHeaders);\n  }\n  const request = {\n    method: 'GET',\n    headers,\n  };\n  const fetchResult = await nodeFetch(url, request);\n\n  if (fetchResult.status !== 200) {\n    throw new Error(`sending a request to the institute server returned with status code ${fetchResult.status}`);\n  }\n\n  return fetchResult.json();\n}\n\nexport async function fetchPost(url: string, data: Record<string, any>, extraHeaders: Record<string, any> = {}) {\n  const request = {\n    method: 'POST',\n    headers: { ...getJsonHeaders(), ...extraHeaders },\n    body: JSON.stringify(data),\n  };\n  const result = await nodeFetch(url, request);\n  return result.json();\n}\n\nexport async function fetchGraphql<TResult>(\n  url: string,\n  query: string,\n  variables: Record<string, unknown> = {},\n  extraHeaders: Record<string, any> = {},\n): Promise<TResult> {\n  const result = await fetchPost(url, { operationName: null, query, variables }, extraHeaders);\n  if (result.errors?.length) {\n    throw new Error(result.errors[0].message);\n  }\n  return result.data as Promise<TResult>;\n}\n\nexport async function fetchGetWithinPage<TResult>(\n  page: Page,\n  url: string,\n  ignoreErrors = false,\n): Promise<TResult | null> {\n  const [result, status] = await page.evaluate(async innerUrl => {\n    let response: Response | undefined;\n    try {\n      response = await fetch(innerUrl, { credentials: 'include' });\n      if (response.status === 204) {\n        return [null, response.status] as const;\n      }\n      return [await response.text(), response.status] as const;\n    } catch (e) {\n      throw new Error(\n        `fetchGetWithinPage error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${innerUrl}, status: ${response?.status}`,\n      );\n    }\n  }, url);\n  if (result !== null) {\n    try {\n      return JSON.parse(result);\n    } catch (e) {\n      if (!ignoreErrors) {\n        throw new Error(\n          `fetchGetWithinPage parse error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${url}, result: ${result}, status: ${status}`,\n        );\n      }\n    }\n  }\n  return null;\n}\n\nexport async function fetchPostWithinPage<TResult>(\n  page: Page,\n  url: string,\n  data: Record<string, any>,\n  extraHeaders: Record<string, any> = {},\n  ignoreErrors = false,\n): Promise<TResult | null> {\n  const result = await page.evaluate(\n    async (innerUrl: string, innerData: Record<string, any>, innerExtraHeaders: Record<string, any>) => {\n      const response = await fetch(innerUrl, {\n        method: 'POST',\n        body: JSON.stringify(innerData),\n        credentials: 'include',\n        // eslint-disable-next-line prefer-object-spread\n        headers: Object.assign(\n          { 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8' },\n          innerExtraHeaders,\n        ),\n      });\n      if (response.status === 204) {\n        return null;\n      }\n      return response.text();\n    },\n    url,\n    data,\n    extraHeaders,\n  );\n\n  try {\n    if (result !== null) {\n      return JSON.parse(result);\n    }\n  } catch (e) {\n    if (!ignoreErrors) {\n      throw new Error(\n        `fetchPostWithinPage parse error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${url}, data: ${JSON.stringify(data)}, extraHeaders: ${JSON.stringify(extraHeaders)}, result: ${result}`,\n      );\n    }\n  }\n  return null;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_nodeFetch","_interopRequireDefault","require","e","__esModule","default","JSON_CONTENT_TYPE","getJsonHeaders","Accept","fetchGet","url","extraHeaders","headers","Object","assign","request","method","fetchResult","nodeFetch","status","Error","json","fetchPost","data","body","JSON","stringify","result","fetchGraphql","query","variables","operationName","errors","length","message","fetchGetWithinPage","page","ignoreErrors","evaluate","innerUrl","response","fetch","credentials","text","stack","String","parse","fetchPostWithinPage","innerData","innerExtraHeaders"],"sources":["../../src/helpers/fetch.ts"],"sourcesContent":["import nodeFetch from 'node-fetch';\nimport { type Page } from 'puppeteer';\n\nconst JSON_CONTENT_TYPE = 'application/json';\n\nfunction getJsonHeaders() {\n  return {\n    Accept: JSON_CONTENT_TYPE,\n    'Content-Type': JSON_CONTENT_TYPE,\n  };\n}\n\nexport async function fetchGet<TResult>(url: string, extraHeaders: Record<string, any>): Promise<TResult> {\n  let headers = getJsonHeaders();\n  if (extraHeaders) {\n    headers = Object.assign(headers, extraHeaders);\n  }\n  const request = {\n    method: 'GET',\n    headers,\n  };\n  const fetchResult = await nodeFetch(url, request);\n\n  if (fetchResult.status !== 200) {\n    throw new Error(`sending a request to the institute server returned with status code ${fetchResult.status}`);\n  }\n\n  return fetchResult.json();\n}\n\nexport async function fetchPost<TResult = any>(\n  url: string,\n  data: Record<string, any>,\n  extraHeaders: Record<string, any> = {},\n): Promise<TResult> {\n  const request = {\n    method: 'POST',\n    headers: { ...getJsonHeaders(), ...extraHeaders },\n    body: JSON.stringify(data),\n  };\n  const result = await nodeFetch(url, request);\n  return result.json();\n}\n\nexport async function fetchGraphql<TResult>(\n  url: string,\n  query: string,\n  variables: Record<string, unknown> = {},\n  extraHeaders: Record<string, any> = {},\n): Promise<TResult> {\n  const result = await fetchPost(url, { operationName: null, query, variables }, extraHeaders);\n  if (result.errors?.length) {\n    throw new Error(result.errors[0].message);\n  }\n  return result.data as Promise<TResult>;\n}\n\nexport async function fetchGetWithinPage<TResult>(\n  page: Page,\n  url: string,\n  ignoreErrors = false,\n): Promise<TResult | null> {\n  const [result, status] = await page.evaluate(async innerUrl => {\n    let response: Response | undefined;\n    try {\n      response = await fetch(innerUrl, { credentials: 'include' });\n      if (response.status === 204) {\n        return [null, response.status] as const;\n      }\n      return [await response.text(), response.status] as const;\n    } catch (e) {\n      throw new Error(\n        `fetchGetWithinPage error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${innerUrl}, status: ${response?.status}`,\n      );\n    }\n  }, url);\n  if (result !== null) {\n    try {\n      return JSON.parse(result);\n    } catch (e) {\n      if (!ignoreErrors) {\n        throw new Error(\n          `fetchGetWithinPage parse error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${url}, result: ${result}, status: ${status}`,\n        );\n      }\n    }\n  }\n  return null;\n}\n\nexport async function fetchPostWithinPage<TResult>(\n  page: Page,\n  url: string,\n  data: Record<string, any>,\n  extraHeaders: Record<string, any> = {},\n  ignoreErrors = false,\n): Promise<TResult | null> {\n  const result = await page.evaluate(\n    async (innerUrl: string, innerData: Record<string, any>, innerExtraHeaders: Record<string, any>) => {\n      const response = await fetch(innerUrl, {\n        method: 'POST',\n        body: JSON.stringify(innerData),\n        credentials: 'include',\n        // eslint-disable-next-line prefer-object-spread\n        headers: Object.assign(\n          { 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8' },\n          innerExtraHeaders,\n        ),\n      });\n      if (response.status === 204) {\n        return null;\n      }\n      return response.text();\n    },\n    url,\n    data,\n    extraHeaders,\n  );\n\n  try {\n    if (result !== null) {\n      return JSON.parse(result);\n    }\n  } catch (e) {\n    if (!ignoreErrors) {\n      throw new Error(\n        `fetchPostWithinPage parse error: ${e instanceof Error ? `${e.message}\\n${e.stack}` : String(e)}, url: ${url}, data: ${JSON.stringify(data)}, extraHeaders: ${JSON.stringify(extraHeaders)}, result: ${result}`,\n      );\n    }\n  }\n  return null;\n}\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,UAAA,GAAAC,sBAAA,CAAAC,OAAA;AAAmC,SAAAD,uBAAAE,CAAA,WAAAA,CAAA,IAAAA,CAAA,CAAAC,UAAA,GAAAD,CAAA,KAAAE,OAAA,EAAAF,CAAA;AAGnC,MAAMG,iBAAiB,GAAG,kBAAkB;AAE5C,SAASC,cAAcA,CAAA,EAAG;EACxB,OAAO;IACLC,MAAM,EAAEF,iBAAiB;IACzB,cAAc,EAAEA;EAClB,CAAC;AACH;AAEO,eAAeG,QAAQA,CAAUC,GAAW,EAAEC,YAAiC,EAAoB;EACxG,IAAIC,OAAO,GAAGL,cAAc,CAAC,CAAC;EAC9B,IAAII,YAAY,EAAE;IAChBC,OAAO,GAAGC,MAAM,CAACC,MAAM,CAACF,OAAO,EAAED,YAAY,CAAC;EAChD;EACA,MAAMI,OAAO,GAAG;IACdC,MAAM,EAAE,KAAK;IACbJ;EACF,CAAC;EACD,MAAMK,WAAW,GAAG,MAAM,IAAAC,kBAAS,EAACR,GAAG,EAAEK,OAAO,CAAC;EAEjD,IAAIE,WAAW,CAACE,MAAM,KAAK,GAAG,EAAE;IAC9B,MAAM,IAAIC,KAAK,CAAC,uEAAuEH,WAAW,CAACE,MAAM,EAAE,CAAC;EAC9G;EAEA,OAAOF,WAAW,CAACI,IAAI,CAAC,CAAC;AAC3B;AAEO,eAAeC,SAASA,CAC7BZ,GAAW,EACXa,IAAyB,EACzBZ,YAAiC,GAAG,CAAC,CAAC,EACpB;EAClB,MAAMI,OAAO,GAAG;IACdC,MAAM,EAAE,MAAM;IACdJ,OAAO,EAAE;MAAE,GAAGL,cAAc,CAAC,CAAC;MAAE,GAAGI;IAAa,CAAC;IACjDa,IAAI,EAAEC,IAAI,CAACC,SAAS,CAACH,IAAI;EAC3B,CAAC;EACD,MAAMI,MAAM,GAAG,MAAM,IAAAT,kBAAS,EAACR,GAAG,EAAEK,OAAO,CAAC;EAC5C,OAAOY,MAAM,CAACN,IAAI,CAAC,CAAC;AACtB;AAEO,eAAeO,YAAYA,CAChClB,GAAW,EACXmB,KAAa,EACbC,SAAkC,GAAG,CAAC,CAAC,EACvCnB,YAAiC,GAAG,CAAC,CAAC,EACpB;EAClB,MAAMgB,MAAM,GAAG,MAAML,SAAS,CAACZ,GAAG,EAAE;IAAEqB,aAAa,EAAE,IAAI;IAAEF,KAAK;IAAEC;EAAU,CAAC,EAAEnB,YAAY,CAAC;EAC5F,IAAIgB,MAAM,CAACK,MAAM,EAAEC,MAAM,EAAE;IACzB,MAAM,IAAIb,KAAK,CAACO,MAAM,CAACK,MAAM,CAAC,CAAC,CAAC,CAACE,OAAO,CAAC;EAC3C;EACA,OAAOP,MAAM,CAACJ,IAAI;AACpB;AAEO,eAAeY,kBAAkBA,CACtCC,IAAU,EACV1B,GAAW,EACX2B,YAAY,GAAG,KAAK,EACK;EACzB,MAAM,CAACV,MAAM,EAAER,MAAM,CAAC,GAAG,MAAMiB,IAAI,CAACE,QAAQ,CAAC,MAAMC,QAAQ,IAAI;IAC7D,IAAIC,QAA8B;IAClC,IAAI;MACFA,QAAQ,GAAG,MAAMC,KAAK,CAACF,QAAQ,EAAE;QAAEG,WAAW,EAAE;MAAU,CAAC,CAAC;MAC5D,IAAIF,QAAQ,CAACrB,MAAM,KAAK,GAAG,EAAE;QAC3B,OAAO,CAAC,IAAI,EAAEqB,QAAQ,CAACrB,MAAM,CAAC;MAChC;MACA,OAAO,CAAC,MAAMqB,QAAQ,CAACG,IAAI,CAAC,CAAC,EAAEH,QAAQ,CAACrB,MAAM,CAAC;IACjD,CAAC,CAAC,OAAOhB,CAAC,EAAE;MACV,MAAM,IAAIiB,KAAK,CACb,6BAA6BjB,CAAC,YAAYiB,KAAK,GAAG,GAAGjB,CAAC,CAAC+B,OAAO,KAAK/B,CAAC,CAACyC,KAAK,EAAE,GAAGC,MAAM,CAAC1C,CAAC,CAAC,UAAUoC,QAAQ,aAAaC,QAAQ,EAAErB,MAAM,EACzI,CAAC;IACH;EACF,CAAC,EAAET,GAAG,CAAC;EACP,IAAIiB,MAAM,KAAK,IAAI,EAAE;IACnB,IAAI;MACF,OAAOF,IAAI,CAACqB,KAAK,CAACnB,MAAM,CAAC;IAC3B,CAAC,CAAC,OAAOxB,CAAC,EAAE;MACV,IAAI,CAACkC,YAAY,EAAE;QACjB,MAAM,IAAIjB,KAAK,CACb,mCAAmCjB,CAAC,YAAYiB,KAAK,GAAG,GAAGjB,CAAC,CAAC+B,OAAO,KAAK/B,CAAC,CAACyC,KAAK,EAAE,GAAGC,MAAM,CAAC1C,CAAC,CAAC,UAAUO,GAAG,aAAaiB,MAAM,aAAaR,MAAM,EACnJ,CAAC;MACH;IACF;EACF;EACA,OAAO,IAAI;AACb;AAEO,eAAe4B,mBAAmBA,CACvCX,IAAU,EACV1B,GAAW,EACXa,IAAyB,EACzBZ,YAAiC,GAAG,CAAC,CAAC,EACtC0B,YAAY,GAAG,KAAK,EACK;EACzB,MAAMV,MAAM,GAAG,MAAMS,IAAI,CAACE,QAAQ,CAChC,OAAOC,QAAgB,EAAES,SAA8B,EAAEC,iBAAsC,KAAK;IAClG,MAAMT,QAAQ,GAAG,MAAMC,KAAK,CAACF,QAAQ,EAAE;MACrCvB,MAAM,EAAE,MAAM;MACdQ,IAAI,EAAEC,IAAI,CAACC,SAAS,CAACsB,SAAS,CAAC;MAC/BN,WAAW,EAAE,SAAS;MACtB;MACA9B,OAAO,EAAEC,MAAM,CAACC,MAAM,CACpB;QAAE,cAAc,EAAE;MAAmD,CAAC,EACtEmC,iBACF;IACF,CAAC,CAAC;IACF,IAAIT,QAAQ,CAACrB,MAAM,KAAK,GAAG,EAAE;MAC3B,OAAO,IAAI;IACb;IACA,OAAOqB,QAAQ,CAACG,IAAI,CAAC,CAAC;EACxB,CAAC,EACDjC,GAAG,EACHa,IAAI,EACJZ,YACF,CAAC;EAED,IAAI;IACF,IAAIgB,MAAM,KAAK,IAAI,EAAE;MACnB,OAAOF,IAAI,CAACqB,KAAK,CAACnB,MAAM,CAAC;IAC3B;EACF,CAAC,CAAC,OAAOxB,CAAC,EAAE;IACV,IAAI,CAACkC,YAAY,EAAE;MACjB,MAAM,IAAIjB,KAAK,CACb,oCAAoCjB,CAAC,YAAYiB,KAAK,GAAG,GAAGjB,CAAC,CAAC+B,OAAO,KAAK/B,CAAC,CAACyC,KAAK,EAAE,GAAGC,MAAM,CAAC1C,CAAC,CAAC,UAAUO,GAAG,WAAWe,IAAI,CAACC,SAAS,CAACH,IAAI,CAAC,mBAAmBE,IAAI,CAACC,SAAS,CAACf,YAAY,CAAC,aAAagB,MAAM,EAC/M,CAAC;IACH;EACF;EACA,OAAO,IAAI;AACb","ignoreList":[]}
|
package/lib/scrapers/visa-cal.js
CHANGED
|
@@ -262,7 +262,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
|
|
|
262
262
|
const finalMonthToFetchMoment = (0, _moment.default)().add(futureMonthsToScrape, 'month');
|
|
263
263
|
const months = finalMonthToFetchMoment.diff(startMoment, 'months');
|
|
264
264
|
const allMonthsData = [];
|
|
265
|
-
const frame = _lodash.default.find(frames.result
|
|
265
|
+
const frame = _lodash.default.find(frames.result?.bankIssuedCards?.cardLevelFrames, {
|
|
266
266
|
cardUniqueId: card.cardUniqueId
|
|
267
267
|
});
|
|
268
268
|
debug(`fetch pending transactions for card ${card.cardUniqueId}`);
|
|
@@ -305,7 +305,7 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
|
|
|
305
305
|
const txns = this.options.outputData?.enableTransactionsFilterByDate ?? true ? (0, _transactions.filterOldTransactions)(transactions, (0, _moment.default)(startDate), this.options.combineInstallments || false) : transactions;
|
|
306
306
|
return {
|
|
307
307
|
txns,
|
|
308
|
-
balance:
|
|
308
|
+
balance: frame?.nextTotalDebit != null ? -frame.nextTotalDebit : undefined,
|
|
309
309
|
accountNumber: card.last4Digits
|
|
310
310
|
};
|
|
311
311
|
}));
|
|
@@ -318,4 +318,4 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
|
|
|
318
318
|
}
|
|
319
319
|
}
|
|
320
320
|
var _default = exports.default = VisaCalScraper;
|
|
321
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_navigation","_storage","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_lodash","e","__esModule","default","apiHeaders","Origin","Referer","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","FRAMES_REQUEST_ENDPOINT","PENDING_TRANSACTIONS_REQUEST_ENDPOINT","SSO_AUTHORIZATION_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","isAuthModule","result","Boolean","auth","calConnectToken","String","trim","authModuleOrUndefined","undefined","isPending","transaction","debCrdDate","isCardTransactionDetails","isCardPendingTransactionDetails","getLoginFrame","page","frame","waitUntil","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","elementPresentOnPage","errorMessage","pageEval","item","innerText","hasChangePasswordForm","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","ChangePassword","createLoginFields","credentials","selector","value","username","password","convertParsedDataToTransactions","data","pendingData","pendingTransactions","cardsList","flatMap","card","authDetalisList","bankAccounts","monthData","regularDebitDays","accounts","debitDates","immediateDebitDays","immidiateDebits","debitDays","completedTransactions","debitDate","transactions","all","map","numOfPayments","numberOfPayments","installments","number","curPaymentNum","total","date","moment","trnPurchaseDate","chargedAmount","trnAmt","amtBeforeConvAndIndex","originalAmount","trnTypeCode","credit","identifier","trnIntId","type","regular","standingOrder","TransactionTypes","Normal","Installments","status","TransactionStatuses","Pending","Completed","add","toISOString","processedDate","Date","originalCurrency","trnCurrencySymbol","chargedCurrency","debCrdCurrencySymbol","description","merchantName","memo","transTypeCommentDetails","toString","category","branchCodeDesc","includeRawTransaction","rawTransaction","VisaCalScraper","BaseScraperWithBrowser","authorization","openLoginPopup","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","getXSiteId","getLoginOptions","authRequestPromise","waitForRequest","timeout","catch","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","postAction","waitForNavigation","currentUrl","getCurrentUrl","endsWith","request","headers","requiresChangePassword","userAgent","fetchData","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","xSiteId","Authorization","futureMonthsToScrape","fetchPost","cardsForFrameData","finalMonthToFetchMoment","months","diff","allMonthsData","_","bankIssuedCards","cardLevelFrames","cardUniqueIDArray","i","month","clone","year","statusCode","title","push","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","balance","nextTotalDebit","accountNumber","JSON","stringify","success","_default","exports"],"sources":["../../src/scrapers/visa-cal.ts"],"sourcesContent":["import moment from 'moment';\nimport { type HTTPRequest, type Frame, type Page } from 'puppeteer';\nimport { getDebug } from '../helpers/debug';\nimport { clickButton, elementPresentOnPage, pageEval, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPost } from '../helpers/fetch';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult, type ScraperOptions } from './interface';\nimport _ from 'lodash';\n\nconst apiHeaders = {\n  'User-Agent':\n    'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/142.0.0.0 Safari/537.36',\n  Origin: 'https://digital-web.cal-online.co.il',\n  Referer: 'https://digital-web.cal-online.co.il',\n  'Accept-Language': 'he-IL,he;q=0.9,en-US;q=0.8,en;q=0.7',\n  'Sec-Fetch-Site': 'same-site',\n  'Sec-Fetch-Mode': 'cors',\n  'Sec-Fetch-Dest': 'empty',\n};\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\nconst FRAMES_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Frames/api/Frames/GetFrameStatus';\nconst PENDING_TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';\nconst SSO_AUTHORIZATION_REQUEST_ENDPOINT = 'https://connect.cal-online.co.il/col-rest/calconnect/authentication/SSO';\n\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\nenum TrnTypeCode {\n  regular = '5',\n  credit = '6',\n  installments = '8',\n  standingOrder = '9',\n}\n\ninterface ScrapedTransaction {\n  amtBeforeConvAndIndex: number;\n  branchCodeDesc: string;\n  cashAccManagerName: null;\n  cashAccountManager: null;\n  cashAccountTrnAmt: number;\n  chargeExternalToCardComment: string;\n  comments: [];\n  curPaymentNum: number;\n  debCrdCurrencySymbol: CurrencySymbol;\n  debCrdDate: string;\n  debitSpreadInd: boolean;\n  discountAmount: unknown;\n  discountReason: unknown;\n  immediateComments: [];\n  isImmediateCommentInd: boolean;\n  isImmediateHHKInd: boolean;\n  isMargarita: boolean;\n  isSpreadPaymenstAbroad: boolean;\n  linkedComments: [];\n  merchantAddress: string;\n  merchantName: string;\n  merchantPhoneNo: string;\n  numOfPayments: number;\n  onGoingTransactionsComment: string;\n  refundInd: boolean;\n  roundingAmount: unknown;\n  roundingReason: unknown;\n  tokenInd: 0;\n  tokenNumberPart4: '';\n  transCardPresentInd: boolean;\n  transTypeCommentDetails: [];\n  trnAmt: number;\n  trnCurrencySymbol: CurrencySymbol;\n  trnExacWay: number;\n  trnIntId: string;\n  trnNumaretor: number;\n  trnPurchaseDate: string;\n  trnType: string;\n  trnTypeCode: TrnTypeCode;\n  walletProviderCode: 0;\n  walletProviderDesc: '';\n  earlyPaymentInd: boolean;\n}\ninterface ScrapedPendingTransaction {\n  merchantID: string;\n  merchantName: string;\n  trnPurchaseDate: string;\n  walletTranInd: number;\n  transactionsOrigin: number;\n  trnAmt: number;\n  tpaApprovalAmount: unknown;\n  trnCurrencySymbol: CurrencySymbol;\n  trnTypeCode: TrnTypeCode;\n  trnType: string;\n  branchCodeDesc: string;\n  transCardPresentInd: boolean;\n  j5Indicator: string;\n  numberOfPayments: number;\n  firstPaymentAmount: number;\n  transTypeCommentDetails: [];\n}\ninterface InitResponse {\n  result: {\n    cards: {\n      cardUniqueId: string;\n      last4Digits: string;\n      [key: string]: unknown;\n    }[];\n  };\n}\ntype CurrencySymbol = string;\ninterface CardTransactionDetailsError {\n  title: string;\n  statusCode: number;\n}\ninterface CardTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    bankAccounts: {\n      bankAccountNum: string;\n      bankName: string;\n      choiceExternalTransactions: any;\n      currentBankAccountInd: boolean;\n      debitDates: {\n        basketAmountComment: unknown;\n        choiceHHKDebit: number;\n        date: string;\n        debitReason: unknown;\n        fixDebitAmount: number;\n        fromPurchaseDate: string;\n        isChoiceRepaiment: boolean;\n        toPurchaseDate: string;\n        totalBasketAmount: number;\n        totalDebits: {\n          currencySymbol: CurrencySymbol;\n          amount: number;\n        }[];\n        transactions: ScrapedTransaction[];\n      }[];\n      immidiateDebits: { totalDebits: []; debitDays: [] };\n    }[];\n    blockedCardInd: boolean;\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\ninterface CardPendingTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    cardsList: {\n      cardUniqueID: string;\n      authDetalisList: ScrapedPendingTransaction[];\n    }[];\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\n\ninterface AuthModule {\n  auth: {\n    calConnectToken: string | null;\n  };\n}\n\nfunction isAuthModule(result: any): result is AuthModule {\n  return Boolean(result?.auth?.calConnectToken && String(result.auth.calConnectToken).trim());\n}\n\nfunction authModuleOrUndefined(result: any): AuthModule | undefined {\n  return isAuthModule(result) ? result : undefined;\n}\n\nfunction isPending(\n  transaction: ScrapedTransaction | ScrapedPendingTransaction,\n): transaction is ScrapedPendingTransaction {\n  return (transaction as ScrapedTransaction).debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction\n}\n\nfunction isCardTransactionDetails(\n  result: CardTransactionDetails | CardTransactionDetailsError,\n): result is CardTransactionDetails {\n  return (result as CardTransactionDetails).result !== undefined;\n}\n\nfunction isCardPendingTransactionDetails(\n  result: CardPendingTransactionDetails | CardTransactionDetailsError,\n): result is CardPendingTransactionDetails {\n  return (result as CardPendingTransactionDetails).result !== undefined;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(\n    () => {\n      frame = page.frames().find(f => f.url().includes('connect')) || null;\n      return Promise.resolve(!!frame);\n    },\n    'wait for iframe with login form',\n    10000,\n    1000,\n  );\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound\n    ? await pageEval(frame, 'div.general-error > div', '', item => {\n        return (item as HTMLDivElement).innerText;\n      })\n    : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nasync function hasChangePasswordForm(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, '.change-password-subtitle');\n  return errorFound;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/dashboard/i],\n    [LoginResults.InvalidPassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasInvalidPasswordError(page);\n      },\n    ],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasChangePasswordForm(page);\n      },\n    ],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\nfunction convertParsedDataToTransactions(\n  data: CardTransactionDetails[],\n  pendingData?: CardPendingTransactionDetails | null,\n  options?: ScraperOptions,\n): Transaction[] {\n  const pendingTransactions = pendingData?.result\n    ? pendingData.result.cardsList.flatMap(card => card.authDetalisList)\n    : [];\n\n  const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);\n  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);\n  const immediateDebitDays = bankAccounts.flatMap(accounts => accounts.immidiateDebits.debitDays);\n  const completedTransactions = [...regularDebitDays, ...immediateDebitDays].flatMap(\n    debitDate => debitDate.transactions,\n  );\n\n  const all: (ScrapedTransaction | ScrapedPendingTransaction)[] = [...pendingTransactions, ...completedTransactions];\n\n  return all.map(transaction => {\n    const numOfPayments = isPending(transaction) ? transaction.numberOfPayments : transaction.numOfPayments;\n    const installments = numOfPayments\n      ? {\n          number: isPending(transaction) ? 1 : transaction.curPaymentNum,\n          total: numOfPayments,\n        }\n      : undefined;\n\n    const date = moment(transaction.trnPurchaseDate);\n\n    const chargedAmount = (isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex) * -1;\n    const originalAmount = transaction.trnAmt * (transaction.trnTypeCode === TrnTypeCode.credit ? 1 : -1);\n\n    const result: Transaction = {\n      identifier: !isPending(transaction) ? transaction.trnIntId : undefined,\n      type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode)\n        ? TransactionTypes.Normal\n        : TransactionTypes.Installments,\n      status: isPending(transaction) ? TransactionStatuses.Pending : TransactionStatuses.Completed,\n      date: installments ? date.add(installments.number - 1, 'month').toISOString() : date.toISOString(),\n      processedDate: isPending(transaction) ? date.toISOString() : new Date(transaction.debCrdDate).toISOString(),\n      originalAmount,\n      originalCurrency: transaction.trnCurrencySymbol,\n      chargedAmount,\n      chargedCurrency: !isPending(transaction) ? transaction.debCrdCurrencySymbol : undefined,\n      description: transaction.merchantName,\n      memo: transaction.transTypeCommentDetails.toString(),\n      category: transaction.branchCodeDesc,\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = transaction;\n    }\n\n    return result;\n  });\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass VisaCalScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private authorization: string | undefined = undefined;\n\n  private authRequestPromise: Promise<HTTPRequest | undefined> | undefined;\n\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  async getCards() {\n    const initData = await waitUntil(\n      () => getFromSessionStorage<InitResponse>(this.page, 'init'),\n      'get init data in session storage',\n      10000,\n      1000,\n    );\n    if (!initData) {\n      throw new Error('could not find \"init\" data in session storage');\n    }\n    return initData?.result.cards.map(({ cardUniqueId, last4Digits }) => ({ cardUniqueId, last4Digits }));\n  }\n\n  async getAuthorizationHeader() {\n    if (!this.authorization) {\n      debug('fetching authorization header');\n      const authModule = await waitUntil(\n        async () => authModuleOrUndefined(await getFromSessionStorage<AuthModule>(this.page, 'auth-module')),\n        'get authorization header with valid token in session storage',\n        10_000,\n        50,\n      );\n      return `CALAuthScheme ${authModule.auth.calConnectToken}`;\n    }\n    return this.authorization;\n  }\n\n  async getXSiteId() {\n    /*\n      I don't know if the constant below will change in the feature.\n      If so, use the next code:\n\n      return this.page.evaluate(() => new Ut().xSiteId);\n\n      To get the classname search for 'xSiteId' in the page source\n      class Ut {\n        constructor(_e, on, yn) {\n            this.store = _e,\n            this.config = on,\n            this.eventBusService = yn,\n            this.xSiteId = \"09031987-273E-2311-906C-8AF85B17C8D9\",\n    */\n    return Promise.resolve('09031987-273E-2311-906C-8AF85B17C8D9');\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    this.authRequestPromise = this.page\n      .waitForRequest(SSO_AUTHORIZATION_REQUEST_ENDPOINT, { timeout: 10_000 })\n      .catch(e => {\n        debug('error while waiting for the token request', e);\n        return undefined;\n      });\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      postAction: async () => {\n        try {\n          await waitForNavigation(this.page);\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\n          const request = await this.authRequestPromise;\n          this.authorization = String(request?.headers().authorization || '').trim();\n        } catch (e) {\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('dashboard')) return;\n          const requiresChangePassword = await hasChangePasswordForm(this.page);\n          if (requiresChangePassword) return;\n          throw e;\n        }\n      },\n      userAgent: apiHeaders['User-Agent'],\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').subtract(6, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    const [cards, xSiteId, Authorization] = await Promise.all([\n      this.getCards(),\n      this.getXSiteId(),\n      this.getAuthorizationHeader(),\n    ]);\n\n    const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;\n\n    debug('fetch frames (misgarot) of cards');\n    const frames = await fetchPost(\n      FRAMES_REQUEST_ENDPOINT,\n      { cardsForFrameData: cards.map(({ cardUniqueId }) => ({ cardUniqueId })) },\n      {\n        Authorization,\n        'X-Site-Id': xSiteId,\n        'Content-Type': 'application/json',\n        ...apiHeaders,\n      },\n    );\n\n    const accounts = await Promise.all(\n      cards.map(async card => {\n        const finalMonthToFetchMoment = moment().add(futureMonthsToScrape, 'month');\n        const months = finalMonthToFetchMoment.diff(startMoment, 'months');\n        const allMonthsData: CardTransactionDetails[] = [];\n        const frame = _.find(frames.result.bankIssuedCards?.cardLevelFrames, { cardUniqueId: card.cardUniqueId });\n\n        debug(`fetch pending transactions for card ${card.cardUniqueId}`);\n        let pendingData = await fetchPost(\n          PENDING_TRANSACTIONS_REQUEST_ENDPOINT,\n          { cardUniqueIDArray: [card.cardUniqueId] },\n          {\n            Authorization,\n            'X-Site-Id': xSiteId,\n            'Content-Type': 'application/json',\n            ...apiHeaders,\n          },\n        );\n\n        debug(`fetch completed transactions for card ${card.cardUniqueId}`);\n        for (let i = 0; i <= months; i++) {\n          const month = finalMonthToFetchMoment.clone().subtract(i, 'months');\n          const monthData = await fetchPost(\n            TRANSACTIONS_REQUEST_ENDPOINT,\n            { cardUniqueId: card.cardUniqueId, month: month.format('M'), year: month.format('YYYY') },\n            {\n              Authorization,\n              'X-Site-Id': xSiteId,\n              'Content-Type': 'application/json',\n              ...apiHeaders,\n            },\n          );\n\n          if (monthData?.statusCode !== 1)\n            throw new Error(\n              `failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`,\n            );\n\n          if (!isCardTransactionDetails(monthData)) {\n            throw new Error('monthData is not of type CardTransactionDetails');\n          }\n\n          allMonthsData.push(monthData);\n        }\n\n        if (pendingData?.statusCode !== 1 && pendingData?.statusCode !== 96) {\n          debug(\n            `failed to fetch pending transactions for card ${card.last4Digits}. Message: ${pendingData?.title || ''}`,\n          );\n          pendingData = null;\n        } else if (!isCardPendingTransactionDetails(pendingData)) {\n          debug('pendingData is not of type CardTransactionDetails');\n          pendingData = null;\n        }\n\n        const transactions = convertParsedDataToTransactions(allMonthsData, pendingData, this.options);\n\n        debug('filter out old transactions');\n        const txns =\n          (this.options.outputData?.enableTransactionsFilterByDate ?? true)\n            ? filterOldTransactions(transactions, moment(startDate), this.options.combineInstallments || false)\n            : transactions;\n\n        return {\n          txns,\n          balance: -frame?.nextTotalDebit,\n          accountNumber: card.last4Digits,\n        } as TransactionsAccount;\n      }),\n    );\n\n    debug('return the scraped accounts');\n\n    debug(JSON.stringify(accounts, null, 2));\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"],"mappings":"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","ignoreList":[]}
|
|
321
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_navigation","_storage","_transactions","_waiting","_transactions2","_baseScraperWithBrowser","_lodash","e","__esModule","default","apiHeaders","Origin","Referer","LOGIN_URL","TRANSACTIONS_REQUEST_ENDPOINT","FRAMES_REQUEST_ENDPOINT","PENDING_TRANSACTIONS_REQUEST_ENDPOINT","SSO_AUTHORIZATION_REQUEST_ENDPOINT","InvalidPasswordMessage","debug","getDebug","TrnTypeCode","isAuthModule","result","Boolean","auth","calConnectToken","String","trim","authModuleOrUndefined","undefined","isPending","transaction","debCrdDate","isCardTransactionDetails","isCardPendingTransactionDetails","getLoginFrame","page","frame","waitUntil","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","elementPresentOnPage","errorMessage","pageEval","item","innerText","hasChangePasswordForm","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","ChangePassword","createLoginFields","credentials","selector","value","username","password","convertParsedDataToTransactions","data","pendingData","pendingTransactions","cardsList","flatMap","card","authDetalisList","bankAccounts","monthData","regularDebitDays","accounts","debitDates","immediateDebitDays","immidiateDebits","debitDays","completedTransactions","debitDate","transactions","all","map","numOfPayments","numberOfPayments","installments","number","curPaymentNum","total","date","moment","trnPurchaseDate","chargedAmount","trnAmt","amtBeforeConvAndIndex","originalAmount","trnTypeCode","credit","identifier","trnIntId","type","regular","standingOrder","TransactionTypes","Normal","Installments","status","TransactionStatuses","Pending","Completed","add","toISOString","processedDate","Date","originalCurrency","trnCurrencySymbol","chargedCurrency","debCrdCurrencySymbol","description","merchantName","memo","transTypeCommentDetails","toString","category","branchCodeDesc","includeRawTransaction","rawTransaction","VisaCalScraper","BaseScraperWithBrowser","authorization","openLoginPopup","waitUntilElementFound","clickButton","getCards","initData","getFromSessionStorage","cards","cardUniqueId","last4Digits","getAuthorizationHeader","authModule","getXSiteId","getLoginOptions","authRequestPromise","waitForRequest","timeout","catch","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","postAction","waitForNavigation","currentUrl","getCurrentUrl","endsWith","request","headers","requiresChangePassword","userAgent","fetchData","defaultStartMoment","subtract","startDate","toDate","startMoment","max","format","xSiteId","Authorization","futureMonthsToScrape","fetchPost","cardsForFrameData","finalMonthToFetchMoment","months","diff","allMonthsData","_","bankIssuedCards","cardLevelFrames","cardUniqueIDArray","i","month","clone","year","statusCode","title","push","txns","outputData","enableTransactionsFilterByDate","filterOldTransactions","combineInstallments","balance","nextTotalDebit","accountNumber","JSON","stringify","success","_default","exports"],"sources":["../../src/scrapers/visa-cal.ts"],"sourcesContent":["import moment from 'moment';\nimport { type HTTPRequest, type Frame, type Page } from 'puppeteer';\nimport { getDebug } from '../helpers/debug';\nimport { clickButton, elementPresentOnPage, pageEval, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPost } from '../helpers/fetch';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { getFromSessionStorage } from '../helpers/storage';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { waitUntil } from '../helpers/waiting';\nimport { TransactionStatuses, TransactionTypes, type Transaction, type TransactionsAccount } from '../transactions';\nimport { BaseScraperWithBrowser, LoginResults, type LoginOptions } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult, type ScraperOptions } from './interface';\nimport _ from 'lodash';\n\nconst apiHeaders = {\n  'User-Agent':\n    'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/142.0.0.0 Safari/537.36',\n  Origin: 'https://digital-web.cal-online.co.il',\n  Referer: 'https://digital-web.cal-online.co.il',\n  'Accept-Language': 'he-IL,he;q=0.9,en-US;q=0.8,en;q=0.7',\n  'Sec-Fetch-Site': 'same-site',\n  'Sec-Fetch-Mode': 'cors',\n  'Sec-Fetch-Dest': 'empty',\n};\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/transactionsDetails/getCardTransactionsDetails';\nconst FRAMES_REQUEST_ENDPOINT = 'https://api.cal-online.co.il/Frames/api/Frames/GetFrameStatus';\nconst PENDING_TRANSACTIONS_REQUEST_ENDPOINT =\n  'https://api.cal-online.co.il/Transactions/api/approvals/getClearanceRequests';\nconst SSO_AUTHORIZATION_REQUEST_ENDPOINT = 'https://connect.cal-online.co.il/col-rest/calconnect/authentication/SSO';\n\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\nenum TrnTypeCode {\n  regular = '5',\n  credit = '6',\n  installments = '8',\n  standingOrder = '9',\n}\n\ninterface ScrapedTransaction {\n  amtBeforeConvAndIndex: number;\n  branchCodeDesc: string;\n  cashAccManagerName: null;\n  cashAccountManager: null;\n  cashAccountTrnAmt: number;\n  chargeExternalToCardComment: string;\n  comments: [];\n  curPaymentNum: number;\n  debCrdCurrencySymbol: CurrencySymbol;\n  debCrdDate: string;\n  debitSpreadInd: boolean;\n  discountAmount: unknown;\n  discountReason: unknown;\n  immediateComments: [];\n  isImmediateCommentInd: boolean;\n  isImmediateHHKInd: boolean;\n  isMargarita: boolean;\n  isSpreadPaymenstAbroad: boolean;\n  linkedComments: [];\n  merchantAddress: string;\n  merchantName: string;\n  merchantPhoneNo: string;\n  numOfPayments: number;\n  onGoingTransactionsComment: string;\n  refundInd: boolean;\n  roundingAmount: unknown;\n  roundingReason: unknown;\n  tokenInd: 0;\n  tokenNumberPart4: '';\n  transCardPresentInd: boolean;\n  transTypeCommentDetails: [];\n  trnAmt: number;\n  trnCurrencySymbol: CurrencySymbol;\n  trnExacWay: number;\n  trnIntId: string;\n  trnNumaretor: number;\n  trnPurchaseDate: string;\n  trnType: string;\n  trnTypeCode: TrnTypeCode;\n  walletProviderCode: 0;\n  walletProviderDesc: '';\n  earlyPaymentInd: boolean;\n}\ninterface ScrapedPendingTransaction {\n  merchantID: string;\n  merchantName: string;\n  trnPurchaseDate: string;\n  walletTranInd: number;\n  transactionsOrigin: number;\n  trnAmt: number;\n  tpaApprovalAmount: unknown;\n  trnCurrencySymbol: CurrencySymbol;\n  trnTypeCode: TrnTypeCode;\n  trnType: string;\n  branchCodeDesc: string;\n  transCardPresentInd: boolean;\n  j5Indicator: string;\n  numberOfPayments: number;\n  firstPaymentAmount: number;\n  transTypeCommentDetails: [];\n}\ninterface InitResponse {\n  result: {\n    cards: {\n      cardUniqueId: string;\n      last4Digits: string;\n      [key: string]: unknown;\n    }[];\n  };\n}\ntype CurrencySymbol = string;\ninterface CardTransactionDetailsError {\n  title: string;\n  statusCode: number;\n}\ninterface CardTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    bankAccounts: {\n      bankAccountNum: string;\n      bankName: string;\n      choiceExternalTransactions: any;\n      currentBankAccountInd: boolean;\n      debitDates: {\n        basketAmountComment: unknown;\n        choiceHHKDebit: number;\n        date: string;\n        debitReason: unknown;\n        fixDebitAmount: number;\n        fromPurchaseDate: string;\n        isChoiceRepaiment: boolean;\n        toPurchaseDate: string;\n        totalBasketAmount: number;\n        totalDebits: {\n          currencySymbol: CurrencySymbol;\n          amount: number;\n        }[];\n        transactions: ScrapedTransaction[];\n      }[];\n      immidiateDebits: { totalDebits: []; debitDays: [] };\n    }[];\n    blockedCardInd: boolean;\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\ninterface CardPendingTransactionDetails extends CardTransactionDetailsError {\n  result: {\n    cardsList: {\n      cardUniqueID: string;\n      authDetalisList: ScrapedPendingTransaction[];\n    }[];\n  };\n  statusCode: 1;\n  statusDescription: string;\n  statusTitle: string;\n}\n\ninterface CardLevelFrame {\n  cardUniqueId: string;\n  nextTotalDebit?: number;\n}\n\ninterface FramesResponse {\n  result?: {\n    bankIssuedCards?: {\n      cardLevelFrames?: CardLevelFrame[];\n    };\n  };\n}\n\ninterface AuthModule {\n  auth: {\n    calConnectToken: string | null;\n  };\n}\n\nfunction isAuthModule(result: any): result is AuthModule {\n  return Boolean(result?.auth?.calConnectToken && String(result.auth.calConnectToken).trim());\n}\n\nfunction authModuleOrUndefined(result: any): AuthModule | undefined {\n  return isAuthModule(result) ? result : undefined;\n}\n\nfunction isPending(\n  transaction: ScrapedTransaction | ScrapedPendingTransaction,\n): transaction is ScrapedPendingTransaction {\n  return (transaction as ScrapedTransaction).debCrdDate === undefined; // an arbitrary field that only appears in a completed transaction\n}\n\nfunction isCardTransactionDetails(\n  result: CardTransactionDetails | CardTransactionDetailsError,\n): result is CardTransactionDetails {\n  return (result as CardTransactionDetails).result !== undefined;\n}\n\nfunction isCardPendingTransactionDetails(\n  result: CardPendingTransactionDetails | CardTransactionDetailsError,\n): result is CardPendingTransactionDetails {\n  return (result as CardPendingTransactionDetails).result !== undefined;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(\n    () => {\n      frame = page.frames().find(f => f.url().includes('connect')) || null;\n      return Promise.resolve(!!frame);\n    },\n    'wait for iframe with login form',\n    10000,\n    1000,\n  );\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound\n    ? await pageEval(frame, 'div.general-error > div', '', item => {\n        return (item as HTMLDivElement).innerText;\n      })\n    : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nasync function hasChangePasswordForm(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, '.change-password-subtitle');\n  return errorFound;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/dashboard/i],\n    [LoginResults.InvalidPassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasInvalidPasswordError(page);\n      },\n    ],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    [LoginResults.ChangePassword]: [\n      async (options?: { page?: Page }) => {\n        const page = options?.page;\n        if (!page) {\n          return false;\n        }\n        return hasChangePasswordForm(page);\n      },\n    ],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\nfunction convertParsedDataToTransactions(\n  data: CardTransactionDetails[],\n  pendingData?: CardPendingTransactionDetails | null,\n  options?: ScraperOptions,\n): Transaction[] {\n  const pendingTransactions = pendingData?.result\n    ? pendingData.result.cardsList.flatMap(card => card.authDetalisList)\n    : [];\n\n  const bankAccounts = data.flatMap(monthData => monthData.result.bankAccounts);\n  const regularDebitDays = bankAccounts.flatMap(accounts => accounts.debitDates);\n  const immediateDebitDays = bankAccounts.flatMap(accounts => accounts.immidiateDebits.debitDays);\n  const completedTransactions = [...regularDebitDays, ...immediateDebitDays].flatMap(\n    debitDate => debitDate.transactions,\n  );\n\n  const all: (ScrapedTransaction | ScrapedPendingTransaction)[] = [...pendingTransactions, ...completedTransactions];\n\n  return all.map(transaction => {\n    const numOfPayments = isPending(transaction) ? transaction.numberOfPayments : transaction.numOfPayments;\n    const installments = numOfPayments\n      ? {\n          number: isPending(transaction) ? 1 : transaction.curPaymentNum,\n          total: numOfPayments,\n        }\n      : undefined;\n\n    const date = moment(transaction.trnPurchaseDate);\n\n    const chargedAmount = (isPending(transaction) ? transaction.trnAmt : transaction.amtBeforeConvAndIndex) * -1;\n    const originalAmount = transaction.trnAmt * (transaction.trnTypeCode === TrnTypeCode.credit ? 1 : -1);\n\n    const result: Transaction = {\n      identifier: !isPending(transaction) ? transaction.trnIntId : undefined,\n      type: [TrnTypeCode.regular, TrnTypeCode.standingOrder].includes(transaction.trnTypeCode)\n        ? TransactionTypes.Normal\n        : TransactionTypes.Installments,\n      status: isPending(transaction) ? TransactionStatuses.Pending : TransactionStatuses.Completed,\n      date: installments ? date.add(installments.number - 1, 'month').toISOString() : date.toISOString(),\n      processedDate: isPending(transaction) ? date.toISOString() : new Date(transaction.debCrdDate).toISOString(),\n      originalAmount,\n      originalCurrency: transaction.trnCurrencySymbol,\n      chargedAmount,\n      chargedCurrency: !isPending(transaction) ? transaction.debCrdCurrencySymbol : undefined,\n      description: transaction.merchantName,\n      memo: transaction.transTypeCommentDetails.toString(),\n      category: transaction.branchCodeDesc,\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    if (options?.includeRawTransaction) {\n      result.rawTransaction = transaction;\n    }\n\n    return result;\n  });\n}\n\ntype ScraperSpecificCredentials = { username: string; password: string };\n\nclass VisaCalScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  private authorization: string | undefined = undefined;\n\n  private authRequestPromise: Promise<HTTPRequest | undefined> | undefined;\n\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  async getCards() {\n    const initData = await waitUntil(\n      () => getFromSessionStorage<InitResponse>(this.page, 'init'),\n      'get init data in session storage',\n      10000,\n      1000,\n    );\n    if (!initData) {\n      throw new Error('could not find \"init\" data in session storage');\n    }\n    return initData?.result.cards.map(({ cardUniqueId, last4Digits }) => ({ cardUniqueId, last4Digits }));\n  }\n\n  async getAuthorizationHeader() {\n    if (!this.authorization) {\n      debug('fetching authorization header');\n      const authModule = await waitUntil(\n        async () => authModuleOrUndefined(await getFromSessionStorage<AuthModule>(this.page, 'auth-module')),\n        'get authorization header with valid token in session storage',\n        10_000,\n        50,\n      );\n      return `CALAuthScheme ${authModule.auth.calConnectToken}`;\n    }\n    return this.authorization;\n  }\n\n  async getXSiteId() {\n    /*\n      I don't know if the constant below will change in the feature.\n      If so, use the next code:\n\n      return this.page.evaluate(() => new Ut().xSiteId);\n\n      To get the classname search for 'xSiteId' in the page source\n      class Ut {\n        constructor(_e, on, yn) {\n            this.store = _e,\n            this.config = on,\n            this.eventBusService = yn,\n            this.xSiteId = \"09031987-273E-2311-906C-8AF85B17C8D9\",\n    */\n    return Promise.resolve('09031987-273E-2311-906C-8AF85B17C8D9');\n  }\n\n  getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    this.authRequestPromise = this.page\n      .waitForRequest(SSO_AUTHORIZATION_REQUEST_ENDPOINT, { timeout: 10_000 })\n      .catch(e => {\n        debug('error while waiting for the token request', e);\n        return undefined;\n      });\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      postAction: async () => {\n        try {\n          await waitForNavigation(this.page);\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('site-tutorial')) {\n            await clickButton(this.page, 'button.btn-close');\n          }\n          const request = await this.authRequestPromise;\n          this.authorization = String(request?.headers().authorization || '').trim();\n        } catch (e) {\n          const currentUrl = await getCurrentUrl(this.page);\n          if (currentUrl.endsWith('dashboard')) return;\n          const requiresChangePassword = await hasChangePasswordForm(this.page);\n          if (requiresChangePassword) return;\n          throw e;\n        }\n      },\n      userAgent: apiHeaders['User-Agent'],\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').subtract(6, 'months').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    const [cards, xSiteId, Authorization] = await Promise.all([\n      this.getCards(),\n      this.getXSiteId(),\n      this.getAuthorizationHeader(),\n    ]);\n\n    const futureMonthsToScrape = this.options.futureMonthsToScrape ?? 1;\n\n    debug('fetch frames (misgarot) of cards');\n    const frames = await fetchPost<FramesResponse>(\n      FRAMES_REQUEST_ENDPOINT,\n      { cardsForFrameData: cards.map(({ cardUniqueId }) => ({ cardUniqueId })) },\n      {\n        Authorization,\n        'X-Site-Id': xSiteId,\n        'Content-Type': 'application/json',\n        ...apiHeaders,\n      },\n    );\n\n    const accounts = await Promise.all(\n      cards.map(async card => {\n        const finalMonthToFetchMoment = moment().add(futureMonthsToScrape, 'month');\n        const months = finalMonthToFetchMoment.diff(startMoment, 'months');\n        const allMonthsData: CardTransactionDetails[] = [];\n        const frame = _.find(frames.result?.bankIssuedCards?.cardLevelFrames, { cardUniqueId: card.cardUniqueId });\n\n        debug(`fetch pending transactions for card ${card.cardUniqueId}`);\n        let pendingData = await fetchPost(\n          PENDING_TRANSACTIONS_REQUEST_ENDPOINT,\n          { cardUniqueIDArray: [card.cardUniqueId] },\n          {\n            Authorization,\n            'X-Site-Id': xSiteId,\n            'Content-Type': 'application/json',\n            ...apiHeaders,\n          },\n        );\n\n        debug(`fetch completed transactions for card ${card.cardUniqueId}`);\n        for (let i = 0; i <= months; i++) {\n          const month = finalMonthToFetchMoment.clone().subtract(i, 'months');\n          const monthData = await fetchPost(\n            TRANSACTIONS_REQUEST_ENDPOINT,\n            { cardUniqueId: card.cardUniqueId, month: month.format('M'), year: month.format('YYYY') },\n            {\n              Authorization,\n              'X-Site-Id': xSiteId,\n              'Content-Type': 'application/json',\n              ...apiHeaders,\n            },\n          );\n\n          if (monthData?.statusCode !== 1)\n            throw new Error(\n              `failed to fetch transactions for card ${card.last4Digits}. Message: ${monthData?.title || ''}`,\n            );\n\n          if (!isCardTransactionDetails(monthData)) {\n            throw new Error('monthData is not of type CardTransactionDetails');\n          }\n\n          allMonthsData.push(monthData);\n        }\n\n        if (pendingData?.statusCode !== 1 && pendingData?.statusCode !== 96) {\n          debug(\n            `failed to fetch pending transactions for card ${card.last4Digits}. Message: ${pendingData?.title || ''}`,\n          );\n          pendingData = null;\n        } else if (!isCardPendingTransactionDetails(pendingData)) {\n          debug('pendingData is not of type CardTransactionDetails');\n          pendingData = null;\n        }\n\n        const transactions = convertParsedDataToTransactions(allMonthsData, pendingData, this.options);\n\n        debug('filter out old transactions');\n        const txns =\n          (this.options.outputData?.enableTransactionsFilterByDate ?? true)\n            ? filterOldTransactions(transactions, moment(startDate), this.options.combineInstallments || false)\n            : transactions;\n\n        return {\n          txns,\n          balance: frame?.nextTotalDebit != null ? -frame.nextTotalDebit : undefined,\n          accountNumber: card.last4Digits,\n        } as TransactionsAccount;\n      }),\n    );\n\n    debug('return the scraped accounts');\n\n    debug(JSON.stringify(accounts, null, 2));\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"],"mappings":"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","ignoreList":[]}
|