israeli-bank-scrapers 1.10.4 → 1.11.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
@@ -24,6 +24,7 @@ Currently only the following banks are supported:
24
24
  - Beinleumi (Thanks to [@dudiventura](https://github.com/dudiventura) from the Intuit FDP OpenSource Team)
25
25
  - Massad
26
26
  - Yahav (Thanks to [@gczobel](https://github.com/gczobel))
27
+ - Beyhad Bishvilha - [ביחד בשבילך](https://www.hist.org.il/) (thanks [@esakal](https://github.com/esakal))
27
28
 
28
29
  # Prerequisites
29
30
  To use this you will need to have [Node.js](https://nodejs.org) >= 10.x installed.
@@ -282,6 +283,16 @@ const credentials = {
282
283
  ```
283
284
  This scraper supports fetching transaction from up to six months.
284
285
 
286
+ ## Beyhad Bishvilha
287
+ This scraper expects the following credentials object::
288
+ ```node
289
+ const credentials = {
290
+ id: <user identification number>,
291
+ password: <user password>
292
+ };
293
+ ```
294
+
295
+
285
296
  # Known projects
286
297
  These are the projects known to be using this module:
287
298
  - [Israeli YNAB updater](https://github.com/eshaham/israeli-ynab-updater) - A command line tool for exporting banks data to CSVs, formatted specifically for [YNAB](https://www.youneedabudget.com)
@@ -14,7 +14,8 @@ export declare enum CompanyTypes {
14
14
  mizrahi = "mizrahi",
15
15
  leumi = "leumi",
16
16
  massad = "massad",
17
- yahav = "yahav"
17
+ yahav = "yahav",
18
+ beyahadBishvilha = "beyahadBishvilha"
18
19
  }
19
20
  export declare const SCRAPERS: {
20
21
  hapoalim: {
@@ -77,4 +78,8 @@ export declare const SCRAPERS: {
77
78
  name: string;
78
79
  loginFields: string[];
79
80
  };
81
+ beyahadBishvilha: {
82
+ name: string;
83
+ loginFields: string[];
84
+ };
80
85
  };
@@ -26,6 +26,7 @@ exports.CompanyTypes = CompanyTypes;
26
26
  CompanyTypes["leumi"] = "leumi";
27
27
  CompanyTypes["massad"] = "massad";
28
28
  CompanyTypes["yahav"] = "yahav";
29
+ CompanyTypes["beyahadBishvilha"] = "beyahadBishvilha";
29
30
  })(CompanyTypes || (exports.CompanyTypes = CompanyTypes = {}));
30
31
 
31
32
  const SCRAPERS = {
@@ -90,7 +91,11 @@ const SCRAPERS = {
90
91
  [CompanyTypes.yahav]: {
91
92
  name: 'Bank Yahav',
92
93
  loginFields: ['username', 'nationalID', PASSWORD_FIELD]
94
+ },
95
+ [CompanyTypes.beyahadBishvilha]: {
96
+ name: 'Beyahad Bishvilha',
97
+ loginFields: ['id', PASSWORD_FIELD]
93
98
  }
94
99
  };
95
100
  exports.SCRAPERS = SCRAPERS;
96
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZpbml0aW9ucy50cyJdLCJuYW1lcyI6WyJQQVNTV09SRF9GSUVMRCIsIkNvbXBhbnlUeXBlcyIsIlNDUkFQRVJTIiwiaGFwb2FsaW0iLCJuYW1lIiwibG9naW5GaWVsZHMiLCJoYXBvYWxpbUJlT25saW5lIiwibGV1bWkiLCJtaXpyYWhpIiwiZGlzY291bnQiLCJvdHNhckhhaGF5YWwiLCJsZXVtaUNhcmQiLCJtYXgiLCJ2aXNhQ2FsIiwiaXNyYWNhcmQiLCJhbWV4IiwidW5pb24iLCJiZWlubGV1bWkiLCJtYXNzYWQiLCJ5YWhhdiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFFTyxNQUFNQSxjQUFjLEdBQUcsVUFBdkI7O0lBRUtDLFk7OztXQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0dBQUFBLFksNEJBQUFBLFk7O0FBa0JMLE1BQU1DLFFBQVEsR0FBRztBQUN0QixHQUFDRCxZQUFZLENBQUNFLFFBQWQsR0FBeUI7QUFDdkJDLElBQUFBLElBQUksRUFBRSxlQURpQjtBQUV2QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlUsR0FESDtBQUt0QixHQUFDQyxZQUFZLENBQUNLLGdCQUFkLEdBQWlDO0FBQUU7QUFDakNGLElBQUFBLElBQUksRUFBRSxlQUR5QjtBQUUvQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRmtCLEdBTFg7QUFTdEIsR0FBQ0MsWUFBWSxDQUFDTSxLQUFkLEdBQXNCO0FBQ3BCSCxJQUFBQSxJQUFJLEVBQUUsWUFEYztBQUVwQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRk8sR0FUQTtBQWF0QixHQUFDQyxZQUFZLENBQUNPLE9BQWQsR0FBd0I7QUFDdEJKLElBQUFBLElBQUksRUFBRSxjQURnQjtBQUV0QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlMsR0FiRjtBQWlCdEIsR0FBQ0MsWUFBWSxDQUFDUSxRQUFkLEdBQXlCO0FBQ3ZCTCxJQUFBQSxJQUFJLEVBQUUsZUFEaUI7QUFFdkJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLElBQUQsRUFBT0wsY0FBUCxFQUF1QixLQUF2QjtBQUZVLEdBakJIO0FBcUJ0QixHQUFDQyxZQUFZLENBQUNTLFlBQWQsR0FBNkI7QUFDM0JOLElBQUFBLElBQUksRUFBRSxvQkFEcUI7QUFFM0JDLElBQUFBLFdBQVcsRUFBRSxDQUFDLFVBQUQsRUFBYUwsY0FBYjtBQUZjLEdBckJQO0FBeUJ0QixHQUFDQyxZQUFZLENBQUNVLFNBQWQsR0FBMEI7QUFBRTtBQUMxQlAsSUFBQUEsSUFBSSxFQUFFLFlBRGtCO0FBRXhCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGVyxHQXpCSjtBQTZCdEIsR0FBQ0MsWUFBWSxDQUFDVyxHQUFkLEdBQW9CO0FBQ2xCUixJQUFBQSxJQUFJLEVBQUUsS0FEWTtBQUVsQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRkssR0E3QkU7QUFpQ3RCLEdBQUNDLFlBQVksQ0FBQ1ksT0FBZCxHQUF3QjtBQUN0QlQsSUFBQUEsSUFBSSxFQUFFLFVBRGdCO0FBRXRCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGUyxHQWpDRjtBQXFDdEIsR0FBQ0MsWUFBWSxDQUFDYSxRQUFkLEdBQXlCO0FBQ3ZCVixJQUFBQSxJQUFJLEVBQUUsVUFEaUI7QUFFdkJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLElBQUQsRUFBTyxhQUFQLEVBQXNCTCxjQUF0QjtBQUZVLEdBckNIO0FBeUN0QixHQUFDQyxZQUFZLENBQUNjLElBQWQsR0FBcUI7QUFDbkJYLElBQUFBLElBQUksRUFBRSxNQURhO0FBRW5CQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxJQUFELEVBQU8sYUFBUCxFQUFzQkwsY0FBdEI7QUFGTSxHQXpDQztBQTZDdEIsR0FBQ0MsWUFBWSxDQUFDZSxLQUFkLEdBQXNCO0FBQ3BCWixJQUFBQSxJQUFJLEVBQUUsT0FEYztBQUVwQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRk8sR0E3Q0E7QUFpRHRCLEdBQUNDLFlBQVksQ0FBQ2dCLFNBQWQsR0FBMEI7QUFDeEJiLElBQUFBLElBQUksRUFBRSxXQURrQjtBQUV4QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlcsR0FqREo7QUFxRHRCLEdBQUNDLFlBQVksQ0FBQ2lCLE1BQWQsR0FBdUI7QUFDckJkLElBQUFBLElBQUksRUFBRSxRQURlO0FBRXJCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGUSxHQXJERDtBQXlEdEIsR0FBQ0MsWUFBWSxDQUFDa0IsS0FBZCxHQUFzQjtBQUNwQmYsSUFBQUEsSUFBSSxFQUFFLFlBRGM7QUFFcEJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLFVBQUQsRUFBYSxZQUFiLEVBQTJCTCxjQUEzQjtBQUZPO0FBekRBLENBQWpCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTk9USUNFOiBhdm9pZCBjaGFuZ2luZyBleHBvcnRlZCBrZXlzIGFzIHRoZXkgYXJlIHBhcnQgb2YgdGhlIHB1YmxpYyBhcGlcblxuZXhwb3J0IGNvbnN0IFBBU1NXT1JEX0ZJRUxEID0gJ3Bhc3N3b3JkJztcblxuZXhwb3J0IGVudW0gQ29tcGFueVR5cGVzIHtcbiAgaGFwb2FsaW0gPSAnaGFwb2FsaW0nLFxuICBoYXBvYWxpbUJlT25saW5lID0gJ2hhcG9hbGltQmVPbmxpbmUnLFxuICBiZWlubGV1bWkgPSAnYmVpbmxldW1pJyxcbiAgdW5pb24gPSAndW5pb24nLFxuICBhbWV4ID0gJ2FtZXgnLFxuICBpc3JhY2FyZCA9ICdpc3JhY2FyZCcsXG4gIHZpc2FDYWwgPSAndmlzYUNhbCcsXG4gIG1heCA9ICdtYXgnLFxuICBsZXVtaUNhcmQgPSAnbGV1bWlDYXJkJyxcbiAgb3RzYXJIYWhheWFsID0gJ290c2FySGFoYXlhbCcsXG4gIGRpc2NvdW50ID0gJ2Rpc2NvdW50JyxcbiAgbWl6cmFoaSA9ICdtaXpyYWhpJyxcbiAgbGV1bWkgPSAnbGV1bWknLFxuICBtYXNzYWQgPSAnbWFzc2FkJyxcbiAgeWFoYXYgPSAneWFoYXYnXG59XG5cbmV4cG9ydCBjb25zdCBTQ1JBUEVSUyA9IHtcbiAgW0NvbXBhbnlUeXBlcy5oYXBvYWxpbV06IHtcbiAgICBuYW1lOiAnQmFuayBIYXBvYWxpbScsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlckNvZGUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuaGFwb2FsaW1CZU9ubGluZV06IHsgLy8gVE9ETyByZW1vdmUgaW4gTWFqb3IgdmVyc2lvblxuICAgIG5hbWU6ICdCYW5rIEhhcG9hbGltJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VyQ29kZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5sZXVtaV06IHtcbiAgICBuYW1lOiAnQmFuayBMZXVtaScsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubWl6cmFoaV06IHtcbiAgICBuYW1lOiAnTWl6cmFoaSBCYW5rJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5kaXNjb3VudF06IHtcbiAgICBuYW1lOiAnRGlzY291bnQgQmFuaycsXG4gICAgbG9naW5GaWVsZHM6IFsnaWQnLCBQQVNTV09SRF9GSUVMRCwgJ251bSddLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm90c2FySGFoYXlhbF06IHtcbiAgICBuYW1lOiAnQmFuayBPdHNhciBIYWhheWFsJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5sZXVtaUNhcmRdOiB7IC8vIFRPRE8gcmVtb3ZlIGluIE1ham9yIHZlcnNpb25cbiAgICBuYW1lOiAnTGV1bWkgQ2FyZCcsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubWF4XToge1xuICAgIG5hbWU6ICdNYXgnLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLnZpc2FDYWxdOiB7XG4gICAgbmFtZTogJ1Zpc2EgQ2FsJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5pc3JhY2FyZF06IHtcbiAgICBuYW1lOiAnSXNyYWNhcmQnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgJ2NhcmQ2RGlnaXRzJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLmFtZXhdOiB7XG4gICAgbmFtZTogJ0FtZXgnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgJ2NhcmQ2RGlnaXRzJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLnVuaW9uXToge1xuICAgIG5hbWU6ICdVbmlvbicsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuYmVpbmxldW1pXToge1xuICAgIG5hbWU6ICdCZWlubGV1bWknLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm1hc3NhZF06IHtcbiAgICBuYW1lOiAnTWFzc2FkJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy55YWhhdl06IHtcbiAgICBuYW1lOiAnQmFuayBZYWhhdicsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCAnbmF0aW9uYWxJRCcsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbn07XG4iXX0=
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9kZWZpbml0aW9ucy50cyJdLCJuYW1lcyI6WyJQQVNTV09SRF9GSUVMRCIsIkNvbXBhbnlUeXBlcyIsIlNDUkFQRVJTIiwiaGFwb2FsaW0iLCJuYW1lIiwibG9naW5GaWVsZHMiLCJoYXBvYWxpbUJlT25saW5lIiwibGV1bWkiLCJtaXpyYWhpIiwiZGlzY291bnQiLCJvdHNhckhhaGF5YWwiLCJsZXVtaUNhcmQiLCJtYXgiLCJ2aXNhQ2FsIiwiaXNyYWNhcmQiLCJhbWV4IiwidW5pb24iLCJiZWlubGV1bWkiLCJtYXNzYWQiLCJ5YWhhdiIsImJleWFoYWRCaXNodmlsaGEiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBRU8sTUFBTUEsY0FBYyxHQUFHLFVBQXZCOztJQUVLQyxZOzs7V0FBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0FBQUFBLEVBQUFBLFk7QUFBQUEsRUFBQUEsWTtBQUFBQSxFQUFBQSxZO0dBQUFBLFksNEJBQUFBLFk7O0FBbUJMLE1BQU1DLFFBQVEsR0FBRztBQUN0QixHQUFDRCxZQUFZLENBQUNFLFFBQWQsR0FBeUI7QUFDdkJDLElBQUFBLElBQUksRUFBRSxlQURpQjtBQUV2QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlUsR0FESDtBQUt0QixHQUFDQyxZQUFZLENBQUNLLGdCQUFkLEdBQWlDO0FBQUU7QUFDakNGLElBQUFBLElBQUksRUFBRSxlQUR5QjtBQUUvQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRmtCLEdBTFg7QUFTdEIsR0FBQ0MsWUFBWSxDQUFDTSxLQUFkLEdBQXNCO0FBQ3BCSCxJQUFBQSxJQUFJLEVBQUUsWUFEYztBQUVwQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRk8sR0FUQTtBQWF0QixHQUFDQyxZQUFZLENBQUNPLE9BQWQsR0FBd0I7QUFDdEJKLElBQUFBLElBQUksRUFBRSxjQURnQjtBQUV0QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlMsR0FiRjtBQWlCdEIsR0FBQ0MsWUFBWSxDQUFDUSxRQUFkLEdBQXlCO0FBQ3ZCTCxJQUFBQSxJQUFJLEVBQUUsZUFEaUI7QUFFdkJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLElBQUQsRUFBT0wsY0FBUCxFQUF1QixLQUF2QjtBQUZVLEdBakJIO0FBcUJ0QixHQUFDQyxZQUFZLENBQUNTLFlBQWQsR0FBNkI7QUFDM0JOLElBQUFBLElBQUksRUFBRSxvQkFEcUI7QUFFM0JDLElBQUFBLFdBQVcsRUFBRSxDQUFDLFVBQUQsRUFBYUwsY0FBYjtBQUZjLEdBckJQO0FBeUJ0QixHQUFDQyxZQUFZLENBQUNVLFNBQWQsR0FBMEI7QUFBRTtBQUMxQlAsSUFBQUEsSUFBSSxFQUFFLFlBRGtCO0FBRXhCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGVyxHQXpCSjtBQTZCdEIsR0FBQ0MsWUFBWSxDQUFDVyxHQUFkLEdBQW9CO0FBQ2xCUixJQUFBQSxJQUFJLEVBQUUsS0FEWTtBQUVsQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRkssR0E3QkU7QUFpQ3RCLEdBQUNDLFlBQVksQ0FBQ1ksT0FBZCxHQUF3QjtBQUN0QlQsSUFBQUEsSUFBSSxFQUFFLFVBRGdCO0FBRXRCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGUyxHQWpDRjtBQXFDdEIsR0FBQ0MsWUFBWSxDQUFDYSxRQUFkLEdBQXlCO0FBQ3ZCVixJQUFBQSxJQUFJLEVBQUUsVUFEaUI7QUFFdkJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLElBQUQsRUFBTyxhQUFQLEVBQXNCTCxjQUF0QjtBQUZVLEdBckNIO0FBeUN0QixHQUFDQyxZQUFZLENBQUNjLElBQWQsR0FBcUI7QUFDbkJYLElBQUFBLElBQUksRUFBRSxNQURhO0FBRW5CQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxJQUFELEVBQU8sYUFBUCxFQUFzQkwsY0FBdEI7QUFGTSxHQXpDQztBQTZDdEIsR0FBQ0MsWUFBWSxDQUFDZSxLQUFkLEdBQXNCO0FBQ3BCWixJQUFBQSxJQUFJLEVBQUUsT0FEYztBQUVwQkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRk8sR0E3Q0E7QUFpRHRCLEdBQUNDLFlBQVksQ0FBQ2dCLFNBQWQsR0FBMEI7QUFDeEJiLElBQUFBLElBQUksRUFBRSxXQURrQjtBQUV4QkMsSUFBQUEsV0FBVyxFQUFFLENBQUMsVUFBRCxFQUFhTCxjQUFiO0FBRlcsR0FqREo7QUFxRHRCLEdBQUNDLFlBQVksQ0FBQ2lCLE1BQWQsR0FBdUI7QUFDckJkLElBQUFBLElBQUksRUFBRSxRQURlO0FBRXJCQyxJQUFBQSxXQUFXLEVBQUUsQ0FBQyxVQUFELEVBQWFMLGNBQWI7QUFGUSxHQXJERDtBQXlEdEIsR0FBQ0MsWUFBWSxDQUFDa0IsS0FBZCxHQUFzQjtBQUNwQmYsSUFBQUEsSUFBSSxFQUFFLFlBRGM7QUFFcEJDLElBQUFBLFdBQVcsRUFBRSxDQUFDLFVBQUQsRUFBYSxZQUFiLEVBQTJCTCxjQUEzQjtBQUZPLEdBekRBO0FBNkR0QixHQUFDQyxZQUFZLENBQUNtQixnQkFBZCxHQUFpQztBQUMvQmhCLElBQUFBLElBQUksRUFBRSxtQkFEeUI7QUFFL0JDLElBQUFBLFdBQVcsRUFBRSxDQUFDLElBQUQsRUFBT0wsY0FBUDtBQUZrQjtBQTdEWCxDQUFqQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIE5PVElDRTogYXZvaWQgY2hhbmdpbmcgZXhwb3J0ZWQga2V5cyBhcyB0aGV5IGFyZSBwYXJ0IG9mIHRoZSBwdWJsaWMgYXBpXG5cbmV4cG9ydCBjb25zdCBQQVNTV09SRF9GSUVMRCA9ICdwYXNzd29yZCc7XG5cbmV4cG9ydCBlbnVtIENvbXBhbnlUeXBlcyB7XG4gIGhhcG9hbGltID0gJ2hhcG9hbGltJyxcbiAgaGFwb2FsaW1CZU9ubGluZSA9ICdoYXBvYWxpbUJlT25saW5lJyxcbiAgYmVpbmxldW1pID0gJ2JlaW5sZXVtaScsXG4gIHVuaW9uID0gJ3VuaW9uJyxcbiAgYW1leCA9ICdhbWV4JyxcbiAgaXNyYWNhcmQgPSAnaXNyYWNhcmQnLFxuICB2aXNhQ2FsID0gJ3Zpc2FDYWwnLFxuICBtYXggPSAnbWF4JyxcbiAgbGV1bWlDYXJkID0gJ2xldW1pQ2FyZCcsXG4gIG90c2FySGFoYXlhbCA9ICdvdHNhckhhaGF5YWwnLFxuICBkaXNjb3VudCA9ICdkaXNjb3VudCcsXG4gIG1penJhaGkgPSAnbWl6cmFoaScsXG4gIGxldW1pID0gJ2xldW1pJyxcbiAgbWFzc2FkID0gJ21hc3NhZCcsXG4gIHlhaGF2ID0gJ3lhaGF2JyxcbiAgYmV5YWhhZEJpc2h2aWxoYSA9ICdiZXlhaGFkQmlzaHZpbGhhJ1xufVxuXG5leHBvcnQgY29uc3QgU0NSQVBFUlMgPSB7XG4gIFtDb21wYW55VHlwZXMuaGFwb2FsaW1dOiB7XG4gICAgbmFtZTogJ0JhbmsgSGFwb2FsaW0nLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJDb2RlJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLmhhcG9hbGltQmVPbmxpbmVdOiB7IC8vIFRPRE8gcmVtb3ZlIGluIE1ham9yIHZlcnNpb25cbiAgICBuYW1lOiAnQmFuayBIYXBvYWxpbScsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlckNvZGUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubGV1bWldOiB7XG4gICAgbmFtZTogJ0JhbmsgTGV1bWknLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm1penJhaGldOiB7XG4gICAgbmFtZTogJ01penJhaGkgQmFuaycsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuZGlzY291bnRdOiB7XG4gICAgbmFtZTogJ0Rpc2NvdW50IEJhbmsnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgUEFTU1dPUkRfRklFTEQsICdudW0nXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5vdHNhckhhaGF5YWxdOiB7XG4gICAgbmFtZTogJ0JhbmsgT3RzYXIgSGFoYXlhbCcsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMubGV1bWlDYXJkXTogeyAvLyBUT0RPIHJlbW92ZSBpbiBNYWpvciB2ZXJzaW9uXG4gICAgbmFtZTogJ0xldW1pIENhcmQnLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLm1heF06IHtcbiAgICBuYW1lOiAnTWF4JyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy52aXNhQ2FsXToge1xuICAgIG5hbWU6ICdWaXNhIENhbCcsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuaXNyYWNhcmRdOiB7XG4gICAgbmFtZTogJ0lzcmFjYXJkJyxcbiAgICBsb2dpbkZpZWxkczogWydpZCcsICdjYXJkNkRpZ2l0cycsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5hbWV4XToge1xuICAgIG5hbWU6ICdBbWV4JyxcbiAgICBsb2dpbkZpZWxkczogWydpZCcsICdjYXJkNkRpZ2l0cycsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy51bmlvbl06IHtcbiAgICBuYW1lOiAnVW5pb24nLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxuICBbQ29tcGFueVR5cGVzLmJlaW5sZXVtaV06IHtcbiAgICBuYW1lOiAnQmVpbmxldW1pJyxcbiAgICBsb2dpbkZpZWxkczogWyd1c2VybmFtZScsIFBBU1NXT1JEX0ZJRUxEXSxcbiAgfSxcbiAgW0NvbXBhbnlUeXBlcy5tYXNzYWRdOiB7XG4gICAgbmFtZTogJ01hc3NhZCcsXG4gICAgbG9naW5GaWVsZHM6IFsndXNlcm5hbWUnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMueWFoYXZdOiB7XG4gICAgbmFtZTogJ0JhbmsgWWFoYXYnLFxuICAgIGxvZ2luRmllbGRzOiBbJ3VzZXJuYW1lJywgJ25hdGlvbmFsSUQnLCBQQVNTV09SRF9GSUVMRF0sXG4gIH0sXG4gIFtDb21wYW55VHlwZXMuYmV5YWhhZEJpc2h2aWxoYV06IHtcbiAgICBuYW1lOiAnQmV5YWhhZCBCaXNodmlsaGEnLFxuICAgIGxvZ2luRmllbGRzOiBbJ2lkJywgUEFTU1dPUkRfRklFTERdLFxuICB9LFxufTtcbiJdfQ==
@@ -24,7 +24,7 @@ export interface LoginOptions {
24
24
  selector: string;
25
25
  value: string;
26
26
  }[];
27
- submitButtonSelector: string;
27
+ submitButtonSelector: string | (() => Promise<void>);
28
28
  preAction?: () => Promise<Frame | void>;
29
29
  postAction?: () => Promise<void>;
30
30
  possibleResults: PossibleLoginResults;
@@ -33,6 +33,10 @@ export interface LoginOptions {
33
33
  declare class BaseScraperWithBrowser extends BaseScraper {
34
34
  protected browser: Browser;
35
35
  protected page: Page;
36
+ protected getViewPort(): {
37
+ width: number;
38
+ height: number;
39
+ };
36
40
  initialize(): Promise<void>;
37
41
  navigateTo(url: string, page?: Page, timeout?: number): Promise<void>;
38
42
  getLoginOptions(_credentials: ScraperCredentials): LoginOptions;
@@ -129,6 +129,13 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
129
129
  _defineProperty(this, "page", void 0);
130
130
  }
131
131
 
132
+ getViewPort() {
133
+ return {
134
+ width: VIEWPORT_WIDTH,
135
+ height: VIEWPORT_HEIGHT
136
+ };
137
+ }
138
+
132
139
  async initialize() {
133
140
  debug('initialize scraper');
134
141
  this.emitProgress(_baseScraper.ScaperProgressTypes.Initializing);
@@ -181,10 +188,11 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
181
188
  await this.options.preparePage(this.page);
182
189
  }
183
190
 
184
- debug(`set viewport to width ${VIEWPORT_WIDTH}, height ${VIEWPORT_HEIGHT}`);
191
+ const viewport = this.getViewPort();
192
+ debug(`set viewport to width ${viewport.width}, height ${viewport.height}`);
185
193
  await this.page.setViewport({
186
- width: VIEWPORT_WIDTH,
187
- height: VIEWPORT_HEIGHT
194
+ width: viewport.width,
195
+ height: viewport.height
188
196
  });
189
197
  this.page.on('requestfailed', request => {
190
198
  var _request$failure;
@@ -250,7 +258,7 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
250
258
  if (loginOptions.checkReadiness) {
251
259
  debug('execute \'checkReadiness\' interceptor provided in login options');
252
260
  await loginOptions.checkReadiness();
253
- } else {
261
+ } else if (typeof loginOptions.submitButtonSelector === 'string') {
254
262
  debug('wait until submit button is available');
255
263
  await (0, _elementsInteractions.waitUntilElementFound)(this.page, loginOptions.submitButtonSelector);
256
264
  }
@@ -265,7 +273,13 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
265
273
  debug('fill login components input with relevant values');
266
274
  await this.fillInputs(loginFrameOrPage, loginOptions.fields);
267
275
  debug('click on login submit button');
268
- await (0, _elementsInteractions.clickButton)(loginFrameOrPage, loginOptions.submitButtonSelector);
276
+
277
+ if (typeof loginOptions.submitButtonSelector === 'string') {
278
+ await (0, _elementsInteractions.clickButton)(loginFrameOrPage, loginOptions.submitButtonSelector);
279
+ } else {
280
+ await loginOptions.submitButtonSelector();
281
+ }
282
+
269
283
  this.emitProgress(_baseScraper.ScaperProgressTypes.LoggingIn);
270
284
 
271
285
  if (loginOptions.postAction) {
@@ -305,4 +319,4 @@ class BaseScraperWithBrowser extends _baseScraper.BaseScraper {
305
319
  }
306
320
 
307
321
  exports.BaseScraperWithBrowser = BaseScraperWithBrowser;
308
- //# 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","handleLoginResult","scraper","loginResult","Success","emitProgress","ScaperProgressTypes","LoginSuccess","success","InvalidPassword","LoginFailed","errorType","errorMessage","ChangePassword","Error","createGeneralError","BaseScraperWithBrowser","BaseScraper","initialize","Initializing","env","options","verbose","DEBUG","process","browser","executablePath","undefined","args","headless","showBrowser","puppeteer","launch","prepareBrowser","pages","length","newPage","preparePage","setViewport","width","height","on","request","failure","errorText","url","navigateTo","timeout","pageToUse","response","goto","status","getLoginOptions","_credentials","companyId","fillInputs","pageOrFrame","fields","modified","input","shift","selector","login","credentials","loginOptions","userAgent","setUserAgent","loginUrl","checkReadiness","submitButtonSelector","loginFrameOrPage","preAction","LoggingIn","postAction","current","possibleResults","terminate","_success","Terminating","storeFailureScreenShotPath","screenshot","path","fullPage","close"],"mappings":"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","sourcesContent":["import puppeteer, { Browser, Frame, Page } from 'puppeteer';\n\nimport {\n  ScraperErrorTypes,\n  BaseScraper, ScaperScrapingResult, ScaperProgressTypes,\n  ScraperCredentials,\n} from './base-scraper';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { clickButton, fillInput, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { getDebug } from '../helpers/debug';\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;\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 handleLoginResult(scraper: BaseScraperWithBrowser, loginResult: LoginResults) {\n  switch (loginResult) {\n    case LoginResults.Success:\n      scraper.emitProgress(ScaperProgressTypes.LoginSuccess);\n      return { success: true };\n    case LoginResults.InvalidPassword:\n    case LoginResults.UnknownError:\n      scraper.emitProgress(ScaperProgressTypes.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      scraper.emitProgress(ScaperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    default:\n      throw new Error(`unexpected login result \"${loginResult}\"`);\n  }\n}\n\nfunction createGeneralError(): ScaperScrapingResult {\n  return {\n    success: false,\n    errorType: ScraperErrorTypes.General,\n  };\n}\n\nclass BaseScraperWithBrowser extends BaseScraper {\n  // NOTICE - it is discourage 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 discourage 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  async initialize() {\n    debug('initialize scraper');\n    this.emitProgress(ScaperProgressTypes.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\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      });\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.preparePage) {\n      debug('execute \\'preparePage\\' interceptor provided in options');\n      await this.options.preparePage(this.page);\n    }\n\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: Record<string, string>): Promise<ScaperScrapingResult> {\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 {\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    await clickButton(loginFrameOrPage, loginOptions.submitButtonSelector);\n    this.emitProgress(ScaperProgressTypes.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 handleLoginResult(this, loginResult);\n  }\n\n  async terminate(_success: boolean) {\n    debug(`terminating browser with success = ${_success}`);\n    this.emitProgress(ScaperProgressTypes.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\nexport { BaseScraperWithBrowser };\n"]}
322
+ //# 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","handleLoginResult","scraper","loginResult","Success","emitProgress","ScaperProgressTypes","LoginSuccess","success","InvalidPassword","LoginFailed","errorType","errorMessage","ChangePassword","Error","createGeneralError","BaseScraperWithBrowser","BaseScraper","getViewPort","width","height","initialize","Initializing","env","options","verbose","DEBUG","process","browser","executablePath","undefined","args","headless","showBrowser","puppeteer","launch","prepareBrowser","pages","length","newPage","preparePage","viewport","setViewport","on","request","failure","errorText","url","navigateTo","timeout","pageToUse","response","goto","status","getLoginOptions","_credentials","companyId","fillInputs","pageOrFrame","fields","modified","input","shift","selector","login","credentials","loginOptions","userAgent","setUserAgent","loginUrl","checkReadiness","submitButtonSelector","loginFrameOrPage","preAction","LoggingIn","postAction","current","possibleResults","terminate","_success","Terminating","storeFailureScreenShotPath","screenshot","path","fullPage","close"],"mappings":";;;;;;;;;;;AAAA;;AAEA;;AAKA;;AACA;;AACA;;;;;;;;;;;;;;AAEA,MAAMA,cAAc,GAAG,IAAvB;AACA,MAAMC,eAAe,GAAG,GAAxB;AACA,MAAMC,SAAS,GAAG,GAAlB;AAEA,MAAMC,KAAK,GAAG,qBAAS,2BAAT,CAAd;IAEKC,gB;;WAAAA,gB;AAAAA,EAAAA,gB;AAAAA,EAAAA,gB;GAAAA,gB,KAAAA,gB;;AAKL,MAAM;AACJC,EAAAA,OADI;AACKC,EAAAA,OADL;AACcC,EAAAA;AADd,IAEFC,8BAFJ;AAAA,MACgCC,IADhC,4BAEID,8BAFJ;;AAGO,MAAME,YAAY,qBACpBD,IADoB,MAEpBL,gBAFoB,CAAlB;;;;AAyBP,eAAeO,aAAf,CAA6BC,MAA7B,EAA2DC,KAA3D,EAA0EC,IAA1E,EAA6G;AAC3G,QAAMC,IAAI,GAAGC,MAAM,CAACD,IAAP,CAAYH,MAAZ,CAAb;;AACA,OAAK,MAAMK,GAAX,IAAkBF,IAAlB,EAAwB;AACtB;AACA,UAAMG,UAAU,GAAGN,MAAM,CAACK,GAAD,CAAzB;;AAEA,SAAK,MAAME,SAAX,IAAwBD,UAAxB,EAAoC;AAClC,UAAIE,MAAM,GAAG,KAAb;;AAEA,UAAID,SAAS,YAAYE,MAAzB,EAAiC;AAC/BD,QAAAA,MAAM,GAAGD,SAAS,CAACG,IAAV,CAAeT,KAAf,CAAT;AACD,OAFD,MAEO,IAAI,OAAOM,SAAP,KAAqB,UAAzB,EAAqC;AAC1CC,QAAAA,MAAM,GAAG,MAAMD,SAAS,CAAC;AAAEL,UAAAA,IAAF;AAAQD,UAAAA;AAAR,SAAD,CAAxB;AACD,OAFM,MAEA;AACLO,QAAAA,MAAM,GAAGP,KAAK,CAACU,WAAN,OAAwBJ,SAAS,CAACI,WAAV,EAAjC;AACD;;AAED,UAAIH,MAAJ,EAAY;AACV;AACA,eAAOI,OAAO,CAACC,OAAR,CAAgBR,GAAhB,CAAP;AACD;AACF;AACF;;AAED,SAAOO,OAAO,CAACC,OAAR,CAAgBf,YAAY,CAACgB,YAA7B,CAAP;AACD;;AAED,SAASC,iBAAT,CAA2BC,OAA3B,EAA4DC,WAA5D,EAAuF;AACrF,UAAQA,WAAR;AACE,SAAKnB,YAAY,CAACoB,OAAlB;AACEF,MAAAA,OAAO,CAACG,YAAR,CAAqBC,iCAAoBC,YAAzC;AACA,aAAO;AAAEC,QAAAA,OAAO,EAAE;AAAX,OAAP;;AACF,SAAKxB,YAAY,CAACyB,eAAlB;AACA,SAAKzB,YAAY,CAACgB,YAAlB;AACEE,MAAAA,OAAO,CAACG,YAAR,CAAqBC,iCAAoBI,WAAzC;AACA,aAAO;AACLF,QAAAA,OAAO,EAAE,KADJ;AAELG,QAAAA,SAAS,EAAER,WAAW,KAAKnB,YAAY,CAACyB,eAA7B,GAA+C3B,+BAAkB2B,eAAjE,GACT3B,+BAAkBD,OAHf;AAIL+B,QAAAA,YAAY,EAAG,qBAAoBT,WAAY;AAJ1C,OAAP;;AAMF,SAAKnB,YAAY,CAAC6B,cAAlB;AACEX,MAAAA,OAAO,CAACG,YAAR,CAAqBC,iCAAoBO,cAAzC;AACA,aAAO;AACLL,QAAAA,OAAO,EAAE,KADJ;AAELG,QAAAA,SAAS,EAAE7B,+BAAkB+B;AAFxB,OAAP;;AAIF;AACE,YAAM,IAAIC,KAAJ,CAAW,4BAA2BX,WAAY,GAAlD,CAAN;AApBJ;AAsBD;;AAED,SAASY,kBAAT,GAAoD;AAClD,SAAO;AACLP,IAAAA,OAAO,EAAE,KADJ;AAELG,IAAAA,SAAS,EAAE7B,+BAAkBD;AAFxB,GAAP;AAID;;AAED,MAAMmC,sBAAN,SAAqCC,wBAArC,CAAiD;AAAA;AAAA;;AAAA;;AAAA;AAAA;;AASrCC,EAAAA,WAAV,GAAwB;AACtB,WAAO;AACLC,MAAAA,KAAK,EAAE7C,cADF;AAEL8C,MAAAA,MAAM,EAAE7C;AAFH,KAAP;AAID;;AAED,QAAM8C,UAAN,GAAmB;AACjB5C,IAAAA,KAAK,CAAC,oBAAD,CAAL;AACA,SAAK4B,YAAL,CAAkBC,iCAAoBgB,YAAtC;AAEA,QAAIC,GAAJ;;AACA,QAAI,KAAKC,OAAL,CAAaC,OAAjB,EAA0B;AACxBF,MAAAA,GAAG;AAAKG,QAAAA,KAAK,EAAE;AAAZ,SAAoBC,OAAO,CAACJ,GAA5B,CAAH;AACD;;AAED,QAAI,OAAO,KAAKC,OAAL,CAAaI,OAApB,KAAgC,WAAhC,IAA+C,KAAKJ,OAAL,CAAaI,OAAb,KAAyB,IAA5E,EAAkF;AAChFnD,MAAAA,KAAK,CAAC,iDAAD,CAAL;AACA,WAAKmD,OAAL,GAAe,KAAKJ,OAAL,CAAaI,OAA5B;AACD,KAHD,MAGO;AACL,YAAMC,cAAc,GAAG,KAAKL,OAAL,CAAaK,cAAb,IAA+BC,SAAtD;AACA,YAAMC,IAAI,GAAG,KAAKP,OAAL,CAAaO,IAAb,IAAqB,EAAlC;AAEA,YAAMC,QAAQ,GAAG,CAAC,KAAKR,OAAL,CAAaS,WAA/B;AACAxD,MAAAA,KAAK,CAAE,yCAAwCuD,QAAS,EAAnD,CAAL;AACA,WAAKJ,OAAL,GAAe,MAAMM,mBAAUC,MAAV,CAAiB;AACpCZ,QAAAA,GADoC;AAEpCS,QAAAA,QAFoC;AAGpCH,QAAAA,cAHoC;AAIpCE,QAAAA;AAJoC,OAAjB,CAArB;AAMD;;AAED,QAAI,KAAKP,OAAL,CAAaY,cAAjB,EAAiC;AAC/B3D,MAAAA,KAAK,CAAC,4DAAD,CAAL;AACA,YAAM,KAAK+C,OAAL,CAAaY,cAAb,CAA4B,KAAKR,OAAjC,CAAN;AACD;;AAED,QAAI,CAAC,KAAKA,OAAV,EAAmB;AACjBnD,MAAAA,KAAK,CAAC,oCAAD,CAAL;AACA;AACD;;AAED,UAAM4D,KAAK,GAAG,MAAM,KAAKT,OAAL,CAAaS,KAAb,EAApB;;AACA,QAAIA,KAAK,CAACC,MAAV,EAAkB;AAChB7D,MAAAA,KAAK,CAAC,mDAAD,CAAL;AACA,OAAC,KAAKW,IAAN,IAAciD,KAAd;AACD,KAHD,MAGO;AACL5D,MAAAA,KAAK,CAAC,2BAAD,CAAL;AACA,WAAKW,IAAL,GAAY,MAAM,KAAKwC,OAAL,CAAaW,OAAb,EAAlB;AACD;;AAED,QAAI,KAAKf,OAAL,CAAagB,WAAjB,EAA8B;AAC5B/D,MAAAA,KAAK,CAAC,yDAAD,CAAL;AACA,YAAM,KAAK+C,OAAL,CAAagB,WAAb,CAAyB,KAAKpD,IAA9B,CAAN;AACD;;AAED,UAAMqD,QAAQ,GAAG,KAAKvB,WAAL,EAAjB;AACAzC,IAAAA,KAAK,CAAE,yBAAwBgE,QAAQ,CAACtB,KAAM,YAAWsB,QAAQ,CAACrB,MAAO,EAApE,CAAL;AACA,UAAM,KAAKhC,IAAL,CAAUsD,WAAV,CAAsB;AAC1BvB,MAAAA,KAAK,EAAEsB,QAAQ,CAACtB,KADU;AAE1BC,MAAAA,MAAM,EAAEqB,QAAQ,CAACrB;AAFS,KAAtB,CAAN;AAKA,SAAKhC,IAAL,CAAUuD,EAAV,CAAa,eAAb,EAA+BC,OAAD,IAAa;AAAA;;AACzCnE,MAAAA,KAAK,CAAC,uBAAD,sBAA0BmE,OAAO,CAACC,OAAR,EAA1B,qDAA0B,iBAAmBC,SAA7C,EAAwDF,OAAO,CAACG,GAAR,EAAxD,CAAL;AACD,KAFD;AAGD;;AAED,QAAMC,UAAN,CAAiBD,GAAjB,EAA8B3D,IAA9B,EAA2C6D,OAA3C,EAA4E;AAC1E,UAAMC,SAAS,GAAG9D,IAAI,IAAI,KAAKA,IAA/B;;AAEA,QAAI,CAAC8D,SAAL,EAAgB;AACd;AACD;;AAED,UAAM1B,OAAO,qBAASyB,OAAO,KAAK,IAAZ,GAAmB,IAAnB,GAA0B;AAAEA,MAAAA;AAAF,KAAnC,CAAb;;AACA,UAAME,QAAQ,GAAG,MAAMD,SAAS,CAACE,IAAV,CAAeL,GAAf,EAAoBvB,OAApB,CAAvB,CAR0E,CAU1E;;AACA,QAAI2B,QAAQ,KAAK,IAAb,KAAsBA,QAAQ,KAAKrB,SAAb,IAA0BqB,QAAQ,CAACE,MAAT,OAAsB7E,SAAtE,CAAJ,EAAsF;AACpF,YAAM,IAAIsC,KAAJ,CAAW,yCAAwCiC,GAAI,EAAvD,CAAN;AACD;AACF,GA5F8C,CA8F/C;;;AACAO,EAAAA,eAAe,CAACC,YAAD,EAAiD;AAC9D,UAAM,IAAIzC,KAAJ,CAAW,uCAAsC,KAAKU,OAAL,CAAagC,SAAU,EAAxE,CAAN;AACD;;AAED,QAAMC,UAAN,CAAiBC,WAAjB,EAA4CC,MAA5C,EAAyG;AACvG,UAAMC,QAAQ,GAAG,CAAC,GAAGD,MAAJ,CAAjB;AACA,UAAME,KAAK,GAAGD,QAAQ,CAACE,KAAT,EAAd;;AAEA,QAAI,CAACD,KAAL,EAAY;AACV;AACD;;AACD,UAAM,qCAAUH,WAAV,EAAuBG,KAAK,CAACE,QAA7B,EAAuCF,KAAK,CAAC1E,KAA7C,CAAN;;AACA,QAAIyE,QAAQ,CAACtB,MAAb,EAAqB;AACnB,YAAM,KAAKmB,UAAL,CAAgBC,WAAhB,EAA6BE,QAA7B,CAAN;AACD;AACF;;AAED,QAAMI,KAAN,CAAYC,WAAZ,EAAgF;AAC9E,QAAI,CAACA,WAAD,IAAgB,CAAC,KAAK7E,IAA1B,EAAgC;AAC9B,aAAO2B,kBAAkB,EAAzB;AACD;;AAEDtC,IAAAA,KAAK,CAAC,uBAAD,CAAL;AACA,UAAMyF,YAAY,GAAG,KAAKZ,eAAL,CAAqBW,WAArB,CAArB;;AAEA,QAAIC,YAAY,CAACC,SAAjB,EAA4B;AAC1B1F,MAAAA,KAAK,CAAC,2CAAD,CAAL;AACA,YAAM,KAAKW,IAAL,CAAUgF,YAAV,CAAuBF,YAAY,CAACC,SAApC,CAAN;AACD;;AAED1F,IAAAA,KAAK,CAAC,uBAAD,CAAL;AACA,UAAM,KAAKuE,UAAL,CAAgBkB,YAAY,CAACG,QAA7B,CAAN;;AACA,QAAIH,YAAY,CAACI,cAAjB,EAAiC;AAC/B7F,MAAAA,KAAK,CAAC,kEAAD,CAAL;AACA,YAAMyF,YAAY,CAACI,cAAb,EAAN;AACD,KAHD,MAGO,IAAI,OAAOJ,YAAY,CAACK,oBAApB,KAA6C,QAAjD,EAA2D;AAChE9F,MAAAA,KAAK,CAAC,uCAAD,CAAL;AACA,YAAM,iDAAsB,KAAKW,IAA3B,EAAiC8E,YAAY,CAACK,oBAA9C,CAAN;AACD;;AAED,QAAIC,gBAAuC,GAAG,KAAKpF,IAAnD;;AACA,QAAI8E,YAAY,CAACO,SAAjB,EAA4B;AAC1BhG,MAAAA,KAAK,CAAC,6DAAD,CAAL;AACA+F,MAAAA,gBAAgB,GAAG,OAAMN,YAAY,CAACO,SAAb,EAAN,KAAkC,KAAKrF,IAA1D;AACD;;AAEDX,IAAAA,KAAK,CAAC,kDAAD,CAAL;AACA,UAAM,KAAKgF,UAAL,CAAgBe,gBAAhB,EAAkCN,YAAY,CAACP,MAA/C,CAAN;AACAlF,IAAAA,KAAK,CAAC,8BAAD,CAAL;;AACA,QAAI,OAAOyF,YAAY,CAACK,oBAApB,KAA6C,QAAjD,EAA2D;AACzD,YAAM,uCAAYC,gBAAZ,EAA8BN,YAAY,CAACK,oBAA3C,CAAN;AACD,KAFD,MAEO;AACL,YAAML,YAAY,CAACK,oBAAb,EAAN;AACD;;AACD,SAAKlE,YAAL,CAAkBC,iCAAoBoE,SAAtC;;AAEA,QAAIR,YAAY,CAACS,UAAjB,EAA6B;AAC3BlG,MAAAA,KAAK,CAAC,8DAAD,CAAL;AACA,YAAMyF,YAAY,CAACS,UAAb,EAAN;AACD,KAHD,MAGO;AACLlG,MAAAA,KAAK,CAAC,0BAAD,CAAL;AACA,YAAM,mCAAkB,KAAKW,IAAvB,CAAN;AACD;;AAEDX,IAAAA,KAAK,CAAC,oBAAD,CAAL;AACA,UAAMmG,OAAO,GAAG,MAAM,+BAAc,KAAKxF,IAAnB,EAAyB,IAAzB,CAAtB;AACA,UAAMe,WAAW,GAAG,MAAMlB,aAAa,CAACiF,YAAY,CAACW,eAAd,EAA+BD,OAA/B,EAAwC,KAAKxF,IAA7C,CAAvC;AACAX,IAAAA,KAAK,CAAE,wBAAuB0B,WAAY,EAArC,CAAL;AACA,WAAOF,iBAAiB,CAAC,IAAD,EAAOE,WAAP,CAAxB;AACD;;AAED,QAAM2E,SAAN,CAAgBC,QAAhB,EAAmC;AACjCtG,IAAAA,KAAK,CAAE,sCAAqCsG,QAAS,EAAhD,CAAL;AACA,SAAK1E,YAAL,CAAkBC,iCAAoB0E,WAAtC;;AAEA,QAAI,CAACD,QAAD,IAAa,CAAC,CAAC,KAAKvD,OAAL,CAAayD,0BAAhC,EAA4D;AAC1DxG,MAAAA,KAAK,CAAE,0CAAyC,KAAK+C,OAAL,CAAayD,0BAA2B,EAAnF,CAAL;AACA,YAAM,KAAK7F,IAAL,CAAU8F,UAAV,CAAqB;AACzBC,QAAAA,IAAI,EAAE,KAAK3D,OAAL,CAAayD,0BADM;AAEzBG,QAAAA,QAAQ,EAAE;AAFe,OAArB,CAAN;AAID;;AAED,QAAI,CAAC,KAAKxD,OAAV,EAAmB;AACjB;AACD;;AAED,UAAM,KAAKA,OAAL,CAAayD,KAAb,EAAN;AACD;;AAvL8C","sourcesContent":["import puppeteer, { Browser, Frame, Page } from 'puppeteer';\n\nimport {\n  ScraperErrorTypes,\n  BaseScraper, ScaperScrapingResult, ScaperProgressTypes,\n  ScraperCredentials,\n} from './base-scraper';\nimport { getCurrentUrl, waitForNavigation } from '../helpers/navigation';\nimport { clickButton, fillInput, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { getDebug } from '../helpers/debug';\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 handleLoginResult(scraper: BaseScraperWithBrowser, loginResult: LoginResults) {\n  switch (loginResult) {\n    case LoginResults.Success:\n      scraper.emitProgress(ScaperProgressTypes.LoginSuccess);\n      return { success: true };\n    case LoginResults.InvalidPassword:\n    case LoginResults.UnknownError:\n      scraper.emitProgress(ScaperProgressTypes.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      scraper.emitProgress(ScaperProgressTypes.ChangePassword);\n      return {\n        success: false,\n        errorType: ScraperErrorTypes.ChangePassword,\n      };\n    default:\n      throw new Error(`unexpected login result \"${loginResult}\"`);\n  }\n}\n\nfunction createGeneralError(): ScaperScrapingResult {\n  return {\n    success: false,\n    errorType: ScraperErrorTypes.General,\n  };\n}\n\nclass BaseScraperWithBrowser extends BaseScraper {\n  // NOTICE - it is discourage 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 discourage 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    debug('initialize scraper');\n    this.emitProgress(ScaperProgressTypes.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\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      });\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.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: Record<string, string>): Promise<ScaperScrapingResult> {\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(ScaperProgressTypes.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 handleLoginResult(this, loginResult);\n  }\n\n  async terminate(_success: boolean) {\n    debug(`terminating browser with success = ${_success}`);\n    this.emitProgress(ScaperProgressTypes.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\nexport { BaseScraperWithBrowser };\n"]}
@@ -76,7 +76,7 @@ export interface ScaperOptions {
76
76
  */
77
77
  preparePage?: (page: Page) => Promise<void>;
78
78
  /**
79
- * if set, store a screnshot if failed to scrape. Used for debug purposes
79
+ * if set, store a screenshot if failed to scrape. Used for debug purposes
80
80
  */
81
81
  storeFailureScreenShotPath?: string;
82
82
  }
@@ -134,4 +134,4 @@ class BaseScraper {
134
134
  }
135
135
 
136
136
  exports.BaseScraper = BaseScraper;
137
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/base-scraper.ts"],"names":["SCRAPE_PROGRESS","ScraperErrorTypes","ScaperProgressTypes","createErrorResult","errorType","errorMessage","success","createTimeoutError","Timeout","createGenericError","Generic","BaseScraper","constructor","options","EventEmitter","initialize","emitProgress","Initializing","scrape","credentials","StartScraping","loginResult","login","e","TimeoutError","message","scrapeResult","fetchData","terminate","EndScraping","_credentials","Error","companyId","_success","Terminating","type","emit","eventName","payload","eventEmitter","onProgress","func","on"],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\nimport { Browser, Page } from 'puppeteer';\nimport { TimeoutError } from '../helpers/waiting';\nimport { TransactionsAccount } from '../transactions';\nimport { CompanyTypes } from '../definitions';\n\nconst SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';\n\nexport enum ScraperErrorTypes {\n  InvalidPassword ='INVALID_PASSWORD',\n  ChangePassword = 'CHANGE_PASSWORD',\n  Timeout = 'TIMEOUT',\n  AccountBlocked = 'ACCOUNT_BLOCKED',\n  Generic = 'GENERIC',\n  General = 'GENERAL_ERROR'\n}\n\nexport interface ScaperLoginResult {\n  success: boolean;\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport interface ScaperScrapingResult {\n  success: boolean;\n  accounts?: TransactionsAccount[];\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport type ScraperCredentials = Record<string, string>;\n\nexport interface ScaperOptions {\n  /**\n   * The company you want to scrape\n   */\n  companyId: CompanyTypes;\n\n  /**\n   * include more debug info about in the output\n   */\n  verbose?: boolean;\n\n  /**\n   * the date to fetch transactions from (can't be before the minimum allowed time difference for the scraper)\n   */\n  startDate: Date;\n\n  /**\n   * shows the browser while scraping, good for debugging (default false)\n   */\n  showBrowser?: boolean;\n\n\n  /**\n   * scrape transactions to be processed X months in the future\n   */\n  futureMonthsToScrape?: number;\n\n  /**\n   * option from init puppeteer browser instance outside the libary scope. you can get\n   * browser diretly from puppeteer via `puppeteer.launch()`\n   */\n  browser?: any;\n\n  /**\n   * provide a patch to local chromium to be used by puppeteer. Relevant when using\n   * `israeli-bank-scrapers-core` library\n   */\n  executablePath?: string;\n\n  /**\n   * if set to true, all installment transactions will be combine into the first one\n   */\n  combineInstallments?: boolean;\n\n  /**\n   * additional arguments to pass to the browser instance. The list of flags can be found in\n   *\n   * https://developer.mozilla.org/en-US/docs/Mozilla/Command_Line_Options\n   * https://peter.sh/experiments/chromium-command-line-switches/\n   */\n  args?: string[];\n\n  /**\n   * adjust the browser instance before it is being used\n   *\n   * @param browser\n   */\n  prepareBrowser?: (browser: Browser) => Promise<void>;\n\n  /**\n   * adjust the page instance before it is being used.\n   *\n   * @param page\n   */\n  preparePage?: (page: Page) => Promise<void>;\n\n  /**\n   * if set, store a screnshot if failed to scrape. Used for debug purposes\n   */\n  storeFailureScreenShotPath?: string;\n}\n\nexport enum ScaperProgressTypes {\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\nfunction createErrorResult(errorType: ScraperErrorTypes, errorMessage: string) {\n  return {\n    success: false,\n    errorType,\n    errorMessage,\n  };\n}\n\nfunction createTimeoutError(errorMessage: string) {\n  return createErrorResult(ScraperErrorTypes.Timeout, errorMessage);\n}\n\nfunction createGenericError(errorMessage: string) {\n  return createErrorResult(ScraperErrorTypes.Generic, errorMessage);\n}\n\nexport class BaseScraper {\n  private eventEmitter = new EventEmitter();\n\n  constructor(public options: ScaperOptions) {\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async initialize() {\n    this.emitProgress(ScaperProgressTypes.Initializing);\n  }\n\n  async scrape(credentials: ScraperCredentials): Promise<ScaperScrapingResult> {\n    this.emitProgress(ScaperProgressTypes.StartScraping);\n    await this.initialize();\n\n    let loginResult;\n    try {\n      loginResult = await this.login(credentials);\n    } catch (e) {\n      loginResult = e instanceof TimeoutError ?\n        createTimeoutError(e.message) :\n        createGenericError(e.message);\n    }\n\n    let scrapeResult;\n    if (loginResult.success) {\n      try {\n        scrapeResult = await this.fetchData();\n      } catch (e) {\n        scrapeResult =\n          e instanceof TimeoutError ?\n            createTimeoutError(e.message) :\n            createGenericError(e.message);\n      }\n    } else {\n      scrapeResult = loginResult;\n    }\n\n    try {\n      const success = scrapeResult && scrapeResult.success === true;\n      await this.terminate(success);\n    } catch (e) {\n      scrapeResult = createGenericError(e.message);\n    }\n    this.emitProgress(ScaperProgressTypes.EndScraping);\n\n    return scrapeResult;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  async login(_credentials: Record<string, string>): Promise<ScaperLoginResult> {\n    throw new Error(`login() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async fetchData(): Promise<ScaperScrapingResult> {\n    throw new Error(`fetchData() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  async terminate(_success: boolean) {\n    this.emitProgress(ScaperProgressTypes.Terminating);\n  }\n\n  emitProgress(type: ScaperProgressTypes) {\n    this.emit(SCRAPE_PROGRESS, { type });\n  }\n\n  emit(eventName: string, payload: Record<string, any>) {\n    this.eventEmitter.emit(eventName, this.options.companyId, payload);\n  }\n\n  onProgress(func: (...args: any[]) => void) {\n    this.eventEmitter.on(SCRAPE_PROGRESS, func);\n  }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/base-scraper.ts"],"names":["SCRAPE_PROGRESS","ScraperErrorTypes","ScaperProgressTypes","createErrorResult","errorType","errorMessage","success","createTimeoutError","Timeout","createGenericError","Generic","BaseScraper","constructor","options","EventEmitter","initialize","emitProgress","Initializing","scrape","credentials","StartScraping","loginResult","login","e","TimeoutError","message","scrapeResult","fetchData","terminate","EndScraping","_credentials","Error","companyId","_success","Terminating","type","emit","eventName","payload","eventEmitter","onProgress","func","on"],"mappings":"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","sourcesContent":["import { EventEmitter } from 'events';\nimport { Browser, Page } from 'puppeteer';\nimport { TimeoutError } from '../helpers/waiting';\nimport { TransactionsAccount } from '../transactions';\nimport { CompanyTypes } from '../definitions';\n\nconst SCRAPE_PROGRESS = 'SCRAPE_PROGRESS';\n\nexport enum ScraperErrorTypes {\n  InvalidPassword ='INVALID_PASSWORD',\n  ChangePassword = 'CHANGE_PASSWORD',\n  Timeout = 'TIMEOUT',\n  AccountBlocked = 'ACCOUNT_BLOCKED',\n  Generic = 'GENERIC',\n  General = 'GENERAL_ERROR'\n}\n\nexport interface ScaperLoginResult {\n  success: boolean;\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport interface ScaperScrapingResult {\n  success: boolean;\n  accounts?: TransactionsAccount[];\n  errorType?: ScraperErrorTypes;\n  errorMessage?: string; // only on success=false\n}\n\nexport type ScraperCredentials = Record<string, string>;\n\nexport interface ScaperOptions {\n  /**\n   * The company you want to scrape\n   */\n  companyId: CompanyTypes;\n\n  /**\n   * include more debug info about in the output\n   */\n  verbose?: boolean;\n\n  /**\n   * the date to fetch transactions from (can't be before the minimum allowed time difference for the scraper)\n   */\n  startDate: Date;\n\n  /**\n   * shows the browser while scraping, good for debugging (default false)\n   */\n  showBrowser?: boolean;\n\n\n  /**\n   * scrape transactions to be processed X months in the future\n   */\n  futureMonthsToScrape?: number;\n\n  /**\n   * option from init puppeteer browser instance outside the libary scope. you can get\n   * browser diretly from puppeteer via `puppeteer.launch()`\n   */\n  browser?: any;\n\n  /**\n   * provide a patch to local chromium to be used by puppeteer. Relevant when using\n   * `israeli-bank-scrapers-core` library\n   */\n  executablePath?: string;\n\n  /**\n   * if set to true, all installment transactions will be combine into the first one\n   */\n  combineInstallments?: boolean;\n\n  /**\n   * additional arguments to pass to the browser instance. The list of flags can be found in\n   *\n   * https://developer.mozilla.org/en-US/docs/Mozilla/Command_Line_Options\n   * https://peter.sh/experiments/chromium-command-line-switches/\n   */\n  args?: string[];\n\n  /**\n   * adjust the browser instance before it is being used\n   *\n   * @param browser\n   */\n  prepareBrowser?: (browser: Browser) => Promise<void>;\n\n  /**\n   * adjust the page instance before it is being used.\n   *\n   * @param page\n   */\n  preparePage?: (page: Page) => Promise<void>;\n\n  /**\n   * if set, store a screenshot if failed to scrape. Used for debug purposes\n   */\n  storeFailureScreenShotPath?: string;\n\n}\n\nexport enum ScaperProgressTypes {\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\nfunction createErrorResult(errorType: ScraperErrorTypes, errorMessage: string) {\n  return {\n    success: false,\n    errorType,\n    errorMessage,\n  };\n}\n\nfunction createTimeoutError(errorMessage: string) {\n  return createErrorResult(ScraperErrorTypes.Timeout, errorMessage);\n}\n\nfunction createGenericError(errorMessage: string) {\n  return createErrorResult(ScraperErrorTypes.Generic, errorMessage);\n}\n\nexport class BaseScraper {\n  private eventEmitter = new EventEmitter();\n\n  constructor(public options: ScaperOptions) {\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async initialize() {\n    this.emitProgress(ScaperProgressTypes.Initializing);\n  }\n\n  async scrape(credentials: ScraperCredentials): Promise<ScaperScrapingResult> {\n    this.emitProgress(ScaperProgressTypes.StartScraping);\n    await this.initialize();\n\n    let loginResult;\n    try {\n      loginResult = await this.login(credentials);\n    } catch (e) {\n      loginResult = e instanceof TimeoutError ?\n        createTimeoutError(e.message) :\n        createGenericError(e.message);\n    }\n\n    let scrapeResult;\n    if (loginResult.success) {\n      try {\n        scrapeResult = await this.fetchData();\n      } catch (e) {\n        scrapeResult =\n          e instanceof TimeoutError ?\n            createTimeoutError(e.message) :\n            createGenericError(e.message);\n      }\n    } else {\n      scrapeResult = loginResult;\n    }\n\n    try {\n      const success = scrapeResult && scrapeResult.success === true;\n      await this.terminate(success);\n    } catch (e) {\n      scrapeResult = createGenericError(e.message);\n    }\n    this.emitProgress(ScaperProgressTypes.EndScraping);\n\n    return scrapeResult;\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  async login(_credentials: Record<string, string>): Promise<ScaperLoginResult> {\n    throw new Error(`login() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line  @typescript-eslint/require-await\n  async fetchData(): Promise<ScaperScrapingResult> {\n    throw new Error(`fetchData() is not created in ${this.options.companyId}`);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/require-await\n  async terminate(_success: boolean) {\n    this.emitProgress(ScaperProgressTypes.Terminating);\n  }\n\n  emitProgress(type: ScaperProgressTypes) {\n    this.emit(SCRAPE_PROGRESS, { type });\n  }\n\n  emit(eventName: string, payload: Record<string, any>) {\n    this.eventEmitter.emit(eventName, this.options.companyId, payload);\n  }\n\n  onProgress(func: (...args: any[]) => void) {\n    this.eventEmitter.on(SCRAPE_PROGRESS, func);\n  }\n}\n"]}
@@ -0,0 +1,27 @@
1
+ import { BaseScraperWithBrowser, PossibleLoginResults } from './base-scraper-with-browser';
2
+ import { ScraperCredentials } from './base-scraper';
3
+ import { Transaction } from '../transactions';
4
+ declare class BeyahadBishvilhaScraper extends BaseScraperWithBrowser {
5
+ protected getViewPort(): {
6
+ width: number;
7
+ height: number;
8
+ };
9
+ getLoginOptions(credentials: ScraperCredentials): {
10
+ loginUrl: string;
11
+ fields: {
12
+ selector: string;
13
+ value: string;
14
+ }[];
15
+ submitButtonSelector: () => Promise<void>;
16
+ possibleResults: PossibleLoginResults;
17
+ };
18
+ fetchData(): Promise<{
19
+ success: boolean;
20
+ accounts: {
21
+ accountNumber: any;
22
+ balance: number;
23
+ txns: Transaction[];
24
+ }[];
25
+ }>;
26
+ }
27
+ export default BeyahadBishvilhaScraper;
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.symbol.description");
4
+
5
+ require("core-js/modules/es.array.iterator");
6
+
7
+ require("core-js/modules/es.promise");
8
+
9
+ require("core-js/modules/es.string.replace");
10
+
11
+ Object.defineProperty(exports, "__esModule", {
12
+ value: true
13
+ });
14
+ exports.default = void 0;
15
+
16
+ var _moment = _interopRequireDefault(require("moment"));
17
+
18
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
19
+
20
+ var _transactions = require("../transactions");
21
+
22
+ var _elementsInteractions = require("../helpers/elements-interactions");
23
+
24
+ var _debug = require("../helpers/debug");
25
+
26
+ var _transactions2 = require("../helpers/transactions");
27
+
28
+ var _constants = require("../constants");
29
+
30
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
31
+
32
+ const debug = (0, _debug.getDebug)('beyahadBishvilha');
33
+ const DATE_FORMAT = 'DD/MM/YY';
34
+ const LOGIN_URL = 'https://www.hist.org.il/login';
35
+ const SUCCESS_URL = 'https://www.hist.org.il/';
36
+ const CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';
37
+
38
+ function getAmountData(amountStr) {
39
+ const amountStrCln = amountStr.replace(',', '');
40
+ let currency = null;
41
+ let amount = null;
42
+
43
+ if (amountStrCln.includes(_constants.SHEKEL_CURRENCY_SYMBOL)) {
44
+ amount = parseFloat(amountStrCln.replace(_constants.SHEKEL_CURRENCY_SYMBOL, ''));
45
+ currency = _constants.SHEKEL_CURRENCY;
46
+ } else if (amountStrCln.includes(_constants.DOLLAR_CURRENCY_SYMBOL)) {
47
+ amount = parseFloat(amountStrCln.replace(_constants.DOLLAR_CURRENCY_SYMBOL, ''));
48
+ currency = _constants.DOLLAR_CURRENCY;
49
+ } else if (amountStrCln.includes(_constants.EURO_CURRENCY_SYMBOL)) {
50
+ amount = parseFloat(amountStrCln.replace(_constants.EURO_CURRENCY_SYMBOL, ''));
51
+ currency = _constants.EURO_CURRENCY;
52
+ } else {
53
+ const parts = amountStrCln.split(' ');
54
+ [currency] = parts;
55
+ amount = parseFloat(parts[1]);
56
+ }
57
+
58
+ return {
59
+ amount,
60
+ currency
61
+ };
62
+ }
63
+
64
+ function convertTransactions(txns) {
65
+ debug(`convert ${txns.length} raw transactions to official Transaction structure`);
66
+ return txns.map(txn => {
67
+ const chargedAmountTuple = getAmountData(txn.chargedAmount || '');
68
+ const txnProcessedDate = (0, _moment.default)(txn.date, DATE_FORMAT);
69
+ const result = {
70
+ type: _transactions.TransactionTypes.Normal,
71
+ status: _transactions.TransactionStatuses.Completed,
72
+ date: txnProcessedDate.toISOString(),
73
+ processedDate: txnProcessedDate.toISOString(),
74
+ originalAmount: chargedAmountTuple.amount,
75
+ originalCurrency: chargedAmountTuple.currency,
76
+ chargedAmount: chargedAmountTuple.amount,
77
+ chargedCurrency: chargedAmountTuple.currency,
78
+ description: txn.description || '',
79
+ memo: '',
80
+ identifier: txn.identifier
81
+ };
82
+ return result;
83
+ });
84
+ }
85
+
86
+ async function fetchTransactions(page, options) {
87
+ await page.goto(CARD_URL);
88
+ await (0, _elementsInteractions.waitUntilElementFound)(page, '.react-loading.hide', false);
89
+ const defaultStartMoment = (0, _moment.default)().subtract(1, 'years');
90
+ const startDate = options.startDate || defaultStartMoment.toDate();
91
+
92
+ const startMoment = _moment.default.max(defaultStartMoment, (0, _moment.default)(startDate));
93
+
94
+ const accountNumber = await (0, _elementsInteractions.pageEval)(page, '.wallet-details div:nth-of-type(2)', null, element => {
95
+ return element.innerText.replace('מספר כרטיס ', '');
96
+ });
97
+ const balance = await (0, _elementsInteractions.pageEval)(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, element => {
98
+ return element.innerText;
99
+ });
100
+ debug('fetch raw transactions from page');
101
+ const rawTransactions = await (0, _elementsInteractions.pageEvalAll)(page, '.transaction-container, .transaction-component-container', [], items => {
102
+ return items.map(el => {
103
+ const columns = el.querySelectorAll('.transaction-item > span');
104
+
105
+ if (columns.length === 7) {
106
+ return {
107
+ date: columns[0].innerText,
108
+ identifier: columns[1].innerText,
109
+ description: columns[3].innerText,
110
+ type: columns[5].innerText,
111
+ chargedAmount: columns[6].innerText
112
+ };
113
+ }
114
+
115
+ return null;
116
+ });
117
+ });
118
+ debug(`fetched ${rawTransactions.length} raw transactions from page`);
119
+ const accountTransactions = convertTransactions(rawTransactions.filter(item => !!item));
120
+ debug('filer out old transactions');
121
+ const txns = (0, _transactions2.filterOldTransactions)(accountTransactions, startMoment, false);
122
+ debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);
123
+ return {
124
+ accountNumber,
125
+ balance: getAmountData(balance).amount,
126
+ txns
127
+ };
128
+ }
129
+
130
+ function getPossibleLoginResults() {
131
+ const urls = {};
132
+ urls[_baseScraperWithBrowser.LoginResults.Success] = [SUCCESS_URL];
133
+ urls[_baseScraperWithBrowser.LoginResults.ChangePassword] = []; // TODO
134
+
135
+ urls[_baseScraperWithBrowser.LoginResults.InvalidPassword] = []; // TODO
136
+
137
+ urls[_baseScraperWithBrowser.LoginResults.UnknownError] = []; // TODO
138
+
139
+ return urls;
140
+ }
141
+
142
+ function createLoginFields(credentials) {
143
+ return [{
144
+ selector: '#loginId',
145
+ value: credentials.id
146
+ }, {
147
+ selector: '#loginPassword',
148
+ value: credentials.password
149
+ }];
150
+ }
151
+
152
+ class BeyahadBishvilhaScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
153
+ getViewPort() {
154
+ return {
155
+ width: 1500,
156
+ height: 800
157
+ };
158
+ }
159
+
160
+ getLoginOptions(credentials) {
161
+ return {
162
+ loginUrl: LOGIN_URL,
163
+ fields: createLoginFields(credentials),
164
+ submitButtonSelector: async () => {
165
+ const [button] = await this.page.$x("//button[contains(., 'התחבר')]");
166
+
167
+ if (button) {
168
+ await button.click();
169
+ }
170
+ },
171
+ possibleResults: getPossibleLoginResults()
172
+ };
173
+ }
174
+
175
+ async fetchData() {
176
+ const account = await fetchTransactions(this.page, this.options);
177
+ return {
178
+ success: true,
179
+ accounts: [account]
180
+ };
181
+ }
182
+
183
+ }
184
+
185
+ var _default = BeyahadBishvilhaScraper;
186
+ exports.default = _default;
187
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/beyahad-bishvilha.ts"],"names":["debug","DATE_FORMAT","LOGIN_URL","SUCCESS_URL","CARD_URL","getAmountData","amountStr","amountStrCln","replace","currency","amount","includes","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","convertTransactions","txns","length","map","txn","chargedAmountTuple","chargedAmount","txnProcessedDate","date","result","type","TransactionTypes","Normal","status","TransactionStatuses","Completed","toISOString","processedDate","originalAmount","originalCurrency","chargedCurrency","description","memo","identifier","fetchTransactions","page","options","goto","defaultStartMoment","subtract","startDate","toDate","startMoment","moment","max","accountNumber","element","innerText","balance","rawTransactions","items","el","columns","querySelectorAll","accountTransactions","filter","item","substring","getPossibleLoginResults","urls","LoginResults","Success","ChangePassword","InvalidPassword","UnknownError","createLoginFields","credentials","selector","value","id","password","BeyahadBishvilhaScraper","BaseScraperWithBrowser","getViewPort","width","height","getLoginOptions","loginUrl","fields","submitButtonSelector","button","$x","click","possibleResults","fetchData","account","success","accounts"],"mappings":"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","sourcesContent":["import { Page } from 'puppeteer';\nimport moment from 'moment';\nimport { BaseScraperWithBrowser, LoginResults, PossibleLoginResults } from './base-scraper-with-browser';\nimport { ScaperOptions, ScraperCredentials } from './base-scraper';\nimport { Transaction, TransactionStatuses, TransactionTypes } from '../transactions';\nimport { pageEval, pageEvalAll, waitUntilElementFound } from '../helpers/elements-interactions';\nimport { getDebug } from '../helpers/debug';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport {\n  DOLLAR_CURRENCY,\n  DOLLAR_CURRENCY_SYMBOL, EURO_CURRENCY,\n  EURO_CURRENCY_SYMBOL,\n  SHEKEL_CURRENCY,\n  SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\n\nconst debug = getDebug('beyahadBishvilha');\n\nconst DATE_FORMAT = 'DD/MM/YY';\nconst LOGIN_URL = 'https://www.hist.org.il/login';\nconst SUCCESS_URL = 'https://www.hist.org.il/';\nconst CARD_URL = 'https://www.hist.org.il/card/balanceAndUses';\n\ninterface ScrapedTransaction {\n  date: string;\n  description: string;\n  type: string;\n  chargedAmount: string;\n  identifier: string;\n}\n\nfunction getAmountData(amountStr: string) {\n  const amountStrCln = amountStr.replace(',', '');\n  let currency: string | null = null;\n  let amount: number | null = null;\n  if (amountStrCln.includes(SHEKEL_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(SHEKEL_CURRENCY_SYMBOL, ''));\n    currency = SHEKEL_CURRENCY;\n  } else if (amountStrCln.includes(DOLLAR_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(DOLLAR_CURRENCY_SYMBOL, ''));\n    currency = DOLLAR_CURRENCY;\n  } else if (amountStrCln.includes(EURO_CURRENCY_SYMBOL)) {\n    amount = parseFloat(amountStrCln.replace(EURO_CURRENCY_SYMBOL, ''));\n    currency = EURO_CURRENCY;\n  } else {\n    const parts = amountStrCln.split(' ');\n    [currency] = parts;\n    amount = parseFloat(parts[1]);\n  }\n\n  return {\n    amount,\n    currency,\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[]): Transaction[] {\n  debug(`convert ${txns.length} raw transactions to official Transaction structure`);\n  return txns.map((txn) => {\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n    const txnProcessedDate = moment(txn.date, DATE_FORMAT);\n\n    const result: Transaction = {\n      type: TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: txnProcessedDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: chargedAmountTuple.amount,\n      originalCurrency: chargedAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: '',\n      identifier: txn.identifier,\n    };\n\n    return result;\n  });\n}\n\n\nasync function fetchTransactions(page: Page, options: ScaperOptions) {\n  await page.goto(CARD_URL);\n  await waitUntilElementFound(page, '.react-loading.hide', false);\n  const defaultStartMoment = moment().subtract(1, 'years');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const accountNumber = await pageEval(page, '.wallet-details div:nth-of-type(2)', null, (element) => {\n    return (element as any).innerText.replace('מספר כרטיס ', '');\n  });\n\n  const balance = await pageEval(page, '.wallet-details div:nth-of-type(4) > span:nth-of-type(2)', null, (element) => {\n    return (element as any).innerText;\n  });\n\n  debug('fetch raw transactions from page');\n\n  const rawTransactions: (ScrapedTransaction | null)[] = await pageEvalAll<(ScrapedTransaction | null)[]>(page, '.transaction-container, .transaction-component-container', [], (items) => {\n    return (items).map((el) => {\n      const columns: NodeListOf<HTMLSpanElement> = el.querySelectorAll('.transaction-item > span');\n      if (columns.length === 7) {\n        return {\n          date: columns[0].innerText,\n          identifier: columns[1].innerText,\n          description: columns[3].innerText,\n          type: columns[5].innerText,\n          chargedAmount: columns[6].innerText,\n        };\n      }\n      return null;\n    });\n  });\n  debug(`fetched ${rawTransactions.length} raw transactions from page`);\n\n  const accountTransactions = convertTransactions(rawTransactions.filter((item) => !!item) as ScrapedTransaction[]);\n\n  debug('filer out old transactions');\n  const txns = filterOldTransactions(accountTransactions, startMoment, false);\n  debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);\n\n  return {\n    accountNumber,\n    balance: getAmountData(balance).amount,\n    txns,\n  };\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [SUCCESS_URL];\n  urls[LoginResults.ChangePassword] = []; // TODO\n  urls[LoginResults.InvalidPassword] = []; // TODO\n  urls[LoginResults.UnknownError] = []; // TODO\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  return [\n    { selector: '#loginId', value: credentials.id },\n    { selector: '#loginPassword', value: credentials.password },\n  ];\n}\n\nclass BeyahadBishvilhaScraper extends BaseScraperWithBrowser {\n  protected getViewPort(): { width: number, height: number } {\n    return {\n      width: 1500,\n      height: 800,\n    };\n  }\n\n  getLoginOptions(credentials: ScraperCredentials) {\n    return {\n      loginUrl: LOGIN_URL,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: async () => {\n        const [button] = await this.page.$x(\"//button[contains(., 'התחבר')]\");\n        if (button) {\n          await button.click();\n        }\n      },\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    const account = await fetchTransactions(this.page, this.options);\n    return {\n      success: true,\n      accounts: [account],\n    };\n  }\n}\n\nexport default BeyahadBishvilhaScraper;\n"]}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+
3
+ require("core-js/modules/es.promise");
4
+
5
+ require("core-js/modules/es.string.trim");
6
+
7
+ var _beyahadBishvilha = _interopRequireDefault(require("./beyahad-bishvilha"));
8
+
9
+ var _testsUtils = require("../tests/tests-utils");
10
+
11
+ var _definitions = require("../definitions");
12
+
13
+ var _baseScraperWithBrowser = require("./base-scraper-with-browser");
14
+
15
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
+
17
+ 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; }
18
+
19
+ 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; }
20
+
21
+ 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; }
22
+
23
+ const COMPANY_ID = 'beyahadBishvilha'; // TODO this property should be hard-coded in the provider
24
+
25
+ const testsConfig = (0, _testsUtils.getTestsConfig)();
26
+ describe('Beyahad Bishvilha scraper', () => {
27
+ beforeAll(() => {
28
+ (0, _testsUtils.extendAsyncTimeout)(); // The default timeout is 5 seconds per async test, this function extends the timeout value
29
+ });
30
+ test('should expose login fields in scrapers constant', () => {
31
+ expect(_definitions.SCRAPERS.beyahadBishvilha).toBeDefined();
32
+ expect(_definitions.SCRAPERS.beyahadBishvilha.loginFields).toContain('id');
33
+ expect(_definitions.SCRAPERS.beyahadBishvilha.loginFields).toContain('password');
34
+ });
35
+ (0, _testsUtils.maybeTestCompanyAPI)(COMPANY_ID, config => config.companyAPI.invalidPassword)('should fail on invalid user/password"', async () => {
36
+ const options = _objectSpread({}, testsConfig.options, {
37
+ companyId: COMPANY_ID
38
+ });
39
+
40
+ const scraper = new _beyahadBishvilha.default(options);
41
+ const result = await scraper.scrape({
42
+ id: 'e10s12',
43
+ password: '3f3ss3d'
44
+ });
45
+ expect(result).toBeDefined();
46
+ expect(result.success).toBeFalsy();
47
+ expect(result.errorType).toBe(_baseScraperWithBrowser.LoginResults.InvalidPassword);
48
+ });
49
+ (0, _testsUtils.maybeTestCompanyAPI)(COMPANY_ID)('should scrape transactions"', async () => {
50
+ const options = _objectSpread({}, testsConfig.options, {
51
+ companyId: COMPANY_ID
52
+ });
53
+
54
+ const scraper = new _beyahadBishvilha.default(options);
55
+ const result = await scraper.scrape(testsConfig.credentials.beyahadBishvilha);
56
+ expect(result).toBeDefined();
57
+ const error = `${result.errorType || ''} ${result.errorMessage || ''}`.trim();
58
+ expect(error).toBe('');
59
+ expect(result.success).toBeTruthy();
60
+ (0, _testsUtils.exportTransactions)(COMPANY_ID, result.accounts || []);
61
+ });
62
+ });
63
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9iZXlhaGFkLWJpc2h2aWxoYS50ZXN0LnRzIl0sIm5hbWVzIjpbIkNPTVBBTllfSUQiLCJ0ZXN0c0NvbmZpZyIsImRlc2NyaWJlIiwiYmVmb3JlQWxsIiwidGVzdCIsImV4cGVjdCIsIlNDUkFQRVJTIiwiYmV5YWhhZEJpc2h2aWxoYSIsInRvQmVEZWZpbmVkIiwibG9naW5GaWVsZHMiLCJ0b0NvbnRhaW4iLCJjb25maWciLCJjb21wYW55QVBJIiwiaW52YWxpZFBhc3N3b3JkIiwib3B0aW9ucyIsImNvbXBhbnlJZCIsInNjcmFwZXIiLCJCZXlhaGFkQmlzaHZpbGhhU2NyYXBlciIsInJlc3VsdCIsInNjcmFwZSIsImlkIiwicGFzc3dvcmQiLCJzdWNjZXNzIiwidG9CZUZhbHN5IiwiZXJyb3JUeXBlIiwidG9CZSIsIkxvZ2luUmVzdWx0cyIsIkludmFsaWRQYXNzd29yZCIsImNyZWRlbnRpYWxzIiwiZXJyb3IiLCJlcnJvck1lc3NhZ2UiLCJ0cmltIiwidG9CZVRydXRoeSIsImFjY291bnRzIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTs7QUFDQTs7QUFHQTs7QUFDQTs7Ozs7Ozs7OztBQUVBLE1BQU1BLFVBQVUsR0FBRyxrQkFBbkIsQyxDQUF1Qzs7QUFDdkMsTUFBTUMsV0FBVyxHQUFHLGlDQUFwQjtBQUVBQyxRQUFRLENBQUMsMkJBQUQsRUFBOEIsTUFBTTtBQUMxQ0MsRUFBQUEsU0FBUyxDQUFDLE1BQU07QUFDZCwwQ0FEYyxDQUNRO0FBQ3ZCLEdBRlEsQ0FBVDtBQUlBQyxFQUFBQSxJQUFJLENBQUMsaURBQUQsRUFBb0QsTUFBTTtBQUM1REMsSUFBQUEsTUFBTSxDQUFDQyxzQkFBU0MsZ0JBQVYsQ0FBTixDQUFrQ0MsV0FBbEM7QUFDQUgsSUFBQUEsTUFBTSxDQUFDQyxzQkFBU0MsZ0JBQVQsQ0FBMEJFLFdBQTNCLENBQU4sQ0FBOENDLFNBQTlDLENBQXdELElBQXhEO0FBQ0FMLElBQUFBLE1BQU0sQ0FBQ0Msc0JBQVNDLGdCQUFULENBQTBCRSxXQUEzQixDQUFOLENBQThDQyxTQUE5QyxDQUF3RCxVQUF4RDtBQUNELEdBSkcsQ0FBSjtBQU1BLHVDQUFvQlYsVUFBcEIsRUFBaUNXLE1BQUQsSUFBWUEsTUFBTSxDQUFDQyxVQUFQLENBQWtCQyxlQUE5RCxFQUErRSx1Q0FBL0UsRUFBd0gsWUFBWTtBQUNsSSxVQUFNQyxPQUFPLHFCQUNSYixXQUFXLENBQUNhLE9BREo7QUFFWEMsTUFBQUEsU0FBUyxFQUFFZjtBQUZBLE1BQWI7O0FBS0EsVUFBTWdCLE9BQU8sR0FBRyxJQUFJQyx5QkFBSixDQUE0QkgsT0FBNUIsQ0FBaEI7QUFFQSxVQUFNSSxNQUFNLEdBQUcsTUFBTUYsT0FBTyxDQUFDRyxNQUFSLENBQWU7QUFBRUMsTUFBQUEsRUFBRSxFQUFFLFFBQU47QUFBZ0JDLE1BQUFBLFFBQVEsRUFBRTtBQUExQixLQUFmLENBQXJCO0FBRUFoQixJQUFBQSxNQUFNLENBQUNhLE1BQUQsQ0FBTixDQUFlVixXQUFmO0FBQ0FILElBQUFBLE1BQU0sQ0FBQ2EsTUFBTSxDQUFDSSxPQUFSLENBQU4sQ0FBdUJDLFNBQXZCO0FBQ0FsQixJQUFBQSxNQUFNLENBQUNhLE1BQU0sQ0FBQ00sU0FBUixDQUFOLENBQXlCQyxJQUF6QixDQUE4QkMscUNBQWFDLGVBQTNDO0FBQ0QsR0FiRDtBQWVBLHVDQUFvQjNCLFVBQXBCLEVBQWdDLDZCQUFoQyxFQUErRCxZQUFZO0FBQ3pFLFVBQU1jLE9BQU8scUJBQ1JiLFdBQVcsQ0FBQ2EsT0FESjtBQUVYQyxNQUFBQSxTQUFTLEVBQUVmO0FBRkEsTUFBYjs7QUFLQSxVQUFNZ0IsT0FBTyxHQUFHLElBQUlDLHlCQUFKLENBQTRCSCxPQUE1QixDQUFoQjtBQUNBLFVBQU1JLE1BQU0sR0FBRyxNQUFNRixPQUFPLENBQUNHLE1BQVIsQ0FBZWxCLFdBQVcsQ0FBQzJCLFdBQVosQ0FBd0JyQixnQkFBdkMsQ0FBckI7QUFDQUYsSUFBQUEsTUFBTSxDQUFDYSxNQUFELENBQU4sQ0FBZVYsV0FBZjtBQUNBLFVBQU1xQixLQUFLLEdBQUksR0FBRVgsTUFBTSxDQUFDTSxTQUFQLElBQW9CLEVBQUcsSUFBR04sTUFBTSxDQUFDWSxZQUFQLElBQXVCLEVBQUcsRUFBdkQsQ0FBeURDLElBQXpELEVBQWQ7QUFDQTFCLElBQUFBLE1BQU0sQ0FBQ3dCLEtBQUQsQ0FBTixDQUFjSixJQUFkLENBQW1CLEVBQW5CO0FBQ0FwQixJQUFBQSxNQUFNLENBQUNhLE1BQU0sQ0FBQ0ksT0FBUixDQUFOLENBQXVCVSxVQUF2QjtBQUVBLHdDQUFtQmhDLFVBQW5CLEVBQStCa0IsTUFBTSxDQUFDZSxRQUFQLElBQW1CLEVBQWxEO0FBQ0QsR0FkRDtBQWVELENBekNPLENBQVIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQmV5YWhhZEJpc2h2aWxoYVNjcmFwZXIgZnJvbSAnLi9iZXlhaGFkLWJpc2h2aWxoYSc7XG5pbXBvcnQge1xuICBtYXliZVRlc3RDb21wYW55QVBJLCBleHRlbmRBc3luY1RpbWVvdXQsIGdldFRlc3RzQ29uZmlnLCBleHBvcnRUcmFuc2FjdGlvbnMsXG59IGZyb20gJy4uL3Rlc3RzL3Rlc3RzLXV0aWxzJztcbmltcG9ydCB7IFNDUkFQRVJTIH0gZnJvbSAnLi4vZGVmaW5pdGlvbnMnO1xuaW1wb3J0IHsgTG9naW5SZXN1bHRzIH0gZnJvbSAnLi9iYXNlLXNjcmFwZXItd2l0aC1icm93c2VyJztcblxuY29uc3QgQ09NUEFOWV9JRCA9ICdiZXlhaGFkQmlzaHZpbGhhJzsgLy8gVE9ETyB0aGlzIHByb3BlcnR5IHNob3VsZCBiZSBoYXJkLWNvZGVkIGluIHRoZSBwcm92aWRlclxuY29uc3QgdGVzdHNDb25maWcgPSBnZXRUZXN0c0NvbmZpZygpO1xuXG5kZXNjcmliZSgnQmV5YWhhZCBCaXNodmlsaGEgc2NyYXBlcicsICgpID0+IHtcbiAgYmVmb3JlQWxsKCgpID0+IHtcbiAgICBleHRlbmRBc3luY1RpbWVvdXQoKTsgLy8gVGhlIGRlZmF1bHQgdGltZW91dCBpcyA1IHNlY29uZHMgcGVyIGFzeW5jIHRlc3QsIHRoaXMgZnVuY3Rpb24gZXh0ZW5kcyB0aGUgdGltZW91dCB2YWx1ZVxuICB9KTtcblxuICB0ZXN0KCdzaG91bGQgZXhwb3NlIGxvZ2luIGZpZWxkcyBpbiBzY3JhcGVycyBjb25zdGFudCcsICgpID0+IHtcbiAgICBleHBlY3QoU0NSQVBFUlMuYmV5YWhhZEJpc2h2aWxoYSkudG9CZURlZmluZWQoKTtcbiAgICBleHBlY3QoU0NSQVBFUlMuYmV5YWhhZEJpc2h2aWxoYS5sb2dpbkZpZWxkcykudG9Db250YWluKCdpZCcpO1xuICAgIGV4cGVjdChTQ1JBUEVSUy5iZXlhaGFkQmlzaHZpbGhhLmxvZ2luRmllbGRzKS50b0NvbnRhaW4oJ3Bhc3N3b3JkJyk7XG4gIH0pO1xuXG4gIG1heWJlVGVzdENvbXBhbnlBUEkoQ09NUEFOWV9JRCwgKGNvbmZpZykgPT4gY29uZmlnLmNvbXBhbnlBUEkuaW52YWxpZFBhc3N3b3JkKSgnc2hvdWxkIGZhaWwgb24gaW52YWxpZCB1c2VyL3Bhc3N3b3JkXCInLCBhc3luYyAoKSA9PiB7XG4gICAgY29uc3Qgb3B0aW9ucyA9IHtcbiAgICAgIC4uLnRlc3RzQ29uZmlnLm9wdGlvbnMsXG4gICAgICBjb21wYW55SWQ6IENPTVBBTllfSUQsXG4gICAgfTtcblxuICAgIGNvbnN0IHNjcmFwZXIgPSBuZXcgQmV5YWhhZEJpc2h2aWxoYVNjcmFwZXIob3B0aW9ucyk7XG5cbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBzY3JhcGVyLnNjcmFwZSh7IGlkOiAnZTEwczEyJywgcGFzc3dvcmQ6ICczZjNzczNkJyB9KTtcblxuICAgIGV4cGVjdChyZXN1bHQpLnRvQmVEZWZpbmVkKCk7XG4gICAgZXhwZWN0KHJlc3VsdC5zdWNjZXNzKS50b0JlRmFsc3koKTtcbiAgICBleHBlY3QocmVzdWx0LmVycm9yVHlwZSkudG9CZShMb2dpblJlc3VsdHMuSW52YWxpZFBhc3N3b3JkKTtcbiAgfSk7XG5cbiAgbWF5YmVUZXN0Q29tcGFueUFQSShDT01QQU5ZX0lEKSgnc2hvdWxkIHNjcmFwZSB0cmFuc2FjdGlvbnNcIicsIGFzeW5jICgpID0+IHtcbiAgICBjb25zdCBvcHRpb25zID0ge1xuICAgICAgLi4udGVzdHNDb25maWcub3B0aW9ucyxcbiAgICAgIGNvbXBhbnlJZDogQ09NUEFOWV9JRCxcbiAgICB9O1xuXG4gICAgY29uc3Qgc2NyYXBlciA9IG5ldyBCZXlhaGFkQmlzaHZpbGhhU2NyYXBlcihvcHRpb25zKTtcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBzY3JhcGVyLnNjcmFwZSh0ZXN0c0NvbmZpZy5jcmVkZW50aWFscy5iZXlhaGFkQmlzaHZpbGhhKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0JlRGVmaW5lZCgpO1xuICAgIGNvbnN0IGVycm9yID0gYCR7cmVzdWx0LmVycm9yVHlwZSB8fCAnJ30gJHtyZXN1bHQuZXJyb3JNZXNzYWdlIHx8ICcnfWAudHJpbSgpO1xuICAgIGV4cGVjdChlcnJvcikudG9CZSgnJyk7XG4gICAgZXhwZWN0KHJlc3VsdC5zdWNjZXNzKS50b0JlVHJ1dGh5KCk7XG5cbiAgICBleHBvcnRUcmFuc2FjdGlvbnMoQ09NUEFOWV9JRCwgcmVzdWx0LmFjY291bnRzIHx8IFtdKTtcbiAgfSk7XG59KTtcbiJdfQ==
@@ -12,4 +12,5 @@ import BeinleumiScraper from './beinleumi';
12
12
  import MassadScraper from './massad';
