israeli-bank-scrapers 6.0.0 → 6.1.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.
Files changed (83) hide show
  1. package/README.md +1 -0
  2. package/lib/assertNever.js +5 -7
  3. package/lib/constants.js +13 -16
  4. package/lib/definitions.js +109 -113
  5. package/lib/helpers/browser.d.ts +8 -0
  6. package/lib/helpers/browser.js +14 -11
  7. package/lib/helpers/dates.js +18 -19
  8. package/lib/helpers/debug.js +9 -9
  9. package/lib/helpers/elements-interactions.js +78 -84
  10. package/lib/helpers/fetch.js +82 -89
  11. package/lib/helpers/navigation.js +24 -31
  12. package/lib/helpers/storage.js +10 -12
  13. package/lib/helpers/transactions.js +33 -35
  14. package/lib/helpers/waiting.js +45 -44
  15. package/lib/index.js +15 -82
  16. package/lib/scrapers/amex.js +11 -13
  17. package/lib/scrapers/base-beinleumi-group.js +233 -252
  18. package/lib/scrapers/base-isracard-amex.js +273 -286
  19. package/lib/scrapers/base-scraper-with-browser.d.ts +2 -1
  20. package/lib/scrapers/base-scraper-with-browser.js +240 -269
  21. package/lib/scrapers/base-scraper.js +82 -86
  22. package/lib/scrapers/behatsdaa.js +98 -107
  23. package/lib/scrapers/beinleumi.js +11 -20
  24. package/lib/scrapers/beyahad-bishvilha.js +132 -138
  25. package/lib/scrapers/discount.js +97 -103
  26. package/lib/scrapers/errors.js +22 -25
  27. package/lib/scrapers/factory.js +66 -67
  28. package/lib/scrapers/hapoalim.js +162 -182
  29. package/lib/scrapers/interface.d.ts +12 -0
  30. package/lib/scrapers/interface.js +2 -5
  31. package/lib/scrapers/isracard.js +11 -13
  32. package/lib/scrapers/leumi.js +167 -176
  33. package/lib/scrapers/massad.js +11 -20
  34. package/lib/scrapers/max.js +256 -268
  35. package/lib/scrapers/mercantile.js +14 -20
  36. package/lib/scrapers/mizrahi.js +158 -159
  37. package/lib/scrapers/one-zero-queries.js +4 -7
  38. package/lib/scrapers/one-zero.js +176 -240
  39. package/lib/scrapers/otsar-hahayal.js +11 -20
  40. package/lib/scrapers/pagi.js +11 -20
  41. package/lib/scrapers/union-bank.js +172 -179
  42. package/lib/scrapers/visa-cal.js +254 -263
  43. package/lib/scrapers/yahav.js +190 -211
  44. package/lib/transactions.js +13 -16
  45. package/package.json +12 -14
  46. package/lib/scrapers/amex.test.d.ts +0 -1
  47. package/lib/scrapers/amex.test.js +0 -54
  48. package/lib/scrapers/base-scraper-with-browser.test.d.ts +0 -1
  49. package/lib/scrapers/base-scraper-with-browser.test.js +0 -58
  50. package/lib/scrapers/behatsdaa.test.d.ts +0 -1
  51. package/lib/scrapers/behatsdaa.test.js +0 -50
  52. package/lib/scrapers/beinleumi.test.d.ts +0 -1
  53. package/lib/scrapers/beinleumi.test.js +0 -52
  54. package/lib/scrapers/beyahad-bishvilha.test.d.ts +0 -1
  55. package/lib/scrapers/beyahad-bishvilha.test.js +0 -52
  56. package/lib/scrapers/discount.test.d.ts +0 -1
  57. package/lib/scrapers/discount.test.js +0 -54
  58. package/lib/scrapers/factory.test.d.ts +0 -1
  59. package/lib/scrapers/factory.test.js +0 -19
  60. package/lib/scrapers/hapoalim.test.d.ts +0 -1
  61. package/lib/scrapers/hapoalim.test.js +0 -52
  62. package/lib/scrapers/isracard.test.d.ts +0 -1
  63. package/lib/scrapers/isracard.test.js +0 -54
  64. package/lib/scrapers/leumi.test.d.ts +0 -1
  65. package/lib/scrapers/leumi.test.js +0 -52
  66. package/lib/scrapers/max.test.d.ts +0 -1
  67. package/lib/scrapers/max.test.js +0 -71
  68. package/lib/scrapers/mercantile.test.d.ts +0 -1
  69. package/lib/scrapers/mercantile.test.js +0 -50
  70. package/lib/scrapers/mizrahi.test.d.ts +0 -1
  71. package/lib/scrapers/mizrahi.test.js +0 -58
  72. package/lib/scrapers/one-zero.test.d.ts +0 -1
  73. package/lib/scrapers/one-zero.test.js +0 -56
  74. package/lib/scrapers/otsar-hahayal.test.d.ts +0 -1
  75. package/lib/scrapers/otsar-hahayal.test.js +0 -52
  76. package/lib/scrapers/pagi.test.d.ts +0 -1
  77. package/lib/scrapers/pagi.test.js +0 -52
  78. package/lib/scrapers/union-bank.test.d.ts +0 -1
  79. package/lib/scrapers/union-bank.test.js +0 -52
  80. package/lib/scrapers/visa-cal.test.d.ts +0 -1
  81. package/lib/scrapers/visa-cal.test.js +0 -54
  82. package/lib/scrapers/yahav.test.d.ts +0 -1
  83. package/lib/scrapers/yahav.test.js +0 -54
