israeli-bank-scrapers 6.1.1 → 6.1.2

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 (79) hide show
  1. package/lib/assertNever.js +7 -5
  2. package/lib/constants.js +16 -13
  3. package/lib/definitions.js +113 -109
  4. package/lib/helpers/browser.js +13 -9
  5. package/lib/helpers/dates.js +19 -18
  6. package/lib/helpers/debug.js +9 -9
  7. package/lib/helpers/elements-interactions.js +82 -78
  8. package/lib/helpers/fetch.js +85 -82
  9. package/lib/helpers/navigation.js +28 -24
  10. package/lib/helpers/storage.js +11 -10
  11. package/lib/helpers/transactions.js +32 -33
  12. package/lib/helpers/waiting.js +42 -45
  13. package/lib/index.js +82 -15
  14. package/lib/scrapers/amex.js +13 -11
  15. package/lib/scrapers/amex.test.d.ts +1 -0
  16. package/lib/scrapers/amex.test.js +49 -0
  17. package/lib/scrapers/base-beinleumi-group.js +239 -233
  18. package/lib/scrapers/base-isracard-amex.js +273 -273
  19. package/lib/scrapers/base-scraper-with-browser.js +263 -241
  20. package/lib/scrapers/base-scraper-with-browser.test.d.ts +1 -0
  21. package/lib/scrapers/base-scraper-with-browser.test.js +53 -0
  22. package/lib/scrapers/base-scraper.js +82 -82
  23. package/lib/scrapers/behatsdaa.js +103 -98
  24. package/lib/scrapers/behatsdaa.test.d.ts +1 -0
  25. package/lib/scrapers/behatsdaa.test.js +46 -0
  26. package/lib/scrapers/beinleumi.js +13 -11
  27. package/lib/scrapers/beinleumi.test.d.ts +1 -0
  28. package/lib/scrapers/beinleumi.test.js +47 -0
  29. package/lib/scrapers/beyahad-bishvilha.js +132 -132
  30. package/lib/scrapers/beyahad-bishvilha.test.d.ts +1 -0
  31. package/lib/scrapers/beyahad-bishvilha.test.js +47 -0
  32. package/lib/scrapers/discount.js +101 -97
  33. package/lib/scrapers/discount.test.d.ts +1 -0
  34. package/lib/scrapers/discount.test.js +49 -0
  35. package/lib/scrapers/errors.js +25 -22
  36. package/lib/scrapers/factory.js +67 -66
  37. package/lib/scrapers/factory.test.d.ts +1 -0
  38. package/lib/scrapers/factory.test.js +19 -0
  39. package/lib/scrapers/hapoalim.js +175 -162
  40. package/lib/scrapers/hapoalim.test.d.ts +1 -0
  41. package/lib/scrapers/hapoalim.test.js +47 -0
  42. package/lib/scrapers/interface.js +5 -2
  43. package/lib/scrapers/isracard.js +13 -11
  44. package/lib/scrapers/isracard.test.d.ts +1 -0
  45. package/lib/scrapers/isracard.test.js +49 -0
  46. package/lib/scrapers/leumi.js +170 -167
  47. package/lib/scrapers/leumi.test.d.ts +1 -0
  48. package/lib/scrapers/leumi.test.js +47 -0
  49. package/lib/scrapers/massad.js +13 -11
  50. package/lib/scrapers/max.js +261 -261
  51. package/lib/scrapers/max.test.d.ts +1 -0
  52. package/lib/scrapers/max.test.js +65 -0
  53. package/lib/scrapers/mercantile.js +16 -14
  54. package/lib/scrapers/mercantile.test.d.ts +1 -0
  55. package/lib/scrapers/mercantile.test.js +45 -0
  56. package/lib/scrapers/mizrahi.js +154 -158
  57. package/lib/scrapers/mizrahi.test.d.ts +1 -0
  58. package/lib/scrapers/mizrahi.test.js +53 -0
  59. package/lib/scrapers/one-zero-queries.js +7 -4
  60. package/lib/scrapers/one-zero.js +221 -176
  61. package/lib/scrapers/one-zero.test.d.ts +1 -0
  62. package/lib/scrapers/one-zero.test.js +51 -0
  63. package/lib/scrapers/otsar-hahayal.js +13 -11
  64. package/lib/scrapers/otsar-hahayal.test.d.ts +1 -0
  65. package/lib/scrapers/otsar-hahayal.test.js +47 -0
  66. package/lib/scrapers/pagi.js +13 -11
  67. package/lib/scrapers/pagi.test.d.ts +1 -0
  68. package/lib/scrapers/pagi.test.js +47 -0
  69. package/lib/scrapers/union-bank.js +173 -172
  70. package/lib/scrapers/union-bank.test.d.ts +1 -0
  71. package/lib/scrapers/union-bank.test.js +47 -0
  72. package/lib/scrapers/visa-cal.js +250 -254
  73. package/lib/scrapers/visa-cal.test.d.ts +1 -0
  74. package/lib/scrapers/visa-cal.test.js +49 -0
  75. package/lib/scrapers/yahav.js +206 -190
  76. package/lib/scrapers/yahav.test.d.ts +1 -0
  77. package/lib/scrapers/yahav.test.js +49 -0
  78. package/lib/transactions.js +16 -13
  79. package/package.json +8 -3
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+
3
+ var _testsUtils = require("../tests/tests-utils");
4
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
5
+ const testsConfig = (0, _testsUtils.getTestsConfig)();
6
+ function isNoSandbox(browser) {
7
+ // eslint-disable-next-line no-underscore-dangle
8
+ const args = browser._process.spawnargs;
9
+ return args.includes('--no-sandbox');
10
+ }
11
+ describe('Base scraper with browser', () => {
12
+ beforeAll(() => {
13
+ (0, _testsUtils.extendAsyncTimeout)(); // The default timeout is 5 seconds per async test, this function extends the timeout value
14
+ });
15
+ xtest('should pass custom args to scraper if provided', async () => {
16
+ const options = {
17
+ ...testsConfig.options,
18
+ companyId: 'test',
19
+ showBrowser: false,
20
+ args: []
21
+ };
22
+
23
+ // avoid false-positive result by confirming that --no-sandbox is not a default flag provided by puppeteer
24
+ let baseScraperWithBrowser = new _baseScraperWithBrowser.BaseScraperWithBrowser(options);
25
+ try {
26
+ await baseScraperWithBrowser.initialize();
27
+ // @ts-ignore
28
+ expect(baseScraperWithBrowser.browser).toBeDefined();
29
+ // @ts-ignore
30
+ expect(isNoSandbox(baseScraperWithBrowser.browser)).toBe(false);
31
+ await baseScraperWithBrowser.terminate(true);
32
+ } catch (e) {
33
+ await baseScraperWithBrowser.terminate(false);
34
+ throw e;
35
+ }
36
+
37
+ // set --no-sandbox flag and expect it to be passed by puppeteer.lunch to the new created browser instance
38
+ options.args = ['--no-sandbox', '--disable-gpu', '--window-size=1920x1080'];
39
+ baseScraperWithBrowser = new _baseScraperWithBrowser.BaseScraperWithBrowser(options);
40
+ try {
41
+ await baseScraperWithBrowser.initialize();
42
+ // @ts-ignore
43
+ expect(baseScraperWithBrowser.browser).toBeDefined();
44
+ // @ts-ignore
45
+ expect(isNoSandbox(baseScraperWithBrowser.browser)).toBe(true);
46
+ await baseScraperWithBrowser.terminate(true);
47
+ } catch (e) {
48
+ await baseScraperWithBrowser.terminate(false);
49
+ throw e;
50
+ }
51
+ });
52
+ });
53
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdGVzdHNVdGlscyIsInJlcXVpcmUiLCJfYmFzZVNjcmFwZXJXaXRoQnJvd3NlciIsInRlc3RzQ29uZmlnIiwiZ2V0VGVzdHNDb25maWciLCJpc05vU2FuZGJveCIsImJyb3dzZXIiLCJhcmdzIiwiX3Byb2Nlc3MiLCJzcGF3bmFyZ3MiLCJpbmNsdWRlcyIsImRlc2NyaWJlIiwiYmVmb3JlQWxsIiwiZXh0ZW5kQXN5bmNUaW1lb3V0IiwieHRlc3QiLCJvcHRpb25zIiwiY29tcGFueUlkIiwic2hvd0Jyb3dzZXIiLCJiYXNlU2NyYXBlcldpdGhCcm93c2VyIiwiQmFzZVNjcmFwZXJXaXRoQnJvd3NlciIsImluaXRpYWxpemUiLCJleHBlY3QiLCJ0b0JlRGVmaW5lZCIsInRvQmUiLCJ0ZXJtaW5hdGUiLCJlIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2Jhc2Utc2NyYXBlci13aXRoLWJyb3dzZXIudGVzdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBleHRlbmRBc3luY1RpbWVvdXQsIGdldFRlc3RzQ29uZmlnIH0gZnJvbSAnLi4vdGVzdHMvdGVzdHMtdXRpbHMnO1xuaW1wb3J0IHsgQmFzZVNjcmFwZXJXaXRoQnJvd3NlciB9IGZyb20gJy4vYmFzZS1zY3JhcGVyLXdpdGgtYnJvd3Nlcic7XG5cbmNvbnN0IHRlc3RzQ29uZmlnID0gZ2V0VGVzdHNDb25maWcoKTtcblxuZnVuY3Rpb24gaXNOb1NhbmRib3goYnJvd3NlcjogYW55KSB7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby11bmRlcnNjb3JlLWRhbmdsZVxuICBjb25zdCBhcmdzID0gYnJvd3Nlci5fcHJvY2Vzcy5zcGF3bmFyZ3M7XG4gIHJldHVybiBhcmdzLmluY2x1ZGVzKCctLW5vLXNhbmRib3gnKTtcbn1cblxuZGVzY3JpYmUoJ0Jhc2Ugc2NyYXBlciB3aXRoIGJyb3dzZXInLCAoKSA9PiB7XG4gIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgZXh0ZW5kQXN5bmNUaW1lb3V0KCk7IC8vIFRoZSBkZWZhdWx0IHRpbWVvdXQgaXMgNSBzZWNvbmRzIHBlciBhc3luYyB0ZXN0LCB0aGlzIGZ1bmN0aW9uIGV4dGVuZHMgdGhlIHRpbWVvdXQgdmFsdWVcbiAgfSk7XG5cbiAgeHRlc3QoJ3Nob3VsZCBwYXNzIGN1c3RvbSBhcmdzIHRvIHNjcmFwZXIgaWYgcHJvdmlkZWQnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHtcbiAgICAgIC4uLnRlc3RzQ29uZmlnLm9wdGlvbnMsXG4gICAgICBjb21wYW55SWQ6ICd0ZXN0JyxcbiAgICAgIHNob3dCcm93c2VyOiBmYWxzZSxcbiAgICAgIGFyZ3M6IFtdLFxuICAgIH07XG5cbiAgICAvLyBhdm9pZCBmYWxzZS1wb3NpdGl2ZSByZXN1bHQgYnkgY29uZmlybWluZyB0aGF0IC0tbm8tc2FuZGJveCBpcyBub3QgYSBkZWZhdWx0IGZsYWcgcHJvdmlkZWQgYnkgcHVwcGV0ZWVyXG4gICAgbGV0IGJhc2VTY3JhcGVyV2l0aEJyb3dzZXIgPSBuZXcgQmFzZVNjcmFwZXJXaXRoQnJvd3NlcihvcHRpb25zKTtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci5pbml0aWFsaXplKCk7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBleHBlY3QoYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci5icm93c2VyKS50b0JlRGVmaW5lZCgpO1xuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgZXhwZWN0KGlzTm9TYW5kYm94KGJhc2VTY3JhcGVyV2l0aEJyb3dzZXIuYnJvd3NlcikpLnRvQmUoZmFsc2UpO1xuICAgICAgYXdhaXQgYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci50ZXJtaW5hdGUodHJ1ZSk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgYXdhaXQgYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci50ZXJtaW5hdGUoZmFsc2UpO1xuICAgICAgdGhyb3cgZTtcbiAgICB9XG5cbiAgICAvLyBzZXQgLS1uby1zYW5kYm94IGZsYWcgYW5kIGV4cGVjdCBpdCB0byBiZSBwYXNzZWQgYnkgcHVwcGV0ZWVyLmx1bmNoIHRvIHRoZSBuZXcgY3JlYXRlZCBicm93c2VyIGluc3RhbmNlXG4gICAgb3B0aW9ucy5hcmdzID0gWyctLW5vLXNhbmRib3gnLCAnLS1kaXNhYmxlLWdwdScsICctLXdpbmRvdy1zaXplPTE5MjB4MTA4MCddO1xuICAgIGJhc2VTY3JhcGVyV2l0aEJyb3dzZXIgPSBuZXcgQmFzZVNjcmFwZXJXaXRoQnJvd3NlcihvcHRpb25zKTtcbiAgICB0cnkge1xuICAgICAgYXdhaXQgYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci5pbml0aWFsaXplKCk7XG4gICAgICAvLyBAdHMtaWdub3JlXG4gICAgICBleHBlY3QoYmFzZVNjcmFwZXJXaXRoQnJvd3Nlci5icm93c2VyKS50b0JlRGVmaW5lZCgpO1xuICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgZXhwZWN0KGlzTm9TYW5kYm94KGJhc2VTY3JhcGVyV2l0aEJyb3dzZXIuYnJvd3NlcikpLnRvQmUodHJ1ZSk7XG4gICAgICBhd2FpdCBiYXNlU2NyYXBlcldpdGhCcm93c2VyLnRlcm1pbmF0ZSh0cnVlKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBhd2FpdCBiYXNlU2NyYXBlcldpdGhCcm93c2VyLnRlcm1pbmF0ZShmYWxzZSk7XG4gICAgICB0aHJvdyBlO1xuICAgIH1cbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxXQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyx1QkFBQSxHQUFBRCxPQUFBO0FBRUEsTUFBTUUsV0FBVyxHQUFHLElBQUFDLDBCQUFjLEVBQUMsQ0FBQztBQUVwQyxTQUFTQyxXQUFXQSxDQUFDQyxPQUFZLEVBQUU7RUFDakM7RUFDQSxNQUFNQyxJQUFJLEdBQUdELE9BQU8sQ0FBQ0UsUUFBUSxDQUFDQyxTQUFTO0VBQ3ZDLE9BQU9GLElBQUksQ0FBQ0csUUFBUSxDQUFDLGNBQWMsQ0FBQztBQUN0QztBQUVBQyxRQUFRLENBQUMsMkJBQTJCLEVBQUUsTUFBTTtFQUMxQ0MsU0FBUyxDQUFDLE1BQU07SUFDZCxJQUFBQyw4QkFBa0IsRUFBQyxDQUFDLENBQUMsQ0FBQztFQUN4QixDQUFDLENBQUM7RUFFRkMsS0FBSyxDQUFDLGdEQUFnRCxFQUFFLFlBQVk7SUFDbEUsTUFBTUMsT0FBTyxHQUFHO01BQ2QsR0FBR1osV0FBVyxDQUFDWSxPQUFPO01BQ3RCQyxTQUFTLEVBQUUsTUFBTTtNQUNqQkMsV0FBVyxFQUFFLEtBQUs7TUFDbEJWLElBQUksRUFBRTtJQUNSLENBQUM7O0lBRUQ7SUFDQSxJQUFJVyxzQkFBc0IsR0FBRyxJQUFJQyw4Q0FBc0IsQ0FBQ0osT0FBTyxDQUFDO0lBQ2hFLElBQUk7TUFDRixNQUFNRyxzQkFBc0IsQ0FBQ0UsVUFBVSxDQUFDLENBQUM7TUFDekM7TUFDQUMsTUFBTSxDQUFDSCxzQkFBc0IsQ0FBQ1osT0FBTyxDQUFDLENBQUNnQixXQUFXLENBQUMsQ0FBQztNQUNwRDtNQUNBRCxNQUFNLENBQUNoQixXQUFXLENBQUNhLHNCQUFzQixDQUFDWixPQUFPLENBQUMsQ0FBQyxDQUFDaUIsSUFBSSxDQUFDLEtBQUssQ0FBQztNQUMvRCxNQUFNTCxzQkFBc0IsQ0FBQ00sU0FBUyxDQUFDLElBQUksQ0FBQztJQUM5QyxDQUFDLENBQUMsT0FBT0MsQ0FBQyxFQUFFO01BQ1YsTUFBTVAsc0JBQXNCLENBQUNNLFNBQVMsQ0FBQyxLQUFLLENBQUM7TUFDN0MsTUFBTUMsQ0FBQztJQUNUOztJQUVBO0lBQ0FWLE9BQU8sQ0FBQ1IsSUFBSSxHQUFHLENBQUMsY0FBYyxFQUFFLGVBQWUsRUFBRSx5QkFBeUIsQ0FBQztJQUMzRVcsc0JBQXNCLEdBQUcsSUFBSUMsOENBQXNCLENBQUNKLE9BQU8sQ0FBQztJQUM1RCxJQUFJO01BQ0YsTUFBTUcsc0JBQXNCLENBQUNFLFVBQVUsQ0FBQyxDQUFDO01BQ3pDO01BQ0FDLE1BQU0sQ0FBQ0gsc0JBQXNCLENBQUNaLE9BQU8sQ0FBQyxDQUFDZ0IsV0FBVyxDQUFDLENBQUM7TUFDcEQ7TUFDQUQsTUFBTSxDQUFDaEIsV0FBVyxDQUFDYSxzQkFBc0IsQ0FBQ1osT0FBTyxDQUFDLENBQUMsQ0FBQ2lCLElBQUksQ0FBQyxJQUFJLENBQUM7TUFDOUQsTUFBTUwsc0JBQXNCLENBQUNNLFNBQVMsQ0FBQyxJQUFJLENBQUM7SUFDOUMsQ0FBQyxDQUFDLE9BQU9DLENBQUMsRUFBRTtNQUNWLE1BQU1QLHNCQUFzQixDQUFDTSxTQUFTLENBQUMsS0FBSyxDQUFDO01BQzdDLE1BQU1DLENBQUM7SUFDVDtFQUNGLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -1,91 +1,91 @@
1
1
  "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