13
13
  import YahavScraper from './yahav';
14
14
  import { ScaperOptions } from './base-scraper';
15
- export default function createScraper(options: ScaperOptions): HapoalimScraper | OtsarHahayalScraper | LeumiScraper | DiscountScraper | MaxScraper | VisaCalScraper | IsracardScraper | AmexScraper | MizrahiScraper | UnionBankScraper | BeinleumiScraper | MassadScraper | YahavScraper;
15
+ import BeyahadBishvilhaScraper from './beyahad-bishvilha';
16
+ export default function createScraper(options: ScaperOptions): HapoalimScraper | OtsarHahayalScraper | LeumiScraper | DiscountScraper | MaxScraper | VisaCalScraper | IsracardScraper | AmexScraper | MizrahiScraper | UnionBankScraper | BeinleumiScraper | MassadScraper | YahavScraper | BeyahadBishvilhaScraper;
@@ -33,6 +33,8 @@ var _yahav = _interopRequireDefault(require("./yahav"));
33
33
 
34
34
  var _definitions = require("../definitions");
35
35
 
36
+ var _beyahadBishvilha = _interopRequireDefault(require("./beyahad-bishvilha"));
37
+
36
38
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
37
39
 
38
40
  function createScraper(options) {
@@ -48,6 +50,9 @@ function createScraper(options) {
48
50
  case _definitions.CompanyTypes.leumi:
49
51
  return new _leumi.default(options);
50
52
 
53
+ case _definitions.CompanyTypes.beyahadBishvilha:
54
+ return new _beyahadBishvilha.default(options);
55
+
51
56
  case _definitions.CompanyTypes.mizrahi:
52
57
  return new _mizrahi.default(options);
53
58
 
@@ -90,4 +95,4 @@ function createScraper(options) {
90
95
  throw new Error(`unknown company id ${options.companyId}`);
91
96
  }
92
97
  }
93
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9mYWN0b3J5LnRzIl0sIm5hbWVzIjpbImNyZWF0ZVNjcmFwZXIiLCJvcHRpb25zIiwiY29tcGFueUlkIiwiQ29tcGFueVR5cGVzIiwiaGFwb2FsaW0iLCJIYXBvYWxpbVNjcmFwZXIiLCJoYXBvYWxpbUJlT25saW5lIiwiY29uc29sZSIsIndhcm4iLCJsZXVtaSIsIkxldW1pU2NyYXBlciIsIm1penJhaGkiLCJNaXpyYWhpU2NyYXBlciIsImRpc2NvdW50IiwiRGlzY291bnRTY3JhcGVyIiwib3RzYXJIYWhheWFsIiwiT3RzYXJIYWhheWFsU2NyYXBlciIsInZpc2FDYWwiLCJWaXNhQ2FsU2NyYXBlciIsImxldW1pQ2FyZCIsIk1heFNjcmFwZXIiLCJtYXgiLCJpc3JhY2FyZCIsIklzcmFjYXJkU2NyYXBlciIsImFtZXgiLCJBbWV4U2NyYXBlciIsInVuaW9uIiwiVW5pb25CYW5rU2NyYXBlciIsImJlaW5sZXVtaSIsIkJlaW5sZXVtaVNjcmFwZXIiLCJtYXNzYWQiLCJNYXNzYWRTY3JhcGVyIiwieWFoYXYiLCJZYWhhdlNjcmFwZXIiLCJFcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBOzs7O0FBRWUsU0FBU0EsYUFBVCxDQUF1QkMsT0FBdkIsRUFBK0M7QUFDNUQsVUFBUUEsT0FBTyxDQUFDQyxTQUFoQjtBQUNFLFNBQUtDLDBCQUFhQyxRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0JKLE9BQXBCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFHLGdCQUFsQjtBQUNFO0FBQ0FDLE1BQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUFhLHdEQUFiO0FBQ0EsYUFBTyxJQUFJSCxpQkFBSixDQUFvQkosT0FBcEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYU0sS0FBbEI7QUFDRSxhQUFPLElBQUlDLGNBQUosQ0FBaUJULE9BQWpCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFRLE9BQWxCO0FBQ0UsYUFBTyxJQUFJQyxnQkFBSixDQUFtQlgsT0FBbkIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYVUsUUFBbEI7QUFDRSxhQUFPLElBQUlDLGlCQUFKLENBQW9CYixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhWSxZQUFsQjtBQUNFLGFBQU8sSUFBSUMscUJBQUosQ0FBd0JmLE9BQXhCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFjLE9BQWxCO0FBQ0UsYUFBTyxJQUFJQyxnQkFBSixDQUFtQmpCLE9BQW5CLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFnQixTQUFsQjtBQUNFO0FBQ0FaLE1BQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUFhLDRDQUFiO0FBQ0EsYUFBTyxJQUFJWSxZQUFKLENBQWVuQixPQUFmLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFrQixHQUFsQjtBQUNFLGFBQU8sSUFBSUQsWUFBSixDQUFlbkIsT0FBZixDQUFQOztBQUNGLFNBQUtFLDBCQUFhbUIsUUFBbEI7QUFDRSxhQUFPLElBQUlDLGlCQUFKLENBQW9CdEIsT0FBcEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYXFCLElBQWxCO0FBQ0UsYUFBTyxJQUFJQyxhQUFKLENBQWdCeEIsT0FBaEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYXVCLEtBQWxCO0FBQ0UsYUFBTyxJQUFJQyxrQkFBSixDQUFxQjFCLE9BQXJCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWF5QixTQUFsQjtBQUNFLGFBQU8sSUFBSUMsa0JBQUosQ0FBcUI1QixPQUFyQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhMkIsTUFBbEI7QUFDRSxhQUFPLElBQUlDLGVBQUosQ0FBa0I5QixPQUFsQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhNkIsS0FBbEI7QUFDRSxhQUFPLElBQUlDLGNBQUosQ0FBaUJoQyxPQUFqQixDQUFQOztBQUNGO0FBQ0UsWUFBTSxJQUFJaUMsS0FBSixDQUFXLHNCQUFxQmpDLE9BQU8sQ0FBQ0MsU0FBVSxFQUFsRCxDQUFOO0FBcENKO0FBc0NEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEhhcG9hbGltU2NyYXBlciBmcm9tICcuL2hhcG9hbGltJztcbmltcG9ydCBPdHNhckhhaGF5YWxTY3JhcGVyIGZyb20gJy4vb3RzYXItaGFoYXlhbCc7XG5pbXBvcnQgTGV1bWlTY3JhcGVyIGZyb20gJy4vbGV1bWknO1xuaW1wb3J0IERpc2NvdW50U2NyYXBlciBmcm9tICcuL2Rpc2NvdW50JztcbmltcG9ydCBNYXhTY3JhcGVyIGZyb20gJy4vbWF4JztcbmltcG9ydCBWaXNhQ2FsU2NyYXBlciBmcm9tICcuL3Zpc2EtY2FsJztcbmltcG9ydCBJc3JhY2FyZFNjcmFwZXIgZnJvbSAnLi9pc3JhY2FyZCc7XG5pbXBvcnQgQW1leFNjcmFwZXIgZnJvbSAnLi9hbWV4JztcbmltcG9ydCBNaXpyYWhpU2NyYXBlciBmcm9tICcuL21penJhaGknO1xuaW1wb3J0IFVuaW9uQmFua1NjcmFwZXIgZnJvbSAnLi91bmlvbi1iYW5rJztcbmltcG9ydCBCZWlubGV1bWlTY3JhcGVyIGZyb20gJy4vYmVpbmxldW1pJztcbmltcG9ydCBNYXNzYWRTY3JhcGVyIGZyb20gJy4vbWFzc2FkJztcbmltcG9ydCBZYWhhdlNjcmFwZXIgZnJvbSAnLi95YWhhdic7XG5pbXBvcnQgeyBTY2FwZXJPcHRpb25zIH0gZnJvbSAnLi9iYXNlLXNjcmFwZXInO1xuaW1wb3J0IHsgQ29tcGFueVR5cGVzIH0gZnJvbSAnLi4vZGVmaW5pdGlvbnMnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBjcmVhdGVTY3JhcGVyKG9wdGlvbnM6IFNjYXBlck9wdGlvbnMpIHtcbiAgc3dpdGNoIChvcHRpb25zLmNvbXBhbnlJZCkge1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmhhcG9hbGltOlxuICAgICAgcmV0dXJuIG5ldyBIYXBvYWxpbVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaGFwb2FsaW1CZU9ubGluZTpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLndhcm4oXCJoYXBvYWxpbUJlT25saW5lIGlzIGRlcHJlY2F0ZWQsIHVzZSAnaGFwb2FsaW0nIGluc3RlYWRcIik7XG4gICAgICByZXR1cm4gbmV3IEhhcG9hbGltU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5sZXVtaTpcbiAgICAgIHJldHVybiBuZXcgTGV1bWlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLm1penJhaGk6XG4gICAgICByZXR1cm4gbmV3IE1penJhaGlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmRpc2NvdW50OlxuICAgICAgcmV0dXJuIG5ldyBEaXNjb3VudFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMub3RzYXJIYWhheWFsOlxuICAgICAgcmV0dXJuIG5ldyBPdHNhckhhaGF5YWxTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLnZpc2FDYWw6XG4gICAgICByZXR1cm4gbmV3IFZpc2FDYWxTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmxldW1pQ2FyZDpcbiAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby1jb25zb2xlXG4gICAgICBjb25zb2xlLndhcm4oXCJsZXVtaUNhcmQgaXMgZGVwcmVjYXRlZCwgdXNlICdtYXgnIGluc3RlYWRcIik7XG4gICAgICByZXR1cm4gbmV3IE1heFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWF4OlxuICAgICAgcmV0dXJuIG5ldyBNYXhTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmlzcmFjYXJkOlxuICAgICAgcmV0dXJuIG5ldyBJc3JhY2FyZFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYW1leDpcbiAgICAgIHJldHVybiBuZXcgQW1leFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMudW5pb246XG4gICAgICByZXR1cm4gbmV3IFVuaW9uQmFua1NjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYmVpbmxldW1pOlxuICAgICAgcmV0dXJuIG5ldyBCZWlubGV1bWlTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLm1hc3NhZDpcbiAgICAgIHJldHVybiBuZXcgTWFzc2FkU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy55YWhhdjpcbiAgICAgIHJldHVybiBuZXcgWWFoYXZTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVua25vd24gY29tcGFueSBpZCAke29wdGlvbnMuY29tcGFueUlkfWApO1xuICB9XG59XG4iXX0=
98
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY3JhcGVycy9mYWN0b3J5LnRzIl0sIm5hbWVzIjpbImNyZWF0ZVNjcmFwZXIiLCJvcHRpb25zIiwiY29tcGFueUlkIiwiQ29tcGFueVR5cGVzIiwiaGFwb2FsaW0iLCJIYXBvYWxpbVNjcmFwZXIiLCJoYXBvYWxpbUJlT25saW5lIiwiY29uc29sZSIsIndhcm4iLCJsZXVtaSIsIkxldW1pU2NyYXBlciIsImJleWFoYWRCaXNodmlsaGEiLCJCZXlhaGFkQmlzaHZpbGhhU2NyYXBlciIsIm1penJhaGkiLCJNaXpyYWhpU2NyYXBlciIsImRpc2NvdW50IiwiRGlzY291bnRTY3JhcGVyIiwib3RzYXJIYWhheWFsIiwiT3RzYXJIYWhheWFsU2NyYXBlciIsInZpc2FDYWwiLCJWaXNhQ2FsU2NyYXBlciIsImxldW1pQ2FyZCIsIk1heFNjcmFwZXIiLCJtYXgiLCJpc3JhY2FyZCIsIklzcmFjYXJkU2NyYXBlciIsImFtZXgiLCJBbWV4U2NyYXBlciIsInVuaW9uIiwiVW5pb25CYW5rU2NyYXBlciIsImJlaW5sZXVtaSIsIkJlaW5sZXVtaVNjcmFwZXIiLCJtYXNzYWQiLCJNYXNzYWRTY3JhcGVyIiwieWFoYXYiLCJZYWhhdlNjcmFwZXIiLCJFcnJvciJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUVBOztBQUNBOzs7O0FBRWUsU0FBU0EsYUFBVCxDQUF1QkMsT0FBdkIsRUFBK0M7QUFDNUQsVUFBUUEsT0FBTyxDQUFDQyxTQUFoQjtBQUNFLFNBQUtDLDBCQUFhQyxRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0JKLE9BQXBCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFHLGdCQUFsQjtBQUNFO0FBQ0FDLE1BQUFBLE9BQU8sQ0FBQ0MsSUFBUixDQUFhLHdEQUFiO0FBQ0EsYUFBTyxJQUFJSCxpQkFBSixDQUFvQkosT0FBcEIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYU0sS0FBbEI7QUFDRSxhQUFPLElBQUlDLGNBQUosQ0FBaUJULE9BQWpCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFRLGdCQUFsQjtBQUNFLGFBQU8sSUFBSUMseUJBQUosQ0FBNEJYLE9BQTVCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFVLE9BQWxCO0FBQ0UsYUFBTyxJQUFJQyxnQkFBSixDQUFtQmIsT0FBbkIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYVksUUFBbEI7QUFDRSxhQUFPLElBQUlDLGlCQUFKLENBQW9CZixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhYyxZQUFsQjtBQUNFLGFBQU8sSUFBSUMscUJBQUosQ0FBd0JqQixPQUF4QixDQUFQOztBQUNGLFNBQUtFLDBCQUFhZ0IsT0FBbEI7QUFDRSxhQUFPLElBQUlDLGdCQUFKLENBQW1CbkIsT0FBbkIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYWtCLFNBQWxCO0FBQ0U7QUFDQWQsTUFBQUEsT0FBTyxDQUFDQyxJQUFSLENBQWEsNENBQWI7QUFDQSxhQUFPLElBQUljLFlBQUosQ0FBZXJCLE9BQWYsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYW9CLEdBQWxCO0FBQ0UsYUFBTyxJQUFJRCxZQUFKLENBQWVyQixPQUFmLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWFxQixRQUFsQjtBQUNFLGFBQU8sSUFBSUMsaUJBQUosQ0FBb0J4QixPQUFwQixDQUFQOztBQUNGLFNBQUtFLDBCQUFhdUIsSUFBbEI7QUFDRSxhQUFPLElBQUlDLGFBQUosQ0FBZ0IxQixPQUFoQixDQUFQOztBQUNGLFNBQUtFLDBCQUFheUIsS0FBbEI7QUFDRSxhQUFPLElBQUlDLGtCQUFKLENBQXFCNUIsT0FBckIsQ0FBUDs7QUFDRixTQUFLRSwwQkFBYTJCLFNBQWxCO0FBQ0UsYUFBTyxJQUFJQyxrQkFBSixDQUFxQjlCLE9BQXJCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWE2QixNQUFsQjtBQUNFLGFBQU8sSUFBSUMsZUFBSixDQUFrQmhDLE9BQWxCLENBQVA7O0FBQ0YsU0FBS0UsMEJBQWErQixLQUFsQjtBQUNFLGFBQU8sSUFBSUMsY0FBSixDQUFpQmxDLE9BQWpCLENBQVA7O0FBQ0Y7QUFDRSxZQUFNLElBQUltQyxLQUFKLENBQVcsc0JBQXFCbkMsT0FBTyxDQUFDQyxTQUFVLEVBQWxELENBQU47QUF0Q0o7QUF3Q0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgSGFwb2FsaW1TY3JhcGVyIGZyb20gJy4vaGFwb2FsaW0nO1xuaW1wb3J0IE90c2FySGFoYXlhbFNjcmFwZXIgZnJvbSAnLi9vdHNhci1oYWhheWFsJztcbmltcG9ydCBMZXVtaVNjcmFwZXIgZnJvbSAnLi9sZXVtaSc7XG5pbXBvcnQgRGlzY291bnRTY3JhcGVyIGZyb20gJy4vZGlzY291bnQnO1xuaW1wb3J0IE1heFNjcmFwZXIgZnJvbSAnLi9tYXgnO1xuaW1wb3J0IFZpc2FDYWxTY3JhcGVyIGZyb20gJy4vdmlzYS1jYWwnO1xuaW1wb3J0IElzcmFjYXJkU2NyYXBlciBmcm9tICcuL2lzcmFjYXJkJztcbmltcG9ydCBBbWV4U2NyYXBlciBmcm9tICcuL2FtZXgnO1xuaW1wb3J0IE1penJhaGlTY3JhcGVyIGZyb20gJy4vbWl6cmFoaSc7XG5pbXBvcnQgVW5pb25CYW5rU2NyYXBlciBmcm9tICcuL3VuaW9uLWJhbmsnO1xuaW1wb3J0IEJlaW5sZXVtaVNjcmFwZXIgZnJvbSAnLi9iZWlubGV1bWknO1xuaW1wb3J0IE1hc3NhZFNjcmFwZXIgZnJvbSAnLi9tYXNzYWQnO1xuaW1wb3J0IFlhaGF2U2NyYXBlciBmcm9tICcuL3lhaGF2JztcbmltcG9ydCB7IFNjYXBlck9wdGlvbnMgfSBmcm9tICcuL2Jhc2Utc2NyYXBlcic7XG5pbXBvcnQgeyBDb21wYW55VHlwZXMgfSBmcm9tICcuLi9kZWZpbml0aW9ucyc7XG5pbXBvcnQgQmV5YWhhZEJpc2h2aWxoYVNjcmFwZXIgZnJvbSAnLi9iZXlhaGFkLWJpc2h2aWxoYSc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGNyZWF0ZVNjcmFwZXIob3B0aW9uczogU2NhcGVyT3B0aW9ucykge1xuICBzd2l0Y2ggKG9wdGlvbnMuY29tcGFueUlkKSB7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaGFwb2FsaW06XG4gICAgICByZXR1cm4gbmV3IEhhcG9hbGltU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5oYXBvYWxpbUJlT25saW5lOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcImhhcG9hbGltQmVPbmxpbmUgaXMgZGVwcmVjYXRlZCwgdXNlICdoYXBvYWxpbScgaW5zdGVhZFwiKTtcbiAgICAgIHJldHVybiBuZXcgSGFwb2FsaW1TY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLmxldW1pOlxuICAgICAgcmV0dXJuIG5ldyBMZXVtaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuYmV5YWhhZEJpc2h2aWxoYTpcbiAgICAgIHJldHVybiBuZXcgQmV5YWhhZEJpc2h2aWxoYVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWl6cmFoaTpcbiAgICAgIHJldHVybiBuZXcgTWl6cmFoaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuZGlzY291bnQ6XG4gICAgICByZXR1cm4gbmV3IERpc2NvdW50U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5vdHNhckhhaGF5YWw6XG4gICAgICByZXR1cm4gbmV3IE90c2FySGFoYXlhbFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMudmlzYUNhbDpcbiAgICAgIHJldHVybiBuZXcgVmlzYUNhbFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubGV1bWlDYXJkOlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLWNvbnNvbGVcbiAgICAgIGNvbnNvbGUud2FybihcImxldW1pQ2FyZCBpcyBkZXByZWNhdGVkLCB1c2UgJ21heCcgaW5zdGVhZFwiKTtcbiAgICAgIHJldHVybiBuZXcgTWF4U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5tYXg6XG4gICAgICByZXR1cm4gbmV3IE1heFNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMuaXNyYWNhcmQ6XG4gICAgICByZXR1cm4gbmV3IElzcmFjYXJkU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5hbWV4OlxuICAgICAgcmV0dXJuIG5ldyBBbWV4U2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy51bmlvbjpcbiAgICAgIHJldHVybiBuZXcgVW5pb25CYW5rU2NyYXBlcihvcHRpb25zKTtcbiAgICBjYXNlIENvbXBhbnlUeXBlcy5iZWlubGV1bWk6XG4gICAgICByZXR1cm4gbmV3IEJlaW5sZXVtaVNjcmFwZXIob3B0aW9ucyk7XG4gICAgY2FzZSBDb21wYW55VHlwZXMubWFzc2FkOlxuICAgICAgcmV0dXJuIG5ldyBNYXNzYWRTY3JhcGVyKG9wdGlvbnMpO1xuICAgIGNhc2UgQ29tcGFueVR5cGVzLnlhaGF2OlxuICAgICAgcmV0dXJuIG5ldyBZYWhhdlNjcmFwZXIob3B0aW9ucyk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdW5rbm93biBjb21wYW55IGlkICR7b3B0aW9ucy5jb21wYW55SWR9YCk7XG4gIH1cbn1cbiJdfQ==
@@ -26,7 +26,7 @@ export interface Transaction {
26
26
  /**
27
27
  * sometimes called Asmachta
28
28
  */
29
- identifier?: number;
29
+ identifier?: string | number;
30
30
  /**
31
31
  * ISO date string
32
32
  */
@@ -19,4 +19,4 @@ exports.TransactionStatuses = TransactionStatuses;
19
19
  TransactionStatuses["Completed"] = "completed";
20
20
  TransactionStatuses["Pending"] = "pending";
21
21
  })(TransactionStatuses || (exports.TransactionStatuses = TransactionStatuses = {}));