@@ -1,95 +1,91 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.BaseScraper = void 0;
7
- require("core-js/modules/es.promise.js");
8
- var _events = require("events");
9
- var _momentTimezone = _interopRequireDefault(require("moment-timezone"));
10
- var _definitions = require("../definitions");
11
- var _waiting = require("../helpers/waiting");
12
- var _errors = require("./errors");
13
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
14
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
15
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
16
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
+ const events_1 = require("events");
8
+ const moment_timezone_1 = __importDefault(require("moment-timezone"));
9
+ const definitions_1 = require("../definitions");
10
+ const waiting_1 = require("../helpers/waiting");
11
+ const errors_1 = require("./errors");
17
12
  const SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';
18
13
  class BaseScraper {
19
- constructor(options) {
20
- this.options = options;
21
- _defineProperty(this, "eventEmitter", new _events.EventEmitter());
22
- }
23
-
24
- // eslint-disable-next-line @typescript-eslint/require-await
25
- async initialize() {
26
- this.emitProgress(_definitions.ScraperProgressTypes.Initializing);
27
- _momentTimezone.default.tz.setDefault('Asia/Jerusalem');
28
- }
29
- async scrape(credentials) {
30
- this.emitProgress(_definitions.ScraperProgressTypes.StartScraping);
31
- await this.initialize();
32
- let loginResult;
33
- try {
34
- loginResult = await this.login(credentials);
35
- } catch (e) {
36
- loginResult = e instanceof _waiting.TimeoutError ? (0, _errors.createTimeoutError)(e.message) : (0, _errors.createGenericError)(e.message);
14
+ options;
15
+ eventEmitter = new events_1.EventEmitter();
16
+ constructor(options) {
17
+ this.options = options;
37
18
  }
38
- let scrapeResult;
39
- if (loginResult.success) {
40
- try {
41
- scrapeResult = await this.fetchData();
42
- } catch (e) {
43
- scrapeResult = e instanceof _waiting.TimeoutError ? (0, _errors.createTimeoutError)(e.message) : (0, _errors.createGenericError)(e.message);
44
- }
45
- } else {
46
- scrapeResult = loginResult;
19
+ // eslint-disable-next-line @typescript-eslint/require-await
20
+ async initialize() {
21
+ this.emitProgress(definitions_1.ScraperProgressTypes.Initializing);
22
+ moment_timezone_1.default.tz.setDefault('Asia/Jerusalem');
47
23
  }
48
- try {
49
- const success = scrapeResult && scrapeResult.success === true;
50
- await this.terminate(success);
51
- } catch (e) {
52
- scrapeResult = (0, _errors.createGenericError)(e.message);
24
+ async scrape(credentials) {
25
+ this.emitProgress(definitions_1.ScraperProgressTypes.StartScraping);
26
+ await this.initialize();
27
+ let loginResult;
28
+ try {
29
+ loginResult = await this.login(credentials);
30
+ }
31
+ catch (e) {
32
+ loginResult =
33
+ e instanceof waiting_1.TimeoutError ? (0, errors_1.createTimeoutError)(e.message) : (0, errors_1.createGenericError)(e.message);
34
+ }
35
+ let scrapeResult;
36
+ if (loginResult.success) {
37
+ try {
38
+ scrapeResult = await this.fetchData();
39
+ }
40
+ catch (e) {
41
+ scrapeResult =
42
+ e instanceof waiting_1.TimeoutError
43
+ ? (0, errors_1.createTimeoutError)(e.message)
44
+ : (0, errors_1.createGenericError)(e.message);
45
+ }
46
+ }
47
+ else {
48
+ scrapeResult = loginResult;
49
+ }
50
+ try {
51
+ const success = scrapeResult && scrapeResult.success === true;
52
+ await this.terminate(success);
53
+ }
54
+ catch (e) {
55
+ scrapeResult = (0, errors_1.createGenericError)(e.message);
56
+ }
57
+ this.emitProgress(definitions_1.ScraperProgressTypes.EndScraping);
58
+ return scrapeResult;
59
+ }
60
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
61
+ triggerTwoFactorAuth(_phoneNumber) {
62
+ throw new Error(`triggerOtp() is not created in ${this.options.companyId}`);
63
+ }
64
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
65
+ getLongTermTwoFactorToken(_otpCode) {
66
+ throw new Error(`getPermanentOtpToken() is not created in ${this.options.companyId}`);
67
+ }
68
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
69
+ async login(_credentials) {
70
+ throw new Error(`login() is not created in ${this.options.companyId}`);
71
+ }
72
+ // eslint-disable-next-line @typescript-eslint/require-await
73
+ async fetchData() {
74
+ throw new Error(`fetchData() is not created in ${this.options.companyId}`);
75
+ }
76
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
77
+ async terminate(_success) {
78
+ this.emitProgress(definitions_1.ScraperProgressTypes.Terminating);
79
+ }
80
+ emitProgress(type) {
81
+ this.emit(SCRAPE_PROGRESS, { type });
82
+ }
83
+ emit(eventName, payload) {
84
+ this.eventEmitter.emit(eventName, this.options.companyId, payload);
85
+ }
86
+ onProgress(func) {
87
+ this.eventEmitter.on(SCRAPE_PROGRESS, func);
53
88
  }
54
- this.emitProgress(_definitions.ScraperProgressTypes.EndScraping);
55
- return scrapeResult;
56
- }
57
-
58
- // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
59
- triggerTwoFactorAuth(_phoneNumber) {
60
- throw new Error(`triggerOtp() is not created in ${this.options.companyId}`);
61
- }
62
-
63
- // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
64
- getLongTermTwoFactorToken(_otpCode) {
65
- throw new Error(`getPermanentOtpToken() is not created in ${this.options.companyId}`);
66
- }
67
-
68
- // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
69
- async login(_credentials) {
70
- throw new Error(`login() is not created in ${this.options.companyId}`);
71
- }
72
-
73
- // eslint-disable-next-line @typescript-eslint/require-await
74
- async fetchData() {
75
- throw new Error(`fetchData() is not created in ${this.options.companyId}`);
76
- }
77
-
78
- // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
79
- async terminate(_success) {
80
- this.emitProgress(_definitions.ScraperProgressTypes.Terminating);
81
- }
82
- emitProgress(type) {
83
- this.emit(SCRAPE_PROGRESS, {
84
- type
85
- });
86
- }
87
- emit(eventName, payload) {
88
- this.eventEmitter.emit(eventName, this.options.companyId, payload);
89
- }
90
- onProgress(func) {
91
- this.eventEmitter.on(SCRAPE_PROGRESS, func);
92
- }
93
89
  }
94
90
  exports.BaseScraper = BaseScraper;
95
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_events","require","_momentTimezone","_interopRequireDefault","_definitions","_waiting","_errors","e","__esModule","default","_defineProperty","r","t","_toPropertyKey","Object","defineProperty","value","enumerable","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","SCRAPE_PROGRESS","BaseScraper","constructor","options","EventEmitter","initialize","emitProgress","ScraperProgressTypes","Initializing","moment","tz","setDefault","scrape","credentials","StartScraping","loginResult","login","TimeoutError","createTimeoutError","message","createGenericError","scrapeResult","success","fetchData","terminate","EndScraping","triggerTwoFactorAuth","_phoneNumber","Error","companyId","getLongTermTwoFactorToken","_otpCode","_credentials","_success","Terminating","type","emit","eventName","payload","eventEmitter","onProgress","func","on","exports"],"sources":["../../src/scrapers/base-scraper.ts"],"sourcesContent":["import { EventEmitter } from 'events';\nimport moment from 'moment-timezone';\nimport { type CompanyTypes, ScraperProgressTypes } from '../definitions';\nimport { TimeoutError } from '../helpers/waiting';\nimport { createGenericError, createTimeoutError } from './errors';\nimport {\n  type Scraper,\n  type ScraperCredentials,\n  type ScraperGetLongTermTwoFactorTokenResult,\n  type ScraperLoginResult,\n  type ScraperOptions,\n  type ScraperScrapingResult,\n  type ScraperTwoFactorAuthTriggerResult,\n} from './interface';\n\nconst SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';\n\nexport class BaseScraper<TCredentials extends ScraperCredentials> implements Scraper<TCredentials> {\n  private eventEmitter = new EventEmitter();\n\n  constructor(public options: ScraperOptions) {\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async initialize() {\n    this.emitProgress(ScraperProgressTypes.Initializing);\n    moment.tz.setDefault('Asia/Jerusalem');\n  }\n\n  async scrape(credentials: TCredentials): Promise<ScraperScrapingResult> {\n    this.emitProgress(ScraperProgressTypes.StartScraping);\n    await this.initialize();\n\n    let loginResult;\n    try {\n      loginResult = await this.login(credentials);\n    } catch (e) {\n      loginResult = e instanceof TimeoutError ?\n        createTimeoutError((e as Error).message) :\n        createGenericError((e as Error).message);\n    }\n\n    let scrapeResult;\n    if (loginResult.success) {\n      try {\n        scrapeResult = await this.fetchData();\n      } catch (e) {\n        scrapeResult =\n          e instanceof TimeoutError ?\n            createTimeoutError((e as Error).message) :\n            createGenericError((e as Error).message);\n      }\n    } else {\n      scrapeResult = loginResult;\n    }\n\n    try {\n      const success = scrapeResult && scrapeResult.success === true;\n      await this.terminate(success);\n    } catch (e) {\n      scrapeResult = createGenericError((e as Error).message);\n    }\n    this.emitProgress(ScraperProgressTypes.EndScraping);\n\n    return scrapeResult;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  triggerTwoFactorAuth(_phoneNumber: string): Promise<ScraperTwoFactorAuthTriggerResult> {\n    throw new Error(`triggerOtp() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  getLongTermTwoFactorToken(_otpCode: string): Promise<ScraperGetLongTermTwoFactorTokenResult> {\n    throw new Error(`getPermanentOtpToken() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  protected async login(_credentials: TCredentials): Promise<ScraperLoginResult> {\n    throw new Error(`login() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  protected async fetchData(): Promise<ScraperScrapingResult> {\n    throw new Error(`fetchData() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  protected async terminate(_success: boolean) {\n    this.emitProgress(ScraperProgressTypes.Terminating);\n  }\n\n  protected emitProgress(type: ScraperProgressTypes) {\n    this.emit(SCRAPE_PROGRESS, { type });\n  }\n\n  protected emit(eventName: string, payload: Record<string, any>) {\n    this.eventEmitter.emit(eventName, this.options.companyId, payload);\n  }\n\n  onProgress(func: (companyId: CompanyTypes, payload: { type: ScraperProgressTypes }) => void) {\n    this.eventEmitter.on(SCRAPE_PROGRESS, func);\n  }\n}\n"],"mappings":"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","ignoreList":[]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-scraper.js","sourceRoot":"","sources":["../../src/scrapers/base-scraper.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\nimport moment from 'moment-timezone';\nimport { type CompanyTypes, ScraperProgressTypes } from '../definitions';\nimport { TimeoutError } from '../helpers/waiting';\nimport { createGenericError, createTimeoutError } from './errors';\nimport {\n  type Scraper,\n  type ScraperCredentials,\n  type ScraperGetLongTermTwoFactorTokenResult,\n  type ScraperLoginResult,\n  type ScraperOptions,\n  type ScraperScrapingResult,\n  type ScraperTwoFactorAuthTriggerResult,\n} from './interface';\n\nconst SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';\n\nexport class BaseScraper<TCredentials extends ScraperCredentials> implements Scraper<TCredentials> {\n  private eventEmitter = new EventEmitter();\n\n  constructor(public options: ScraperOptions) {}\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async initialize() {\n    this.emitProgress(ScraperProgressTypes.Initializing);\n    moment.tz.setDefault('Asia/Jerusalem');\n  }\n\n  async scrape(credentials: TCredentials): Promise<ScraperScrapingResult> {\n    this.emitProgress(ScraperProgressTypes.StartScraping);\n    await this.initialize();\n\n    let loginResult;\n    try {\n      loginResult = await this.login(credentials);\n    } catch (e) {\n      loginResult =\n        e instanceof TimeoutError ? createTimeoutError((e as Error).message) : createGenericError((e as Error).message);\n    }\n\n    let scrapeResult;\n    if (loginResult.success) {\n      try {\n        scrapeResult = await this.fetchData();\n      } catch (e) {\n        scrapeResult =\n          e instanceof TimeoutError\n            ? createTimeoutError((e as Error).message)\n            : createGenericError((e as Error).message);\n      }\n    } else {\n      scrapeResult = loginResult;\n    }\n\n    try {\n      const success = scrapeResult && scrapeResult.success === true;\n      await this.terminate(success);\n    } catch (e) {\n      scrapeResult = createGenericError((e as Error).message);\n    }\n    this.emitProgress(ScraperProgressTypes.EndScraping);\n\n    return scrapeResult;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  triggerTwoFactorAuth(_phoneNumber: string): Promise<ScraperTwoFactorAuthTriggerResult> {\n    throw new Error(`triggerOtp() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  getLongTermTwoFactorToken(_otpCode: string): Promise<ScraperGetLongTermTwoFactorTokenResult> {\n    throw new Error(`getPermanentOtpToken() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  protected async login(_credentials: TCredentials): Promise<ScraperLoginResult> {\n    throw new Error(`login() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  protected async fetchData(): Promise<ScraperScrapingResult> {\n    throw new Error(`fetchData() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  protected async terminate(_success: boolean) {\n    this.emitProgress(ScraperProgressTypes.Terminating);\n  }\n\n  protected emitProgress(type: ScraperProgressTypes) {\n    this.emit(SCRAPE_PROGRESS, { type });\n  }\n\n  protected emit(eventName: string, payload: Record<string, any>) {\n    this.eventEmitter.emit(eventName, this.options.companyId, payload);\n  }\n\n  onProgress(func: (companyId: CompanyTypes, payload: { type: ScraperProgressTypes }) => void) {\n    this.eventEmitter.on(SCRAPE_PROGRESS, func);\n  }\n}\n"]}
@@ -1,117 +1,108 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- require("core-js/modules/es.array.iterator.js");
8
- require("core-js/modules/es.promise.js");
9
- var _moment = _interopRequireDefault(require("moment"));
10
- var _debug = require("../helpers/debug");
11
- var _elementsInteractions = require("../helpers/elements-interactions");
12
- var _fetch = require("../helpers/fetch");
13
- var _waiting = require("../helpers/waiting");
14
- var _transactions = require("../transactions");
15
- var _baseScraperWithBrowser = require("./base-scraper-with-browser");
16
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const moment_1 = __importDefault(require("moment"));
7
+ const debug_1 = require("../helpers/debug");
8
+ const elements_interactions_1 = require("../helpers/elements-interactions");
9
+ const fetch_1 = require("../helpers/fetch");
10
+ const waiting_1 = require("../helpers/waiting");
11
+ const transactions_1 = require("../transactions");
12
+ const base_scraper_with_browser_1 = require("./base-scraper-with-browser");
17
13
  const BASE_URL = 'https://www.behatsdaa.org.il';
18
14
  const LOGIN_URL = `${BASE_URL}/login`;
19
15
  const PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';
20
- const debug = (0, _debug.getDebug)('behatsdaa');
16
+ const debug = (0, debug_1.getDebug)('behatsdaa');
21
17
  function variantToTransaction(variant) {
22
- // The price is positive, make it negative as it's an expense
23
- const originalAmount = -variant.customerPrice;
24
- return {
25
- type: _transactions.TransactionTypes.Normal,
26
- identifier: variant.tTransactionID,
27
- date: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
28
- processedDate: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
29
- originalAmount,
30
- originalCurrency: 'ILS',
31
- chargedAmount: originalAmount,
32
- chargedCurrency: 'ILS',
33
- description: variant.name,
34
- status: _transactions.TransactionStatuses.Completed,
35
- memo: variant.variantName
36
- };
37
- }
38
- class BehatsdaaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
39
- getLoginOptions(credentials) {
18
+ // The price is positive, make it negative as it's an expense
19
+ const originalAmount = -variant.customerPrice;
40
20
  return {
41
- loginUrl: LOGIN_URL,
42
- fields: [{
43
- selector: '#loginId',
44
- value: credentials.id
45
- }, {
46
- selector: '#loginPassword',
47
- value: credentials.password
48
- }],
49
- checkReadiness: async () => {
50
- await Promise.all([(0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginPassword'), (0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginId')]);
51
- },
52
- possibleResults: {
53
- [_baseScraperWithBrowser.LoginResults.Success]: [`${BASE_URL}/`],
54
- [_baseScraperWithBrowser.LoginResults.InvalidPassword]: ['.custom-input-error-label']
55
- },
56
- submitButtonSelector: async () => {
57
- await (0, _waiting.sleep)(1000);
58
- debug('Trying to find submit button');
59
- const button = await this.page.$('xpath=//button[contains(., "התחברות")]');
60
- if (button) {
61
- debug('Submit button found');
62
- await button.click();
63
- } else {
64
- debug('Submit button not found');
65
- }
66
- }
21
+ type: transactions_1.TransactionTypes.Normal,
22
+ identifier: variant.tTransactionID,
23
+ date: (0, moment_1.default)(variant.orderDate).format('YYYY-MM-DD'),
24
+ processedDate: (0, moment_1.default)(variant.orderDate).format('YYYY-MM-DD'),
25
+ originalAmount,
26
+ originalCurrency: 'ILS',
27
+ chargedAmount: originalAmount,
28
+ chargedCurrency: 'ILS',
29
+ description: variant.name,
30
+ status: transactions_1.TransactionStatuses.Completed,
31
+ memo: variant.variantName,
67
32
  };
68
- }
69
- async fetchData() {
70
- var _res$data;
71
- const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));
72
- if (!token) {
73
- debug('Token not found in local storage');
74
- return {
75
- success: false,
76
- errorMessage: 'TokenNotFound'
77
- };
78
- }
79
- const body = {
80
- FromDate: (0, _moment.default)(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),
81
- ToDate: (0, _moment.default)().format('YYYY-MM-DDTHH:mm:ss'),
82
- BenefitStatusId: null
83
- };
84
- debug('Fetching data');
85
- const res = await (0, _fetch.fetchPostWithinPage)(this.page, PURCHASE_HISTORY_URL, body, {
86
- 'authorization': `Bearer ${token}`,
87
- 'Content-Type': 'application/json',
88
- 'organizationid': '20'
89
- });
90
- debug('Data fetched');
91
- if (res !== null && res !== void 0 && res.errorDescription || res !== null && res !== void 0 && (_res$data = res.data) !== null && _res$data !== void 0 && _res$data.errorDescription) {
92
- var _res$data2;
93
- debug('Error fetching data', res.errorDescription || ((_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : _res$data2.errorDescription));
94
- return {
95
- success: false,
96
- errorMessage: res.errorDescription
97
- };
33
+ }
34
+ class BehatsdaaScraper extends base_scraper_with_browser_1.BaseScraperWithBrowser {
35
+ getLoginOptions(credentials) {
36
+ return {
37
+ loginUrl: LOGIN_URL,
38
+ fields: [
39
+ { selector: '#loginId', value: credentials.id },
40
+ { selector: '#loginPassword', value: credentials.password },
41
+ ],
42
+ checkReadiness: async () => {
43
+ await Promise.all([
44
+ (0, elements_interactions_1.waitUntilElementFound)(this.page, '#loginPassword'),
45
+ (0, elements_interactions_1.waitUntilElementFound)(this.page, '#loginId'),
46
+ ]);
47
+ },
48
+ possibleResults: {
49
+ [base_scraper_with_browser_1.LoginResults.Success]: [`${BASE_URL}/`],
50
+ [base_scraper_with_browser_1.LoginResults.InvalidPassword]: ['.custom-input-error-label'],
51
+ },
52
+ submitButtonSelector: async () => {
53
+ await (0, waiting_1.sleep)(1000);
54
+ debug('Trying to find submit button');
55
+ const button = await this.page.$('xpath=//button[contains(., "התחברות")]');
56
+ if (button) {
57
+ debug('Submit button found');
58
+ await button.click();
59
+ }
60
+ else {
61
+ debug('Submit button not found');
62
+ }
63
+ },
64
+ };
98
65
  }
99
- if (!(res !== null && res !== void 0 && res.data)) {
100
- debug('No data found');
101
- return {
102
- success: false,
103
- errorMessage: 'NoData'
104
- };
66
+ async fetchData() {
67
+ const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));
68
+ if (!token) {
69
+ debug('Token not found in local storage');
70
+ return {
71
+ success: false,
72
+ errorMessage: 'TokenNotFound',
73
+ };
74
+ }
75
+ const body = {
76
+ FromDate: (0, moment_1.default)(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),
77
+ ToDate: (0, moment_1.default)().format('YYYY-MM-DDTHH:mm:ss'),
78
+ BenefitStatusId: null,
79
+ };
80
+ debug('Fetching data');
81
+ const res = await (0, fetch_1.fetchPostWithinPage)(this.page, PURCHASE_HISTORY_URL, body, {
82
+ authorization: `Bearer ${token}`,
83
+ 'Content-Type': 'application/json',
84
+ organizationid: '20',
85
+ });
86
+ debug('Data fetched');
87
+ if (res?.errorDescription || res?.data?.errorDescription) {
88
+ debug('Error fetching data', res.errorDescription || res.data?.errorDescription);
89
+ return { success: false, errorMessage: res.errorDescription };
90
+ }
91
+ if (!res?.data) {
92
+ debug('No data found');
93
+ return { success: false, errorMessage: 'NoData' };
94
+ }
95
+ debug('Data fetched successfully');
96
+ return {
97
+ success: true,
98
+ accounts: [
99
+ {
100
+ accountNumber: res.data.memberId,
101
+ txns: res.data.variants.map(variantToTransaction),
102
+ },
103
+ ],
104
+ };
105
105
  }
106
- debug('Data fetched successfully');
107
- return {
108
- success: true,
109
- accounts: [{
110
- accountNumber: res.data.memberId,
111
- txns: res.data.variants.map(variantToTransaction)
112
- }]
113
- };
114
- }
115
106
  }
116
- var _default = exports.default = BehatsdaaScraper;
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","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","_res$data","token","evaluate","window","localStorage","getItem","success","errorMessage","body","FromDate","options","startDate","ToDate","BenefitStatusId","res","fetchPostWithinPage","errorDescription","data","_res$data2","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        accountNumber: res.data.memberId,\n        txns: res.data.variants.map(variantToTransaction),\n      }],\n    };\n  }\n}\n\nexport default BehatsdaaScraper;\n"],"mappings":"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","ignoreList":[]}
107
+ exports.default = BehatsdaaScraper;
108
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"behatsdaa.js","sourceRoot":"","sources":["../../src/scrapers/behatsdaa.ts"],"names":[],"mappings":"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","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"]}
@@ -1,22 +1,13 @@
1
1
  "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.default = void 0;