6
  exports.BaseScraper = void 0;
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");
7
+ var _events = require("events");
8
+ var _momentTimezone = _interopRequireDefault(require("moment-timezone"));
9
+ var _definitions = require("../definitions");
10
+ var _waiting = require("../helpers/waiting");
11
+ var _errors = require("./errors");
12
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
13
  const SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';
13
14
  class BaseScraper {
14
- options;
15
- eventEmitter = new events_1.EventEmitter();
16
- constructor(options) {
17
- this.options = options;
15
+ eventEmitter = new _events.EventEmitter();
16
+ constructor(options) {
17
+ this.options = options;
18
+ }
19
+
20
+ // eslint-disable-next-line @typescript-eslint/require-await
21
+ async initialize() {
22
+ this.emitProgress(_definitions.ScraperProgressTypes.Initializing);
23
+ _momentTimezone.default.tz.setDefault('Asia/Jerusalem');
24
+ }
25
+ async scrape(credentials) {
26
+ this.emitProgress(_definitions.ScraperProgressTypes.StartScraping);
27
+ await this.initialize();
28
+ let loginResult;
29
+ try {
30
+ loginResult = await this.login(credentials);
31
+ } catch (e) {
32
+ loginResult = e instanceof _waiting.TimeoutError ? (0, _errors.createTimeoutError)(e.message) : (0, _errors.createGenericError)(e.message);
18
33
  }
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');
34
+ let scrapeResult;
35
+ if (loginResult.success) {
36
+ try {
37
+ scrapeResult = await this.fetchData();
38
+ } catch (e) {
39
+ scrapeResult = e instanceof _waiting.TimeoutError ? (0, _errors.createTimeoutError)(e.message) : (0, _errors.createGenericError)(e.message);
40
+ }
41
+ } else {
42
+ scrapeResult = loginResult;
23
43
  }
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);
44
+ try {
45
+ const success = scrapeResult && scrapeResult.success === true;
46
+ await this.terminate(success);
47
+ } catch (e) {
48
+ scrapeResult = (0, _errors.createGenericError)(e.message);
88
49
  }
50
+ this.emitProgress(_definitions.ScraperProgressTypes.EndScraping);
51
+ return scrapeResult;
52
+ }
53
+
54
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
55
+ triggerTwoFactorAuth(_phoneNumber) {
56
+ throw new Error(`triggerOtp() is not created in ${this.options.companyId}`);
57
+ }
58
+
59
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
60
+ getLongTermTwoFactorToken(_otpCode) {
61
+ throw new Error(`getPermanentOtpToken() is not created in ${this.options.companyId}`);
62
+ }
63
+
64
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
65
+ async login(_credentials) {
66
+ throw new Error(`login() is not created in ${this.options.companyId}`);
67
+ }
68
+
69
+ // eslint-disable-next-line @typescript-eslint/require-await
70
+ async fetchData() {
71
+ throw new Error(`fetchData() is not created in ${this.options.companyId}`);
72
+ }
73
+
74
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await
75
+ async terminate(_success) {
76
+ this.emitProgress(_definitions.ScraperProgressTypes.Terminating);
77
+ }
78
+ emitProgress(type) {
79
+ this.emit(SCRAPE_PROGRESS, {
80
+ type
81
+ });
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);
88
+ }
89
89
  }