22
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90cmFuc2FjdGlvbnMudHMiXSwibmFtZXMiOlsiVHJhbnNhY3Rpb25UeXBlcyIsIlRyYW5zYWN0aW9uU3RhdHVzZXMiXSwibWFwcGluZ3MiOiI7Ozs7OztJQU9ZQSxnQjs7O1dBQUFBLGdCO0FBQUFBLEVBQUFBLGdCO0FBQUFBLEVBQUFBLGdCO0dBQUFBLGdCLGdDQUFBQSxnQjs7SUFLQUMsbUI7OztXQUFBQSxtQjtBQUFBQSxFQUFBQSxtQjtBQUFBQSxFQUFBQSxtQjtHQUFBQSxtQixtQ0FBQUEsbUIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25zQWNjb3VudCB7XG4gIGFjY291bnROdW1iZXI6IHN0cmluZztcbiAgYmFsYW5jZT86IG51bWJlcjtcbiAgdHhuczogVHJhbnNhY3Rpb25bXTtcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25UeXBlcyB7XG4gIE5vcm1hbCA9ICdub3JtYWwnLFxuICBJbnN0YWxsbWVudHMgPSAnaW5zdGFsbG1lbnRzJ1xufVxuXG5leHBvcnQgZW51bSBUcmFuc2FjdGlvblN0YXR1c2VzIHtcbiAgQ29tcGxldGVkID0gJ2NvbXBsZXRlZCcsXG4gIFBlbmRpbmcgPSAncGVuZGluZydcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbkluc3RhbGxtZW50cyB7XG4gIC8qKlxuICAgKiB0aGUgY3VycmVudCBpbnN0YWxsbWVudCBudW1iZXJcbiAgICovXG4gIG51bWJlcjogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiB0aGUgdG90YWwgbnVtYmVyIG9mIGluc3RhbGxtZW50c1xuICAgKi9cbiAgdG90YWw6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbiB7XG4gIHR5cGU6IFRyYW5zYWN0aW9uVHlwZXM7XG4gIC8qKlxuICAgKiBzb21ldGltZXMgY2FsbGVkIEFzbWFjaHRhXG4gICAqL1xuICBpZGVudGlmaWVyPzogbnVtYmVyO1xuICAvKipcbiAgICogSVNPIGRhdGUgc3RyaW5nXG4gICAqL1xuICBkYXRlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJU08gZGF0ZSBzdHJpbmdcbiAgICovXG4gIHByb2Nlc3NlZERhdGU6IHN0cmluZztcbiAgb3JpZ2luYWxBbW91bnQ6IG51bWJlcjtcbiAgb3JpZ2luYWxDdXJyZW5jeTogc3RyaW5nO1xuICBjaGFyZ2VkQW1vdW50OiBudW1iZXI7XG4gIGNoYXJnZWRDdXJyZW5jeT86IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgbWVtbz86IHN0cmluZztcbiAgc3RhdHVzOiBUcmFuc2FjdGlvblN0YXR1c2VzO1xuICBpbnN0YWxsbWVudHM/OiBUcmFuc2FjdGlvbkluc3RhbGxtZW50cztcbiAgY2F0ZWdvcnk/OiBzdHJpbmc7XG59XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy90cmFuc2FjdGlvbnMudHMiXSwibmFtZXMiOlsiVHJhbnNhY3Rpb25UeXBlcyIsIlRyYW5zYWN0aW9uU3RhdHVzZXMiXSwibWFwcGluZ3MiOiI7Ozs7OztJQU9ZQSxnQjs7O1dBQUFBLGdCO0FBQUFBLEVBQUFBLGdCO0FBQUFBLEVBQUFBLGdCO0dBQUFBLGdCLGdDQUFBQSxnQjs7SUFLQUMsbUI7OztXQUFBQSxtQjtBQUFBQSxFQUFBQSxtQjtBQUFBQSxFQUFBQSxtQjtHQUFBQSxtQixtQ0FBQUEsbUIiLCJzb3VyY2VzQ29udGVudCI6WyJcbmV4cG9ydCBpbnRlcmZhY2UgVHJhbnNhY3Rpb25zQWNjb3VudCB7XG4gIGFjY291bnROdW1iZXI6IHN0cmluZztcbiAgYmFsYW5jZT86IG51bWJlcjtcbiAgdHhuczogVHJhbnNhY3Rpb25bXTtcbn1cblxuZXhwb3J0IGVudW0gVHJhbnNhY3Rpb25UeXBlcyB7XG4gIE5vcm1hbCA9ICdub3JtYWwnLFxuICBJbnN0YWxsbWVudHMgPSAnaW5zdGFsbG1lbnRzJ1xufVxuXG5leHBvcnQgZW51bSBUcmFuc2FjdGlvblN0YXR1c2VzIHtcbiAgQ29tcGxldGVkID0gJ2NvbXBsZXRlZCcsXG4gIFBlbmRpbmcgPSAncGVuZGluZydcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbkluc3RhbGxtZW50cyB7XG4gIC8qKlxuICAgKiB0aGUgY3VycmVudCBpbnN0YWxsbWVudCBudW1iZXJcbiAgICovXG4gIG51bWJlcjogbnVtYmVyO1xuXG4gIC8qKlxuICAgKiB0aGUgdG90YWwgbnVtYmVyIG9mIGluc3RhbGxtZW50c1xuICAgKi9cbiAgdG90YWw6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBUcmFuc2FjdGlvbiB7XG4gIHR5cGU6IFRyYW5zYWN0aW9uVHlwZXM7XG4gIC8qKlxuICAgKiBzb21ldGltZXMgY2FsbGVkIEFzbWFjaHRhXG4gICAqL1xuICBpZGVudGlmaWVyPzogc3RyaW5nIHwgbnVtYmVyO1xuICAvKipcbiAgICogSVNPIGRhdGUgc3RyaW5nXG4gICAqL1xuICBkYXRlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJU08gZGF0ZSBzdHJpbmdcbiAgICovXG4gIHByb2Nlc3NlZERhdGU6IHN0cmluZztcbiAgb3JpZ2luYWxBbW91bnQ6IG51bWJlcjtcbiAgb3JpZ2luYWxDdXJyZW5jeTogc3RyaW5nO1xuICBjaGFyZ2VkQW1vdW50OiBudW1iZXI7XG4gIGNoYXJnZWRDdXJyZW5jeT86IHN0cmluZztcbiAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgbWVtbz86IHN0cmluZztcbiAgc3RhdHVzOiBUcmFuc2FjdGlvblN0YXR1c2VzO1xuICBpbnN0YWxsbWVudHM/OiBUcmFuc2FjdGlvbkluc3RhbGxtZW50cztcbiAgY2F0ZWdvcnk/OiBzdHJpbmc7XG59XG4iXX0=
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "israeli-bank-scrapers",
3
- "version": "1.10.4",
3
+ "version": "1.11.0",
4
4
  "private": false,
5
5
  "description": "Provide scrapers for all major Israeli banks and credit card companies",
6
6
  "engines": {