7
- require("core-js/modules/es.array.iterator.js");
8
- var _baseBeinleumiGroup = _interopRequireDefault(require("./base-beinleumi-group"));
9
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
10
- function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
11
- function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
12
- function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
13
- class BeinleumiScraper extends _baseBeinleumiGroup.default {
14
- constructor(...args) {
15
- super(...args);
16
- _defineProperty(this, "BASE_URL", 'https://online.fibi.co.il');
17
- _defineProperty(this, "LOGIN_URL", `${this.BASE_URL}/MatafLoginService/MatafLoginServlet?bankId=FIBIPORTAL&site=Private&KODSAFA=HE`);
18
- _defineProperty(this, "TRANSACTIONS_URL", `${this.BASE_URL}/wps/myportal/FibiMenu/Online/OnAccountMngment/OnBalanceTrans/PrivateAccountFlow`);
19
- }
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const base_beinleumi_group_1 = __importDefault(require("./base-beinleumi-group"));
7
+ class BeinleumiScraper extends base_beinleumi_group_1.default {
8
+ BASE_URL = 'https://online.fibi.co.il';
9
+ LOGIN_URL = `${this.BASE_URL}/MatafLoginService/MatafLoginServlet?bankId=FIBIPORTAL&site=Private&KODSAFA=HE`;
10
+ TRANSACTIONS_URL = `${this.BASE_URL}/wps/myportal/FibiMenu/Online/OnAccountMngment/OnBalanceTrans/PrivateAccountFlow`;
20
11
  }
21
- var _default = exports.default = BeinleumiScraper;
22
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYmFzZUJlaW5sZXVtaUdyb3VwIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJfZGVmaW5lUHJvcGVydHkiLCJyIiwidCIsIl90b1Byb3BlcnR5S2V5IiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJ2YWx1ZSIsImVudW1lcmFibGUiLCJjb25maWd1cmFibGUiLCJ3cml0YWJsZSIsImkiLCJfdG9QcmltaXRpdmUiLCJTeW1ib2wiLCJ0b1ByaW1pdGl2ZSIsImNhbGwiLCJUeXBlRXJyb3IiLCJTdHJpbmciLCJOdW1iZXIiLCJCZWlubGV1bWlTY3JhcGVyIiwiQmVpbmxldW1pR3JvdXBCYXNlU2NyYXBlciIsImNvbnN0cnVjdG9yIiwiYXJncyIsIkJBU0VfVVJMIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2JlaW5sZXVtaS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmVpbmxldW1pR3JvdXBCYXNlU2NyYXBlciBmcm9tICcuL2Jhc2UtYmVpbmxldW1pLWdyb3VwJztcblxuY2xhc3MgQmVpbmxldW1pU2NyYXBlciBleHRlbmRzIEJlaW5sZXVtaUdyb3VwQmFzZVNjcmFwZXIge1xuICBCQVNFX1VSTCA9ICdodHRwczovL29ubGluZS5maWJpLmNvLmlsJztcblxuICBMT0dJTl9VUkwgPSBgJHt0aGlzLkJBU0VfVVJMfS9NYXRhZkxvZ2luU2VydmljZS9NYXRhZkxvZ2luU2VydmxldD9iYW5rSWQ9RklCSVBPUlRBTCZzaXRlPVByaXZhdGUmS09EU0FGQT1IRWA7XG5cbiAgVFJBTlNBQ1RJT05TX1VSTCA9IGAke3RoaXMuQkFTRV9VUkx9L3dwcy9teXBvcnRhbC9GaWJpTWVudS9PbmxpbmUvT25BY2NvdW50TW5nbWVudC9PbkJhbGFuY2VUcmFucy9Qcml2YXRlQWNjb3VudEZsb3dgO1xufVxuXG5leHBvcnQgZGVmYXVsdCBCZWlubGV1bWlTY3JhcGVyO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsbUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUErRCxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUFBLFNBQUFHLGdCQUFBSCxDQUFBLEVBQUFJLENBQUEsRUFBQUMsQ0FBQSxZQUFBRCxDQUFBLEdBQUFFLGNBQUEsQ0FBQUYsQ0FBQSxNQUFBSixDQUFBLEdBQUFPLE1BQUEsQ0FBQUMsY0FBQSxDQUFBUixDQUFBLEVBQUFJLENBQUEsSUFBQUssS0FBQSxFQUFBSixDQUFBLEVBQUFLLFVBQUEsTUFBQUMsWUFBQSxNQUFBQyxRQUFBLFVBQUFaLENBQUEsQ0FBQUksQ0FBQSxJQUFBQyxDQUFBLEVBQUFMLENBQUE7QUFBQSxTQUFBTSxlQUFBRCxDQUFBLFFBQUFRLENBQUEsR0FBQUMsWUFBQSxDQUFBVCxDQUFBLHVDQUFBUSxDQUFBLEdBQUFBLENBQUEsR0FBQUEsQ0FBQTtBQUFBLFNBQUFDLGFBQUFULENBQUEsRUFBQUQsQ0FBQSwyQkFBQUMsQ0FBQSxLQUFBQSxDQUFBLFNBQUFBLENBQUEsTUFBQUwsQ0FBQSxHQUFBSyxDQUFBLENBQUFVLE1BQUEsQ0FBQUMsV0FBQSxrQkFBQWhCLENBQUEsUUFBQWEsQ0FBQSxHQUFBYixDQUFBLENBQUFpQixJQUFBLENBQUFaLENBQUEsRUFBQUQsQ0FBQSx1Q0FBQVMsQ0FBQSxTQUFBQSxDQUFBLFlBQUFLLFNBQUEseUVBQUFkLENBQUEsR0FBQWUsTUFBQSxHQUFBQyxNQUFBLEVBQUFmLENBQUE7QUFFL0QsTUFBTWdCLGdCQUFnQixTQUFTQywyQkFBeUIsQ0FBQztFQUFBQyxZQUFBLEdBQUFDLElBQUE7SUFBQSxTQUFBQSxJQUFBO0lBQUFyQixlQUFBLG1CQUM1QywyQkFBMkI7SUFBQUEsZUFBQSxvQkFFMUIsR0FBRyxJQUFJLENBQUNzQixRQUFRLGdGQUFnRjtJQUFBdEIsZUFBQSwyQkFFekYsR0FBRyxJQUFJLENBQUNzQixRQUFRLGtGQUFrRjtFQUFBO0FBQ3ZIO0FBQUMsSUFBQUMsUUFBQSxHQUFBQyxPQUFBLENBQUF6QixPQUFBLEdBRWNtQixnQkFBZ0IiLCJpZ25vcmVMaXN0IjpbXX0=
12
+ exports.default = BeinleumiScraper;
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVpbmxldW1pLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2JlaW5sZXVtaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGtGQUErRDtBQUUvRCxNQUFNLGdCQUFpQixTQUFRLDhCQUF5QjtJQUN0RCxRQUFRLEdBQUcsMkJBQTJCLENBQUM7SUFFdkMsU0FBUyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsZ0ZBQWdGLENBQUM7SUFFN0csZ0JBQWdCLEdBQUcsR0FBRyxJQUFJLENBQUMsUUFBUSxrRkFBa0YsQ0FBQztDQUN2SDtBQUVELGtCQUFlLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJlaW5sZXVtaUdyb3VwQmFzZVNjcmFwZXIgZnJvbSAnLi9iYXNlLWJlaW5sZXVtaS1ncm91cCc7XG5cbmNsYXNzIEJlaW5sZXVtaVNjcmFwZXIgZXh0ZW5kcyBCZWlubGV1bWlHcm91cEJhc2VTY3JhcGVyIHtcbiAgQkFTRV9VUkwgPSAnaHR0cHM6Ly9vbmxpbmUuZmliaS5jby5pbCc7XG5cbiAgTE9HSU5fVVJMID0gYCR7dGhpcy5CQVNFX1VSTH0vTWF0YWZMb2dpblNlcnZpY2UvTWF0YWZMb2dpblNlcnZsZXQ/YmFua0lkPUZJQklQT1JUQUwmc2l0ZT1Qcml2YXRlJktPRFNBRkE9SEVgO1xuXG4gIFRSQU5TQUNUSU9OU19VUkwgPSBgJHt0aGlzLkJBU0VfVVJMfS93cHMvbXlwb3J0YWwvRmliaU1lbnUvT25saW5lL09uQWNjb3VudE1uZ21lbnQvT25CYWxhbmNlVHJhbnMvUHJpdmF0ZUFjY291bnRGbG93YDtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQmVpbmxldW1pU2NyYXBlcjtcbiJdfQ==