90
90
  exports.BaseScraper = BaseScraper;
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"]}
91
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_events","require","_momentTimezone","_interopRequireDefault","_definitions","_waiting","_errors","e","__esModule","default","SCRAPE_PROGRESS","BaseScraper","eventEmitter","EventEmitter","constructor","options","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","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  // 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"],"mappings":"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","ignoreList":[]}
@@ -1,108 +1,113 @@
1
1
  "use strict";
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");
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _moment = _interopRequireDefault(require("moment"));
8
+ var _debug = require("../helpers/debug");
9
+ var _elementsInteractions = require("../helpers/elements-interactions");
10
+ var _fetch = require("../helpers/fetch");
11
+ var _waiting = require("../helpers/waiting");
12
+ var _transactions = require("../transactions");
13
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
14
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
13
15
  const BASE_URL = 'https://www.behatsdaa.org.il';
14
16
  const LOGIN_URL = `${BASE_URL}/login`;
15
17
  const PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';
16
- const debug = (0, debug_1.getDebug)('behatsdaa');
18
+ const debug = (0, _debug.getDebug)('behatsdaa');
17
19
  function variantToTransaction(variant) {
18
- // The price is positive, make it negative as it's an expense
19
- const originalAmount = -variant.customerPrice;
20
+ // The price is positive, make it negative as it's an expense
21
+ const originalAmount = -variant.customerPrice;
22
+ return {
23
+ type: _transactions.TransactionTypes.Normal,
24
+ identifier: variant.tTransactionID,
25
+ date: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
26
+ processedDate: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
27
+ originalAmount,
28
+ originalCurrency: 'ILS',
29
+ chargedAmount: originalAmount,
30
+ chargedCurrency: 'ILS',
31
+ description: variant.name,
32
+ status: _transactions.TransactionStatuses.Completed,
33
+ memo: variant.variantName
34
+ };
35
+ }
36
+ class BehatsdaaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
37
+ getLoginOptions(credentials) {
20
38
  return {
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,
39
+ loginUrl: LOGIN_URL,
40
+ fields: [{
41
+ selector: '#loginId',
42
+ value: credentials.id
43
+ }, {
44
+ selector: '#loginPassword',
45
+ value: credentials.password
46
+ }],
47
+ checkReadiness: async () => {
48
+ await Promise.all([(0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginPassword'), (0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginId')]);
49
+ },
50
+ possibleResults: {
51
+ [_baseScraperWithBrowser.LoginResults.Success]: [`${BASE_URL}/`],
52
+ [_baseScraperWithBrowser.LoginResults.InvalidPassword]: ['.custom-input-error-label']
53
+ },
54
+ submitButtonSelector: async () => {
55
+ await (0, _waiting.sleep)(1000);
56
+ debug('Trying to find submit button');
57
+ const button = await this.page.$('xpath=//button[contains(., "התחברות")]');
58
+ if (button) {
59
+ debug('Submit button found');
60
+ await button.click();
61
+ } else {
62
+ debug('Submit button not found');
63
+ }
64
+ }
32
65
  };
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
- };
66
+ }
67
+ async fetchData() {
68
+ const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));
69
+ if (!token) {
70
+ debug('Token not found in local storage');
71
+ return {
72
+ success: false,
73
+ errorMessage: 'TokenNotFound'
74
+ };
65
75
  }
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
- };
76
+ const body = {
77
+ FromDate: (0, _moment.default)(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),
78
+ ToDate: (0, _moment.default)().format('YYYY-MM-DDTHH:mm:ss'),
79
+ BenefitStatusId: null
80
+ };
81
+ debug('Fetching data');
82
+ const res = await (0, _fetch.fetchPostWithinPage)(this.page, PURCHASE_HISTORY_URL, body, {
83
+ authorization: `Bearer ${token}`,
84
+ 'Content-Type': 'application/json',
85
+ organizationid: '20'
86
+ });
87
+ debug('Data fetched');
88
+ if (res?.errorDescription || res?.data?.errorDescription) {
89
+ debug('Error fetching data', res.errorDescription || res.data?.errorDescription);
90
+ return {
91
+ success: false,
92
+ errorMessage: res.errorDescription
93
+ };
94
+ }
95
+ if (!res?.data) {
96
+ debug('No data found');
97
+ return {
98
+ success: false,
99
+ errorMessage: 'NoData'
100
+ };
105
101
  }
