israeli-bank-scrapers 4.0.2 → 4.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -30,6 +30,7 @@ Currently only the following banks are supported:
30
30
  - Yahav (Thanks to [@gczobel](https://github.com/gczobel))
31
31
  - Beyhad Bishvilha - [ביחד בשבילך](https://www.hist.org.il/) (thanks [@esakal](https://github.com/esakal))
32
32
  - OneZero (Experimental) (thanks [@orzarchi](https://github.com/orzarchi))
33
+ - Behatsdaa - [בהצדעה](behatsdaa.org.il) (thanks [@daniel-hauser](https://github.com/daniel-hauser))
33
34
 
34
35
  # Prerequisites
35
36
  To use this you will need to have [Node.js](https://nodejs.org) >= 16.x installed.
@@ -0,0 +1 @@
1
+ export declare function assertNever(x: never, error?: string): never;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.assertNever = assertNever;
7
+
8
+ function assertNever(x, error = '') {
9
+ throw new Error(error || `Unexpected object: ${x}`);
10
+ }
11
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9hc3NlcnROZXZlci50cyJdLCJuYW1lcyI6WyJhc3NlcnROZXZlciIsIngiLCJlcnJvciIsIkVycm9yIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQU8sU0FBU0EsV0FBVCxDQUFxQkMsQ0FBckIsRUFBK0JDLEtBQUssR0FBRyxFQUF2QyxFQUFrRDtBQUN2RCxRQUFNLElBQUlDLEtBQUosQ0FBVUQsS0FBSyxJQUFLLHNCQUFxQkQsQ0FBRSxFQUEzQyxDQUFOO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gYXNzZXJ0TmV2ZXIoeDogbmV2ZXIsIGVycm9yID0gJycpOiBuZXZlciB7XG4gIHRocm93IG5ldyBFcnJvcihlcnJvciB8fCBgVW5leHBlY3RlZCBvYmplY3Q6ICR7eH1gKTtcbn1cbiJdfQ==
@@ -15,6 +15,7 @@ export declare enum CompanyTypes {
15
15
  leumi = "leumi",
16
16
  massad = "massad",
17
17
  yahav = "yahav",
18
+ behatsdaa = "behatsdaa",
18
19
  beyahadBishvilha = "beyahadBishvilha",
19
20
  oneZero = "oneZero"
20
21
  }
@@ -87,6 +88,10 @@ export declare const SCRAPERS: {
87
88
  name: string;
88
89
  loginFields: string[];
89
90
  };
91
+ behatsdaa: {
92
+ name: string;
93
+ loginFields: string[];
94
+ };
90
95
  };
91
96
  export declare enum ScraperProgressTypes {
92
97
  Initializing = "INITIALIZING",
@@ -26,6 +26,7 @@ exports.CompanyTypes = CompanyTypes;
26
26
  CompanyTypes["leumi"] = "leumi";
27
27
  CompanyTypes["massad"] = "massad";
28
28
  CompanyTypes["yahav"] = "yahav";
29
+ CompanyTypes["behatsdaa"] = "behatsdaa";
29
30
  CompanyTypes["beyahadBishvilha"] = "beyahadBishvilha";
30
31
  CompanyTypes["oneZero"] = "oneZero";
31
32
  })(CompanyTypes || (exports.CompanyTypes = CompanyTypes = {}));
@@ -100,6 +101,10 @@ const SCRAPERS = {
100
101
  [CompanyTypes.oneZero]: {
101
102
  name: 'One Zero',
102
103
  loginFields: ['email', PASSWORD_FIELD, 'otpCodeRetriever', 'phoneNumber', 'otpLongTermToken']
104
+ },
105
+ [CompanyTypes.behatsdaa]: {
106
+ name: 'Behatsdaa',
107
+ loginFields: ['id', PASSWORD_FIELD]
103
108
  }
104
109
  };
105
110
  exports.SCRAPERS = SCRAPERS;
@@ -116,4 +121,4 @@ exports.ScraperProgressTypes = ScraperProgressTypes;
116
121
  ScraperProgressTypes["EndScraping"] = "END_SCRAPING";
117
122
  ScraperProgressTypes["Terminating"] = "TERMINATING";
118
123
  })(ScraperProgressTypes || (exports.ScraperProgressTypes = ScraperProgressTypes = {}));
119
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZpbml0aW9ucy50cyJdLCJuYW1lcyI6WyJQQVNTV09SRF9GSUVMRCIsIkNvbXBhbnlUeXBlcyIsIlNDUkFQRVJTIiwiaGFwb2FsaW0iLCJuYW1lIiwibG9naW5GaWVsZHMiLCJoYXBvYWxpbUJlT25saW5lIiwibGV1bWkiLCJtaXpyYWhpIiwiZGlzY291bnQiLCJvdHNhckhhaGF5YWwiLCJsZXVtaUNhcmQiLCJtYXgiLCJ2aXNhQ2FsIiwiaXNyYWNhcmQiLCJhbWV4IiwidW5pb24iLCJiZWlubGV1bWkiLCJtYXNzYWQiLCJ5YWhhdiIsImJleWFoYWRCaXNodmlsaGEiLCJvbmVaZXJvIiwiU2NyYXBlclByb2dyZXNzVHlwZXMiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBRU8sTUFBTUEsY0FBYyxHQUFHLFVBQXZCOztJQUVLQyxZOzs7V0FBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7R0FBQUEsWSw0QkFBQUEsWTs7QUFvQkwsTUFBTUMsUUFBUSxHQUFHO0FBQ3RCLEdBQUNELFlBQVksQ0FBQ0UsUUFBZCxHQUF5QjtBQUN2QkMsSUFBQUEsSUFBSSxFQUFFLGVBRGlCO0FBRXZCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGVSxHQURIO0FBS3RCLEdBQUNDLFlBQVksQ0FBQ0ssZ0JBQWQsR0FBaUM7QUFBRTtBQUNqQ0YsSUFBQUEsSUFBSSxFQUFFLGVBRHlCO0FBRS9CQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVB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RGdCO0FBRXRCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxPQUFELEVBQVVMLGNBQVYsRUFBMEIsa0JBQTFCLEVBQThDLGFBQTlDLEVBQTZELGtCQUE3RDtBQUZTO0FBakVGLENBQWpCOztJQXVFS3NCLG9COzs7V0FBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7QUFBQUEsRUFBQUEsb0I7R0FBQUEsb0Isb0NBQUFBLG9CIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTk9USUNFOiBhdm9pZCBjaGFuZ2luZyBleHBvcnRlZCBrZXlzIGFzIHRoZXkgYXJlIHBhcnQgb2YgdGhlIHB1YmxpYyBhcGlcblxuZXhwb3J0IGNvbnN0IFBBU1NXT1JEX0ZJRUxEID0gJ3Bhc3N3b3JkJztcblxuZXhwb3J0IGVudW0gQ29tcGFueVR5cGVzIHtcbiAgaGFwb2FsaW0gPSAnaGFwb2FsaW0nLFxuICBoYXBvYWxpbUJlT25saW5lID0gJ2hhcG9hbGltQmVPbmxpbmUnLFxuICBiZWlubGV1bWkgPSAnYmVpbmxldW1pJyxcbiAgdW5pb24gPSAndW5pb24nLFxuICBhbWV4ID0gJ2FtZXgnLFxuICBpc3JhY2FyZCA9ICdpc3JhY2FyZCcsXG4gIHZpc2FDYWwgPSAndmlzYUNhbCcsXG4gIG1heCA9ICdtYXgnLFxuICBsZXVtaUNhcmQgPSAnbGV1bWlDYXJkJyxcbiAgb3RzYXJIYWhheWFsID0gJ290c2FySGFoYXlhbCcsXG4gIGRpc2NvdW50ID0gJ2Rpc2NvdW50JyxcbiAgbWl6cmFoaSA9ICdtaXpyYWhpJyxcbiAgbGV1bWkgPSAnbGV1bWknLFxuICBtYXNzYWQgPSAnbWFzc2FkJyxcbiAgeWFoYXYgPSAneWFoYXYnLFxuICBiZXlhaGFkQmlzaHZpbGhhID0gJ2JleWFoYWRCaXNodmlsaGEnLFxuICBvbmVaZXJvID0gJ29uZVplcm8nXG59XG5cbmV4cG9ydCBjb25zdCBTQ1JBUEVSUyA9IHtcbiAgW0NvbXBhbnlUeXBlcy5oYXBvYWxpbV06IHtcbiAgICBuYW1lOiAnQmFuayBIYXBvYWxpbScsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlckNvZGUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuaGFwb2FsaW1CZU9ubGluZV06IHsgLy8gVE9ETyByZW1vdmUgaW4gTWFqb3IgdmVyc2lvblxuICAgIG5hbWU6ICdCYW5rIEhhcG9hbGltJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VyQ29kZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5sZXVtaV06IHtcbiAgICBuYW1lOiAnQmFuayBMZXVtaScsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubWl6cmFoaV06IHtcbiAgICBuYW1lOiAnTWl6cmFoaSBCYW5rJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5kaXNjb3VudF06IHtcbiAgICBuYW1lOiAnRGlzY291bnQgQmFuaycsXG4gICAgbG9naW5GaWVsZHM6IFsnaWQnLCBQQVNTV09SRF9GSUVMRCwgJ251bSddLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm90c2FySGFoYXlhbF06IHtcbiAgICBuYW1lOiAnQmFuayBPdHNhciBIYWhheWFsJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5sZXVtaUNhcmRdOiB7IC8vIFRPRE8gcmVtb3ZlIGluIE1ham9yIHZlcnNpb25cbiAgICBuYW1lOiAnTGV1bWkgQ2FyZCcsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubWF4XToge1xuICAgIG5hbWU6ICdNYXgnLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLnZpc2FDYWxdOiB7XG4gICAgbmFtZTogJ1Zpc2EgQ2FsJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5pc3JhY2FyZF06IHtcbiAgICBuYW1lOiAnSXNyYWNhcmQnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgJ2NhcmQ2RGlnaXRzJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLmFtZXhdOiB7XG4gICAgbmFtZTogJ0FtZXgnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgJ2NhcmQ2RGlnaXRzJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLnVuaW9uXToge1xuICAgIG5hbWU6ICdVbmlvbicsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuYmVpbmxldW1pXToge1xuICAgIG5hbWU6ICdCZWlubGV1bWknLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm1hc3NhZF06IHtcbiAgICBuYW1lOiAnTWFzc2FkJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy55YWhhdl06IHtcbiAgICBuYW1lOiAnQmFuayBZYWhhdicsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCAnbmF0aW9uYWxJRCcsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5iZXlhaGFkQmlzaHZpbGhhXToge1xuICAgIG5hbWU6ICdCZXlhaGFkIEJpc2h2aWxoYScsXG4gICAgbG9naW5GaWVsZHM6IFsnaWQnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMub25lWmVyb106IHtcbiAgICBuYW1lOiAnT25lIFplcm8nLFxuICAgIGxvZ2luRmllbGRzOiBbJ2VtYWlsJywgUEFTU1dPUkRfRklFTEQsICdvdHBDb2RlUmV0cmlldmVyJywgJ3Bob25lTnVtYmVyJywgJ290cExvbmdUZXJtVG9rZW4nXSxcbiAgfSxcbn07XG5cbmV4cG9ydCBlbnVtIFNjcmFwZXJQcm9ncmVzc1R5cGVzIHtcbiAgSW5pdGlhbGl6aW5nID0gJ0lOSVRJQUxJWklORycsXG4gIFN0YXJ0U2NyYXBpbmcgPSAnU1RBUlRfU0NSQVBJTkcnLFxuICBMb2dnaW5nSW4gPSAnTE9HR0lOR19JTicsXG4gIExvZ2luU3VjY2VzcyA9ICdMT0dJTl9TVUNDRVNTJyxcbiAgTG9naW5GYWlsZWQgPSAnTE9HSU5fRkFJTEVEJyxcbiAgQ2hhbmdlUGFzc3dvcmQgPSAnQ0hBTkdFX1BBU1NXT1JEJyxcbiAgRW5kU2NyYXBpbmcgPSAnRU5EX1NDUkFQSU5HJyxcbiAgVGVybWluYXRpbmcgPSAnVEVSTUlOQVRJTkcnLFxufVxuIl19
124
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/definitions.ts"],"names":["PASSWORD_FIELD","CompanyTypes","SCRAPERS","hapoalim","name","loginFields","hapoalimBeOnline","leumi","mizrahi","discount","otsarHahayal","leumiCard","max","visaCal","isracard","amex","union","beinleumi","massad","yahav","beyahadBishvilha","oneZero","behatsdaa","ScraperProgressTypes"],"mappings":"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","sourcesContent":["// NOTICE: avoid changing exported keys as they are part of the public api\n\nexport const PASSWORD_FIELD = 'password';\n\nexport enum CompanyTypes {\n  hapoalim = 'hapoalim',\n  hapoalimBeOnline = 'hapoalimBeOnline',\n  beinleumi = 'beinleumi',\n  union = 'union',\n  amex = 'amex',\n  isracard = 'isracard',\n  visaCal = 'visaCal',\n  max = 'max',\n  leumiCard = 'leumiCard',\n  otsarHahayal = 'otsarHahayal',\n  discount = 'discount',\n  mizrahi = 'mizrahi',\n  leumi = 'leumi',\n  massad = 'massad',\n  yahav = 'yahav',\n  behatsdaa = 'behatsdaa',\n  beyahadBishvilha = 'beyahadBishvilha',\n  oneZero = 'oneZero'\n}\n\nexport const SCRAPERS = {\n  [CompanyTypes.hapoalim]: {\n    name: 'Bank Hapoalim',\n    loginFields: ['userCode', PASSWORD_FIELD],\n  },\n  [CompanyTypes.hapoalimBeOnline]: { // TODO remove in Major version\n    name: 'Bank Hapoalim',\n    loginFields: ['userCode', PASSWORD_FIELD],\n  },\n  [CompanyTypes.leumi]: {\n    name: 'Bank Leumi',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.mizrahi]: {\n    name: 'Mizrahi Bank',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.discount]: {\n    name: 'Discount Bank',\n    loginFields: ['id', PASSWORD_FIELD, 'num'],\n  },\n  [CompanyTypes.otsarHahayal]: {\n    name: 'Bank Otsar Hahayal',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.leumiCard]: { // TODO remove in Major version\n    name: 'Leumi Card',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.max]: {\n    name: 'Max',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.visaCal]: {\n    name: 'Visa Cal',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.isracard]: {\n    name: 'Isracard',\n    loginFields: ['id', 'card6Digits', PASSWORD_FIELD],\n  },\n  [CompanyTypes.amex]: {\n    name: 'Amex',\n    loginFields: ['id', 'card6Digits', PASSWORD_FIELD],\n  },\n  [CompanyTypes.union]: {\n    name: 'Union',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.beinleumi]: {\n    name: 'Beinleumi',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.massad]: {\n    name: 'Massad',\n    loginFields: ['username', PASSWORD_FIELD],\n  },\n  [CompanyTypes.yahav]: {\n    name: 'Bank Yahav',\n    loginFields: ['username', 'nationalID', PASSWORD_FIELD],\n  },\n  [CompanyTypes.beyahadBishvilha]: {\n    name: 'Beyahad Bishvilha',\n    loginFields: ['id', PASSWORD_FIELD],\n  },\n  [CompanyTypes.oneZero]: {\n    name: 'One Zero',\n    loginFields: ['email', PASSWORD_FIELD, 'otpCodeRetriever', 'phoneNumber', 'otpLongTermToken'],\n  },\n  [CompanyTypes.behatsdaa]: {\n    name: 'Behatsdaa',\n    loginFields: ['id', PASSWORD_FIELD],\n  },\n};\n\nexport enum ScraperProgressTypes {\n  Initializing = 'INITIALIZING',\n  StartScraping = 'START_SCRAPING',\n  LoggingIn = 'LOGGING_IN',\n  LoginSuccess = 'LOGIN_SUCCESS',\n  LoginFailed = 'LOGIN_FAILED',\n  ChangePassword = 'CHANGE_PASSWORD',\n  EndScraping = 'END_SCRAPING',\n  Terminating = 'TERMINATING',\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Browser, Frame, Page } from 'puppeteer';
1
+ import { Browser, Frame, Page, LoadEvent } from 'puppeteer';
2
2
  import { BaseScraper } from './base-scraper';
3
3
  import { ScraperErrorTypes } from './errors';
4
4
  import { ScraperScrapingResult, ScraperCredentials } from './interface';
@@ -32,6 +32,7 @@ export interface LoginOptions {
32
32
  postAction?: () => Promise<void>;
33
33
  possibleResults: PossibleLoginResults;
34
34
  userAgent?: string;
35
+ waitUntil?: LoadEvent;
35
36
  }
36
37
  declare class BaseScraperWithBrowser<TCredentials extends ScraperCredentials> extends BaseScraper<TCredentials> {
37
38
  protected browser: Browser;
@@ -41,7 +42,7 @@ declare class BaseScraperWithBrowser<TCredentials extends ScraperCredentials> ex
41
42
  height: number;
42
43
  };
43
44
  initialize(): Promise<void>;
44
- navigateTo(url: string, page?: Page, timeout?: number): Promise<void>;
45
+ navigateTo(url: string, page?: Page, timeout?: number, waitUntil?: LoadEvent | undefined): Promise<void>;
45
46
  getLoginOptions(_credentials: ScraperCredentials): LoginOptions;
46
47
  fillInputs(pageOrFrame: Page | Frame, fields: {
47
48
  selector: string;
@@ -185,7 +185,7 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
185
185
  });
186
186
  }
187
187
 
188
- async navigateTo(url, page, timeout) {
188
+ async navigateTo(url, page, timeout, waitUntil = 'load') {
189
189
  const pageToUse = page || this.page;
190
190
 
191
191
  if (!pageToUse) {
@@ -194,6 +194,8 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
194
194
 
195
195
  const options = _objectSpread({}, timeout === null ? null : {
196
196
  timeout
197
+ }, {
198
+ waitUntil
197
199
  });
198
200
 
199
201
  const response = await pageToUse.goto(url, options); // note: response will be null when navigating to same url while changing the hash part. the condition below will always accept null as valid result.
@@ -237,7 +239,7 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
237
239
  }
238
240
 
239
241
  debug('navigate to login url');
240
- await this.navigateTo(loginOptions.loginUrl);
242
+ await this.navigateTo(loginOptions.loginUrl, undefined, undefined, loginOptions.waitUntil);
241
243
 
242
244
  if (loginOptions.checkReadiness) {
243
245
  debug('execute \'checkReadiness\' interceptor provided in login options');
@@ -332,4 +334,4 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
332
334
  }
333
335
 
334
336
  exports.BaseScraperWithBrowser = BaseScraperWithBrowser;
335
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/base-scraper-with-browser.ts"],"names":["VIEWPORT_WIDTH","VIEWPORT_HEIGHT","OK_STATUS","debug","LoginBaseResults","Timeout","Generic","General","ScraperErrorTypes","rest","LoginResults","getKeyByValue","object","value","page","keys","Object","key","conditions","condition","result","RegExp","test","toLowerCase","Promise","resolve","UnknownError","createGeneralError","success","errorType","BaseScraperWithBrowser","BaseScraper","getViewPort","width","height","initialize","emitProgress","ScraperProgressTypes","Initializing","env","options","verbose","DEBUG","process","browser","executablePath","undefined","args","timeout","headless","showBrowser","puppeteer","launch","prepareBrowser","pages","length","newPage","defaultTimeout","setDefaultTimeout","preparePage","viewport","setViewport","on","request","failure","errorText","url","navigateTo","pageToUse","response","goto","status","Error","getLoginOptions","_credentials","companyId","fillInputs","pageOrFrame","fields","modified","input","shift","selector","login","credentials","loginOptions","userAgent","setUserAgent","loginUrl","checkReadiness","submitButtonSelector","loginFrameOrPage","preAction","LoggingIn","postAction","current","loginResult","possibleResults","handleLoginResult","terminate","_success","Terminating","storeFailureScreenShotPath","screenshot","path","fullPage","close","Success","LoginSuccess","InvalidPassword","LoginFailed","errorMessage","ChangePassword"],"mappings":"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","sourcesContent":["import puppeteer, { Browser, Frame, Page } from 'puppeteer';\n\nimport {\n  BaseScraper,\n\n} from './base-scraper';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { clickButton, fillInput, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { getDebug } from '../helpers/debug';\nimport { ScraperErrorTypes } from './errors';\nimport { ScraperScrapingResult, ScraperCredentials } from './interface';\nimport { ScraperProgressTypes } from '../definitions';\n\nconst VIEWPORT_WIDTH = 1024;\nconst VIEWPORT_HEIGHT = 768;\nconst OK_STATUS = 200;\n\nconst debug = getDebug('base-scraper-with-browser');\n\nenum LoginBaseResults {\n  Success = 'SUCCESS',\n  UnknownError = 'UNKNOWN_ERROR'\n}\n\nconst {\n  Timeout, Generic, General, ...rest\n} = ScraperErrorTypes;\nexport const LoginResults = {\n  ...rest,\n  ...LoginBaseResults,\n};\n\nexport type LoginResults = Exclude<ScraperErrorTypes,\nScraperErrorTypes.Timeout\n| ScraperErrorTypes.Generic\n| ScraperErrorTypes.General> | LoginBaseResults;\n\nexport type PossibleLoginResults = {\n  [key in LoginResults]?: (string | RegExp | ((options?: { page?: Page}) => Promise<boolean>))[]\n};\n\nexport interface LoginOptions {\n  loginUrl: string;\n  checkReadiness?: () => Promise<void>;\n  fields: {selector: string, value: string}[];\n  submitButtonSelector: string | (() => Promise<void>);\n  preAction?: () => Promise<Frame | void>;\n  postAction?: () => Promise<void>;\n  possibleResults: PossibleLoginResults;\n  userAgent?: string;\n}\n\nasync function getKeyByValue(object: PossibleLoginResults, value: string, page: Page): Promise<LoginResults> {\n  const keys = Object.keys(object);\n  for (const key of keys) {\n    // @ts-ignore\n    const conditions = object[key];\n\n    for (const condition of conditions) {\n      let result = false;\n\n      if (condition instanceof RegExp) {\n        result = condition.test(value);\n      } else if (typeof condition === 'function') {\n        result = await condition({ page, value });\n      } else {\n        result = value.toLowerCase() === condition.toLowerCase();\n      }\n\n      if (result) {\n        // @ts-ignore\n        return Promise.resolve(key);\n      }\n    }\n  }\n\n  return Promise.resolve(LoginResults.UnknownError);\n}\n\nfunction createGeneralError(): ScraperScrapingResult {\n  return {\n    success: false,\n    errorType: ScraperErrorTypes.General,\n  };\n}\n\nclass BaseScraperWithBrowser<TCredentials extends ScraperCredentials> extends BaseScraper<TCredentials> {\n  // NOTICE - it is discouraged to use bang (!) in general. It is used here because\n  // all the classes that inherit from this base assume is it mandatory.\n  protected browser!: Browser;\n\n  // NOTICE - it is discouraged to use bang (!) in general. It is used here because\n  // all the classes that inherit from this base assume is it mandatory.\n  protected page!: Page;\n\n  protected getViewPort() {\n    return {\n      width: VIEWPORT_WIDTH,\n      height: VIEWPORT_HEIGHT,\n    };\n  }\n\n  async initialize() {\n    await super.initialize();\n    debug('initialize scraper');\n    this.emitProgress(ScraperProgressTypes.Initializing);\n\n    let env: Record<string, any> | undefined;\n    if (this.options.verbose) {\n      env = { DEBUG: '*', ...process.env };\n    }\n\n    if (typeof this.options.browser !== 'undefined' && this.options.browser !== null) {\n      debug('use custom browser instance provided in options');\n      this.browser = this.options.browser;\n    } else {\n      const executablePath = this.options.executablePath || undefined;\n      const args = this.options.args || [];\n      const { timeout } = this.options;\n\n      const headless = !this.options.showBrowser;\n      debug(`launch a browser with headless mode = ${headless}`);\n      this.browser = await puppeteer.launch({\n        env,\n        headless,\n        executablePath,\n        args,\n        timeout,\n      });\n    }\n\n    if (this.options.prepareBrowser) {\n      debug('execute \\'prepareBrowser\\' interceptor provided in options');\n      await this.options.prepareBrowser(this.browser);\n    }\n\n    if (!this.browser) {\n      debug('failed to initiate a browser, exit');\n      return;\n    }\n\n    const pages = await this.browser.pages();\n    if (pages.length) {\n      debug('browser has already pages open, use the first one');\n      [this.page] = pages;\n    } else {\n      debug('create a new browser page');\n      this.page = await this.browser.newPage();\n    }\n\n    if (this.options.defaultTimeout) {\n      this.page.setDefaultTimeout(this.options.defaultTimeout);\n    }\n\n    if (this.options.preparePage) {\n      debug('execute \\'preparePage\\' interceptor provided in options');\n      await this.options.preparePage(this.page);\n    }\n\n    const viewport = this.getViewPort();\n    debug(`set viewport to width ${viewport.width}, height ${viewport.height}`);\n    await this.page.setViewport({\n      width: viewport.width,\n      height: viewport.height,\n    });\n\n    this.page.on('requestfailed', (request) => {\n      debug('Request failed: %s %s', request.failure()?.errorText, request.url());\n    });\n  }\n\n  async navigateTo(url: string, page?: Page, timeout?: number): Promise<void> {\n    const pageToUse = page || this.page;\n\n    if (!pageToUse) {\n      return;\n    }\n\n    const options = { ...(timeout === null ? null : { timeout }) };\n    const response = await pageToUse.goto(url, options);\n\n    // note: response will be null when navigating to same url while changing the hash part. the condition below will always accept null as valid result.\n    if (response !== null && (response === undefined || response.status() !== OK_STATUS)) {\n      throw new Error(`Error while trying to navigate to url ${url}`);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  getLoginOptions(_credentials: ScraperCredentials): LoginOptions {\n    throw new Error(`getLoginOptions() is not created in ${this.options.companyId}`);\n  }\n\n  async fillInputs(pageOrFrame: Page | Frame, fields: { selector: string, value: string}[]): Promise<void> {\n    const modified = [...fields];\n    const input = modified.shift();\n\n    if (!input) {\n      return;\n    }\n    await fillInput(pageOrFrame, input.selector, input.value);\n    if (modified.length) {\n      await this.fillInputs(pageOrFrame, modified);\n    }\n  }\n\n  async login(credentials: ScraperCredentials): Promise<ScraperScrapingResult> {\n    if (!credentials || !this.page) {\n      return createGeneralError();\n    }\n\n    debug('execute login process');\n    const loginOptions = this.getLoginOptions(credentials);\n\n    if (loginOptions.userAgent) {\n      debug('set custom user agent provided in options');\n      await this.page.setUserAgent(loginOptions.userAgent);\n    }\n\n    debug('navigate to login url');\n    await this.navigateTo(loginOptions.loginUrl);\n    if (loginOptions.checkReadiness) {\n      debug('execute \\'checkReadiness\\' interceptor provided in login options');\n      await loginOptions.checkReadiness();\n    } else if (typeof loginOptions.submitButtonSelector === 'string') {\n      debug('wait until submit button is available');\n      await waitUntilElementFound(this.page, loginOptions.submitButtonSelector);\n    }\n\n    let loginFrameOrPage: (Page | Frame | null) = this.page;\n    if (loginOptions.preAction) {\n      debug('execute \\'preAction\\' interceptor provided in login options');\n      loginFrameOrPage = await loginOptions.preAction() || this.page;\n    }\n\n    debug('fill login components input with relevant values');\n    await this.fillInputs(loginFrameOrPage, loginOptions.fields);\n    debug('click on login submit button');\n    if (typeof loginOptions.submitButtonSelector === 'string') {\n      await clickButton(loginFrameOrPage, loginOptions.submitButtonSelector);\n    } else {\n      await loginOptions.submitButtonSelector();\n    }\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    if (loginOptions.postAction) {\n      debug('execute \\'postAction\\' interceptor provided in login options');\n      await loginOptions.postAction();\n    } else {\n      debug('wait for page navigation');\n      await waitForNavigation(this.page);\n    }\n\n    debug('check login result');\n    const current = await getCurrentUrl(this.page, true);\n    const loginResult = await getKeyByValue(loginOptions.possibleResults, current, this.page);\n    debug(`handle login results ${loginResult}`);\n    return this.handleLoginResult(loginResult);\n  }\n\n  async terminate(_success: boolean) {\n    debug(`terminating browser with success = ${_success}`);\n    this.emitProgress(ScraperProgressTypes.Terminating);\n\n    if (!_success && !!this.options.storeFailureScreenShotPath) {\n      debug(`create a snapshot before terminated in ${this.options.storeFailureScreenShotPath}`);\n      await this.page.screenshot({\n        path: this.options.storeFailureScreenShotPath,\n        fullPage: true,\n      });\n    }\n\n    if (!this.browser) {\n      return;\n    }\n\n    await this.browser.close();\n  }\n\n  private handleLoginResult(loginResult: LoginResults) {\n    switch (loginResult) {\n      case LoginResults.Success:\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      case LoginResults.InvalidPassword:\n      case LoginResults.UnknownError:\n        this.emitProgress(ScraperProgressTypes.LoginFailed);\n        return {\n          success: false,\n          errorType: loginResult === LoginResults.InvalidPassword ? ScraperErrorTypes.InvalidPassword :\n            ScraperErrorTypes.General,\n          errorMessage: `Login failed with ${loginResult} error`,\n        };\n      case LoginResults.ChangePassword:\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      default:\n        throw new Error(`unexpected login result \"${loginResult}\"`);\n    }\n  }\n}\n\nexport { BaseScraperWithBrowser };\n"]}
337
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/base-scraper-with-browser.ts"],"names":["VIEWPORT_WIDTH","VIEWPORT_HEIGHT","OK_STATUS","debug","LoginBaseResults","Timeout","Generic","General","ScraperErrorTypes","rest","LoginResults","getKeyByValue","object","value","page","keys","Object","key","conditions","condition","result","RegExp","test","toLowerCase","Promise","resolve","UnknownError","createGeneralError","success","errorType","BaseScraperWithBrowser","BaseScraper","getViewPort","width","height","initialize","emitProgress","ScraperProgressTypes","Initializing","env","options","verbose","DEBUG","process","browser","executablePath","undefined","args","timeout","headless","showBrowser","puppeteer","launch","prepareBrowser","pages","length","newPage","defaultTimeout","setDefaultTimeout","preparePage","viewport","setViewport","on","request","failure","errorText","url","navigateTo","waitUntil","pageToUse","response","goto","status","Error","getLoginOptions","_credentials","companyId","fillInputs","pageOrFrame","fields","modified","input","shift","selector","login","credentials","loginOptions","userAgent","setUserAgent","loginUrl","checkReadiness","submitButtonSelector","loginFrameOrPage","preAction","LoggingIn","postAction","current","loginResult","possibleResults","handleLoginResult","terminate","_success","Terminating","storeFailureScreenShotPath","screenshot","path","fullPage","close","Success","LoginSuccess","InvalidPassword","LoginFailed","errorMessage","ChangePassword"],"mappings":"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","sourcesContent":["import puppeteer, {\n  Browser, Frame, Page, LoadEvent,\n} from 'puppeteer';\n\nimport {\n  BaseScraper,\n\n} from './base-scraper';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { clickButton, fillInput, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { getDebug } from '../helpers/debug';\nimport { ScraperErrorTypes } from './errors';\nimport { ScraperScrapingResult, ScraperCredentials } from './interface';\nimport { ScraperProgressTypes } from '../definitions';\n\nconst VIEWPORT_WIDTH = 1024;\nconst VIEWPORT_HEIGHT = 768;\nconst OK_STATUS = 200;\n\nconst debug = getDebug('base-scraper-with-browser');\n\nenum LoginBaseResults {\n  Success = 'SUCCESS',\n  UnknownError = 'UNKNOWN_ERROR'\n}\n\nconst {\n  Timeout, Generic, General, ...rest\n} = ScraperErrorTypes;\nexport const LoginResults = {\n  ...rest,\n  ...LoginBaseResults,\n};\n\nexport type LoginResults = Exclude<ScraperErrorTypes,\nScraperErrorTypes.Timeout\n| ScraperErrorTypes.Generic\n| ScraperErrorTypes.General> | LoginBaseResults;\n\nexport type PossibleLoginResults = {\n  [key in LoginResults]?: (string | RegExp | ((options?: { page?: Page}) => Promise<boolean>))[]\n};\n\nexport interface LoginOptions {\n  loginUrl: string;\n  checkReadiness?: () => Promise<void>;\n  fields: {selector: string, value: string}[];\n  submitButtonSelector: string | (() => Promise<void>);\n  preAction?: () => Promise<Frame | void>;\n  postAction?: () => Promise<void>;\n  possibleResults: PossibleLoginResults;\n  userAgent?: string;\n  waitUntil?: LoadEvent;\n}\n\nasync function getKeyByValue(object: PossibleLoginResults, value: string, page: Page): Promise<LoginResults> {\n  const keys = Object.keys(object);\n  for (const key of keys) {\n    // @ts-ignore\n    const conditions = object[key];\n\n    for (const condition of conditions) {\n      let result = false;\n\n      if (condition instanceof RegExp) {\n        result = condition.test(value);\n      } else if (typeof condition === 'function') {\n        result = await condition({ page, value });\n      } else {\n        result = value.toLowerCase() === condition.toLowerCase();\n      }\n\n      if (result) {\n        // @ts-ignore\n        return Promise.resolve(key);\n      }\n    }\n  }\n\n  return Promise.resolve(LoginResults.UnknownError);\n}\n\nfunction createGeneralError(): ScraperScrapingResult {\n  return {\n    success: false,\n    errorType: ScraperErrorTypes.General,\n  };\n}\n\nclass BaseScraperWithBrowser<TCredentials extends ScraperCredentials> extends BaseScraper<TCredentials> {\n  // NOTICE - it is discouraged to use bang (!) in general. It is used here because\n  // all the classes that inherit from this base assume is it mandatory.\n  protected browser!: Browser;\n\n  // NOTICE - it is discouraged to use bang (!) in general. It is used here because\n  // all the classes that inherit from this base assume is it mandatory.\n  protected page!: Page;\n\n  protected getViewPort() {\n    return {\n      width: VIEWPORT_WIDTH,\n      height: VIEWPORT_HEIGHT,\n    };\n  }\n\n  async initialize() {\n    await super.initialize();\n    debug('initialize scraper');\n    this.emitProgress(ScraperProgressTypes.Initializing);\n\n    let env: Record<string, any> | undefined;\n    if (this.options.verbose) {\n      env = { DEBUG: '*', ...process.env };\n    }\n\n    if (typeof this.options.browser !== 'undefined' && this.options.browser !== null) {\n      debug('use custom browser instance provided in options');\n      this.browser = this.options.browser;\n    } else {\n      const executablePath = this.options.executablePath || undefined;\n      const args = this.options.args || [];\n      const { timeout } = this.options;\n\n      const headless = !this.options.showBrowser;\n      debug(`launch a browser with headless mode = ${headless}`);\n      this.browser = await puppeteer.launch({\n        env,\n        headless,\n        executablePath,\n        args,\n        timeout,\n      });\n    }\n\n    if (this.options.prepareBrowser) {\n      debug('execute \\'prepareBrowser\\' interceptor provided in options');\n      await this.options.prepareBrowser(this.browser);\n    }\n\n    if (!this.browser) {\n      debug('failed to initiate a browser, exit');\n      return;\n    }\n\n    const pages = await this.browser.pages();\n    if (pages.length) {\n      debug('browser has already pages open, use the first one');\n      [this.page] = pages;\n    } else {\n      debug('create a new browser page');\n      this.page = await this.browser.newPage();\n    }\n\n    if (this.options.defaultTimeout) {\n      this.page.setDefaultTimeout(this.options.defaultTimeout);\n    }\n\n    if (this.options.preparePage) {\n      debug('execute \\'preparePage\\' interceptor provided in options');\n      await this.options.preparePage(this.page);\n    }\n\n    const viewport = this.getViewPort();\n    debug(`set viewport to width ${viewport.width}, height ${viewport.height}`);\n    await this.page.setViewport({\n      width: viewport.width,\n      height: viewport.height,\n    });\n\n    this.page.on('requestfailed', (request) => {\n      debug('Request failed: %s %s', request.failure()?.errorText, request.url());\n    });\n  }\n\n  async navigateTo(url: string, page?: Page, timeout?: number, waitUntil: LoadEvent | undefined = 'load'): Promise<void> {\n    const pageToUse = page || this.page;\n\n    if (!pageToUse) {\n      return;\n    }\n\n    const options = { ...(timeout === null ? null : { timeout }), waitUntil };\n    const response = await pageToUse.goto(url, options);\n\n    // note: response will be null when navigating to same url while changing the hash part. the condition below will always accept null as valid result.\n    if (response !== null && (response === undefined || response.status() !== OK_STATUS)) {\n      throw new Error(`Error while trying to navigate to url ${url}`);\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars\n  getLoginOptions(_credentials: ScraperCredentials): LoginOptions {\n    throw new Error(`getLoginOptions() is not created in ${this.options.companyId}`);\n  }\n\n  async fillInputs(pageOrFrame: Page | Frame, fields: { selector: string, value: string}[]): Promise<void> {\n    const modified = [...fields];\n    const input = modified.shift();\n\n    if (!input) {\n      return;\n    }\n    await fillInput(pageOrFrame, input.selector, input.value);\n    if (modified.length) {\n      await this.fillInputs(pageOrFrame, modified);\n    }\n  }\n\n  async login(credentials: ScraperCredentials): Promise<ScraperScrapingResult> {\n    if (!credentials || !this.page) {\n      return createGeneralError();\n    }\n\n    debug('execute login process');\n    const loginOptions = this.getLoginOptions(credentials);\n\n    if (loginOptions.userAgent) {\n      debug('set custom user agent provided in options');\n      await this.page.setUserAgent(loginOptions.userAgent);\n    }\n\n    debug('navigate to login url');\n    await this.navigateTo(loginOptions.loginUrl, undefined, undefined, loginOptions.waitUntil);\n    if (loginOptions.checkReadiness) {\n      debug('execute \\'checkReadiness\\' interceptor provided in login options');\n      await loginOptions.checkReadiness();\n    } else if (typeof loginOptions.submitButtonSelector === 'string') {\n      debug('wait until submit button is available');\n      await waitUntilElementFound(this.page, loginOptions.submitButtonSelector);\n    }\n\n    let loginFrameOrPage: (Page | Frame | null) = this.page;\n    if (loginOptions.preAction) {\n      debug('execute \\'preAction\\' interceptor provided in login options');\n      loginFrameOrPage = await loginOptions.preAction() || this.page;\n    }\n\n    debug('fill login components input with relevant values');\n    await this.fillInputs(loginFrameOrPage, loginOptions.fields);\n    debug('click on login submit button');\n    if (typeof loginOptions.submitButtonSelector === 'string') {\n      await clickButton(loginFrameOrPage, loginOptions.submitButtonSelector);\n    } else {\n      await loginOptions.submitButtonSelector();\n    }\n    this.emitProgress(ScraperProgressTypes.LoggingIn);\n\n    if (loginOptions.postAction) {\n      debug('execute \\'postAction\\' interceptor provided in login options');\n      await loginOptions.postAction();\n    } else {\n      debug('wait for page navigation');\n      await waitForNavigation(this.page);\n    }\n\n    debug('check login result');\n    const current = await getCurrentUrl(this.page, true);\n    const loginResult = await getKeyByValue(loginOptions.possibleResults, current, this.page);\n    debug(`handle login results ${loginResult}`);\n    return this.handleLoginResult(loginResult);\n  }\n\n  async terminate(_success: boolean) {\n    debug(`terminating browser with success = ${_success}`);\n    this.emitProgress(ScraperProgressTypes.Terminating);\n\n    if (!_success && !!this.options.storeFailureScreenShotPath) {\n      debug(`create a snapshot before terminated in ${this.options.storeFailureScreenShotPath}`);\n      await this.page.screenshot({\n        path: this.options.storeFailureScreenShotPath,\n        fullPage: true,\n      });\n    }\n\n    if (!this.browser) {\n      return;\n    }\n\n    await this.browser.close();\n  }\n\n  private handleLoginResult(loginResult: LoginResults) {\n    switch (loginResult) {\n      case LoginResults.Success:\n        this.emitProgress(ScraperProgressTypes.LoginSuccess);\n        return { success: true };\n      case LoginResults.InvalidPassword:\n      case LoginResults.UnknownError:\n        this.emitProgress(ScraperProgressTypes.LoginFailed);\n        return {\n          success: false,\n          errorType: loginResult === LoginResults.InvalidPassword ? ScraperErrorTypes.InvalidPassword :\n            ScraperErrorTypes.General,\n          errorMessage: `Login failed with ${loginResult} error`,\n        };\n      case LoginResults.ChangePassword:\n        this.emitProgress(ScraperProgressTypes.ChangePassword);\n        return {\n          success: false,\n          errorType: ScraperErrorTypes.ChangePassword,\n        };\n      default:\n        throw new Error(`unexpected login result \"${loginResult}\"`);\n    }\n  }\n}\n\nexport { BaseScraperWithBrowser };\n"]}
@@ -0,0 +1,11 @@
1
+ import { BaseScraperWithBrowser, LoginOptions } from './base-scraper-with-browser';
2
+ import { ScraperScrapingResult } from './interface';
3
+ declare type ScraperSpecificCredentials = {
4
+ id: string;
5
+ password: string;
6
+ };
7
+ declare class BehatsdaaScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {
8
+ getLoginOptions(credentials: ScraperSpecificCredentials): LoginOptions;
9
+ fetchData(): Promise<ScraperScrapingResult>;
10
+ }
11
+ export default BehatsdaaScraper;
@@ -0,0 +1,138 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.array.iterator");
4
+
5
+ require("core-js/modules/es.promise");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.default = void 0;
11
+
12
+ var _moment = _interopRequireDefault(require("moment"));
13
+
14
+ var _debug = require("../helpers/debug");
15
+
16
+ var _fetch = require("../helpers/fetch");
17
+
18
+ var _transactions = require("../transactions");
19
+
20
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
21
+
22
+ var _elementsInteractions = require("../helpers/elements-interactions");
23
+
24
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
25
+
26
+ const BASE_URL = 'https://www.behatsdaa.org.il';
27
+ const LOGIN_URL = `${BASE_URL}/login`;
28
+ const PURCHASE_HISTORY_URL = 'https://back.behatsdaa.org.il/api/purchases/purchaseHistory';
29
+ const debug = (0, _debug.getDebug)('behatsdaa');
30
+
31
+ function variantToTransaction(variant) {
32
+ return {
33
+ type: _transactions.TransactionTypes.Normal,
34
+ identifier: variant.tTransactionID,
35
+ date: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
36
+ processedDate: (0, _moment.default)(variant.orderDate).format('YYYY-MM-DD'),
37
+ originalAmount: variant.customerPrice,
38
+ originalCurrency: 'ILS',
39
+ chargedAmount: variant.customerPrice,
40
+ chargedCurrency: 'ILS',
41
+ description: variant.name,
42
+ status: _transactions.TransactionStatuses.Completed,
43
+ memo: variant.variantName
44
+ };
45
+ }
46
+
47
+ class BehatsdaaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
48
+ getLoginOptions(credentials) {
49
+ return {
50
+ loginUrl: LOGIN_URL,
51
+ fields: [{
52
+ selector: '#loginId',
53
+ value: credentials.id
54
+ }, {
55
+ selector: '#loginPassword',
56
+ value: credentials.password
57
+ }],
58
+ checkReadiness: async () => {
59
+ await Promise.all([(0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginPassword'), (0, _elementsInteractions.waitUntilElementFound)(this.page, '#loginId')]);
60
+ },
61
+ possibleResults: {
62
+ [_baseScraperWithBrowser.LoginResults.Success]: [`${BASE_URL}/`],
63
+ [_baseScraperWithBrowser.LoginResults.InvalidPassword]: ['.custom-input-error-label']
64
+ },
65
+ submitButtonSelector: async () => {
66
+ await this.page.waitForTimeout(1000);
67
+ debug('Trying to find submit button');
68
+ const [button] = await this.page.$x("//button[contains(., 'התחברות')]");
69
+
70
+ if (button) {
71
+ debug('Submit button found');
72
+ await button.click();
73
+ } else {
74
+ debug('Submit button not found');
75
+ }
76
+ }
77
+ };
78
+ }
79
+
80
+ async fetchData() {
81
+ var _res$data;
82
+
83
+ const token = await this.page.evaluate(() => window.localStorage.getItem('userToken'));
84
+
85
+ if (!token) {
86
+ debug('Token not found in local storage');
87
+ return {
88
+ success: false,
89
+ errorMessage: 'TokenNotFound'
90
+ };
91
+ }
92
+
93
+ const body = {
94
+ FromDate: (0, _moment.default)(this.options.startDate).format('YYYY-MM-DDTHH:mm:ss'),
95
+ ToDate: (0, _moment.default)().format('YYYY-MM-DDTHH:mm:ss'),
96
+ BenefitStatusId: null
97
+ };
98
+ debug('Fetching data');
99
+ const res = await (0, _fetch.fetchPostWithinPage)(this.page, PURCHASE_HISTORY_URL, body, {
100
+ authorization: `Bearer ${token}`,
101
+ 'Content-Type': 'application/json',
102
+ organizationid: '20'
103
+ });
104
+ debug('Data fetched');
105
+
106
+ if ((res === null || res === void 0 ? void 0 : res.errorDescription) || (res === null || res === void 0 ? void 0 : (_res$data = res.data) === null || _res$data === void 0 ? void 0 : _res$data.errorDescription)) {
107
+ var _res$data2;
108
+
109
+ debug('Error fetching data', res.errorDescription || ((_res$data2 = res.data) === null || _res$data2 === void 0 ? void 0 : _res$data2.errorDescription));
110
+ return {
111
+ success: false,
112
+ errorMessage: res.errorDescription
113
+ };
114
+ }
115
+
116
+ if (!(res === null || res === void 0 ? void 0 : res.data)) {
117
+ debug('No data found');
118
+ return {
119
+ success: false,
120
+ errorMessage: 'NoData'
121
+ };
122
+ }
123
+
124
+ debug('Data fetched successfully');
125
+ return {
126
+ success: true,
127
+ accounts: [{
128
+ accountNumber: res.data.memberId,
129
+ txns: res.data.variants.map(variantToTransaction)
130
+ }]
131
+ };
132
+ }
133
+
134
+ }
135
+
136
+ var _default = BehatsdaaScraper;
137
+ exports.default = _default;
138
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/behatsdaa.ts"],"names":["BASE_URL","LOGIN_URL","PURCHASE_HISTORY_URL","debug","variantToTransaction","variant","type","TransactionTypes","Normal","identifier","tTransactionID","date","orderDate","format","processedDate","originalAmount","customerPrice","originalCurrency","chargedAmount","chargedCurrency","description","name","status","TransactionStatuses","Completed","memo","variantName","BehatsdaaScraper","BaseScraperWithBrowser","getLoginOptions","credentials","loginUrl","fields","selector","value","id","password","checkReadiness","Promise","all","page","possibleResults","LoginResults","Success","InvalidPassword","submitButtonSelector","waitForTimeout","button","$x","click","fetchData","token","evaluate","window","localStorage","getItem","success","errorMessage","body","FromDate","options","startDate","ToDate","BenefitStatusId","res","authorization","organizationid","errorDescription","data","accounts","accountNumber","memberId","txns","variants","map"],"mappings":"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","sourcesContent":["import moment from 'moment';\nimport { getDebug } from '../helpers/debug';\nimport { fetchPostWithinPage } from '../helpers/fetch';\nimport { Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { BaseScraperWithBrowser, LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport { ScraperScrapingResult } from './interface';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\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  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: variant.customerPrice,\n    originalCurrency: 'ILS',\n    chargedAmount: variant.customerPrice,\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 this.page.waitForTimeout(1000);\n        debug('Trying to find submit button');\n        const [button] = await this.page.$x(\"//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"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.promise");
4
+
5
+ var _definitions = require("../definitions");
6
+
7
+ var _testsUtils = require("../tests/tests-utils");
8
+
9
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
10
+
11
+ var _behatsdaa = _interopRequireDefault(require("./behatsdaa"));
12
+
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+
15
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
16
+
17
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
18
+
19
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
20
+
21
+ const testsConfig = (0, _testsUtils.getTestsConfig)();
22
+ describe('Behatsdaa scraper', () => {
23
+ beforeAll(() => {
24
+ (0, _testsUtils.extendAsyncTimeout)();
25
+ });
26
+ it('should expose login fields in scrapers constant', () => {
27
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa]).toBeDefined();
28
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa].loginFields).toContain('id');
29
+ expect(_definitions.SCRAPERS[_definitions.CompanyTypes.behatsdaa].loginFields).toContain('password');
30
+ });
31
+ (0, _testsUtils.maybeTestCompanyAPI)(_definitions.CompanyTypes.behatsdaa, config => config.companyAPI.invalidPassword)('should fail on invalid user/password"', async () => {
32
+ const scraper = new _behatsdaa.default(_objectSpread({}, testsConfig.options, {
33
+ companyId: _definitions.CompanyTypes.behatsdaa
34
+ }));
35
+ const result = await scraper.scrape({
36
+ id: 'foofoofoo',
37
+ password: 'barbarbar'
38
+ });
39
+ expect(result).toBeDefined();
40
+ expect(result.success).toBeFalsy();
41
+ expect(result.errorType).toBe(_baseScraperWithBrowser.LoginResults.InvalidPassword);
42
+ });
43
+ (0, _testsUtils.maybeTestCompanyAPI)(_definitions.CompanyTypes.behatsdaa)('should scrape transactions', async () => {
44
+ const scraper = new _behatsdaa.default(_objectSpread({}, testsConfig.options, {
45
+ companyId: _definitions.CompanyTypes.behatsdaa
46
+ }));
47
+ const result = await scraper.scrape(testsConfig.credentials[_definitions.CompanyTypes.behatsdaa]);
48
+ expect(result).toBeDefined();
49
+ expect(result.errorMessage).toBeFalsy();
50
+ expect(result.errorType).toBeFalsy();
51
+ expect(result.success).toBeTruthy();
52
+ expect(result.accounts).toBeDefined();
53
+ expect(result.accounts).toHaveLength(1);
54
+ (0, _testsUtils.exportTransactions)(_definitions.CompanyTypes.behatsdaa, result.accounts || []);
55
+ });
56
+ });
57
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9iZWhhdHNkYWEudGVzdC50cyJdLCJuYW1lcyI6WyJ0ZXN0c0NvbmZpZyIsImRlc2NyaWJlIiwiYmVmb3JlQWxsIiwiaXQiLCJleHBlY3QiLCJTQ1JBUEVSUyIsIkNvbXBhbnlUeXBlcyIsImJlaGF0c2RhYSIsInRvQmVEZWZpbmVkIiwibG9naW5GaWVsZHMiLCJ0b0NvbnRhaW4iLCJjb25maWciLCJjb21wYW55QVBJIiwiaW52YWxpZFBhc3N3b3JkIiwic2NyYXBlciIsIkJlaGF0c2RhYVNjcmFwZXIiLCJvcHRpb25zIiwiY29tcGFueUlkIiwicmVzdWx0Iiwic2NyYXBlIiwiaWQiLCJwYXNzd29yZCIsInN1Y2Nlc3MiLCJ0b0JlRmFsc3kiLCJlcnJvclR5cGUiLCJ0b0JlIiwiTG9naW5SZXN1bHRzIiwiSW52YWxpZFBhc3N3b3JkIiwiY3JlZGVudGlhbHMiLCJlcnJvck1lc3NhZ2UiLCJ0b0JlVHJ1dGh5IiwiYWNjb3VudHMiLCJ0b0hhdmVMZW5ndGgiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7QUFDQTs7QUFHQTs7QUFDQTs7Ozs7Ozs7OztBQUVBLE1BQU1BLFdBQVcsR0FBRyxpQ0FBcEI7QUFFQUMsUUFBUSxDQUFDLG1CQUFELEVBQXNCLE1BQU07QUFDbENDLEVBQUFBLFNBQVMsQ0FBQyxNQUFNO0FBQ2Q7QUFDRCxHQUZRLENBQVQ7QUFJQUMsRUFBQUEsRUFBRSxDQUFDLGlEQUFELEVBQW9ELE1BQU07QUFDMURDLElBQUFBLE1BQU0sQ0FBQ0Msc0JBQVNDLDBCQUFhQyxTQUF0QixDQUFELENBQU4sQ0FBeUNDLFdBQXpDO0FBQ0FKLElBQUFBLE1BQU0sQ0FBQ0Msc0JBQVNDLDBCQUFhQyxTQUF0QixFQUFpQ0UsV0FBbEMsQ0FBTixDQUFxREMsU0FBckQsQ0FBK0QsSUFBL0Q7QUFDQU4sSUFBQUEsTUFBTSxDQUFDQyxzQkFBU0MsMEJBQWFDLFNBQXRCLEVBQWlDRSxXQUFsQyxDQUFOLENBQXFEQyxTQUFyRCxDQUErRCxVQUEvRDtBQUNELEdBSkMsQ0FBRjtBQU1BLHVDQUFvQkosMEJBQWFDLFNBQWpDLEVBQTZDSSxNQUFELElBQVlBLE1BQU0sQ0FBQ0MsVUFBUCxDQUFrQkMsZUFBMUUsRUFBMkYsdUNBQTNGLEVBQW9JLFlBQVk7QUFDOUksVUFBTUMsT0FBTyxHQUFHLElBQUlDLGtCQUFKLG1CQUNYZixXQUFXLENBQUNnQixPQUREO0FBRWRDLE1BQUFBLFNBQVMsRUFBRVgsMEJBQWFDO0FBRlYsT0FBaEI7QUFLQSxVQUFNVyxNQUFNLEdBQUcsTUFBTUosT0FBTyxDQUFDSyxNQUFSLENBQWU7QUFBRUMsTUFBQUEsRUFBRSxFQUFFLFdBQU47QUFBbUJDLE1BQUFBLFFBQVEsRUFBRTtBQUE3QixLQUFmLENBQXJCO0FBRUFqQixJQUFBQSxNQUFNLENBQUNjLE1BQUQsQ0FBTixDQUFlVixXQUFmO0FBQ0FKLElBQUFBLE1BQU0sQ0FBQ2MsTUFBTSxDQUFDSSxPQUFSLENBQU4sQ0FBdUJDLFNBQXZCO0FBQ0FuQixJQUFBQSxNQUFNLENBQUNjLE1BQU0sQ0FBQ00sU0FBUixDQUFOLENBQXlCQyxJQUF6QixDQUE4QkMscUNBQWFDLGVBQTNDO0FBQ0QsR0FYRDtBQWFBLHVDQUFvQnJCLDBCQUFhQyxTQUFqQyxFQUE0Qyw0QkFBNUMsRUFBMEUsWUFBWTtBQUNwRixVQUFNTyxPQUFPLEdBQUcsSUFBSUMsa0JBQUosbUJBQ1hmLFdBQVcsQ0FBQ2dCLE9BREQ7QUFFZEMsTUFBQUEsU0FBUyxFQUFFWCwwQkFBYUM7QUFGVixPQUFoQjtBQUtBLFVBQU1XLE1BQU0sR0FBRyxNQUFNSixPQUFPLENBQUNLLE1BQVIsQ0FBZW5CLFdBQVcsQ0FBQzRCLFdBQVosQ0FBd0J0QiwwQkFBYUMsU0FBckMsQ0FBZixDQUFyQjtBQUNBSCxJQUFBQSxNQUFNLENBQUNjLE1BQUQsQ0FBTixDQUFlVixXQUFmO0FBQ0FKLElBQUFBLE1BQU0sQ0FBQ2MsTUFBTSxDQUFDVyxZQUFSLENBQU4sQ0FBNEJOLFNBQTVCO0FBQ0FuQixJQUFBQSxNQUFNLENBQUNjLE1BQU0sQ0FBQ00sU0FBUixDQUFOLENBQXlCRCxTQUF6QjtBQUNBbkIsSUFBQUEsTUFBTSxDQUFDYyxNQUFNLENBQUNJLE9BQVIsQ0FBTixDQUF1QlEsVUFBdkI7QUFDQTFCLElBQUFBLE1BQU0sQ0FBQ2MsTUFBTSxDQUFDYSxRQUFSLENBQU4sQ0FBd0J2QixXQUF4QjtBQUNBSixJQUFBQSxNQUFNLENBQUNjLE1BQU0sQ0FBQ2EsUUFBUixDQUFOLENBQXdCQyxZQUF4QixDQUFxQyxDQUFyQztBQUNBLHdDQUFtQjFCLDBCQUFhQyxTQUFoQyxFQUEyQ1csTUFBTSxDQUFDYSxRQUFQLElBQW1CLEVBQTlEO0FBQ0QsR0FkRDtBQWVELENBdkNPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wYW55VHlwZXMsIFNDUkFQRVJTIH0gZnJvbSAnLi4vZGVmaW5pdGlvbnMnO1xuaW1wb3J0IHtcbiAgZXhwb3J0VHJhbnNhY3Rpb25zLCBleHRlbmRBc3luY1RpbWVvdXQsIGdldFRlc3RzQ29uZmlnLCBtYXliZVRlc3RDb21wYW55QVBJLFxufSBmcm9tICcuLi90ZXN0cy90ZXN0cy11dGlscyc7XG5pbXBvcnQgeyBMb2dpblJlc3VsdHMgfSBmcm9tICcuL2Jhc2Utc2NyYXBlci13aXRoLWJyb3dzZXInO1xuaW1wb3J0IEJlaGF0c2RhYVNjcmFwZXIgZnJvbSAnLi9iZWhhdHNkYWEnO1xuXG5jb25zdCB0ZXN0c0NvbmZpZyA9IGdldFRlc3RzQ29uZmlnKCk7XG5cbmRlc2NyaWJlKCdCZWhhdHNkYWEgc2NyYXBlcicsICgpID0+IHtcbiAgYmVmb3JlQWxsKCgpID0+IHtcbiAgICBleHRlbmRBc3luY1RpbWVvdXQoKTtcbiAgfSk7XG5cbiAgaXQoJ3Nob3VsZCBleHBvc2UgbG9naW4gZmllbGRzIGluIHNjcmFwZXJzIGNvbnN0YW50JywgKCkgPT4ge1xuICAgIGV4cGVjdChTQ1JBUEVSU1tDb21wYW55VHlwZXMuYmVoYXRzZGFhXSkudG9CZURlZmluZWQoKTtcbiAgICBleHBlY3QoU0NSQVBFUlNbQ29tcGFueVR5cGVzLmJlaGF0c2RhYV0ubG9naW5GaWVsZHMpLnRvQ29udGFpbignaWQnKTtcbiAgICBleHBlY3QoU0NSQVBFUlNbQ29tcGFueVR5cGVzLmJlaGF0c2RhYV0ubG9naW5GaWVsZHMpLnRvQ29udGFpbigncGFzc3dvcmQnKTtcbiAgfSk7XG5cbiAgbWF5YmVUZXN0Q29tcGFueUFQSShDb21wYW55VHlwZXMuYmVoYXRzZGFhLCAoY29uZmlnKSA9PiBjb25maWcuY29tcGFueUFQSS5pbnZhbGlkUGFzc3dvcmQpKCdzaG91bGQgZmFpbCBvbiBpbnZhbGlkIHVzZXIvcGFzc3dvcmRcIicsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBzY3JhcGVyID0gbmV3IEJlaGF0c2RhYVNjcmFwZXIoe1xuICAgICAgLi4udGVzdHNDb25maWcub3B0aW9ucyxcbiAgICAgIGNvbXBhbnlJZDogQ29tcGFueVR5cGVzLmJlaGF0c2RhYSxcbiAgICB9KTtcblxuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHNjcmFwZXIuc2NyYXBlKHsgaWQ6ICdmb29mb29mb28nLCBwYXNzd29yZDogJ2JhcmJhcmJhcicgfSk7XG5cbiAgICBleHBlY3QocmVzdWx0KS50b0JlRGVmaW5lZCgpO1xuICAgIGV4cGVjdChyZXN1bHQuc3VjY2VzcykudG9CZUZhbHN5KCk7XG4gICAgZXhwZWN0KHJlc3VsdC5lcnJvclR5cGUpLnRvQmUoTG9naW5SZXN1bHRzLkludmFsaWRQYXNzd29yZCk7XG4gIH0pO1xuXG4gIG1heWJlVGVzdENvbXBhbnlBUEkoQ29tcGFueVR5cGVzLmJlaGF0c2RhYSkoJ3Nob3VsZCBzY3JhcGUgdHJhbnNhY3Rpb25zJywgYXN5bmMgKCkgPT4ge1xuICAgIGNvbnN0IHNjcmFwZXIgPSBuZXcgQmVoYXRzZGFhU2NyYXBlcih7XG4gICAgICAuLi50ZXN0c0NvbmZpZy5vcHRpb25zLFxuICAgICAgY29tcGFueUlkOiBDb21wYW55VHlwZXMuYmVoYXRzZGFhLFxuICAgIH0pO1xuXG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgc2NyYXBlci5zY3JhcGUodGVzdHNDb25maWcuY3JlZGVudGlhbHNbQ29tcGFueVR5cGVzLmJlaGF0c2RhYV0pO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvQmVEZWZpbmVkKCk7XG4gICAgZXhwZWN0KHJlc3VsdC5lcnJvck1lc3NhZ2UpLnRvQmVGYWxzeSgpO1xuICAgIGV4cGVjdChyZXN1bHQuZXJyb3JUeXBlKS50b0JlRmFsc3koKTtcbiAgICBleHBlY3QocmVzdWx0LnN1Y2Nlc3MpLnRvQmVUcnV0aHkoKTtcbiAgICBleHBlY3QocmVzdWx0LmFjY291bnRzKS50b0JlRGVmaW5lZCgpO1xuICAgIGV4cGVjdChyZXN1bHQuYWNjb3VudHMpLnRvSGF2ZUxlbmd0aCgxKTtcbiAgICBleHBvcnRUcmFuc2FjdGlvbnMoQ29tcGFueVR5cGVzLmJlaGF0c2RhYSwgcmVzdWx0LmFjY291bnRzIHx8IFtdKTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -37,6 +37,10 @@ var _beyahadBishvilha = _interopRequireDefault(require("./beyahad-bishvilha"));
37
37
 
38
38
  var _oneZero = _interopRequireDefault(require("./one-zero"));
39
39
 
40
+ var _behatsdaa = _interopRequireDefault(require("./behatsdaa"));
41
+
42
+ var _assertNever = require("../assertNever");
43
+
40
44
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
41
45
 
42
46
  function createScraper(options) {
@@ -96,8 +100,11 @@ function createScraper(options) {
96
100
  case _definitions.CompanyTypes.oneZero:
97
101
  return new _oneZero.default(options);
98
102
 
103
+ case _definitions.CompanyTypes.behatsdaa:
104
+ return new _behatsdaa.default(options);
105
+
99
106
  default:
100
- throw new Error(`unknown company id ${options.companyId}`);
107
+ return (0, _assertNever.assertNever)(options.companyId, `unknown company id ${options.companyId}`);
101
108
  }
102
109
  }
103
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9mYWN0b3J5LnRzIl0sIm5hbWVzIjpbImNyZWF0ZVNjcmFwZXIiLCJvcHRpb25zIiwiY29tcGFueUlkIiwiQ29tcGFueVR5cGVzIiwiaGFwb2FsaW0iLCJIYXBvYWxpbVNjcmFwZXIiLCJoYXBvYWxpbUJlT25saW5lIiwiY29uc29sZSIsIndhcm4iLCJsZXVtaSIsIkxldW1pU2NyYXBlciIsImJleWFoYWRCaXNodmlsaGEiLCJCZXlhaGFkQmlzaHZpbGhhU2NyYXBlciIsIm1penJhaGkiLCJNaXpyYWhpU2NyYXBlciIsImRpc2NvdW50IiwiRGlzY291bnRTY3JhcGVyIiwib3RzYXJIYWhheWFsIiwiT3RzYXJIYWhheWFsU2NyYXBlciIsInZpc2FDYWwiLCJWaXNhQ2FsU2NyYXBlciIsImxldW1pQ2FyZCIsIk1heFNjcmFwZXIiLCJtYXgiLCJpc3JhY2FyZCIsIklzcmFjYXJkU2NyYXBlciIsImFtZXgiLCJBbWV4U2NyYXBlciIsInVuaW9uIiwiVW5pb25CYW5rU2NyYXBlciIsImJlaW5sZXVtaSIsIkJlaW5sZXVtaVNjcmFwZXIiLCJtYXNzYWQiLCJNYXNzYWRTY3JhcGVyIiwieWFoYXYiLCJZYWhhdlNjcmFwZXIiLCJvbmVaZXJvIiwiT25lWmVyb1NjcmFwZXIiLCJFcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBOztBQUNBOztBQUNBOzs7O0FBRWUsU0FBU0EsYUFBVCxDQUF1QkMsT0FBdkIsRUFBNkU7QUFDMUYsVUFBUUEsT0FBTyxDQUFDQyxTQUFoQjtBQUNFLFNBQUtDLDBCQUFhQyxRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0JKLE9BQXBCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFHLGdCQUFsQjtBQUNFO0FBQ0FDLE1BQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUFhLHdEQUFiO0FBQ0EsYUFBTyxJQUFJSCxpQkFBSixDQUFvQkosT0FBcEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYU0sS0FBbEI7QUFDRSxhQUFPLElBQUlDLGNBQUosQ0FBaUJULE9BQWpCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFRLGdCQUFsQjtBQUNFLGFBQU8sSUFBSUMseUJBQUosQ0FBNEJYLE9BQTVCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFVLE9BQWxCO0FBQ0UsYUFBTyxJQUFJQyxnQkFBSixDQUFtQmIsT0FBbkIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYVksUUFBbEI7QUFDRSxhQUFPLElBQUlDLGlCQUFKLENBQW9CZixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhYyxZQUFsQjtBQUNFLGFBQU8sSUFBSUMscUJBQUosQ0FBd0JqQixPQUF4QixDQUFQOztBQUNGLFNBQUtFLDBCQUFhZ0IsT0FBbEI7QUFDRSxhQUFPLElBQUlDLGdCQUFKLENBQW1CbkIsT0FBbkIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYWtCLFNBQWxCO0FBQ0U7QUFDQWQsTUFBQUEsT0FBTyxDQUFDQyxJQUFSLENBQWEsNENBQWI7QUFDQSxhQUFPLElBQUljLFlBQUosQ0FBZXJCLE9BQWYsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYW9CLEdBQWxCO0FBQ0UsYUFBTyxJQUFJRCxZQUFKLENBQWVyQixPQUFmLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFxQixRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0J4QixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhdUIsSUFBbEI7QUFDRSxhQUFPLElBQUlDLGFBQUosQ0FBZ0IxQixPQUFoQixDQUFQOztBQUNGLFNBQUtFLDBCQUFheUIsS0FBbEI7QUFDRSxhQUFPLElBQUlDLGtCQUFKLENBQXFCNUIsT0FBckIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYTJCLFNBQWxCO0FBQ0UsYUFBTyxJQUFJQyxrQkFBSixDQUFxQjlCLE9BQXJCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWE2QixNQUFsQjtBQUNFLGFBQU8sSUFBSUMsZUFBSixDQUFrQmhDLE9BQWxCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWErQixLQUFsQjtBQUNFLGFBQU8sSUFBSUMsY0FBSixDQUFpQmxDLE9BQWpCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFpQyxPQUFsQjtBQUNFLGFBQU8sSUFBSUMsZ0JBQUosQ0FBbUJwQyxPQUFuQixDQUFQOztBQUNGO0FBQ0UsWUFBTSxJQUFJcUMsS0FBSixDQUFXLHNCQUFxQnJDLE9BQU8sQ0FBQ0MsU0FBVSxFQUFsRCxDQUFOO0FBeENKO0FBMENEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEhhcG9hbGltU2NyYXBlciBmcm9tICcuL2hhcG9hbGltJztcbmltcG9ydCBPdHNhckhhaGF5YWxTY3JhcGVyIGZyb20gJy4vb3RzYXItaGFoYXlhbCc7XG5pbXBvcnQgTGV1bWlTY3JhcGVyIGZyb20gJy4vbGV1bWknO1xuaW1wb3J0IERpc2NvdW50U2NyYXBlciBmcm9tICcuL2Rpc2NvdW50JztcbmltcG9ydCBNYXhTY3JhcGVyIGZyb20gJy4vbWF4JztcbmltcG9ydCBWaXNhQ2FsU2NyYXBlciBmcm9tICcuL3Zpc2EtY2FsJztcbmltcG9ydCBJc3JhY2FyZFNjcmFwZXIgZnJvbSAnLi9pc3JhY2FyZCc7XG5pbXBvcnQgQW1leFNjcmFwZXIgZnJvbSAnLi9hbWV4JztcbmltcG9ydCBNaXpyYWhpU2NyYXBlciBmcm9tICcuL21penJhaGknO1xuaW1wb3J0IFVuaW9uQmFua1NjcmFwZXIgZnJvbSAnLi91bmlvbi1iYW5rJztcbmltcG9ydCBCZWlubGV1bWlTY3JhcGVyIGZyb20gJy4vYmVpbmxldW1pJztcbmltcG9ydCBNYXNzYWRTY3JhcGVyIGZyb20gJy4vbWFzc2FkJztcbmltcG9ydCBZYWhhdlNjcmFwZXIgZnJvbSAnLi95YWhhdic7XG5pbXBvcnQgeyBTY3JhcGVyLCBTY3JhcGVyQ3JlZGVudGlhbHMsIFNjcmFwZXJPcHRpb25zIH0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQ29tcGFueVR5cGVzIH0gZnJvbSAnLi4vZGVmaW5pdGlvbnMnO1xuaW1wb3J0IEJleWFoYWRCaXNodmlsaGFTY3JhcGVyIGZyb20gJy4vYmV5YWhhZC1iaXNodmlsaGEnO1xuaW1wb3J0IE9uZVplcm9TY3JhcGVyIGZyb20gJy4vb25lLXplcm8nO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVTY3JhcGVyKG9wdGlvbnM6IFNjcmFwZXJPcHRpb25zKTogU2NyYXBlcjxTY3JhcGVyQ3JlZGVudGlhbHM+IHtcbiAgc3dpdGNoIChvcHRpb25zLmNvbXBhbnlJZCkge1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmhhcG9hbGltOlxuICAgICAgcmV0dXJuIG5ldyBIYXBvYWxpbVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaGFwb2FsaW1CZU9ubGluZTpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLndhcm4oXCJoYXBvYWxpbUJlT25saW5lIGlzIGRlcHJlY2F0ZWQsIHVzZSAnaGFwb2FsaW0nIGluc3RlYWRcIik7XG4gICAgICByZXR1cm4gbmV3IEhhcG9hbGltU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5sZXVtaTpcbiAgICAgIHJldHVybiBuZXcgTGV1bWlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmJleWFoYWRCaXNodmlsaGE6XG4gICAgICByZXR1cm4gbmV3IEJleWFoYWRCaXNodmlsaGFTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLm1penJhaGk6XG4gICAgICByZXR1cm4gbmV3IE1penJhaGlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmRpc2NvdW50OlxuICAgICAgcmV0dXJuIG5ldyBEaXNjb3VudFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMub3RzYXJIYWhheWFsOlxuICAgICAgcmV0dXJuIG5ldyBPdHNhckhhaGF5YWxTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLnZpc2FDYWw6XG4gICAgICByZXR1cm4gbmV3IFZpc2FDYWxTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmxldW1pQ2FyZDpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLndhcm4oXCJsZXVtaUNhcmQgaXMgZGVwcmVjYXRlZCwgdXNlICdtYXgnIGluc3RlYWRcIik7XG4gICAgICByZXR1cm4gbmV3IE1heFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWF4OlxuICAgICAgcmV0dXJuIG5ldyBNYXhTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmlzcmFjYXJkOlxuICAgICAgcmV0dXJuIG5ldyBJc3JhY2FyZFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYW1leDpcbiAgICAgIHJldHVybiBuZXcgQW1leFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMudW5pb246XG4gICAgICByZXR1cm4gbmV3IFVuaW9uQmFua1NjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYmVpbmxldW1pOlxuICAgICAgcmV0dXJuIG5ldyBCZWlubGV1bWlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLm1hc3NhZDpcbiAgICAgIHJldHVybiBuZXcgTWFzc2FkU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy55YWhhdjpcbiAgICAgIHJldHVybiBuZXcgWWFoYXZTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLm9uZVplcm86XG4gICAgICByZXR1cm4gbmV3IE9uZVplcm9TY3JhcGVyKG9wdGlvbnMpO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVua25vd24gY29tcGFueSBpZCAke29wdGlvbnMuY29tcGFueUlkfWApO1xuICB9XG59XG4iXX0=
110
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9mYWN0b3J5LnRzIl0sIm5hbWVzIjpbImNyZWF0ZVNjcmFwZXIiLCJvcHRpb25zIiwiY29tcGFueUlkIiwiQ29tcGFueVR5cGVzIiwiaGFwb2FsaW0iLCJIYXBvYWxpbVNjcmFwZXIiLCJoYXBvYWxpbUJlT25saW5lIiwiY29uc29sZSIsIndhcm4iLCJsZXVtaSIsIkxldW1pU2NyYXBlciIsImJleWFoYWRCaXNodmlsaGEiLCJCZXlhaGFkQmlzaHZpbGhhU2NyYXBlciIsIm1penJhaGkiLCJNaXpyYWhpU2NyYXBlciIsImRpc2NvdW50IiwiRGlzY291bnRTY3JhcGVyIiwib3RzYXJIYWhheWFsIiwiT3RzYXJIYWhheWFsU2NyYXBlciIsInZpc2FDYWwiLCJWaXNhQ2FsU2NyYXBlciIsImxldW1pQ2FyZCIsIk1heFNjcmFwZXIiLCJtYXgiLCJpc3JhY2FyZCIsIklzcmFjYXJkU2NyYXBlciIsImFtZXgiLCJBbWV4U2NyYXBlciIsInVuaW9uIiwiVW5pb25CYW5rU2NyYXBlciIsImJlaW5sZXVtaSIsIkJlaW5sZXVtaVNjcmFwZXIiLCJtYXNzYWQiLCJNYXNzYWRTY3JhcGVyIiwieWFoYXYiLCJZYWhhdlNjcmFwZXIiLCJvbmVaZXJvIiwiT25lWmVyb1NjcmFwZXIiLCJiZWhhdHNkYWEiLCJCZWhhdHNkYWFTY3JhcGVyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBRUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7Ozs7QUFFZSxTQUFTQSxhQUFULENBQXVCQyxPQUF2QixFQUE2RTtBQUMxRixVQUFRQSxPQUFPLENBQUNDLFNBQWhCO0FBQ0UsU0FBS0MsMEJBQWFDLFFBQWxCO0FBQ0UsYUFBTyxJQUFJQyxpQkFBSixDQUFvQkosT0FBcEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYUcsZ0JBQWxCO0FBQ0U7QUFDQUMsTUFBQUEsT0FBTyxDQUFDQyxJQUFSLENBQWEsd0RBQWI7QUFDQSxhQUFPLElBQUlILGlCQUFKLENBQW9CSixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhTSxLQUFsQjtBQUNFLGFBQU8sSUFBSUMsY0FBSixDQUFpQlQsT0FBakIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYVEsZ0JBQWxCO0FBQ0UsYUFBTyxJQUFJQyx5QkFBSixDQUE0QlgsT0FBNUIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYVUsT0FBbEI7QUFDRSxhQUFPLElBQUlDLGdCQUFKLENBQW1CYixPQUFuQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhWSxRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0JmLE9BQXBCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFjLFlBQWxCO0FBQ0UsYUFBTyxJQUFJQyxxQkFBSixDQUF3QmpCLE9BQXhCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFnQixPQUFsQjtBQUNFLGFBQU8sSUFBSUMsZ0JBQUosQ0FBbUJuQixPQUFuQixDQUFQOztBQUNGLFNBQUtFLDBCQUFha0IsU0FBbEI7QUFDRTtBQUNBZCxNQUFBQSxPQUFPLENBQUNDLElBQVIsQ0FBYSw0Q0FBYjtBQUNBLGFBQU8sSUFBSWMsWUFBSixDQUFlckIsT0FBZixDQUFQOztBQUNGLFNBQUtFLDBCQUFhb0IsR0FBbEI7QUFDRSxhQUFPLElBQUlELFlBQUosQ0FBZXJCLE9BQWYsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYXFCLFFBQWxCO0FBQ0UsYUFBTyxJQUFJQyxpQkFBSixDQUFvQnhCLE9BQXBCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWF1QixJQUFsQjtBQUNFLGFBQU8sSUFBSUMsYUFBSixDQUFnQjFCLE9BQWhCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWF5QixLQUFsQjtBQUNFLGFBQU8sSUFBSUMsa0JBQUosQ0FBcUI1QixPQUFyQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhMkIsU0FBbEI7QUFDRSxhQUFPLElBQUlDLGtCQUFKLENBQXFCOUIsT0FBckIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYTZCLE1BQWxCO0FBQ0UsYUFBTyxJQUFJQyxlQUFKLENBQWtCaEMsT0FBbEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYStCLEtBQWxCO0FBQ0UsYUFBTyxJQUFJQyxjQUFKLENBQWlCbEMsT0FBakIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYWlDLE9BQWxCO0FBQ0UsYUFBTyxJQUFJQyxnQkFBSixDQUFtQnBDLE9BQW5CLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFtQyxTQUFsQjtBQUNFLGFBQU8sSUFBSUMsa0JBQUosQ0FBcUJ0QyxPQUFyQixDQUFQOztBQUNGO0FBQ0UsYUFBTyw4QkFBWUEsT0FBTyxDQUFDQyxTQUFwQixFQUFnQyxzQkFBcUJELE9BQU8sQ0FBQ0MsU0FBVSxFQUF2RSxDQUFQO0FBMUNKO0FBNENEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEhhcG9hbGltU2NyYXBlciBmcm9tICcuL2hhcG9hbGltJztcbmltcG9ydCBPdHNhckhhaGF5YWxTY3JhcGVyIGZyb20gJy4vb3RzYXItaGFoYXlhbCc7XG5pbXBvcnQgTGV1bWlTY3JhcGVyIGZyb20gJy4vbGV1bWknO1xuaW1wb3J0IERpc2NvdW50U2NyYXBlciBmcm9tICcuL2Rpc2NvdW50JztcbmltcG9ydCBNYXhTY3JhcGVyIGZyb20gJy4vbWF4JztcbmltcG9ydCBWaXNhQ2FsU2NyYXBlciBmcm9tICcuL3Zpc2EtY2FsJztcbmltcG9ydCBJc3JhY2FyZFNjcmFwZXIgZnJvbSAnLi9pc3JhY2FyZCc7XG5pbXBvcnQgQW1leFNjcmFwZXIgZnJvbSAnLi9hbWV4JztcbmltcG9ydCBNaXpyYWhpU2NyYXBlciBmcm9tICcuL21penJhaGknO1xuaW1wb3J0IFVuaW9uQmFua1NjcmFwZXIgZnJvbSAnLi91bmlvbi1iYW5rJztcbmltcG9ydCBCZWlubGV1bWlTY3JhcGVyIGZyb20gJy4vYmVpbmxldW1pJztcbmltcG9ydCBNYXNzYWRTY3JhcGVyIGZyb20gJy4vbWFzc2FkJztcbmltcG9ydCBZYWhhdlNjcmFwZXIgZnJvbSAnLi95YWhhdic7XG5pbXBvcnQgeyBTY3JhcGVyLCBTY3JhcGVyQ3JlZGVudGlhbHMsIFNjcmFwZXJPcHRpb25zIH0gZnJvbSAnLi9pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQ29tcGFueVR5cGVzIH0gZnJvbSAnLi4vZGVmaW5pdGlvbnMnO1xuaW1wb3J0IEJleWFoYWRCaXNodmlsaGFTY3JhcGVyIGZyb20gJy4vYmV5YWhhZC1iaXNodmlsaGEnO1xuaW1wb3J0IE9uZVplcm9TY3JhcGVyIGZyb20gJy4vb25lLXplcm8nO1xuaW1wb3J0IEJlaGF0c2RhYVNjcmFwZXIgZnJvbSAnLi9iZWhhdHNkYWEnO1xuaW1wb3J0IHsgYXNzZXJ0TmV2ZXIgfSBmcm9tICcuLi9hc3NlcnROZXZlcic7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVNjcmFwZXIob3B0aW9uczogU2NyYXBlck9wdGlvbnMpOiBTY3JhcGVyPFNjcmFwZXJDcmVkZW50aWFscz4ge1xuICBzd2l0Y2ggKG9wdGlvbnMuY29tcGFueUlkKSB7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaGFwb2FsaW06XG4gICAgICByZXR1cm4gbmV3IEhhcG9hbGltU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5oYXBvYWxpbUJlT25saW5lOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcImhhcG9hbGltQmVPbmxpbmUgaXMgZGVwcmVjYXRlZCwgdXNlICdoYXBvYWxpbScgaW5zdGVhZFwiKTtcbiAgICAgIHJldHVybiBuZXcgSGFwb2FsaW1TY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmxldW1pOlxuICAgICAgcmV0dXJuIG5ldyBMZXVtaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYmV5YWhhZEJpc2h2aWxoYTpcbiAgICAgIHJldHVybiBuZXcgQmV5YWhhZEJpc2h2aWxoYVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWl6cmFoaTpcbiAgICAgIHJldHVybiBuZXcgTWl6cmFoaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuZGlzY291bnQ6XG4gICAgICByZXR1cm4gbmV3IERpc2NvdW50U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5vdHNhckhhaGF5YWw6XG4gICAgICByZXR1cm4gbmV3IE90c2FySGFoYXlhbFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMudmlzYUNhbDpcbiAgICAgIHJldHVybiBuZXcgVmlzYUNhbFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubGV1bWlDYXJkOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcImxldW1pQ2FyZCBpcyBkZXByZWNhdGVkLCB1c2UgJ21heCcgaW5zdGVhZFwiKTtcbiAgICAgIHJldHVybiBuZXcgTWF4U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5tYXg6XG4gICAgICByZXR1cm4gbmV3IE1heFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaXNyYWNhcmQ6XG4gICAgICByZXR1cm4gbmV3IElzcmFjYXJkU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5hbWV4OlxuICAgICAgcmV0dXJuIG5ldyBBbWV4U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy51bmlvbjpcbiAgICAgIHJldHVybiBuZXcgVW5pb25CYW5rU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5iZWlubGV1bWk6XG4gICAgICByZXR1cm4gbmV3IEJlaW5sZXVtaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWFzc2FkOlxuICAgICAgcmV0dXJuIG5ldyBNYXNzYWRTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLnlhaGF2OlxuICAgICAgcmV0dXJuIG5ldyBZYWhhdlNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMub25lWmVybzpcbiAgICAgIHJldHVybiBuZXcgT25lWmVyb1NjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYmVoYXRzZGFhOlxuICAgICAgcmV0dXJuIG5ldyBCZWhhdHNkYWFTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gYXNzZXJ0TmV2ZXIob3B0aW9ucy5jb21wYW55SWQsIGB1bmtub3duIGNvbXBhbnkgaWQgJHtvcHRpb25zLmNvbXBhbnlJZH1gKTtcbiAgfVxufVxuIl19
@@ -1,3 +1,4 @@
1
+ import { LoadEvent } from 'puppeteer';
1
2
  import { BaseScraperWithBrowser, PossibleLoginResults } from './base-scraper-with-browser';
2
3
  import { Transaction } from '../transactions';
3
4
  declare type ScraperSpecificCredentials = {
@@ -16,6 +17,7 @@ declare class MaxScraper extends BaseScraperWithBrowser<ScraperSpecificCredentia
16
17
  checkReadiness: () => Promise<void>;
17
18
  postAction: () => Promise<void>;
18
19
  possibleResults: PossibleLoginResults;
20
+ waitUntil: LoadEvent;
19
21
  };
20
22
  fetchData(): Promise<{
21
23
  success: boolean;
@@ -60,8 +60,10 @@ const FUTURE_PURCHASE_FINANCING = 'מימון לרכישה עתידית';
60
60
  const MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME = 'דחוי חודש תשלומים';
61
61
  const THIRTY_DAYS_PLUS_TYPE_NAME = 'עסקת 30 פלוס';
62
62
  const TWO_MONTHS_POSTPONED_TYPE_NAME = 'דחוי חודשיים';
63
+ const TWO_MONTHS_POSTPONED_TYPE_NAME2 = 'דחוי 2 ח\' תשלומים';
63
64
  const MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME = 'חודשי + ריבית';
64
65
  const CREDIT_TYPE_NAME = 'קרדיט';
66
+ const CREDIT_OUTSIDE_THE_LIMIT = 'קרדיט-מחוץ למסגרת';
65
67
  const ACCUMULATING_BASKET = 'סל מצטבר';
66
68
  const POSTPONED_TRANSACTION_INSTALLMENTS = 'פריסת העסקה הדחויה';
67
69
  const REPLACEMENT_CARD = 'כרטיס חליפי';
@@ -120,6 +122,7 @@ function getTransactionType(txnTypeStr) {
120
122
  case MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME:
121
123
  case THIRTY_DAYS_PLUS_TYPE_NAME:
122
124
  case TWO_MONTHS_POSTPONED_TYPE_NAME:
125
+ case TWO_MONTHS_POSTPONED_TYPE_NAME2:
123
126
  case ACCUMULATING_BASKET:
124
127
  case INTERNET_SHOPPING_TYPE_NAME:
125
128
  case MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME:
@@ -131,6 +134,7 @@ function getTransactionType(txnTypeStr) {
131
134
 
132
135
  case INSTALLMENTS_TYPE_NAME:
133
136
  case CREDIT_TYPE_NAME:
137
+ case CREDIT_OUTSIDE_THE_LIMIT:
134
138
  return _transactions2.TransactionTypes.Installments;
135
139
 
136
140
  default:
@@ -292,7 +296,8 @@ class MaxScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
292
296
  await (0, _elementsInteractions.waitUntilElementFound)(this.page, '.personal-area > a.go-to-personal-area', true);
293
297
  },
294
298
  postAction: async () => redirectOrDialog(this.page),
295
- possibleResults: getPossibleLoginResults(this.page)
299
+ possibleResults: getPossibleLoginResults(this.page),
300
+ waitUntil: 'domcontentloaded'
296
301
  };
297
302
  }
298
303
 
@@ -314,4 +319,4 @@ class MaxScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
314
319
 
315
320
  var _default = MaxScraper;
316
321
  exports.default = _default;
317
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/max.ts"],"names":["debug","BASE_ACTIONS_URL","BASE_API_ACTIONS_URL","BASE_WELCOME_URL","LOGIN_URL","PASSWORD_EXPIRED_URL","SUCCESS_URL","NORMAL_TYPE_NAME","ATM_TYPE_NAME","INTERNET_SHOPPING_TYPE_NAME","INSTALLMENTS_TYPE_NAME","MONTHLY_CHARGE_TYPE_NAME","ONE_MONTH_POSTPONED_TYPE_NAME","MONTHLY_POSTPONED_TYPE_NAME","MONTHLY_PAYMENT_TYPE_NAME","FUTURE_PURCHASE_FINANCING","MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME","THIRTY_DAYS_PLUS_TYPE_NAME","TWO_MONTHS_POSTPONED_TYPE_NAME","MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME","CREDIT_TYPE_NAME","ACCUMULATING_BASKET","POSTPONED_TRANSACTION_INSTALLMENTS","REPLACEMENT_CARD","EARLY_REPAYMENT","MONTHLY_CARD_FEE","INVALID_DETAILS_SELECTOR","LOGIN_ERROR_SELECTOR","categories","Map","redirectOrDialog","page","Promise","race","getTransactionsUrl","monthMoment","month","year","date","path","loadCategories","res","Array","isArray","result","length","forEach","id","name","set","getTransactionType","txnTypeStr","cleanedUpTxnTypeStr","replace","trim","TransactionTypes","Normal","Installments","Error","getInstallmentsInfo","comments","undefined","matches","match","number","parseInt","total","mapTransaction","rawTransaction","isPending","paymentDate","processedDate","purchaseDate","toISOString","status","TransactionStatuses","Pending","Completed","installments","identifier","dealData","arn","type","planName","originalAmount","originalCurrency","chargedAmount","actualPaymentAmount","description","merchantName","memo","category","get","categoryId","fetchTransactionsForMonth","url","data","transactionsByAccount","transactions","filter","transaction","shortCardNumber","mappedTransaction","push","addResult","allResults","clonedResults","Object","keys","accountNumber","prepareTransactions","txns","startMoment","combineInstallments","enableTransactionsFilterByDate","clonedTxns","from","fetchTransactions","options","futureMonthsToScrape","defaultStartMoment","subtract","startDate","toDate","moment","max","allMonths","i","outputData","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","username","password","MaxScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","preAction","checkReadiness","postAction","possibleResults","fetchData","results","accounts","map","success"],"mappings":"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","sourcesContent":["import buildUrl from 'build-url';\nimport moment, { Moment } from 'moment';\nimport { Page } from 'puppeteer';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport { BaseScraperWithBrowser, LoginResults, PossibleLoginResults } from './base-scraper-with-browser';\nimport { waitForRedirect } from '../helpers/navigation';\nimport { waitUntilElementFound, elementPresentOnPage, clickButton } from '../helpers/elements-interactions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { fixInstallments, sortTransactionsByDate, filterOldTransactions } from '../helpers/transactions';\nimport { Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { getDebug } from '../helpers/debug';\nimport { ScraperOptions } from './interface';\n\nconst debug = getDebug('max');\n\ninterface ScrapedTransaction {\n  shortCardNumber: string;\n  paymentDate?: string;\n  purchaseDate: string;\n  actualPaymentAmount: string;\n  originalCurrency: string;\n  originalAmount: number;\n  planName: string;\n  comments: string;\n  merchantName: string;\n  categoryId: number;\n  dealData?: {\n    arn: string;\n  };\n}\n\nconst BASE_ACTIONS_URL = 'https://online.max.co.il';\nconst BASE_API_ACTIONS_URL = 'https://onlinelcapi.max.co.il';\nconst BASE_WELCOME_URL = 'https://www.max.co.il';\n\nconst LOGIN_URL = `${BASE_WELCOME_URL}/homepage/welcome`;\nconst PASSWORD_EXPIRED_URL = `${BASE_ACTIONS_URL}/Anonymous/Login/PasswordExpired.aspx`;\nconst SUCCESS_URL = `${BASE_WELCOME_URL}/homepage/personal`;\n\nconst NORMAL_TYPE_NAME = 'רגילה';\nconst ATM_TYPE_NAME = 'חיוב עסקות מיידי';\nconst INTERNET_SHOPPING_TYPE_NAME = 'אינטרנט/חו\"ל';\nconst INSTALLMENTS_TYPE_NAME = 'תשלומים';\nconst MONTHLY_CHARGE_TYPE_NAME = 'חיוב חודשי';\nconst ONE_MONTH_POSTPONED_TYPE_NAME = 'דחוי חודש';\nconst MONTHLY_POSTPONED_TYPE_NAME = 'דחוי לחיוב החודשי';\nconst MONTHLY_PAYMENT_TYPE_NAME = 'תשלום חודשי';\nconst FUTURE_PURCHASE_FINANCING = 'מימון לרכישה עתידית';\nconst MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME = 'דחוי חודש תשלומים';\nconst THIRTY_DAYS_PLUS_TYPE_NAME = 'עסקת 30 פלוס';\nconst TWO_MONTHS_POSTPONED_TYPE_NAME = 'דחוי חודשיים';\nconst MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME = 'חודשי + ריבית';\nconst CREDIT_TYPE_NAME = 'קרדיט';\nconst ACCUMULATING_BASKET = 'סל מצטבר';\nconst POSTPONED_TRANSACTION_INSTALLMENTS = 'פריסת העסקה הדחויה';\nconst REPLACEMENT_CARD = 'כרטיס חליפי';\nconst EARLY_REPAYMENT = 'פרעון מוקדם';\nconst MONTHLY_CARD_FEE = 'דמי כרטיס';\n\nconst INVALID_DETAILS_SELECTOR = '#popupWrongDetails';\nconst LOGIN_ERROR_SELECTOR = '#popupCardHoldersLoginError';\n\nconst categories = new Map<number, string>();\n\nfunction redirectOrDialog(page: Page) {\n  return Promise.race([\n    waitForRedirect(page, 20000, false, [BASE_WELCOME_URL, `${BASE_WELCOME_URL}/`]),\n    waitUntilElementFound(page, INVALID_DETAILS_SELECTOR, true),\n    waitUntilElementFound(page, LOGIN_ERROR_SELECTOR, true),\n  ]);\n}\n\nfunction getTransactionsUrl(monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const date = `${year}-${month}-01`;\n\n  /**\n     * url explanation:\n     * userIndex: -1 for all account owners\n     * cardIndex: -1 for all cards under the account\n     * all other query params are static, beside the date which changes for request per month\n     */\n  return buildUrl(BASE_API_ACTIONS_URL, {\n    path: `/api/registered/transactionDetails/getTransactionsAndGraphs?filterData={\"userIndex\":-1,\"cardIndex\":-1,\"monthView\":true,\"date\":\"${date}\",\"dates\":{\"startDate\":\"0\",\"endDate\":\"0\"},\"bankAccount\":{\"bankAccountIndex\":-1,\"cards\":null}}&firstCallCardIndex=-1`,\n  });\n}\n\ninterface FetchCategoryResult {\n  result? : Array<{\n    id: number;\n    name: string;\n  }>;\n}\n\nasync function loadCategories(page: Page) {\n  debug('Loading categories');\n  const res = await fetchGetWithinPage<FetchCategoryResult>(page, `${BASE_API_ACTIONS_URL}/api/contents/getCategories`);\n  if (res && Array.isArray(res.result)) {\n    debug(`${res.result.length} categories loaded`);\n      res.result?.forEach(({ id, name }) => categories.set(id, name));\n  }\n}\n\nfunction getTransactionType(txnTypeStr: string) {\n  const cleanedUpTxnTypeStr = txnTypeStr.replace('\\t', ' ').trim();\n  switch (cleanedUpTxnTypeStr) {\n    case ATM_TYPE_NAME:\n    case NORMAL_TYPE_NAME:\n    case MONTHLY_CHARGE_TYPE_NAME:\n    case ONE_MONTH_POSTPONED_TYPE_NAME:\n    case MONTHLY_POSTPONED_TYPE_NAME:\n    case FUTURE_PURCHASE_FINANCING:\n    case MONTHLY_PAYMENT_TYPE_NAME:\n    case MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME:\n    case THIRTY_DAYS_PLUS_TYPE_NAME:\n    case TWO_MONTHS_POSTPONED_TYPE_NAME:\n    case ACCUMULATING_BASKET:\n    case INTERNET_SHOPPING_TYPE_NAME:\n    case MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME:\n    case POSTPONED_TRANSACTION_INSTALLMENTS:\n    case REPLACEMENT_CARD:\n    case EARLY_REPAYMENT:\n    case MONTHLY_CARD_FEE:\n      return TransactionTypes.Normal;\n    case INSTALLMENTS_TYPE_NAME:\n    case CREDIT_TYPE_NAME:\n      return TransactionTypes.Installments;\n    default:\n      throw new Error(`Unknown transaction type ${cleanedUpTxnTypeStr}`);\n  }\n}\n\nfunction getInstallmentsInfo(comments: string) {\n  if (!comments) {\n    return undefined;\n  }\n  const matches = comments.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\nfunction mapTransaction(rawTransaction: ScrapedTransaction): Transaction {\n  const isPending = rawTransaction.paymentDate === null;\n  const processedDate = moment(isPending ?\n    rawTransaction.purchaseDate :\n    rawTransaction.paymentDate).toISOString();\n  const status = isPending ? TransactionStatuses.Pending : TransactionStatuses.Completed;\n\n  const installments = getInstallmentsInfo(rawTransaction.comments);\n  const identifier = installments ?\n    `${rawTransaction.dealData?.arn}_${installments.number}` :\n    rawTransaction.dealData?.arn;\n\n  return {\n    type: getTransactionType(rawTransaction.planName),\n    date: moment(rawTransaction.purchaseDate).toISOString(),\n    processedDate,\n    originalAmount: -rawTransaction.originalAmount,\n    originalCurrency: rawTransaction.originalCurrency,\n    chargedAmount: -rawTransaction.actualPaymentAmount,\n    description: rawTransaction.merchantName.trim(),\n    memo: rawTransaction.comments,\n    category: categories.get(rawTransaction?.categoryId),\n    installments,\n    identifier,\n    status,\n  };\n}\ninterface ScrapedTransactionsResult{\n  result?: {\n    transactions: ScrapedTransaction[];\n  };\n}\n\nasync function fetchTransactionsForMonth(page: Page, monthMoment: Moment) {\n  const url = getTransactionsUrl(monthMoment);\n\n  const data = await fetchGetWithinPage<ScrapedTransactionsResult>(page, url);\n  const transactionsByAccount: Record<string, Transaction[]> = {};\n\n  if (!data || !data.result) return transactionsByAccount;\n\n  data.result.transactions\n    // Filter out non-transactions without a plan type, e.g. summary rows\n    .filter((transaction) => !!transaction.planName)\n    .forEach((transaction: ScrapedTransaction) => {\n      if (!transactionsByAccount[transaction.shortCardNumber]) {\n        transactionsByAccount[transaction.shortCardNumber] = [];\n      }\n\n      const mappedTransaction = mapTransaction(transaction);\n      transactionsByAccount[transaction.shortCardNumber].push(mappedTransaction);\n    });\n\n  return transactionsByAccount;\n}\n\nfunction addResult(allResults: Record<string, Transaction[]>, result: Record<string, Transaction[]>) {\n  const clonedResults: Record<string, Transaction[]> = { ...allResults };\n  Object.keys(result).forEach((accountNumber) => {\n    if (!clonedResults[accountNumber]) {\n      clonedResults[accountNumber] = [];\n    }\n    clonedResults[accountNumber].push(...result[accountNumber]);\n  });\n  return clonedResults;\n}\n\nfunction prepareTransactions(txns: Transaction[], startMoment: moment.Moment, combineInstallments: boolean, enableTransactionsFilterByDate: boolean) {\n  let clonedTxns = Array.from(txns);\n  if (!combineInstallments) {\n    clonedTxns = fixInstallments(clonedTxns);\n  }\n  clonedTxns = sortTransactionsByDate(clonedTxns);\n  clonedTxns = enableTransactionsFilterByDate ?\n    filterOldTransactions(clonedTxns, startMoment, combineInstallments || false) :\n    clonedTxns;\n  return clonedTxns;\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n\n  await loadCategories(page);\n\n  let allResults: Record<string, Transaction[]> = {};\n  for (let i = 0; i < allMonths.length; i += 1) {\n    const result = await fetchTransactionsForMonth(page, allMonths[i]);\n    allResults = addResult(allResults, result);\n  }\n\n  Object.keys(allResults).forEach((accountNumber) => {\n    let txns = allResults[accountNumber];\n    txns = prepareTransactions(txns, startMoment, options.combineInstallments || false,\n      (options.outputData?.enableTransactionsFilterByDate ?? true));\n    allResults[accountNumber] = txns;\n  });\n\n  return allResults;\n}\n\nfunction getPossibleLoginResults(page: Page): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = [PASSWORD_EXPIRED_URL];\n  urls[LoginResults.InvalidPassword] = [async () => {\n    return elementPresentOnPage(page, INVALID_DETAILS_SELECTOR);\n  }];\n  urls[LoginResults.UnknownError] = [async () => {\n    return elementPresentOnPage(page, LOGIN_ERROR_SELECTOR);\n  }];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#user-name', value: credentials.username },\n    { selector: '#password', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = {username: string, password: string};\n\nclass MaxScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#login-password #send-code',\n      preAction: async () => {\n        if (await elementPresentOnPage(this.page, '#closePopup')) {\n          await clickButton(this.page, '#closePopup');\n        }\n        await clickButton(this.page, '.personal-area > a.go-to-personal-area');\n        await waitUntilElementFound(this.page, '#login-password-link', true);\n        await clickButton(this.page, '#login-password-link');\n        await waitUntilElementFound(this.page, '#login-password.tab-pane.active app-user-login-form', true);\n      },\n      checkReadiness: async () => {\n        await waitUntilElementFound(this.page, '.personal-area > a.go-to-personal-area', true);\n      },\n      postAction: async () => redirectOrDialog(this.page),\n      possibleResults: getPossibleLoginResults(this.page),\n    };\n  }\n\n  async fetchData() {\n    const results = await fetchTransactions(this.page, this.options);\n    const accounts = Object.keys(results).map((accountNumber) => {\n      return {\n        accountNumber,\n        txns: results[accountNumber],\n      };\n    });\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default MaxScraper;\n"]}
322
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/max.ts"],"names":["debug","BASE_ACTIONS_URL","BASE_API_ACTIONS_URL","BASE_WELCOME_URL","LOGIN_URL","PASSWORD_EXPIRED_URL","SUCCESS_URL","NORMAL_TYPE_NAME","ATM_TYPE_NAME","INTERNET_SHOPPING_TYPE_NAME","INSTALLMENTS_TYPE_NAME","MONTHLY_CHARGE_TYPE_NAME","ONE_MONTH_POSTPONED_TYPE_NAME","MONTHLY_POSTPONED_TYPE_NAME","MONTHLY_PAYMENT_TYPE_NAME","FUTURE_PURCHASE_FINANCING","MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME","THIRTY_DAYS_PLUS_TYPE_NAME","TWO_MONTHS_POSTPONED_TYPE_NAME","TWO_MONTHS_POSTPONED_TYPE_NAME2","MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME","CREDIT_TYPE_NAME","CREDIT_OUTSIDE_THE_LIMIT","ACCUMULATING_BASKET","POSTPONED_TRANSACTION_INSTALLMENTS","REPLACEMENT_CARD","EARLY_REPAYMENT","MONTHLY_CARD_FEE","INVALID_DETAILS_SELECTOR","LOGIN_ERROR_SELECTOR","categories","Map","redirectOrDialog","page","Promise","race","getTransactionsUrl","monthMoment","month","year","date","path","loadCategories","res","Array","isArray","result","length","forEach","id","name","set","getTransactionType","txnTypeStr","cleanedUpTxnTypeStr","replace","trim","TransactionTypes","Normal","Installments","Error","getInstallmentsInfo","comments","undefined","matches","match","number","parseInt","total","mapTransaction","rawTransaction","isPending","paymentDate","processedDate","purchaseDate","toISOString","status","TransactionStatuses","Pending","Completed","installments","identifier","dealData","arn","type","planName","originalAmount","originalCurrency","chargedAmount","actualPaymentAmount","description","merchantName","memo","category","get","categoryId","fetchTransactionsForMonth","url","data","transactionsByAccount","transactions","filter","transaction","shortCardNumber","mappedTransaction","push","addResult","allResults","clonedResults","Object","keys","accountNumber","prepareTransactions","txns","startMoment","combineInstallments","enableTransactionsFilterByDate","clonedTxns","from","fetchTransactions","options","futureMonthsToScrape","defaultStartMoment","subtract","startDate","toDate","moment","max","allMonths","i","outputData","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","username","password","MaxScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","preAction","checkReadiness","postAction","possibleResults","waitUntil","fetchData","results","accounts","map","success"],"mappings":"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","sourcesContent":["import buildUrl from 'build-url';\nimport moment, { Moment } from 'moment';\nimport { Page, LoadEvent } from 'puppeteer';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport { BaseScraperWithBrowser, LoginResults, PossibleLoginResults } from './base-scraper-with-browser';\nimport { waitForRedirect } from '../helpers/navigation';\nimport { waitUntilElementFound, elementPresentOnPage, clickButton } from '../helpers/elements-interactions';\nimport getAllMonthMoments from '../helpers/dates';\nimport { fixInstallments, sortTransactionsByDate, filterOldTransactions } from '../helpers/transactions';\nimport { Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { getDebug } from '../helpers/debug';\nimport { ScraperOptions } from './interface';\n\nconst debug = getDebug('max');\n\ninterface ScrapedTransaction {\n  shortCardNumber: string;\n  paymentDate?: string;\n  purchaseDate: string;\n  actualPaymentAmount: string;\n  originalCurrency: string;\n  originalAmount: number;\n  planName: string;\n  comments: string;\n  merchantName: string;\n  categoryId: number;\n  dealData?: {\n    arn: string;\n  };\n}\n\nconst BASE_ACTIONS_URL = 'https://online.max.co.il';\nconst BASE_API_ACTIONS_URL = 'https://onlinelcapi.max.co.il';\nconst BASE_WELCOME_URL = 'https://www.max.co.il';\n\nconst LOGIN_URL = `${BASE_WELCOME_URL}/homepage/welcome`;\nconst PASSWORD_EXPIRED_URL = `${BASE_ACTIONS_URL}/Anonymous/Login/PasswordExpired.aspx`;\nconst SUCCESS_URL = `${BASE_WELCOME_URL}/homepage/personal`;\n\nconst NORMAL_TYPE_NAME = 'רגילה';\nconst ATM_TYPE_NAME = 'חיוב עסקות מיידי';\nconst INTERNET_SHOPPING_TYPE_NAME = 'אינטרנט/חו\"ל';\nconst INSTALLMENTS_TYPE_NAME = 'תשלומים';\nconst MONTHLY_CHARGE_TYPE_NAME = 'חיוב חודשי';\nconst ONE_MONTH_POSTPONED_TYPE_NAME = 'דחוי חודש';\nconst MONTHLY_POSTPONED_TYPE_NAME = 'דחוי לחיוב החודשי';\nconst MONTHLY_PAYMENT_TYPE_NAME = 'תשלום חודשי';\nconst FUTURE_PURCHASE_FINANCING = 'מימון לרכישה עתידית';\nconst MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME = 'דחוי חודש תשלומים';\nconst THIRTY_DAYS_PLUS_TYPE_NAME = 'עסקת 30 פלוס';\nconst TWO_MONTHS_POSTPONED_TYPE_NAME = 'דחוי חודשיים';\nconst TWO_MONTHS_POSTPONED_TYPE_NAME2 = 'דחוי 2 ח\\' תשלומים';\nconst MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME = 'חודשי + ריבית';\nconst CREDIT_TYPE_NAME = 'קרדיט';\nconst CREDIT_OUTSIDE_THE_LIMIT = 'קרדיט-מחוץ למסגרת';\nconst ACCUMULATING_BASKET = 'סל מצטבר';\nconst POSTPONED_TRANSACTION_INSTALLMENTS = 'פריסת העסקה הדחויה';\nconst REPLACEMENT_CARD = 'כרטיס חליפי';\nconst EARLY_REPAYMENT = 'פרעון מוקדם';\nconst MONTHLY_CARD_FEE = 'דמי כרטיס';\n\nconst INVALID_DETAILS_SELECTOR = '#popupWrongDetails';\nconst LOGIN_ERROR_SELECTOR = '#popupCardHoldersLoginError';\n\nconst categories = new Map<number, string>();\n\nfunction redirectOrDialog(page: Page) {\n  return Promise.race([\n    waitForRedirect(page, 20000, false, [BASE_WELCOME_URL, `${BASE_WELCOME_URL}/`]),\n    waitUntilElementFound(page, INVALID_DETAILS_SELECTOR, true),\n    waitUntilElementFound(page, LOGIN_ERROR_SELECTOR, true),\n  ]);\n}\n\nfunction getTransactionsUrl(monthMoment: Moment) {\n  const month = monthMoment.month() + 1;\n  const year = monthMoment.year();\n  const date = `${year}-${month}-01`;\n\n  /**\n     * url explanation:\n     * userIndex: -1 for all account owners\n     * cardIndex: -1 for all cards under the account\n     * all other query params are static, beside the date which changes for request per month\n     */\n  return buildUrl(BASE_API_ACTIONS_URL, {\n    path: `/api/registered/transactionDetails/getTransactionsAndGraphs?filterData={\"userIndex\":-1,\"cardIndex\":-1,\"monthView\":true,\"date\":\"${date}\",\"dates\":{\"startDate\":\"0\",\"endDate\":\"0\"},\"bankAccount\":{\"bankAccountIndex\":-1,\"cards\":null}}&firstCallCardIndex=-1`,\n  });\n}\n\ninterface FetchCategoryResult {\n  result? : Array<{\n    id: number;\n    name: string;\n  }>;\n}\n\nasync function loadCategories(page: Page) {\n  debug('Loading categories');\n  const res = await fetchGetWithinPage<FetchCategoryResult>(page, `${BASE_API_ACTIONS_URL}/api/contents/getCategories`);\n  if (res && Array.isArray(res.result)) {\n    debug(`${res.result.length} categories loaded`);\n      res.result?.forEach(({ id, name }) => categories.set(id, name));\n  }\n}\n\nfunction getTransactionType(txnTypeStr: string) {\n  const cleanedUpTxnTypeStr = txnTypeStr.replace('\\t', ' ').trim();\n  switch (cleanedUpTxnTypeStr) {\n    case ATM_TYPE_NAME:\n    case NORMAL_TYPE_NAME:\n    case MONTHLY_CHARGE_TYPE_NAME:\n    case ONE_MONTH_POSTPONED_TYPE_NAME:\n    case MONTHLY_POSTPONED_TYPE_NAME:\n    case FUTURE_PURCHASE_FINANCING:\n    case MONTHLY_PAYMENT_TYPE_NAME:\n    case MONTHLY_POSTPONED_INSTALLMENTS_TYPE_NAME:\n    case THIRTY_DAYS_PLUS_TYPE_NAME:\n    case TWO_MONTHS_POSTPONED_TYPE_NAME:\n    case TWO_MONTHS_POSTPONED_TYPE_NAME2:\n    case ACCUMULATING_BASKET:\n    case INTERNET_SHOPPING_TYPE_NAME:\n    case MONTHLY_CHARGE_PLUS_INTEREST_TYPE_NAME:\n    case POSTPONED_TRANSACTION_INSTALLMENTS:\n    case REPLACEMENT_CARD:\n    case EARLY_REPAYMENT:\n    case MONTHLY_CARD_FEE:\n      return TransactionTypes.Normal;\n    case INSTALLMENTS_TYPE_NAME:\n    case CREDIT_TYPE_NAME:\n    case CREDIT_OUTSIDE_THE_LIMIT:\n      return TransactionTypes.Installments;\n    default:\n      throw new Error(`Unknown transaction type ${cleanedUpTxnTypeStr}`);\n  }\n}\n\nfunction getInstallmentsInfo(comments: string) {\n  if (!comments) {\n    return undefined;\n  }\n  const matches = comments.match(/\\d+/g);\n  if (!matches || matches.length < 2) {\n    return undefined;\n  }\n\n  return {\n    number: parseInt(matches[0], 10),\n    total: parseInt(matches[1], 10),\n  };\n}\nfunction mapTransaction(rawTransaction: ScrapedTransaction): Transaction {\n  const isPending = rawTransaction.paymentDate === null;\n  const processedDate = moment(isPending ?\n    rawTransaction.purchaseDate :\n    rawTransaction.paymentDate).toISOString();\n  const status = isPending ? TransactionStatuses.Pending : TransactionStatuses.Completed;\n\n  const installments = getInstallmentsInfo(rawTransaction.comments);\n  const identifier = installments ?\n    `${rawTransaction.dealData?.arn}_${installments.number}` :\n    rawTransaction.dealData?.arn;\n\n  return {\n    type: getTransactionType(rawTransaction.planName),\n    date: moment(rawTransaction.purchaseDate).toISOString(),\n    processedDate,\n    originalAmount: -rawTransaction.originalAmount,\n    originalCurrency: rawTransaction.originalCurrency,\n    chargedAmount: -rawTransaction.actualPaymentAmount,\n    description: rawTransaction.merchantName.trim(),\n    memo: rawTransaction.comments,\n    category: categories.get(rawTransaction?.categoryId),\n    installments,\n    identifier,\n    status,\n  };\n}\ninterface ScrapedTransactionsResult{\n  result?: {\n    transactions: ScrapedTransaction[];\n  };\n}\n\nasync function fetchTransactionsForMonth(page: Page, monthMoment: Moment) {\n  const url = getTransactionsUrl(monthMoment);\n\n  const data = await fetchGetWithinPage<ScrapedTransactionsResult>(page, url);\n  const transactionsByAccount: Record<string, Transaction[]> = {};\n\n  if (!data || !data.result) return transactionsByAccount;\n\n  data.result.transactions\n    // Filter out non-transactions without a plan type, e.g. summary rows\n    .filter((transaction) => !!transaction.planName)\n    .forEach((transaction: ScrapedTransaction) => {\n      if (!transactionsByAccount[transaction.shortCardNumber]) {\n        transactionsByAccount[transaction.shortCardNumber] = [];\n      }\n\n      const mappedTransaction = mapTransaction(transaction);\n      transactionsByAccount[transaction.shortCardNumber].push(mappedTransaction);\n    });\n\n  return transactionsByAccount;\n}\n\nfunction addResult(allResults: Record<string, Transaction[]>, result: Record<string, Transaction[]>) {\n  const clonedResults: Record<string, Transaction[]> = { ...allResults };\n  Object.keys(result).forEach((accountNumber) => {\n    if (!clonedResults[accountNumber]) {\n      clonedResults[accountNumber] = [];\n    }\n    clonedResults[accountNumber].push(...result[accountNumber]);\n  });\n  return clonedResults;\n}\n\nfunction prepareTransactions(txns: Transaction[], startMoment: moment.Moment, combineInstallments: boolean, enableTransactionsFilterByDate: boolean) {\n  let clonedTxns = Array.from(txns);\n  if (!combineInstallments) {\n    clonedTxns = fixInstallments(clonedTxns);\n  }\n  clonedTxns = sortTransactionsByDate(clonedTxns);\n  clonedTxns = enableTransactionsFilterByDate ?\n    filterOldTransactions(clonedTxns, startMoment, combineInstallments || false) :\n    clonedTxns;\n  return clonedTxns;\n}\n\nasync function fetchTransactions(page: Page, options: ScraperOptions) {\n  const futureMonthsToScrape = options.futureMonthsToScrape ?? 1;\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n  const allMonths = getAllMonthMoments(startMoment, futureMonthsToScrape);\n\n  await loadCategories(page);\n\n  let allResults: Record<string, Transaction[]> = {};\n  for (let i = 0; i < allMonths.length; i += 1) {\n    const result = await fetchTransactionsForMonth(page, allMonths[i]);\n    allResults = addResult(allResults, result);\n  }\n\n  Object.keys(allResults).forEach((accountNumber) => {\n    let txns = allResults[accountNumber];\n    txns = prepareTransactions(txns, startMoment, options.combineInstallments || false,\n      (options.outputData?.enableTransactionsFilterByDate ?? true));\n    allResults[accountNumber] = txns;\n  });\n\n  return allResults;\n}\n\nfunction getPossibleLoginResults(page: Page): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = [PASSWORD_EXPIRED_URL];\n  urls[LoginResults.InvalidPassword] = [async () => {\n    return elementPresentOnPage(page, INVALID_DETAILS_SELECTOR);\n  }];\n  urls[LoginResults.UnknownError] = [async () => {\n    return elementPresentOnPage(page, LOGIN_ERROR_SELECTOR);\n  }];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperSpecificCredentials) {\n  return [\n    { selector: '#user-name', value: credentials.username },\n    { selector: '#password', value: credentials.password },\n  ];\n}\n\ntype ScraperSpecificCredentials = {username: string, password: string};\n\nclass MaxScraper extends BaseScraperWithBrowser<ScraperSpecificCredentials> {\n  getLoginOptions(credentials: ScraperSpecificCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#login-password #send-code',\n      preAction: async () => {\n        if (await elementPresentOnPage(this.page, '#closePopup')) {\n          await clickButton(this.page, '#closePopup');\n        }\n        await clickButton(this.page, '.personal-area > a.go-to-personal-area');\n        await waitUntilElementFound(this.page, '#login-password-link', true);\n        await clickButton(this.page, '#login-password-link');\n        await waitUntilElementFound(this.page, '#login-password.tab-pane.active app-user-login-form', true);\n      },\n      checkReadiness: async () => {\n        await waitUntilElementFound(this.page, '.personal-area > a.go-to-personal-area', true);\n      },\n      postAction: async () => redirectOrDialog(this.page),\n      possibleResults: getPossibleLoginResults(this.page),\n      waitUntil: 'domcontentloaded' as LoadEvent,\n    };\n  }\n\n  async fetchData() {\n    const results = await fetchTransactions(this.page, this.options);\n    const accounts = Object.keys(results).map((accountNumber) => {\n      return {\n        accountNumber,\n        txns: results[accountNumber],\n      };\n    });\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default MaxScraper;\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers",
3
- "version": "4.0.2",
3
+ "version": "4.1.0",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {