israeli-bank-scrapers 1.10.1 → 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,12 +283,21 @@ 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)
288
299
  - [Israel Finance Telegram Bot](https://github.com/GuyLewin/israel-finance-telegram-bot) - A simple telegram bot that sends notifications about new transactions and interacts with them
289
300
  - [Caspion](https://github.com/brafdlog/caspion) - An app for automatically sending transactions from Israeli banks and credit cards to budget tracking apps
290
- - [Oshi](https://github.com/baruchiro/israeli-bank-scrapers-desktop) - Secure desktop app for retriving your transactions from all israeli banks and credit cards
291
301
  - [Finance Notifier](https://github.com/LiranBri/finance-notifier) - A simple script with the ability to send custom financial alerts to multiple contacts and platforms
292
302
 
293
303
  Built something interesting you want to share here? [Let me know](https://goo.gl/forms/5Fb9JAjvzMIpmzqo2).
@@ -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":"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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 | (() => 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":";;;;;;;;;AAAA;;AAEA;;;;AAIA,MAAMA,eAAe,GAAG,iBAAxB;IAEYC,iB;;;WAAAA,iB;AAAAA,EAAAA,iB;AAAAA,EAAAA,iB;AAAAA,EAAAA,iB;AAAAA,EAAAA,iB;AAAAA,EAAAA,iB;AAAAA,EAAAA,iB;GAAAA,iB,iCAAAA,iB;;IAgGAC,mB;;;WAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;AAAAA,EAAAA,mB;GAAAA,mB,mCAAAA,mB;;AAWZ,SAASC,iBAAT,CAA2BC,SAA3B,EAAyDC,YAAzD,EAA+E;AAC7E,SAAO;AACLC,IAAAA,OAAO,EAAE,KADJ;AAELF,IAAAA,SAFK;AAGLC,IAAAA;AAHK,GAAP;AAKD;;AAED,SAASE,kBAAT,CAA4BF,YAA5B,EAAkD;AAChD,SAAOF,iBAAiB,CAACF,iBAAiB,CAACO,OAAnB,EAA4BH,YAA5B,CAAxB;AACD;;AAED,SAASI,kBAAT,CAA4BJ,YAA5B,EAAkD;AAChD,SAAOF,iBAAiB,CAACF,iBAAiB,CAACS,OAAnB,EAA4BL,YAA5B,CAAxB;AACD;;AAEM,MAAMM,WAAN,CAAkB;AAGvBC,EAAAA,WAAW,CAAQC,OAAR,EAAgC;AAAA,SAAxBA,OAAwB,GAAxBA,OAAwB;;AAAA,0CAFpB,IAAIC,oBAAJ,EAEoB;AAC1C,GAJsB,CAMvB;;;AACA,QAAMC,UAAN,GAAmB;AACjB,SAAKC,YAAL,CAAkBd,mBAAmB,CAACe,YAAtC;AACD;;AAED,QAAMC,MAAN,CAAaC,WAAb,EAA6E;AAC3E,SAAKH,YAAL,CAAkBd,mBAAmB,CAACkB,aAAtC;AACA,UAAM,KAAKL,UAAL,EAAN;AAEA,QAAIM,WAAJ;;AACA,QAAI;AACFA,MAAAA,WAAW,GAAG,MAAM,KAAKC,KAAL,CAAWH,WAAX,CAApB;AACD,KAFD,CAEE,OAAOI,CAAP,EAAU;AACVF,MAAAA,WAAW,GAAGE,CAAC,YAAYC,qBAAb,GACZjB,kBAAkB,CAACgB,CAAC,CAACE,OAAH,CADN,GAEZhB,kBAAkB,CAACc,CAAC,CAACE,OAAH,CAFpB;AAGD;;AAED,QAAIC,YAAJ;;AACA,QAAIL,WAAW,CAACf,OAAhB,EAAyB;AACvB,UAAI;AACFoB,QAAAA,YAAY,GAAG,MAAM,KAAKC,SAAL,EAArB;AACD,OAFD,CAEE,OAAOJ,CAAP,EAAU;AACVG,QAAAA,YAAY,GACVH,CAAC,YAAYC,qBAAb,GACEjB,kBAAkB,CAACgB,CAAC,CAACE,OAAH,CADpB,GAEEhB,kBAAkB,CAACc,CAAC,CAACE,OAAH,CAHtB;AAID;AACF,KATD,MASO;AACLC,MAAAA,YAAY,GAAGL,WAAf;AACD;;AAED,QAAI;AACF,YAAMf,OAAO,GAAGoB,YAAY,IAAIA,YAAY,CAACpB,OAAb,KAAyB,IAAzD;AACA,YAAM,KAAKsB,SAAL,CAAetB,OAAf,CAAN;AACD,KAHD,CAGE,OAAOiB,CAAP,EAAU;AACVG,MAAAA,YAAY,GAAGjB,kBAAkB,CAACc,CAAC,CAACE,OAAH,CAAjC;AACD;;AACD,SAAKT,YAAL,CAAkBd,mBAAmB,CAAC2B,WAAtC;AAEA,WAAOH,YAAP;AACD,GA/CsB,CAiDvB;;;AACA,QAAMJ,KAAN,CAAYQ,YAAZ,EAA8E;AAC5E,UAAM,IAAIC,KAAJ,CAAW,6BAA4B,KAAKlB,OAAL,CAAamB,SAAU,EAA9D,CAAN;AACD,GApDsB,CAsDvB;;;AACA,QAAML,SAAN,GAAiD;AAC/C,UAAM,IAAII,KAAJ,CAAW,iCAAgC,KAAKlB,OAAL,CAAamB,SAAU,EAAlE,CAAN;AACD,GAzDsB,CA2DvB;;;AACA,QAAMJ,SAAN,CAAgBK,QAAhB,EAAmC;AACjC,SAAKjB,YAAL,CAAkBd,mBAAmB,CAACgC,WAAtC;AACD;;AAEDlB,EAAAA,YAAY,CAACmB,IAAD,EAA4B;AACtC,SAAKC,IAAL,CAAUpC,eAAV,EAA2B;AAAEmC,MAAAA;AAAF,KAA3B;AACD;;AAEDC,EAAAA,IAAI,CAACC,SAAD,EAAoBC,OAApB,EAAkD;AACpD,SAAKC,YAAL,CAAkBH,IAAlB,CAAuBC,SAAvB,EAAkC,KAAKxB,OAAL,CAAamB,SAA/C,EAA0DM,OAA1D;AACD;;AAEDE,EAAAA,UAAU,CAACC,IAAD,EAAiC;AACzC,SAAKF,YAAL,CAAkBG,EAAlB,CAAqB1C,eAArB,EAAsCyC,IAAtC;AACD;;AA1EsB","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==
@@ -107,7 +107,7 @@ async function navigateOrErrorLabel(page) {
107
107
 
108
108
  function getPossibleLoginResults() {
109
109
  const urls = {};
110
- urls[_baseScraperWithBrowser.LoginResults.Success] = [`${BASE_URL}/apollo/core/templates/RETAIL/masterPage.html#/MY_ACCOUNT_HOMEPAGE`];
110
+ urls[_baseScraperWithBrowser.LoginResults.Success] = [`${BASE_URL}/apollo/retail/#/MY_ACCOUNT_HOMEPAGE`];
111
111
  urls[_baseScraperWithBrowser.LoginResults.InvalidPassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`];
112
112
  urls[_baseScraperWithBrowser.LoginResults.ChangePassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/PWD_RENEW`];
113
113
  return urls;
@@ -146,4 +146,4 @@ class DiscountScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
146
146
 
147
147
  var _default = DiscountScraper;
148
148
  exports.default = _default;
149
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/discount.ts"],"names":["BASE_URL","DATE_FORMAT","convertTransactions","txns","txnStatus","map","txn","type","TransactionTypes","Normal","identifier","OperationNumber","date","OperationDate","toISOString","processedDate","ValueDate","originalAmount","OperationAmount","originalCurrency","chargedAmount","description","OperationDescriptionToDisplay","status","fetchAccountData","page","options","apiSiteUrl","accountDataUrl","accountInfo","success","errorType","ScraperErrorTypes","Generic","errorMessage","accountNumber","UserAccountsData","DefaultAccountNumber","defaultStartMoment","subtract","add","startDate","toDate","startMoment","moment","max","startDateStr","format","txnsUrl","txnsResult","Error","CurrentAccountLastTransactions","MsgText","completedTxns","OperationEntry","TransactionStatuses","Completed","rawFutureTxns","_","get","pendingTxns","Pending","accountData","accounts","balance","CurrentAccountInfo","AccountBalance","navigateOrErrorLabel","e","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","ChangePassword","createLoginFields","credentials","selector","value","id","password","num","DiscountScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","checkReadiness","fields","submitButtonSelector","postAction","possibleResults","fetchData"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport moment from 'moment';\nimport { Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginResults, PossibleLoginResults } from './base-scraper-with-browser';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport {\n  Transaction, TransactionStatuses, TransactionTypes,\n} from '../transactions';\nimport {\n  ScaperOptions,\n  ScraperErrorTypes, ScaperScrapingResult, ScraperCredentials,\n} from './base-scraper';\n\nconst BASE_URL = 'https://start.telebank.co.il';\nconst DATE_FORMAT = 'YYYYMMDD';\n\ninterface ScrapedTransaction {\n  OperationNumber: number;\n  OperationDate: string;\n  ValueDate: string;\n  OperationAmount: number;\n  OperationDescriptionToDisplay: string;\n}\n\ninterface CurrentAccountInfo {\n  AccountBalance: number;\n}\n\ninterface ScrapedAccountData {\n  UserAccountsData: {\n    DefaultAccountNumber: string;\n  };\n}\n\ninterface ScrapedTransactionData {\n  Error?: { MsgText: string };\n  CurrentAccountLastTransactions?: {\n    OperationEntry: ScrapedTransaction[];\n    CurrentAccountInfo: CurrentAccountInfo;\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], txnStatus: TransactionStatuses): Transaction[] {\n  if (!txns) {\n    return [];\n  }\n  return txns.map((txn) => {\n    return {\n      type: TransactionTypes.Normal,\n      identifier: txn.OperationNumber,\n      date: moment(txn.OperationDate, DATE_FORMAT).toISOString(),\n      processedDate: moment(txn.ValueDate, DATE_FORMAT).toISOString(),\n      originalAmount: txn.OperationAmount,\n      originalCurrency: 'ILS',\n      chargedAmount: txn.OperationAmount,\n      description: txn.OperationDescriptionToDisplay,\n      status: txnStatus,\n    };\n  });\n}\n\n\nasync function fetchAccountData(page: Page, options: ScaperOptions): Promise<ScaperScrapingResult> {\n  const apiSiteUrl = `${BASE_URL}/Titan/gatewayAPI`;\n\n  const accountDataUrl = `${apiSiteUrl}/userAccountsData`;\n  const accountInfo = await fetchGetWithinPage<ScrapedAccountData>(page, accountDataUrl);\n\n  if (!accountInfo) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: 'failed to get account data',\n    };\n  }\n  const accountNumber = accountInfo.UserAccountsData.DefaultAccountNumber;\n\n  const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const startDateStr = startMoment.format(DATE_FORMAT);\n  const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;\n  const txnsResult = await fetchGetWithinPage<ScrapedTransactionData>(page, txnsUrl);\n  if (!txnsResult || txnsResult.Error ||\n    !txnsResult.CurrentAccountLastTransactions) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error',\n    };\n  }\n\n  const completedTxns = convertTransactions(\n    txnsResult.CurrentAccountLastTransactions.OperationEntry,\n    TransactionStatuses.Completed,\n  );\n  const rawFutureTxns = _.get(txnsResult, 'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry');\n  const pendingTxns = convertTransactions(rawFutureTxns, TransactionStatuses.Pending);\n\n  const accountData = {\n    success: true,\n    accounts: [{\n      accountNumber,\n      balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,\n      txns: [...completedTxns, ...pendingTxns],\n    }],\n  };\n\n  return accountData;\n}\n\nasync function navigateOrErrorLabel(page: Page) {\n  try {\n    await waitForNavigation(page);\n  } catch (e) {\n    await waitUntilElementFound(page, '#general-error', false, 100);\n  }\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [`${BASE_URL}/apollo/core/templates/RETAIL/masterPage.html#/MY_ACCOUNT_HOMEPAGE`];\n  urls[LoginResults.InvalidPassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`];\n  urls[LoginResults.ChangePassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/PWD_RENEW`];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  return [\n    { selector: '#tzId', value: credentials.id },\n    { selector: '#tzPassword', value: credentials.password },\n    { selector: '#aidnum', value: credentials.num },\n  ];\n}\n\nclass DiscountScraper extends BaseScraperWithBrowser {\n  getLoginOptions(credentials: ScraperCredentials) {\n    return {\n      loginUrl: `${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`,\n      checkReadiness: async () => waitUntilElementFound(this.page, '#tzId'),\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '.sendBtn',\n      postAction: async () => navigateOrErrorLabel(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    return fetchAccountData(this.page, this.options);\n  }\n}\n\nexport default DiscountScraper;\n"]}
149
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/discount.ts"],"names":["BASE_URL","DATE_FORMAT","convertTransactions","txns","txnStatus","map","txn","type","TransactionTypes","Normal","identifier","OperationNumber","date","OperationDate","toISOString","processedDate","ValueDate","originalAmount","OperationAmount","originalCurrency","chargedAmount","description","OperationDescriptionToDisplay","status","fetchAccountData","page","options","apiSiteUrl","accountDataUrl","accountInfo","success","errorType","ScraperErrorTypes","Generic","errorMessage","accountNumber","UserAccountsData","DefaultAccountNumber","defaultStartMoment","subtract","add","startDate","toDate","startMoment","moment","max","startDateStr","format","txnsUrl","txnsResult","Error","CurrentAccountLastTransactions","MsgText","completedTxns","OperationEntry","TransactionStatuses","Completed","rawFutureTxns","_","get","pendingTxns","Pending","accountData","accounts","balance","CurrentAccountInfo","AccountBalance","navigateOrErrorLabel","e","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","ChangePassword","createLoginFields","credentials","selector","value","id","password","num","DiscountScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","checkReadiness","fields","submitButtonSelector","postAction","possibleResults","fetchData"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport moment from 'moment';\nimport { Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginResults, PossibleLoginResults } from './base-scraper-with-browser';\nimport { waitUntilElementFound } from '../helpers/elements-interactions';\nimport { waitForNavigation } from '../helpers/navigation';\nimport { fetchGetWithinPage } from '../helpers/fetch';\nimport {\n  Transaction, TransactionStatuses, TransactionTypes,\n} from '../transactions';\nimport {\n  ScaperOptions,\n  ScraperErrorTypes, ScaperScrapingResult, ScraperCredentials,\n} from './base-scraper';\n\nconst BASE_URL = 'https://start.telebank.co.il';\nconst DATE_FORMAT = 'YYYYMMDD';\n\ninterface ScrapedTransaction {\n  OperationNumber: number;\n  OperationDate: string;\n  ValueDate: string;\n  OperationAmount: number;\n  OperationDescriptionToDisplay: string;\n}\n\ninterface CurrentAccountInfo {\n  AccountBalance: number;\n}\n\ninterface ScrapedAccountData {\n  UserAccountsData: {\n    DefaultAccountNumber: string;\n  };\n}\n\ninterface ScrapedTransactionData {\n  Error?: { MsgText: string };\n  CurrentAccountLastTransactions?: {\n    OperationEntry: ScrapedTransaction[];\n    CurrentAccountInfo: CurrentAccountInfo;\n  };\n}\n\nfunction convertTransactions(txns: ScrapedTransaction[], txnStatus: TransactionStatuses): Transaction[] {\n  if (!txns) {\n    return [];\n  }\n  return txns.map((txn) => {\n    return {\n      type: TransactionTypes.Normal,\n      identifier: txn.OperationNumber,\n      date: moment(txn.OperationDate, DATE_FORMAT).toISOString(),\n      processedDate: moment(txn.ValueDate, DATE_FORMAT).toISOString(),\n      originalAmount: txn.OperationAmount,\n      originalCurrency: 'ILS',\n      chargedAmount: txn.OperationAmount,\n      description: txn.OperationDescriptionToDisplay,\n      status: txnStatus,\n    };\n  });\n}\n\n\nasync function fetchAccountData(page: Page, options: ScaperOptions): Promise<ScaperScrapingResult> {\n  const apiSiteUrl = `${BASE_URL}/Titan/gatewayAPI`;\n\n  const accountDataUrl = `${apiSiteUrl}/userAccountsData`;\n  const accountInfo = await fetchGetWithinPage<ScrapedAccountData>(page, accountDataUrl);\n\n  if (!accountInfo) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: 'failed to get account data',\n    };\n  }\n  const accountNumber = accountInfo.UserAccountsData.DefaultAccountNumber;\n\n  const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n  const startDate = options.startDate || defaultStartMoment.toDate();\n  const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n  const startDateStr = startMoment.format(DATE_FORMAT);\n  const txnsUrl = `${apiSiteUrl}/lastTransactions/${accountNumber}/Date?IsCategoryDescCode=True&IsTransactionDetails=True&IsEventNames=True&IsFutureTransactionFlag=True&FromDate=${startDateStr}`;\n  const txnsResult = await fetchGetWithinPage<ScrapedTransactionData>(page, txnsUrl);\n  if (!txnsResult || txnsResult.Error ||\n    !txnsResult.CurrentAccountLastTransactions) {\n    return {\n      success: false,\n      errorType: ScraperErrorTypes.Generic,\n      errorMessage: txnsResult && txnsResult.Error ? txnsResult.Error.MsgText : 'unknown error',\n    };\n  }\n\n  const completedTxns = convertTransactions(\n    txnsResult.CurrentAccountLastTransactions.OperationEntry,\n    TransactionStatuses.Completed,\n  );\n  const rawFutureTxns = _.get(txnsResult, 'CurrentAccountLastTransactions.FutureTransactionsBlock.FutureTransactionEntry');\n  const pendingTxns = convertTransactions(rawFutureTxns, TransactionStatuses.Pending);\n\n  const accountData = {\n    success: true,\n    accounts: [{\n      accountNumber,\n      balance: txnsResult.CurrentAccountLastTransactions.CurrentAccountInfo.AccountBalance,\n      txns: [...completedTxns, ...pendingTxns],\n    }],\n  };\n\n  return accountData;\n}\n\nasync function navigateOrErrorLabel(page: Page) {\n  try {\n    await waitForNavigation(page);\n  } catch (e) {\n    await waitUntilElementFound(page, '#general-error', false, 100);\n  }\n}\n\nfunction getPossibleLoginResults(): PossibleLoginResults {\n  const urls: PossibleLoginResults = {};\n  urls[LoginResults.Success] = [`${BASE_URL}/apollo/retail/#/MY_ACCOUNT_HOMEPAGE`];\n  urls[LoginResults.InvalidPassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`];\n  urls[LoginResults.ChangePassword] = [`${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/PWD_RENEW`];\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  return [\n    { selector: '#tzId', value: credentials.id },\n    { selector: '#tzPassword', value: credentials.password },\n    { selector: '#aidnum', value: credentials.num },\n  ];\n}\n\nclass DiscountScraper extends BaseScraperWithBrowser {\n  getLoginOptions(credentials: ScraperCredentials) {\n    return {\n      loginUrl: `${BASE_URL}/apollo/core/templates/lobby/masterPage.html#/LOGIN_PAGE`,\n      checkReadiness: async () => waitUntilElementFound(this.page, '#tzId'),\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '.sendBtn',\n      postAction: async () => navigateOrErrorLabel(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData() {\n    return fetchAccountData(this.page, this.options);\n  }\n}\n\nexport default DiscountScraper;\n"]}
@@ -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==
@@ -162,7 +162,7 @@ async function fetchTransactions(page, startDate) {
162
162
 
163
163
  async function waitForPostLogin(page) {
164
164
  // TODO check for condition to provide new password
165
- await Promise.race([(0, _elementsInteractions.waitUntilElementFound)(page, 'div.leumi-container', true), (0, _elementsInteractions.waitUntilElementFound)(page, '#BodyContent_ctl00_loginErrMsg', true), (0, _elementsInteractions.waitUntilElementFound)(page, '.ErrMsg', true), (0, _elementsInteractions.waitUntilElementFound)(page, 'form[action="/changepassword"]', true)]);
165
+ await Promise.race([(0, _elementsInteractions.waitUntilElementFound)(page, 'a[title="דלג לחשבון"]', true), (0, _elementsInteractions.waitUntilElementFound)(page, 'div.leumi-container', true), (0, _elementsInteractions.waitUntilElementFound)(page, '#BodyContent_ctl00_loginErrMsg', true), (0, _elementsInteractions.waitUntilElementFound)(page, '.ErrMsg', true), (0, _elementsInteractions.waitUntilElementFound)(page, 'form[action="/changepassword"]', true)]);
166
166
  }
167
167
 
168
168
  class LeumiScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
@@ -194,4 +194,4 @@ class LeumiScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
194
194
 
195
195
  var _default = LeumiScraper;
196
196
  exports.default = _default;
197
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/leumi.ts"],"names":["BASE_URL","TRANSACTIONS_URL","FILTERED_TRANSACTIONS_URL","DATE_FORMAT","ACCOUNT_BLOCKED_MSG","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","AccountBlocked","options","page","Error","errorMessage","label","innerText","startsWith","ChangePassword","createLoginFields","credentials","selector","value","username","password","extractTransactionsFromPage","transactions","status","length","result","map","rawTransaction","newTransaction","type","TransactionTypes","Normal","date","DateUTC","processedDate","description","Description","identifier","ReferenceNumberLong","memo","AdditionalData","originalCurrency","SHEKEL_CURRENCY","chargedAmount","Amount","originalAmount","hangProcess","timeout","Promise","resolve","setTimeout","clickByXPath","xpath","waitForXPath","visible","elm","$x","click","removeSpecialCharacters","str","replace","fetchTransactionsForAccount","startDate","accountId","format","focus","finalResponse","waitForResponse","response","url","request","method","responseJson","json","accountNumber","JSON","parse","jsonResp","pendingTransactions","TodayTransactionsItems","HistoryTransactionsItems","balance","BalanceDisplay","parseFloat","undefined","pendingTxns","TransactionStatuses","Pending","completedTxns","Completed","txns","fetchTransactions","accounts","accountsIds","evaluate","Array","from","document","querySelectorAll","e","textContent","push","waitForPostLogin","race","LeumiScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","postAction","possibleResults","fetchData","defaultStartMoment","subtract","add","toDate","startMoment","moment","max","navigateTo","success"],"mappings":"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","sourcesContent":["import moment, { Moment } from 'moment';\nimport { Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginResults, LoginOptions } from './base-scraper-with-browser';\nimport {\n  fillInput,\n  clickButton,\n  waitUntilElementFound,\n  pageEvalAll,\n} from '../helpers/elements-interactions';\nimport { SHEKEL_CURRENCY } from '../constants';\nimport {\n  TransactionsAccount, Transaction, TransactionStatuses, TransactionTypes,\n} from '../transactions';\nimport { ScaperScrapingResult, ScraperCredentials } from './base-scraper';\n\nconst BASE_URL = 'https://hb2.bankleumi.co.il';\nconst TRANSACTIONS_URL = `${BASE_URL}/eBanking/SO/SPA.aspx#/ts/BusinessAccountTrx?WidgetPar=1`;\nconst FILTERED_TRANSACTIONS_URL = `${BASE_URL}/ChannelWCF/Broker.svc/ProcessRequest?moduleName=UC_SO_27_GetBusinessAccountTrx`;\n\nconst DATE_FORMAT = 'DD.MM.YY';\nconst ACCOUNT_BLOCKED_MSG = 'המנוי חסום';\n\n\nfunction getPossibleLoginResults() {\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/ebanking\\/SO\\/SPA.aspx/i],\n    [LoginResults.InvalidPassword]: [/InternalSite\\/CustomUpdate\\/leumi\\/LoginPage.ASP/],\n    [LoginResults.AccountBlocked]: [\n      async (options) => {\n        if (!options || !options.page) {\n          throw new Error('missing page options argument');\n        }\n        const errorMessage = await pageEvalAll(options.page, '.errHeader', [], (label) => {\n          return (label[0] as HTMLElement)?.innerText;\n        });\n\n        return errorMessage?.startsWith(ACCOUNT_BLOCKED_MSG);\n      },\n    ],\n    [LoginResults.ChangePassword]: ['https://hb2.bankleumi.co.il/authenticate'],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  return [\n    { selector: '#wtr_uid', value: credentials.username },\n    { selector: '#wtr_password', value: credentials.password },\n  ];\n}\n\nfunction extractTransactionsFromPage(transactions: any[], status: TransactionStatuses): Transaction[] {\n  if (transactions === null || transactions.length === 0) {\n    return [];\n  }\n\n  const result: Transaction[] = transactions.map((rawTransaction) => {\n    const newTransaction: Transaction = {\n      status,\n      type: TransactionTypes.Normal,\n      date: rawTransaction.DateUTC,\n      processedDate: rawTransaction.DateUTC,\n      description: rawTransaction.Description || '',\n      identifier: rawTransaction.ReferenceNumberLong,\n      memo: rawTransaction.AdditionalData || '',\n      originalCurrency: SHEKEL_CURRENCY,\n      chargedAmount: rawTransaction.Amount,\n      originalAmount: rawTransaction.Amount,\n    };\n\n    return newTransaction;\n  });\n\n  return result;\n}\n\nfunction hangProcess(timeout: number) {\n  return new Promise<void>((resolve) => {\n    setTimeout(() => {\n      resolve();\n    }, timeout);\n  });\n}\n\nasync function clickByXPath(page: Page, xpath: string): Promise<void> {\n  await page.waitForXPath(xpath, { timeout: 30000, visible: true });\n  const elm = await page.$x(xpath);\n  await elm[0].click();\n}\n\nfunction removeSpecialCharacters(str: string): string {\n  return str.replace(/[^0-9/-]/g, '');\n}\n\nasync function fetchTransactionsForAccount(page: Page, startDate: Moment, accountId: string): Promise<TransactionsAccount> {\n  // DEVELOPER NOTICE the account number received from the server is being altered at\n  // runtime for some accounts after 1-2 seconds so we need to hang the process for a short while.\n  await hangProcess(4000);\n\n  await waitUntilElementFound(page, 'button[title=\"חיפוש מתקדם\"]', true);\n  await clickButton(page, 'button[title=\"חיפוש מתקדם\"]');\n  await waitUntilElementFound(page, 'bll-radio-button', true);\n  await clickButton(page, 'bll-radio-button:not([checked])');\n\n  await waitUntilElementFound(page, 'input[formcontrolname=\"txtInputFrom\"]', true);\n\n  await fillInput(\n    page,\n    'input[formcontrolname=\"txtInputFrom\"]',\n    startDate.format(DATE_FORMAT),\n  );\n\n  // we must blur the from control otherwise the search will use the previous value\n  await page.focus(\"button[aria-label='סנן']\");\n\n  await clickButton(page, \"button[aria-label='סנן']\");\n  const finalResponse = await page.waitForResponse((response) => {\n    return response.url() === FILTERED_TRANSACTIONS_URL &&\n      response.request().method() === 'POST';\n  });\n\n  const responseJson: any = await finalResponse.json();\n\n  const accountNumber = accountId.replace('/', '_').replace(/[^\\d-_]/g, '');\n\n  const response = JSON.parse(responseJson.jsonResp);\n\n  const pendingTransactions = response.TodayTransactionsItems;\n  const transactions = response.HistoryTransactionsItems;\n  const balance = response.BalanceDisplay ? parseFloat(response.BalanceDisplay) : undefined;\n\n  const pendingTxns = extractTransactionsFromPage(pendingTransactions, TransactionStatuses.Pending);\n  const completedTxns = extractTransactionsFromPage(transactions, TransactionStatuses.Completed);\n  const txns = [\n    ...pendingTxns,\n    ...completedTxns,\n  ];\n\n  return {\n    accountNumber,\n    balance,\n    txns,\n  };\n}\n\nasync function fetchTransactions(page: Page, startDate: Moment): Promise<TransactionsAccount[]> {\n  const accounts: TransactionsAccount[] = [];\n\n  // DEVELOPER NOTICE the account number received from the server is being altered at\n  // runtime for some accounts after 1-2 seconds so we need to hang the process for a short while.\n  await hangProcess(4000);\n\n  const accountsIds = await page.evaluate(() => Array.from(document.querySelectorAll('app-masked-number-combo span.display-number-li'), (e) => e.textContent)) as string[];\n\n  // due to a bug, the altered value might include undesired signs like & that should be removed\n\n  if (!accountsIds.length) {\n    throw new Error('Failed to extract or parse the account number');\n  }\n\n  for (const accountId of accountsIds) {\n    if (accountsIds.length > 1) {\n      // get list of accounts and check accountId\n      await clickByXPath(page, '//*[contains(@class, \"number\") and contains(@class, \"combo-inner\")]');\n      await clickByXPath(page, `//span[contains(text(), '${accountId}')]`);\n    }\n\n    accounts.push(await fetchTransactionsForAccount(page, startDate, removeSpecialCharacters(accountId)));\n  }\n\n  return accounts;\n}\n\nasync function waitForPostLogin(page: Page): Promise<void> {\n  // TODO check for condition to provide new password\n  await Promise.race([\n    waitUntilElementFound(page, 'div.leumi-container', true),\n    waitUntilElementFound(page, '#BodyContent_ctl00_loginErrMsg', true),\n    waitUntilElementFound(page, '.ErrMsg', true),\n    waitUntilElementFound(page, 'form[action=\"/changepassword\"]', true),\n  ]);\n}\n\nclass LeumiScraper extends BaseScraperWithBrowser {\n  getLoginOptions(credentials: Record<string, string>) {\n    return {\n      loginUrl: `${BASE_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#enter',\n      postAction: async () => waitForPostLogin(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData(): Promise<ScaperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    await this.navigateTo(TRANSACTIONS_URL);\n\n    const accounts = await fetchTransactions(this.page, startMoment);\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default LeumiScraper;\n"]}
197
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/leumi.ts"],"names":["BASE_URL","TRANSACTIONS_URL","FILTERED_TRANSACTIONS_URL","DATE_FORMAT","ACCOUNT_BLOCKED_MSG","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","AccountBlocked","options","page","Error","errorMessage","label","innerText","startsWith","ChangePassword","createLoginFields","credentials","selector","value","username","password","extractTransactionsFromPage","transactions","status","length","result","map","rawTransaction","newTransaction","type","TransactionTypes","Normal","date","DateUTC","processedDate","description","Description","identifier","ReferenceNumberLong","memo","AdditionalData","originalCurrency","SHEKEL_CURRENCY","chargedAmount","Amount","originalAmount","hangProcess","timeout","Promise","resolve","setTimeout","clickByXPath","xpath","waitForXPath","visible","elm","$x","click","removeSpecialCharacters","str","replace","fetchTransactionsForAccount","startDate","accountId","format","focus","finalResponse","waitForResponse","response","url","request","method","responseJson","json","accountNumber","JSON","parse","jsonResp","pendingTransactions","TodayTransactionsItems","HistoryTransactionsItems","balance","BalanceDisplay","parseFloat","undefined","pendingTxns","TransactionStatuses","Pending","completedTxns","Completed","txns","fetchTransactions","accounts","accountsIds","evaluate","Array","from","document","querySelectorAll","e","textContent","push","waitForPostLogin","race","LeumiScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","postAction","possibleResults","fetchData","defaultStartMoment","subtract","add","toDate","startMoment","moment","max","navigateTo","success"],"mappings":"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","sourcesContent":["import moment, { Moment } from 'moment';\nimport { Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginResults, LoginOptions } from './base-scraper-with-browser';\nimport {\n  fillInput,\n  clickButton,\n  waitUntilElementFound,\n  pageEvalAll,\n} from '../helpers/elements-interactions';\nimport { SHEKEL_CURRENCY } from '../constants';\nimport {\n  TransactionsAccount, Transaction, TransactionStatuses, TransactionTypes,\n} from '../transactions';\nimport { ScaperScrapingResult, ScraperCredentials } from './base-scraper';\n\nconst BASE_URL = 'https://hb2.bankleumi.co.il';\nconst TRANSACTIONS_URL = `${BASE_URL}/eBanking/SO/SPA.aspx#/ts/BusinessAccountTrx?WidgetPar=1`;\nconst FILTERED_TRANSACTIONS_URL = `${BASE_URL}/ChannelWCF/Broker.svc/ProcessRequest?moduleName=UC_SO_27_GetBusinessAccountTrx`;\n\nconst DATE_FORMAT = 'DD.MM.YY';\nconst ACCOUNT_BLOCKED_MSG = 'המנוי חסום';\n\n\nfunction getPossibleLoginResults() {\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/ebanking\\/SO\\/SPA.aspx/i],\n    [LoginResults.InvalidPassword]: [/InternalSite\\/CustomUpdate\\/leumi\\/LoginPage.ASP/],\n    [LoginResults.AccountBlocked]: [\n      async (options) => {\n        if (!options || !options.page) {\n          throw new Error('missing page options argument');\n        }\n        const errorMessage = await pageEvalAll(options.page, '.errHeader', [], (label) => {\n          return (label[0] as HTMLElement)?.innerText;\n        });\n\n        return errorMessage?.startsWith(ACCOUNT_BLOCKED_MSG);\n      },\n    ],\n    [LoginResults.ChangePassword]: ['https://hb2.bankleumi.co.il/authenticate'],\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  return [\n    { selector: '#wtr_uid', value: credentials.username },\n    { selector: '#wtr_password', value: credentials.password },\n  ];\n}\n\nfunction extractTransactionsFromPage(transactions: any[], status: TransactionStatuses): Transaction[] {\n  if (transactions === null || transactions.length === 0) {\n    return [];\n  }\n\n  const result: Transaction[] = transactions.map((rawTransaction) => {\n    const newTransaction: Transaction = {\n      status,\n      type: TransactionTypes.Normal,\n      date: rawTransaction.DateUTC,\n      processedDate: rawTransaction.DateUTC,\n      description: rawTransaction.Description || '',\n      identifier: rawTransaction.ReferenceNumberLong,\n      memo: rawTransaction.AdditionalData || '',\n      originalCurrency: SHEKEL_CURRENCY,\n      chargedAmount: rawTransaction.Amount,\n      originalAmount: rawTransaction.Amount,\n    };\n\n    return newTransaction;\n  });\n\n  return result;\n}\n\nfunction hangProcess(timeout: number) {\n  return new Promise<void>((resolve) => {\n    setTimeout(() => {\n      resolve();\n    }, timeout);\n  });\n}\n\nasync function clickByXPath(page: Page, xpath: string): Promise<void> {\n  await page.waitForXPath(xpath, { timeout: 30000, visible: true });\n  const elm = await page.$x(xpath);\n  await elm[0].click();\n}\n\nfunction removeSpecialCharacters(str: string): string {\n  return str.replace(/[^0-9/-]/g, '');\n}\n\nasync function fetchTransactionsForAccount(page: Page, startDate: Moment, accountId: string): Promise<TransactionsAccount> {\n  // DEVELOPER NOTICE the account number received from the server is being altered at\n  // runtime for some accounts after 1-2 seconds so we need to hang the process for a short while.\n  await hangProcess(4000);\n\n  await waitUntilElementFound(page, 'button[title=\"חיפוש מתקדם\"]', true);\n  await clickButton(page, 'button[title=\"חיפוש מתקדם\"]');\n  await waitUntilElementFound(page, 'bll-radio-button', true);\n  await clickButton(page, 'bll-radio-button:not([checked])');\n\n  await waitUntilElementFound(page, 'input[formcontrolname=\"txtInputFrom\"]', true);\n\n  await fillInput(\n    page,\n    'input[formcontrolname=\"txtInputFrom\"]',\n    startDate.format(DATE_FORMAT),\n  );\n\n  // we must blur the from control otherwise the search will use the previous value\n  await page.focus(\"button[aria-label='סנן']\");\n\n  await clickButton(page, \"button[aria-label='סנן']\");\n  const finalResponse = await page.waitForResponse((response) => {\n    return response.url() === FILTERED_TRANSACTIONS_URL &&\n      response.request().method() === 'POST';\n  });\n\n  const responseJson: any = await finalResponse.json();\n\n  const accountNumber = accountId.replace('/', '_').replace(/[^\\d-_]/g, '');\n\n  const response = JSON.parse(responseJson.jsonResp);\n\n  const pendingTransactions = response.TodayTransactionsItems;\n  const transactions = response.HistoryTransactionsItems;\n  const balance = response.BalanceDisplay ? parseFloat(response.BalanceDisplay) : undefined;\n\n  const pendingTxns = extractTransactionsFromPage(pendingTransactions, TransactionStatuses.Pending);\n  const completedTxns = extractTransactionsFromPage(transactions, TransactionStatuses.Completed);\n  const txns = [\n    ...pendingTxns,\n    ...completedTxns,\n  ];\n\n  return {\n    accountNumber,\n    balance,\n    txns,\n  };\n}\n\nasync function fetchTransactions(page: Page, startDate: Moment): Promise<TransactionsAccount[]> {\n  const accounts: TransactionsAccount[] = [];\n\n  // DEVELOPER NOTICE the account number received from the server is being altered at\n  // runtime for some accounts after 1-2 seconds so we need to hang the process for a short while.\n  await hangProcess(4000);\n\n  const accountsIds = await page.evaluate(() => Array.from(document.querySelectorAll('app-masked-number-combo span.display-number-li'), (e) => e.textContent)) as string[];\n\n  // due to a bug, the altered value might include undesired signs like & that should be removed\n\n  if (!accountsIds.length) {\n    throw new Error('Failed to extract or parse the account number');\n  }\n\n  for (const accountId of accountsIds) {\n    if (accountsIds.length > 1) {\n      // get list of accounts and check accountId\n      await clickByXPath(page, '//*[contains(@class, \"number\") and contains(@class, \"combo-inner\")]');\n      await clickByXPath(page, `//span[contains(text(), '${accountId}')]`);\n    }\n\n    accounts.push(await fetchTransactionsForAccount(page, startDate, removeSpecialCharacters(accountId)));\n  }\n\n  return accounts;\n}\n\nasync function waitForPostLogin(page: Page): Promise<void> {\n  // TODO check for condition to provide new password\n  await Promise.race([\n    waitUntilElementFound(page, 'a[title=\"דלג לחשבון\"]', true),\n    waitUntilElementFound(page, 'div.leumi-container', true),\n    waitUntilElementFound(page, '#BodyContent_ctl00_loginErrMsg', true),\n    waitUntilElementFound(page, '.ErrMsg', true),\n    waitUntilElementFound(page, 'form[action=\"/changepassword\"]', true),\n  ]);\n}\n\nclass LeumiScraper extends BaseScraperWithBrowser {\n  getLoginOptions(credentials: Record<string, string>) {\n    return {\n      loginUrl: `${BASE_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: '#enter',\n      postAction: async () => waitForPostLogin(this.page),\n      possibleResults: getPossibleLoginResults(),\n    };\n  }\n\n  async fetchData(): Promise<ScaperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n\n    await this.navigateTo(TRANSACTIONS_URL);\n\n    const accounts = await fetchTransactions(this.page, startMoment);\n\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default LeumiScraper;\n"]}
@@ -178,6 +178,7 @@ async function fetchTransactionsForAccount(page, startDate, accountNumber, scrap
178
178
  const buttonSelector = '[id$="FormAreaNoBorder_FormArea_ctlSubmitRequest"]';
179
179
  const nextPageSelector = '[id$="FormAreaNoBorder_FormArea_ctlGridPager_btnNext"]';
180
180
  const billingLabelSelector = '[id$=FormAreaNoBorder_FormArea_ctlMainToolBar_lblCaption]';
181
+ const secondaryBillingLabelSelector = '[id$=FormAreaNoBorder_FormArea_ctlSecondaryToolBar_lblCaption]';
181
182
  const noDataSelector = '[id$=FormAreaNoBorder_FormArea_msgboxErrorMessages]';
182
183
  debug('find the start date index in the dropbox');
183
184
  const options = await (0, _elementsInteractions.pageEvalAll)(page, '[id$="FormAreaNoBorder_FormArea_clndrDebitDateScope_OptionList"] li', [], items => {
@@ -207,13 +208,22 @@ async function fetchTransactionsForAccount(page, startDate, accountNumber, scrap
207
208
  if (pageHasNoTransactions) {
208
209
  debug('page has no transactions');
209
210
  } else {
210
- var _$exec;
211
+ var _settlementDateRegex$;
211
212
 
212
213
  debug('find the billing date');
213
- const billingDateLabel = await (0, _elementsInteractions.pageEval)(page, billingLabelSelector, '', element => {
214
+ let billingDateLabel = await (0, _elementsInteractions.pageEval)(page, billingLabelSelector, '', element => {
214
215
  return element.innerText;
215
216
  });
216
- const billingDate = (_$exec = /\d{1,2}[/]\d{2}[/]\d{2,4}/.exec(billingDateLabel)) === null || _$exec === void 0 ? void 0 : _$exec[0];
217
+ let settlementDateRegex = /\d{1,2}[/]\d{2}[/]\d{2,4}/;
218
+
219
+ if (billingDateLabel === '') {
220
+ billingDateLabel = await (0, _elementsInteractions.pageEval)(page, secondaryBillingLabelSelector, '', element => {
221
+ return element.innerText;
222
+ });
223
+ settlementDateRegex = /\d{1,2}[/]\d{2,4}/;
224
+ }
225
+
226
+ const billingDate = (_settlementDateRegex$ = settlementDateRegex.exec(billingDateLabel)) === null || _settlementDateRegex$ === void 0 ? void 0 : _settlementDateRegex$[0];
217
227
 
218
228
  if (!billingDate) {
219
229
  throw new Error('failed to fetch process date');
@@ -279,9 +289,9 @@ async function fetchTransactionsForAccount(page, startDate, accountNumber, scrap
279
289
 
280
290
  async function getAccountNumbers(page) {
281
291
  return (0, _elementsInteractions.pageEvalAll)(page, '[id$=lnkItem]', [], elements => elements.map(e => e.text)).then(res => res.map(text => {
282
- var _$exec$, _$exec2;
292
+ var _$exec$, _$exec;
283
293
 
284
- return (_$exec$ = (_$exec2 = /\d+$/.exec(text.trim())) === null || _$exec2 === void 0 ? void 0 : _$exec2[0]) !== null && _$exec$ !== void 0 ? _$exec$ : '';
294
+ return (_$exec$ = (_$exec = /\d+$/.exec(text.trim())) === null || _$exec === void 0 ? void 0 : _$exec[0]) !== null && _$exec$ !== void 0 ? _$exec$ : '';
285
295
  }));
286
296
  }
287
297
 
@@ -366,4 +376,4 @@ class VisaCalScraper extends _baseScraperWithBrowser.BaseScraperWithBrowser {
366
376
 
367
377
  var _default = VisaCalScraper;
368
378
  exports.default = _default;
369
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/visa-cal.ts"],"names":["LOGIN_URL","TRANSACTIONS_URL","LONG_DATE_FORMAT","DATE_FORMAT","InvalidPasswordMessage","debug","getLoginFrame","page","frame","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","errorMessage","item","innerText","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","createLoginFields","credentials","selector","value","username","password","getAmountData","amountStr","amountStrCln","replace","currency","amount","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","getTransactionInstallments","memo","parsedMemo","exec","length","number","parseInt","total","convertTransactions","txns","map","txn","originalAmountTuple","originalAmount","chargedAmountTuple","chargedAmount","installments","txnDate","date","processedDateFormat","processedDate","txnProcessedDate","result","type","TransactionTypes","Installments","Normal","status","TransactionStatuses","Completed","add","toISOString","originalCurrency","chargedCurrency","description","fetchTransactionsForAccount","startDate","accountNumber","scraperOptions","startDateValue","format","dateSelector","dateHiddenFieldSelector","buttonSelector","nextPageSelector","billingLabelSelector","noDataSelector","items","el","startDateIndex","findIndex","option","accountTransactions","currentDateIndex","waitFor","all","waitForNavigation","waitUntil","pageHasNoTransactions","element","siteValue","billingDateLabel","billingDate","hasNextPage","rawTransactions","columns","getElementsByTagName","push","filter","combineInstallments","substring","getAccountNumbers","elements","e","text","then","res","trim","setAccount","account","elem","a","click","fetchTransactions","accountNumbers","accounts","VisaCalScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","openLoginPopup","userAgent","fetchData","defaultStartMoment","subtract","toDate","startMoment","moment","max","navigateTo","undefined","success"],"mappings":"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","sourcesContent":["import moment, { Moment } from 'moment';\nimport { Frame, Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport {\n  clickButton, elementPresentOnPage, pageEval, pageEvalAll, setValue, waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport {\n  Transaction,\n  TransactionInstallments,\n  TransactionsAccount,\n  TransactionStatuses,\n  TransactionTypes,\n} from '../transactions';\nimport { ScaperOptions, ScaperScrapingResult, ScraperCredentials } from './base-scraper';\nimport {\n  DOLLAR_CURRENCY, DOLLAR_CURRENCY_SYMBOL, EURO_CURRENCY, EURO_CURRENCY_SYMBOL, SHEKEL_CURRENCY, SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { waitUntil } from '../helpers/waiting';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { getDebug } from '../helpers/debug';\n\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_URL = 'https://services.cal-online.co.il/Card-Holders/Screens/Transactions/Transactions.aspx';\nconst LONG_DATE_FORMAT = 'DD/MM/YYYY';\nconst DATE_FORMAT = 'DD/MM/YY';\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\ninterface ScrapedTransaction {\n  date: string;\n  processedDate: string;\n  description: string;\n  originalAmount: string;\n  chargedAmount: string;\n  memo: string;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(() => {\n    frame = page\n      .frames()\n      .find((f) => f.url().includes('connect.cal-online')) || null;\n    return Promise.resolve(!!frame);\n  }, 'wait for iframe with login form', 10000, 1000);\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound ? await pageEval(frame, 'div.general-error > div', '', (item) => {\n    return (item as HTMLDivElement).innerText;\n  }) : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/AccountManagement/i],\n    [LoginResults.InvalidPassword]: [async (options?: { page?: Page}) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasInvalidPasswordError(page);\n    }],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    // [LoginResults.ChangePassword]: [], // TODO add when reaching this scenario\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\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 getTransactionInstallments(memo: string): TransactionInstallments | null {\n  const parsedMemo = (/תשלום (\\d+) מתוך (\\d+)/).exec(memo || '');\n\n  if (!parsedMemo || parsedMemo.length === 0) {\n    return null;\n  }\n\n  return {\n    number: parseInt(parsedMemo[1], 10),\n    total: parseInt(parsedMemo[2], 10),\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 originalAmountTuple = getAmountData(txn.originalAmount || '');\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n\n    const installments = getTransactionInstallments(txn.memo);\n    const txnDate = moment(txn.date, DATE_FORMAT);\n    const processedDateFormat =\n      txn.processedDate.length === 8 ?\n        DATE_FORMAT :\n        txn.processedDate.length === 9 || txn.processedDate.length === 10 ?\n          LONG_DATE_FORMAT :\n          null;\n    if (!processedDateFormat) {\n      throw new Error('invalid processed date');\n    }\n    const txnProcessedDate = moment(txn.processedDate, processedDateFormat);\n\n    const result: Transaction = {\n      type: installments ? TransactionTypes.Installments : TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: installments ? txnDate.add(installments.number - 1, 'month').toISOString() : txnDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: originalAmountTuple.amount,\n      originalCurrency: originalAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: txn.memo || '',\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    return result;\n  });\n}\n\nasync function fetchTransactionsForAccount(page: Page, startDate: Moment, accountNumber: string, scraperOptions: ScaperOptions): Promise<TransactionsAccount> {\n  const startDateValue = startDate.format('MM/YYYY');\n  const dateSelector = '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_TextBox\"]';\n  const dateHiddenFieldSelector = '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_HiddenField\"]';\n  const buttonSelector = '[id$=\"FormAreaNoBorder_FormArea_ctlSubmitRequest\"]';\n  const nextPageSelector = '[id$=\"FormAreaNoBorder_FormArea_ctlGridPager_btnNext\"]';\n  const billingLabelSelector = '[id$=FormAreaNoBorder_FormArea_ctlMainToolBar_lblCaption]';\n  const noDataSelector = '[id$=FormAreaNoBorder_FormArea_msgboxErrorMessages]';\n\n  debug('find the start date index in the dropbox');\n  const options = await pageEvalAll(page, '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_OptionList\"] li', [], (items) => {\n    return items.map((el: any) => el.innerText);\n  });\n  const startDateIndex = options.findIndex((option) => option === startDateValue);\n\n  debug(`scrape ${options.length - startDateIndex} billing cycles`);\n  const accountTransactions: Transaction[] = [];\n  for (let currentDateIndex = startDateIndex; currentDateIndex < options.length; currentDateIndex += 1) {\n    debug('wait for date selector to be found');\n    await waitUntilElementFound(page, dateSelector, true);\n    debug(`set hidden value of the date selector to be the index ${currentDateIndex}`);\n    await setValue(page, dateHiddenFieldSelector, `${currentDateIndex}`);\n    debug('wait a second to workaround navigation issue in headless browser mode');\n    await page.waitFor(1000);\n    debug('click on the filter submit button and wait for navigation');\n    await Promise.all([\n      page.waitForNavigation({ waitUntil: 'domcontentloaded' }),\n      clickButton(page, buttonSelector),\n    ]);\n    debug('check if month has no transactions');\n    const pageHasNoTransactions = await pageEval(page, noDataSelector, false, ((element) => {\n      const siteValue = ((element as HTMLSpanElement).innerText || '').replace(/[^ א-ת]/g, '');\n      return siteValue === 'לא נמצאו נתונים';\n    }));\n\n    if (pageHasNoTransactions) {\n      debug('page has no transactions');\n    } else {\n      debug('find the billing date');\n      const billingDateLabel = await pageEval(page, billingLabelSelector, '', ((element) => {\n        return (element as HTMLSpanElement).innerText;\n      }));\n\n      const billingDate = /\\d{1,2}[/]\\d{2}[/]\\d{2,4}/.exec(billingDateLabel)?.[0];\n\n      if (!billingDate) {\n        throw new Error('failed to fetch process date');\n      }\n\n      debug(`found the billing date for that month ${billingDate}`);\n      let hasNextPage = false;\n      do {\n        debug('fetch raw transactions from page');\n        const rawTransactions = await pageEvalAll<(ScrapedTransaction | null)[]>(page, '#ctlMainGrid > tbody tr, #ctlSecondaryGrid > tbody tr', [], (items, billingDate) => {\n          return (items).map((el) => {\n            const columns = el.getElementsByTagName('td');\n            if (columns.length === 6) {\n              return {\n                processedDate: columns[0].innerText,\n                date: columns[1].innerText,\n                description: columns[2].innerText,\n                originalAmount: columns[3].innerText,\n                chargedAmount: columns[4].innerText,\n                memo: columns[5].innerText,\n              };\n            }\n            if (columns.length === 5) {\n              return {\n                processedDate: billingDate,\n                date: columns[0].innerText,\n                description: columns[1].innerText,\n                originalAmount: columns[2].innerText,\n                chargedAmount: columns[3].innerText,\n                memo: columns[4].innerText,\n              };\n            }\n            return null;\n          });\n        }, billingDate);\n        debug(`fetched ${rawTransactions.length} raw transactions from page`);\n        accountTransactions.push(...convertTransactions((rawTransactions as ScrapedTransaction[])\n          .filter((item) => !!item)));\n\n        debug('check for existance of another page');\n        hasNextPage = await elementPresentOnPage(page, nextPageSelector);\n        if (hasNextPage) {\n          debug('has another page, click on button next and wait for page navigation');\n          await Promise.all([\n            page.waitForNavigation({ waitUntil: 'domcontentloaded' }),\n            await clickButton(page, '[id$=FormAreaNoBorder_FormArea_ctlGridPager_btnNext]'),\n          ]);\n        }\n      } while (hasNextPage);\n    }\n  }\n\n  debug('filer out old transactions');\n  const txns = filterOldTransactions(accountTransactions, startDate, scraperOptions.combineInstallments || false);\n  debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);\n  return {\n    accountNumber,\n    txns,\n  };\n}\n\nasync function getAccountNumbers(page: Page): Promise<string[]> {\n  return pageEvalAll(page, '[id$=lnkItem]', [], (elements) => elements.map((e) => (e as HTMLAnchorElement).text)).then((res) => res.map((text) => /\\d+$/.exec(text.trim())?.[0] ?? ''));\n}\n\nasync function setAccount(page: Page, account: string) {\n  await pageEvalAll(\n    page,\n    '[id$=lnkItem]',\n    null,\n    (elements, account) => {\n      for (const elem of elements) {\n        const a = elem as HTMLAnchorElement;\n        if (a.text.includes(account)) {\n          a.click();\n        }\n      }\n    },\n    account,\n  );\n}\n\nasync function fetchTransactions(page: Page, startDate: Moment, scraperOptions: ScaperOptions): Promise<TransactionsAccount[]> {\n  const accountNumbers: string[] = await getAccountNumbers(page);\n  const accounts: TransactionsAccount[] = [];\n\n  for (const account of accountNumbers) {\n    debug(`setting account: ${account}`);\n    await setAccount(page, account);\n    await page.waitFor(1000);\n    accounts.push(\n      await fetchTransactionsForAccount(\n        page,\n        startDate,\n        account,\n        scraperOptions,\n      ),\n    );\n  }\n\n  return accounts;\n}\n\n\nclass VisaCalScraper extends BaseScraperWithBrowser {\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  getLoginOptions(credentials: Record<string, string>) {\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      userAgent: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36',\n    };\n  }\n\n  async fetchData(): Promise<ScaperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    debug('navigate to transactions page');\n    await this.navigateTo(TRANSACTIONS_URL, undefined, 60000);\n\n    debug('fetch accounts transactions');\n    const accounts = await fetchTransactions(this.page, startMoment, this.options);\n    debug('return the scraped accounts');\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"]}
379
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scrapers/visa-cal.ts"],"names":["LOGIN_URL","TRANSACTIONS_URL","LONG_DATE_FORMAT","DATE_FORMAT","InvalidPasswordMessage","debug","getLoginFrame","page","frame","frames","find","f","url","includes","Promise","resolve","Error","hasInvalidPasswordError","errorFound","errorMessage","item","innerText","getPossibleLoginResults","urls","LoginResults","Success","InvalidPassword","options","createLoginFields","credentials","selector","value","username","password","getAmountData","amountStr","amountStrCln","replace","currency","amount","SHEKEL_CURRENCY_SYMBOL","parseFloat","SHEKEL_CURRENCY","DOLLAR_CURRENCY_SYMBOL","DOLLAR_CURRENCY","EURO_CURRENCY_SYMBOL","EURO_CURRENCY","parts","split","getTransactionInstallments","memo","parsedMemo","exec","length","number","parseInt","total","convertTransactions","txns","map","txn","originalAmountTuple","originalAmount","chargedAmountTuple","chargedAmount","installments","txnDate","date","processedDateFormat","processedDate","txnProcessedDate","result","type","TransactionTypes","Installments","Normal","status","TransactionStatuses","Completed","add","toISOString","originalCurrency","chargedCurrency","description","fetchTransactionsForAccount","startDate","accountNumber","scraperOptions","startDateValue","format","dateSelector","dateHiddenFieldSelector","buttonSelector","nextPageSelector","billingLabelSelector","secondaryBillingLabelSelector","noDataSelector","items","el","startDateIndex","findIndex","option","accountTransactions","currentDateIndex","waitFor","all","waitForNavigation","waitUntil","pageHasNoTransactions","element","siteValue","billingDateLabel","settlementDateRegex","billingDate","hasNextPage","rawTransactions","columns","getElementsByTagName","push","filter","combineInstallments","substring","getAccountNumbers","elements","e","text","then","res","trim","setAccount","account","elem","a","click","fetchTransactions","accountNumbers","accounts","VisaCalScraper","BaseScraperWithBrowser","getLoginOptions","loginUrl","fields","submitButtonSelector","possibleResults","checkReadiness","preAction","openLoginPopup","userAgent","fetchData","defaultStartMoment","subtract","toDate","startMoment","moment","max","navigateTo","undefined","success"],"mappings":"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","sourcesContent":["import moment, { Moment } from 'moment';\nimport { Frame, Page } from 'puppeteer';\nimport { BaseScraperWithBrowser, LoginOptions, LoginResults } from './base-scraper-with-browser';\nimport {\n  clickButton, elementPresentOnPage, pageEval, pageEvalAll, setValue, waitUntilElementFound,\n} from '../helpers/elements-interactions';\nimport {\n  Transaction,\n  TransactionInstallments,\n  TransactionsAccount,\n  TransactionStatuses,\n  TransactionTypes,\n} from '../transactions';\nimport { ScaperOptions, ScaperScrapingResult, ScraperCredentials } from './base-scraper';\nimport {\n  DOLLAR_CURRENCY, DOLLAR_CURRENCY_SYMBOL, EURO_CURRENCY, EURO_CURRENCY_SYMBOL, SHEKEL_CURRENCY, SHEKEL_CURRENCY_SYMBOL,\n} from '../constants';\nimport { waitUntil } from '../helpers/waiting';\nimport { filterOldTransactions } from '../helpers/transactions';\nimport { getDebug } from '../helpers/debug';\n\nconst LOGIN_URL = 'https://www.cal-online.co.il/';\nconst TRANSACTIONS_URL = 'https://services.cal-online.co.il/Card-Holders/Screens/Transactions/Transactions.aspx';\nconst LONG_DATE_FORMAT = 'DD/MM/YYYY';\nconst DATE_FORMAT = 'DD/MM/YY';\nconst InvalidPasswordMessage = 'שם המשתמש או הסיסמה שהוזנו שגויים';\n\nconst debug = getDebug('visa-cal');\n\ninterface ScrapedTransaction {\n  date: string;\n  processedDate: string;\n  description: string;\n  originalAmount: string;\n  chargedAmount: string;\n  memo: string;\n}\n\nasync function getLoginFrame(page: Page) {\n  let frame: Frame | null = null;\n  debug('wait until login frame found');\n  await waitUntil(() => {\n    frame = page\n      .frames()\n      .find((f) => f.url().includes('connect.cal-online')) || null;\n    return Promise.resolve(!!frame);\n  }, 'wait for iframe with login form', 10000, 1000);\n\n  if (!frame) {\n    debug('failed to find login frame for 10 seconds');\n    throw new Error('failed to extract login iframe');\n  }\n\n  return frame;\n}\n\nasync function hasInvalidPasswordError(page: Page) {\n  const frame = await getLoginFrame(page);\n  const errorFound = await elementPresentOnPage(frame, 'div.general-error > div');\n  const errorMessage = errorFound ? await pageEval(frame, 'div.general-error > div', '', (item) => {\n    return (item as HTMLDivElement).innerText;\n  }) : '';\n  return errorMessage === InvalidPasswordMessage;\n}\n\nfunction getPossibleLoginResults() {\n  debug('return possible login results');\n  const urls: LoginOptions['possibleResults'] = {\n    [LoginResults.Success]: [/AccountManagement/i],\n    [LoginResults.InvalidPassword]: [async (options?: { page?: Page}) => {\n      const page = options?.page;\n      if (!page) {\n        return false;\n      }\n      return hasInvalidPasswordError(page);\n    }],\n    // [LoginResults.AccountBlocked]: [], // TODO add when reaching this scenario\n    // [LoginResults.ChangePassword]: [], // TODO add when reaching this scenario\n  };\n  return urls;\n}\n\nfunction createLoginFields(credentials: ScraperCredentials) {\n  debug('create login fields for username and password');\n  return [\n    { selector: '[formcontrolname=\"userName\"]', value: credentials.username },\n    { selector: '[formcontrolname=\"password\"]', value: credentials.password },\n  ];\n}\n\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 getTransactionInstallments(memo: string): TransactionInstallments | null {\n  const parsedMemo = (/תשלום (\\d+) מתוך (\\d+)/).exec(memo || '');\n\n  if (!parsedMemo || parsedMemo.length === 0) {\n    return null;\n  }\n\n  return {\n    number: parseInt(parsedMemo[1], 10),\n    total: parseInt(parsedMemo[2], 10),\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 originalAmountTuple = getAmountData(txn.originalAmount || '');\n    const chargedAmountTuple = getAmountData(txn.chargedAmount || '');\n\n    const installments = getTransactionInstallments(txn.memo);\n    const txnDate = moment(txn.date, DATE_FORMAT);\n    const processedDateFormat =\n      txn.processedDate.length === 8 ?\n        DATE_FORMAT :\n        txn.processedDate.length === 9 || txn.processedDate.length === 10 ?\n          LONG_DATE_FORMAT :\n          null;\n    if (!processedDateFormat) {\n      throw new Error('invalid processed date');\n    }\n    const txnProcessedDate = moment(txn.processedDate, processedDateFormat);\n\n    const result: Transaction = {\n      type: installments ? TransactionTypes.Installments : TransactionTypes.Normal,\n      status: TransactionStatuses.Completed,\n      date: installments ? txnDate.add(installments.number - 1, 'month').toISOString() : txnDate.toISOString(),\n      processedDate: txnProcessedDate.toISOString(),\n      originalAmount: originalAmountTuple.amount,\n      originalCurrency: originalAmountTuple.currency,\n      chargedAmount: chargedAmountTuple.amount,\n      chargedCurrency: chargedAmountTuple.currency,\n      description: txn.description || '',\n      memo: txn.memo || '',\n    };\n\n    if (installments) {\n      result.installments = installments;\n    }\n\n    return result;\n  });\n}\n\nasync function fetchTransactionsForAccount(page: Page, startDate: Moment, accountNumber: string, scraperOptions: ScaperOptions): Promise<TransactionsAccount> {\n  const startDateValue = startDate.format('MM/YYYY');\n  const dateSelector = '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_TextBox\"]';\n  const dateHiddenFieldSelector = '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_HiddenField\"]';\n  const buttonSelector = '[id$=\"FormAreaNoBorder_FormArea_ctlSubmitRequest\"]';\n  const nextPageSelector = '[id$=\"FormAreaNoBorder_FormArea_ctlGridPager_btnNext\"]';\n  const billingLabelSelector = '[id$=FormAreaNoBorder_FormArea_ctlMainToolBar_lblCaption]';\n  const secondaryBillingLabelSelector = '[id$=FormAreaNoBorder_FormArea_ctlSecondaryToolBar_lblCaption]';\n  const noDataSelector = '[id$=FormAreaNoBorder_FormArea_msgboxErrorMessages]';\n\n  debug('find the start date index in the dropbox');\n  const options = await pageEvalAll(page, '[id$=\"FormAreaNoBorder_FormArea_clndrDebitDateScope_OptionList\"] li', [], (items) => {\n    return items.map((el: any) => el.innerText);\n  });\n  const startDateIndex = options.findIndex((option) => option === startDateValue);\n\n  debug(`scrape ${options.length - startDateIndex} billing cycles`);\n  const accountTransactions: Transaction[] = [];\n  for (let currentDateIndex = startDateIndex; currentDateIndex < options.length; currentDateIndex += 1) {\n    debug('wait for date selector to be found');\n    await waitUntilElementFound(page, dateSelector, true);\n    debug(`set hidden value of the date selector to be the index ${currentDateIndex}`);\n    await setValue(page, dateHiddenFieldSelector, `${currentDateIndex}`);\n    debug('wait a second to workaround navigation issue in headless browser mode');\n    await page.waitFor(1000);\n    debug('click on the filter submit button and wait for navigation');\n    await Promise.all([\n      page.waitForNavigation({ waitUntil: 'domcontentloaded' }),\n      clickButton(page, buttonSelector),\n    ]);\n    debug('check if month has no transactions');\n    const pageHasNoTransactions = await pageEval(page, noDataSelector, false, ((element) => {\n      const siteValue = ((element as HTMLSpanElement).innerText || '').replace(/[^ א-ת]/g, '');\n      return siteValue === 'לא נמצאו נתונים';\n    }));\n\n    if (pageHasNoTransactions) {\n      debug('page has no transactions');\n    } else {\n      debug('find the billing date');\n      let billingDateLabel = await pageEval(page, billingLabelSelector, '', ((element) => {\n        return (element as HTMLSpanElement).innerText;\n      }));\n      let settlementDateRegex = /\\d{1,2}[/]\\d{2}[/]\\d{2,4}/;\n\n      if (billingDateLabel === '') {\n        billingDateLabel = await pageEval(page, secondaryBillingLabelSelector, '', ((element) => {\n          return (element as HTMLSpanElement).innerText;\n        }));\n        settlementDateRegex = /\\d{1,2}[/]\\d{2,4}/;\n      }\n\n      const billingDate = settlementDateRegex.exec(billingDateLabel)?.[0];\n\n      if (!billingDate) {\n        throw new Error('failed to fetch process date');\n      }\n\n      debug(`found the billing date for that month ${billingDate}`);\n      let hasNextPage = false;\n      do {\n        debug('fetch raw transactions from page');\n        const rawTransactions = await pageEvalAll<(ScrapedTransaction | null)[]>(page, '#ctlMainGrid > tbody tr, #ctlSecondaryGrid > tbody tr', [], (items, billingDate) => {\n          return (items).map((el) => {\n            const columns = el.getElementsByTagName('td');\n            if (columns.length === 6) {\n              return {\n                processedDate: columns[0].innerText,\n                date: columns[1].innerText,\n                description: columns[2].innerText,\n                originalAmount: columns[3].innerText,\n                chargedAmount: columns[4].innerText,\n                memo: columns[5].innerText,\n              };\n            }\n            if (columns.length === 5) {\n              return {\n                processedDate: billingDate,\n                date: columns[0].innerText,\n                description: columns[1].innerText,\n                originalAmount: columns[2].innerText,\n                chargedAmount: columns[3].innerText,\n                memo: columns[4].innerText,\n              };\n            }\n            return null;\n          });\n        }, billingDate);\n        debug(`fetched ${rawTransactions.length} raw transactions from page`);\n        accountTransactions.push(...convertTransactions((rawTransactions as ScrapedTransaction[])\n          .filter((item) => !!item)));\n\n        debug('check for existance of another page');\n        hasNextPage = await elementPresentOnPage(page, nextPageSelector);\n        if (hasNextPage) {\n          debug('has another page, click on button next and wait for page navigation');\n          await Promise.all([\n            page.waitForNavigation({ waitUntil: 'domcontentloaded' }),\n            await clickButton(page, '[id$=FormAreaNoBorder_FormArea_ctlGridPager_btnNext]'),\n          ]);\n        }\n      } while (hasNextPage);\n    }\n  }\n\n  debug('filer out old transactions');\n  const txns = filterOldTransactions(accountTransactions, startDate, scraperOptions.combineInstallments || false);\n  debug(`found ${txns.length} valid transactions out of ${accountTransactions.length} transactions for account ending with ${accountNumber.substring(accountNumber.length - 2)}`);\n  return {\n    accountNumber,\n    txns,\n  };\n}\n\nasync function getAccountNumbers(page: Page): Promise<string[]> {\n  return pageEvalAll(page, '[id$=lnkItem]', [], (elements) => elements.map((e) => (e as HTMLAnchorElement).text)).then((res) => res.map((text) => /\\d+$/.exec(text.trim())?.[0] ?? ''));\n}\n\nasync function setAccount(page: Page, account: string) {\n  await pageEvalAll(\n    page,\n    '[id$=lnkItem]',\n    null,\n    (elements, account) => {\n      for (const elem of elements) {\n        const a = elem as HTMLAnchorElement;\n        if (a.text.includes(account)) {\n          a.click();\n        }\n      }\n    },\n    account,\n  );\n}\n\nasync function fetchTransactions(page: Page, startDate: Moment, scraperOptions: ScaperOptions): Promise<TransactionsAccount[]> {\n  const accountNumbers: string[] = await getAccountNumbers(page);\n  const accounts: TransactionsAccount[] = [];\n\n  for (const account of accountNumbers) {\n    debug(`setting account: ${account}`);\n    await setAccount(page, account);\n    await page.waitFor(1000);\n    accounts.push(\n      await fetchTransactionsForAccount(\n        page,\n        startDate,\n        account,\n        scraperOptions,\n      ),\n    );\n  }\n\n  return accounts;\n}\n\n\nclass VisaCalScraper extends BaseScraperWithBrowser {\n  openLoginPopup = async () => {\n    debug('open login popup, wait until login button available');\n    await waitUntilElementFound(this.page, '#ccLoginDesktopBtn', true);\n    debug('click on the login button');\n    await clickButton(this.page, '#ccLoginDesktopBtn');\n    debug('get the frame that holds the login');\n    const frame = await getLoginFrame(this.page);\n    debug('wait until the password login tab header is available');\n    await waitUntilElementFound(frame, '#regular-login');\n    debug('navigate to the password login tab');\n    await clickButton(frame, '#regular-login');\n    debug('wait until the password login tab is active');\n    await waitUntilElementFound(frame, 'regular-login');\n\n    return frame;\n  };\n\n  getLoginOptions(credentials: Record<string, string>) {\n    return {\n      loginUrl: `${LOGIN_URL}`,\n      fields: createLoginFields(credentials),\n      submitButtonSelector: 'button[type=\"submit\"]',\n      possibleResults: getPossibleLoginResults(),\n      checkReadiness: async () => waitUntilElementFound(this.page, '#ccLoginDesktopBtn'),\n      preAction: this.openLoginPopup,\n      userAgent: 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/78.0.3904.108 Safari/537.36',\n    };\n  }\n\n  async fetchData(): Promise<ScaperScrapingResult> {\n    const defaultStartMoment = moment().subtract(1, 'years').add(1, 'day');\n    const startDate = this.options.startDate || defaultStartMoment.toDate();\n    const startMoment = moment.max(defaultStartMoment, moment(startDate));\n    debug(`fetch transactions starting ${startMoment.format()}`);\n\n    debug('navigate to transactions page');\n    await this.navigateTo(TRANSACTIONS_URL, undefined, 60000);\n\n    debug('fetch accounts transactions');\n    const accounts = await fetchTransactions(this.page, startMoment, this.options);\n    debug('return the scraped accounts');\n    return {\n      success: true,\n      accounts,\n    };\n  }\n}\n\nexport default VisaCalScraper;\n"]}
@@ -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.1",
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": {