102
+ debug('Data fetched successfully');
103
+ return {
104
+ success: true,
105
+ accounts: [{
106
+ accountNumber: res.data.memberId,
107
+ txns: res.data.variants.map(variantToTransaction)
108
+ }]
109
+ };
110
+ }
106
111
  }
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"]}
112
+ var _default = exports.default = BehatsdaaScraper;
113
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_moment","_interopRequireDefault","require","_debug","_elementsInteractions","_fetch","_waiting","_transactions","_baseScraperWithBrowser","e","__esModule","default","BASE_URL","LOGIN_URL","PURCHASE_HISTORY_URL","debug","getDebug","variantToTransaction","variant","originalAmount","customerPrice","type","TransactionTypes","Normal","identifier","tTransactionID","date","moment","orderDate","format","processedDate","originalCurrency","chargedAmount","chargedCurrency","description","name","status","TransactionStatuses","Completed","memo","variantName","BehatsdaaScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","selector","value","id","password","checkReadiness","Promise","all","waitUntilElementFound","page","possibleResults","LoginResults","Success","InvalidPassword","submitButtonSelector","sleep","button","$","click","fetchData","token","evaluate","window","localStorage","getItem","success","errorMessage","body","FromDate","options","startDate","ToDate","BenefitStatusId","res","fetchPostWithinPage","authorization","organizationid","errorDescription","data","accounts","accountNumber","memberId","txns","variants","map","_default","exports"],"sources":["../../src/scrapers/behatsdaa.ts"],"sourcesContent":["import moment from 'moment';\nimport { getDebug } from '../helpers/debug';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { sleep } from '../helpers/waiting';\nimport { type Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, type LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport { type ScraperScrapingResult } from './interface';\n\nconst BASE_URL = 'https://www.behatsdaa.org.il';\nconst LOGIN_URL = `${BASE_URL}/login`;\nconst PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';\n\nconst debug = getDebug('behatsdaa');\n\ntype ScraperSpecificCredentials = { id: string; password: string };\n\ntype Variant = {\n  name: string;\n  variantName: string;\n  customerPrice: number;\n  orderDate: string; // ISO timestamp with no timezone\n  tTransactionID: string;\n};\n\ntype PurchaseHistoryResponse = {\n  data?: {\n    errorDescription?: string;\n    memberId: string;\n    variants: Variant[];\n  };\n  errorDescription?: string;\n};\n\nfunction variantToTransaction(variant: Variant): Transaction {\n  // The price is positive, make it negative as it's an expense\n  const originalAmount = -variant.customerPrice;\n  return {\n    type: TransactionTypes.Normal,\n    identifier: variant.tTransactionID,\n    date: moment(variant.orderDate).format('YYYY-MM-DD'),\n    processedDate: moment(variant.orderDate).format('YYYY-MM-DD'),\n    originalAmount,\n    originalCurrency: 'ILS',\n    chargedAmount: originalAmount,\n    chargedCurrency: 'ILS',\n    description: variant.name,\n    status: TransactionStatuses.Completed,\n    memo: variant.variantName,\n  };\n}\n\nclass BehatsdaaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  public getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: [\n        { selector: '#loginId', value: credentials.id },\n        { selector: '#loginPassword', value: credentials.password },\n      ],\n      checkReadiness: async () => {\n        await Promise.all([\n          waitUntilElementFound(this.page, '#loginPassword'),\n          waitUntilElementFound(this.page, '#loginId'),\n        ]);\n      },\n      possibleResults: {\n        [LoginResults.Success]: [`${BASE_URL}/`],\n        [LoginResults.InvalidPassword]: ['.custom-input-error-label'],\n      },\n      submitButtonSelector: async () => {\n        await sleep(1000);\n        debug('Trying to find submit button');\n        const button = await this.page.$('xpath=//button[contains(., \"התחברות\")]');\n        if (button) {\n          debug('Submit button found');\n          await button.click();\n        } else {\n          debug('Submit button not found');\n        }\n      },\n    };\n  }\n\n  async fetchData(): Promise<ScraperScrapingResult> {\n    const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));\n    if (!token) {\n      debug('Token not found in local storage');\n      return {\n        success: false,\n        errorMessage: 'TokenNotFound',\n      };\n    }\n\n    const body = {\n      FromDate: moment(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),\n      ToDate: moment().format('YYYY-MM-DDTHH:mm:ss'),\n      BenefitStatusId: null,\n    };\n\n    debug('Fetching data');\n\n    const res = await fetchPostWithinPage<PurchaseHistoryResponse>(this.page, PURCHASE_HISTORY_URL, body, {\n      authorization: `Bearer ${token}`,\n      'Content-Type': 'application/json',\n      organizationid: '20',\n    });\n\n    debug('Data fetched');\n\n    if (res?.errorDescription || res?.data?.errorDescription) {\n      debug('Error fetching data', res.errorDescription || res.data?.errorDescription);\n      return { success: false, errorMessage: res.errorDescription };\n    }\n\n    if (!res?.data) {\n      debug('No data found');\n      return { success: false, errorMessage: 'NoData' };\n    }\n\n    debug('Data fetched successfully');\n    return {\n      success: true,\n      accounts: [\n        {\n          accountNumber: res.data.memberId,\n          txns: res.data.variants.map(variantToTransaction),\n        },\n      ],\n    };\n  }\n}\n\nexport default BehatsdaaScraper;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ var _definitions = require("../definitions");
4
+ var _testsUtils = require("../tests/tests-utils");
5
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
6
+ var _behatsdaa = _interopRequireDefault(require("./behatsdaa"));
7
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
8
+ const testsConfig = (0, _testsUtils.getTestsConfig)();
9
+ describe('Behatsdaa scraper', () => {
10
+ beforeAll(() => {
11
+ (0, _testsUtils.extendAsyncTimeout)();
12
+ });
13
+ it('should expose login fields in scrapers constant', () => {
14
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa]).toBeDefined();
15
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa].loginFields).toContain('id');
16
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa].loginFields).toContain('password');
17
+ });
18
+ (0, _testsUtils.maybeTestCompanyAPI)(_definitions.CompanyTypes.behatsdaa, config => config.companyAPI.invalidPassword)('should fail on invalid user/password"', async () => {
19
+ const scraper = new _behatsdaa.default({
20
+ ...testsConfig.options,
21
+ companyId: _definitions.CompanyTypes.behatsdaa
22
+ });
23
+ const result = await scraper.scrape({
24
+ id: 'foofoofoo',
25
+ password: 'barbarbar'
26
+ });
27
+ expect(result).toBeDefined();
28
+ expect(result.success).toBeFalsy();
29
+ expect(result.errorType).toBe(_baseScraperWithBrowser.LoginResults.InvalidPassword);
30
+ });
31
+ (0, _testsUtils.maybeTestCompanyAPI)(_definitions.CompanyTypes.behatsdaa)('should scrape transactions', async () => {
32
+ const scraper = new _behatsdaa.default({
33
+ ...testsConfig.options,
34
+ companyId: _definitions.CompanyTypes.behatsdaa
35
+ });
36
+ const result = await scraper.scrape(testsConfig.credentials[_definitions.CompanyTypes.behatsdaa]);
37
+ expect(result).toBeDefined();
38
+ expect(result.errorMessage).toBeFalsy();
39
+ expect(result.errorType).toBeFalsy();
40
+ expect(result.success).toBeTruthy();
41
+ expect(result.accounts).toBeDefined();
42
+ expect(result.accounts).toHaveLength(1);
43
+ (0, _testsUtils.exportTransactions)(_definitions.CompanyTypes.behatsdaa, result.accounts || []);
44
+ });
45
+ });
46
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGVmaW5pdGlvbnMiLCJyZXF1aXJlIiwiX3Rlc3RzVXRpbHMiLCJfYmFzZVNjcmFwZXJXaXRoQnJvd3NlciIsIl9iZWhhdHNkYWEiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwidGVzdHNDb25maWciLCJnZXRUZXN0c0NvbmZpZyIsImRlc2NyaWJlIiwiYmVmb3JlQWxsIiwiZXh0ZW5kQXN5bmNUaW1lb3V0IiwiaXQiLCJleHBlY3QiLCJTQ1JBUEVSUyIsIkNvbXBhbnlUeXBlcyIsImJlaGF0c2RhYSIsInRvQmVEZWZpbmVkIiwibG9naW5GaWVsZHMiLCJ0b0NvbnRhaW4iLCJtYXliZVRlc3RDb21wYW55QVBJIiwiY29uZmlnIiwiY29tcGFueUFQSSIsImludmFsaWRQYXNzd29yZCIsInNjcmFwZXIiLCJCZWhhdHNkYWFTY3JhcGVyIiwib3B0aW9ucyIsImNvbXBhbnlJZCIsInJlc3VsdCIsInNjcmFwZSIsImlkIiwicGFzc3dvcmQiLCJzdWNjZXNzIiwidG9CZUZhbHN5IiwiZXJyb3JUeXBlIiwidG9CZSIsIkxvZ2luUmVzdWx0cyIsIkludmFsaWRQYXNzd29yZCIsImNyZWRlbnRpYWxzIiwiZXJyb3JNZXNzYWdlIiwidG9CZVRydXRoeSIsImFjY291bnRzIiwidG9IYXZlTGVuZ3RoIiwiZXhwb3J0VHJhbnNhY3Rpb25zIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2JlaGF0c2RhYS50ZXN0LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBhbnlUeXBlcywgU0NSQVBFUlMgfSBmcm9tICcuLi9kZWZpbml0aW9ucyc7XG5pbXBvcnQgeyBleHBvcnRUcmFuc2FjdGlvbnMsIGV4dGVuZEFzeW5jVGltZW91dCwgZ2V0VGVzdHNDb25maWcsIG1heWJlVGVzdENvbXBhbnlBUEkgfSBmcm9tICcuLi90ZXN0cy90ZXN0cy11dGlscyc7XG5pbXBvcnQgeyBMb2dpblJlc3VsdHMgfSBmcm9tICcuL2Jhc2Utc2NyYXBlci13aXRoLWJyb3dzZXInO1xuaW1wb3J0IEJlaGF0c2RhYVNjcmFwZXIgZnJvbSAnLi9iZWhhdHNkYWEnO1xuXG5jb25zdCB0ZXN0c0NvbmZpZyA9IGdldFRlc3RzQ29uZmlnKCk7XG5cbmRlc2NyaWJlKCdCZWhhdHNkYWEgc2NyYXBlcicsICgpID0+IHtcbiAgYmVmb3JlQWxsKCgpID0+IHtcbiAgICBleHRlbmRBc3luY1RpbWVvdXQoKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBleHBvc2UgbG9naW4gZmllbGRzIGluIHNjcmFwZXJzIGNvbnN0YW50JywgKCkgPT4ge1xuICAgIGV4cGVjdChTQ1JBUEVSU1tDb21wYW55VHlwZXMuYmVoYXRzZGFhXSkudG9CZURlZmluZWQoKTtcbiAgICBleHBlY3QoU0NSQVBFUlNbQ29tcGFueVR5cGVzLmJlaGF0c2RhYV0ubG9naW5GaWVsZHMpLnRvQ29udGFpbignaWQnKTtcbiAgICBleHBlY3QoU0NSQVBFUlNbQ29tcGFueVR5cGVzLmJlaGF0c2RhYV0ubG9naW5GaWVsZHMpLnRvQ29udGFpbigncGFzc3dvcmQnKTtcbiAgfSk7XG5cbiAgbWF5YmVUZXN0Q29tcGFueUFQSShDb21wYW55VHlwZXMuYmVoYXRzZGFhLCBjb25maWcgPT4gY29uZmlnLmNvbXBhbnlBUEkuaW52YWxpZFBhc3N3b3JkKShcbiAgICAnc2hvdWxkIGZhaWwgb24gaW52YWxpZCB1c2VyL3Bhc3N3b3JkXCInLFxuICAgIGFzeW5jICgpID0+IHtcbiAgICAgIGNvbnN0IHNjcmFwZXIgPSBuZXcgQmVoYXRzZGFhU2NyYXBlcih7XG4gICAgICAgIC4uLnRlc3RzQ29uZmlnLm9wdGlvbnMsXG4gICAgICAgIGNvbXBhbnlJZDogQ29tcGFueVR5cGVzLmJlaGF0c2RhYSxcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBzY3JhcGVyLnNjcmFwZSh7IGlkOiAnZm9vZm9vZm9vJywgcGFzc3dvcmQ6ICdiYXJiYXJiYXInIH0pO1xuXG4gICAgICBleHBlY3QocmVzdWx0KS50b0JlRGVmaW5lZCgpO1xuICAgICAgZXhwZWN0KHJlc3VsdC5zdWNjZXNzKS50b0JlRmFsc3koKTtcbiAgICAgIGV4cGVjdChyZXN1bHQuZXJyb3JUeXBlKS50b0JlKExvZ2luUmVzdWx0cy5JbnZhbGlkUGFzc3dvcmQpO1xuICAgIH0sXG4gICk7XG5cbiAgbWF5YmVUZXN0Q29tcGFueUFQSShDb21wYW55VHlwZXMuYmVoYXRzZGFhKSgnc2hvdWxkIHNjcmFwZSB0cmFuc2FjdGlvbnMnLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgc2NyYXBlciA9IG5ldyBCZWhhdHNkYWFTY3JhcGVyKHtcbiAgICAgIC4uLnRlc3RzQ29uZmlnLm9wdGlvbnMsXG4gICAgICBjb21wYW55SWQ6IENvbXBhbnlUeXBlcy5iZWhhdHNkYWEsXG4gICAgfSk7XG5cbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBzY3JhcGVyLnNjcmFwZSh0ZXN0c0NvbmZpZy5jcmVkZW50aWFsc1tDb21wYW55VHlwZXMuYmVoYXRzZGFhXSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9CZURlZmluZWQoKTtcbiAgICBleHBlY3QocmVzdWx0LmVycm9yTWVzc2FnZSkudG9CZUZhbHN5KCk7XG4gICAgZXhwZWN0KHJlc3VsdC5lcnJvclR5cGUpLnRvQmVGYWxzeSgpO1xuICAgIGV4cGVjdChyZXN1bHQuc3VjY2VzcykudG9CZVRydXRoeSgpO1xuICAgIGV4cGVjdChyZXN1bHQuYWNjb3VudHMpLnRvQmVEZWZpbmVkKCk7XG4gICAgZXhwZWN0KHJlc3VsdC5hY2NvdW50cykudG9IYXZlTGVuZ3RoKDEpO1xuICAgIGV4cG9ydFRyYW5zYWN0aW9ucyhDb21wYW55VHlwZXMuYmVoYXRzZGFhLCByZXN1bHQuYWNjb3VudHMgfHwgW10pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLElBQUFBLFlBQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLFdBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLHVCQUFBLEdB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
@@ -1,13 +1,15 @@
1
1
  "use strict";
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`;
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _baseBeinleumiGroup = _interopRequireDefault(require("./base-beinleumi-group"));
8
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
+ class BeinleumiScraper extends _baseBeinleumiGroup.default {
10
+ BASE_URL = 'https://online.fibi.co.il';
11
+ LOGIN_URL = `${this.BASE_URL}/MatafLoginService/MatafLoginServlet?bankId=FIBIPORTAL&site=Private&KODSAFA=HE`;
12
+ TRANSACTIONS_URL = `${this.BASE_URL}/wps/myportal/FibiMenu/Online/OnAccountMngment/OnBalanceTrans/PrivateAccountFlow`;
11
13
  }
12
- exports.default = BeinleumiScraper;
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVpbmxldW1pLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NjcmFwZXJzL2JlaW5sZXVtaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGtGQUErRDtBQUUvRCxNQUFNLGdCQUFpQixTQUFRLDhCQUF5QjtJQUN0RCxRQUFRLEdBQUcsMkJBQTJCLENBQUM7SUFFdkMsU0FBUyxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsZ0ZBQWdGLENBQUM7SUFFN0csZ0JBQWdCLEdBQUcsR0FBRyxJQUFJLENBQUMsUUFBUSxrRkFBa0YsQ0FBQztDQUN2SDtBQUVELGtCQUFlLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJlaW5sZXVtaUdyb3VwQmFzZVNjcmFwZXIgZnJvbSAnLi9iYXNlLWJlaW5sZXVtaS1ncm91cCc7XG5cbmNsYXNzIEJlaW5sZXVtaVNjcmFwZXIgZXh0ZW5kcyBCZWlubGV1bWlHcm91cEJhc2VTY3JhcGVyIHtcbiAgQkFTRV9VUkwgPSAnaHR0cHM6Ly9vbmxpbmUuZmliaS5jby5pbCc7XG5cbiAgTE9HSU5fVVJMID0gYCR7dGhpcy5CQVNFX1VSTH0vTWF0YWZMb2dpblNlcnZpY2UvTWF0YWZMb2dpblNlcnZsZXQ/YmFua0lkPUZJQklQT1JUQUwmc2l0ZT1Qcml2YXRlJktPRFNBRkE9SEVgO1xuXG4gIFRSQU5TQUNUSU9OU19VUkwgPSBgJHt0aGlzLkJBU0VfVVJMfS93cHMvbXlwb3J0YWwvRmliaU1lbnUvT25saW5lL09uQWNjb3VudE1uZ21lbnQvT25CYWxhbmNlVHJhbnMvUHJpdmF0ZUFjY291bnRGbG93YDtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQmVpbmxldW1pU2NyYXBlcjtcbiJdfQ==
14
+ var _default = exports.default = BeinleumiScraper;
15
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfYmFzZUJlaW5sZXVtaUdyb3VwIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJCZWlubGV1bWlTY3JhcGVyIiwiQmVpbmxldW1pR3JvdXBCYXNlU2NyYXBlciIsIkJBU0VfVVJMIiwiTE9HSU5fVVJMIiwiVFJBTlNBQ1RJT05TX1VSTCIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9iZWlubGV1bWkudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEJlaW5sZXVtaUdyb3VwQmFzZVNjcmFwZXIgZnJvbSAnLi9iYXNlLWJlaW5sZXVtaS1ncm91cCc7XG5cbmNsYXNzIEJlaW5sZXVtaVNjcmFwZXIgZXh0ZW5kcyBCZWlubGV1bWlHcm91cEJhc2VTY3JhcGVyIHtcbiAgQkFTRV9VUkwgPSAnaHR0cHM6Ly9vbmxpbmUuZmliaS5jby5pbCc7XG5cbiAgTE9HSU5fVVJMID0gYCR7dGhpcy5CQVNFX1VSTH0vTWF0YWZMb2dpblNlcnZpY2UvTWF0YWZMb2dpblNlcnZsZXQ/YmFua0lkPUZJQklQT1JUQUwmc2l0ZT1Qcml2YXRlJktPRFNBRkE9SEVgO1xuXG4gIFRSQU5TQUNUSU9OU19VUkwgPSBgJHt0aGlzLkJBU0VfVVJMfS93cHMvbXlwb3J0YWwvRmliaU1lbnUvT25saW5lL09uQWNjb3VudE1uZ21lbnQvT25CYWxhbmNlVHJhbnMvUHJpdmF0ZUFjY291bnRGbG93YDtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQmVpbmxldW1pU2NyYXBlcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsbUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUErRCxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUUvRCxNQUFNRyxnQkFBZ0IsU0FBU0MsMkJBQXlCLENBQUM7RUFDdkRDLFFBQVEsR0FBRywyQkFBMkI7RUFFdENDLFNBQVMsR0FBRyxHQUFHLElBQUksQ0FBQ0QsUUFBUSxnRkFBZ0Y7RUFFNUdFLGdCQUFnQixHQUFHLEdBQUcsSUFBSSxDQUFDRixRQUFRLGtGQUFrRjtBQUN2SDtBQUFDLElBQUFHLFFBQUEsR0FBQUMsT0FBQSxDQUFBUCxPQUFBLEdBRWNDLGdCQUFnQiIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1 @@
1
+ export {};