Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eshaham/israeli-bank-scrapers
Provide scrapers for all major Israeli banks and credit card companies
https://github.com/eshaham/israeli-bank-scrapers
Last synced: about 2 months ago
JSON representation
Provide scrapers for all major Israeli banks and credit card companies
- Host: GitHub
- URL: https://github.com/eshaham/israeli-bank-scrapers
- Owner: eshaham
- License: mit
- Created: 2017-07-29T09:15:12.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-04-02T13:28:41.000Z (9 months ago)
- Last Synced: 2024-04-03T13:46:03.983Z (9 months ago)
- Language: TypeScript
- Size: 2.48 MB
- Stars: 519
- Watchers: 25
- Forks: 147
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-opensource-israel - israeli-bank-scrapers - Provide scrapers for all major Israeli banks and credit card companies ![GitHub last commit](https://img.shields.io/github/last-commit/eshaham/israeli-bank-scrapers?style=flat-square "GitHub last commit") ![GitHub top language](https://img.shields.io/github/languages/top/eshaham/israeli-bank-scrapers?style=flat-square "GitHub top language") ![GitHub stars](https://img.shields.io/github/stars/eshaham/israeli-bank-scrapers?style=flat-square) (Projects by main language / typescript)
README
Israeli Bank Scrapers - Get closer to your own data!
========[![NPM](https://nodei.co/npm/israeli-bank-scrapers.png)](https://nodei.co/npm/israeli-bank-scrapers/)
[![npm version](https://badge.fury.io/js/israeli-bank-scrapers.svg)](https://badge.fury.io/js/israeli-bank-scrapers)
[![dependencies Status](https://david-dm.org/eshaham/israeli-bank-scrapers/status.svg)](https://david-dm.org/eshaham/israeli-bank-scrapers)
[![devDependencies Status](https://david-dm.org/eshaham/israeli-bank-scrapers/dev-status.svg)](https://david-dm.org/eshaham/israeli-bank-scrapers?type=dev)> Important!
>
> The scrapers are set to use timezone `Asia/Jerusalem` to avoid conflicts in case you're running the scrapers outside Israel.
# What's here?
What you can find here is scrapers for all major Israeli banks and credit card companies. That's the plan at least.
Currently only the following banks are supported:
- Bank Hapoalim (thanks [@sebikaplun](https://github.com/sebikaplun))
- Leumi Bank (thanks [@esakal](https://github.com/esakal))
- Discount Bank
- Mercantile Bank (thanks [@ezzatq](https://github.com/ezzatq) and [@kfirarad](https://github.com/kfirarad)))
- Mizrahi Bank (thanks [@baruchiro](https://github.com/baruchiro))
- Otsar Hahayal Bank (thanks [@matanelgabsi](https://github.com/matanelgabsi))
- Visa Cal (thanks [@erikash](https://github.com/erikash), [@esakal](https://github.com/esakal) and [@nirgin](https://github.com/nirgin))
- Max (Formerly Leumi Card)
- Isracard
- Amex (thanks [@erezd](https://github.com/erezd))
- Union Bank (Thanks to Intuit FDP OpenSource Team [@dratler](https://github.com/dratler),[@kalinoy](https://github.com/kalinoy),[@shanigad](https://github.com/shanigad),[@dudiventura](https://github.com/dudiventura) and [@NoamGoren](https://github.com/NoamGoren))
- Beinleumi (Thanks to [@dudiventura](https://github.com/dudiventura) from the Intuit FDP OpenSource Team)
- Massad
- Yahav (Thanks to [@gczobel](https://github.com/gczobel))
- Beyhad Bishvilha - [ביחד בשבילך](https://www.hist.org.il/) (thanks [@esakal](https://github.com/esakal))
- OneZero (Experimental) (thanks [@orzarchi](https://github.com/orzarchi))
- Behatsdaa - [בהצדעה](behatsdaa.org.il) (thanks [@daniel-hauser](https://github.com/daniel-hauser))# Prerequisites
To use this you will need to have [Node.js](https://nodejs.org) >= 16.x installed.# Getting started
To use these scrapers you'll need to install the package from npm:
```sh
npm install israeli-bank-scrapers --save
```
Then you can simply import and use it in your node module:```node
import { CompanyTypes, createScraper } from 'israeli-bank-scrapers';(async function() {
try {
// read documentation below for available options
const options = {
companyId: CompanyTypes.leumi,
startDate: new Date('2020-05-01'),
combineInstallments: false,
showBrowser: true
};// read documentation below for information about credentials
const credentials = {
username: 'vr29485',
password: 'sometingsomething'
};const scraper = createScraper(options);
const scrapeResult = await scraper.scrape(credentials);if (scrapeResult.success) {
scrapeResult.accounts.forEach((account) => {
console.log(`found ${account.txns.length} transactions for account number ${account.accountNumber}`);
});
}
else {
throw new Error(scrapeResult.errorType);
}
} catch(e) {
console.error(`scraping failed for the following reason: ${e.message}`);
}
})();
```Check the options declaration [here](./src/scrapers/interface.ts#L29) for available options.
Regarding credentials, you should provide the relevant credentials for the chosen company. See [this file](./src/definitions.ts) with list of credentials per company.
The structure of the result object is as follows:
```node
{
success: boolean,
accounts: [{
accountNumber: string,
balance?: number, // Account balance. Not implemented for all accounts.
txns: [{
type: string, // can be either 'normal' or 'installments'
identifier: int, // only if exists
date: string, // ISO date string
processedDate: string, // ISO date string
originalAmount: double,
originalCurrency: string,
chargedAmount: double,
description: string,
memo: string, // can be null or empty
installments: { // only if exists
number: int, // the current installment number
total: int, // the total number of installments
},
status: string //can either be 'completed' or 'pending'
}],
}],
errorType: "INVALID_PASSWORD"|"CHANGE_PASSWORD"|"ACCOUNT_BLOCKED"|"UNKNOWN_ERROR"|"TIMEOUT"|"GENERIC", // only on success=false
errorMessage: string, // only on success=false
}
```You can also use the `SCRAPERS` list to get scraper metadata:
```node
import { SCRAPERS } from 'israeli-bank-scrapers';
```The return value is a list of scraper metadata:
```node
{
: {
name: string, // the name of the scraper
loginFields: [ // a list of login field required by this scraper
'' // the name of the field
]
}
}
```## Two-Factor Authentication Scrapers
Some companies require two-factor authentication, and as such the scraper cannot be fully automated. When using the relevant scrapers, you have two options:
1. Provide an async callback that knows how to retrieve real time secrets like OTP codes.
2. When supported by the scraper - provide a "long term token". These are usually available if the financial provider only requires Two-Factor authentication periodically, and not on every login. You can retrieve your long term token from the relevant credit/banking app using reverse engineering and a MITM proxy, or use helper functions that are provided by some Two-Factor Auth scrapers (e.g. OneZero).```node
import { CompanyTypes, createScraper } from 'israeli-bank-scrapers';
import { prompt } from 'enquirer';// Option 1 - Provide a callback
const result = await scraper.login({
email: relevantAccount.credentials.email,
password: relevantAccount.credentials.password,
phoneNumber,
otpCodeRetriever: async () => {
let otpCode;
while (!otpCode) {
otpCode = await questions('OTP Code?');
}return otpCode[0];
}
});// Option 2 - Retrieve a long term otp token (OneZero)
await scraper.triggerTwoFactorAuth(phoneNumber);// OTP is sent, retrieve it somehow
const otpCode='...';const result = scraper.getLongTermTwoFactorToken(otpCode);
/*
result = {
success: true;
longTermTwoFactorAuthToken: 'eyJraWQiOiJiNzU3OGM5Yy0wM2YyLTRkMzktYjBm...';
}
*/
```# Getting deployed version of latest changes in master
This library is deployed automatically to NPM with any change merged into the master branch.# `Israeli-bank-scrapers-core` library
> TL;DR this is the same library as the default library. The only difference is that it is using `puppeteer-core` instead of `puppeteer` which is useful if you are using frameworks like Electron to pack your application.
>
> In most cases you will probably want to use the default library (read [Getting Started](#getting-started) section).Israeli bank scrapers library is published twice:
1. [israeli-bank-scrapers](https://www.npmjs.com/package/israeli-bank-scrapers) - the default variation, great for common usage as node dependency in server application or cli.
2. [israeli-bank-scrapers-core](https://www.npmjs.com/package/israeli-bank-scrapers-core) - extremely useful for applications that bundle `node_modules` like Electron applications.
## Differences between default and core variations
The default variation [israeli-bank-scrapers](https://www.npmjs.com/package/israeli-bank-scrapers) is using [puppeteer](https://www.npmjs.com/package/puppeteer) which handles the installation of local chroumium on its' own. This behavior is very handy since it takes care on all the hard work figuring which chromium to download and manage the actual download process. As a side effect it increases node_modules by several hundred megabytes.
The core variation [israeli-bank-scrapers-core](https://www.npmjs.com/package/israeli-bank-scrapers-core) is using [puppeteer-core](https://www.npmjs.com/package/puppeteer-core) which is exactly the same library as `puppeteer` except that it doesn't download chromium when installed by npm. It is up to you to make sure the specific version of chromium is installed locally and provide a path to that version. It is useful in Electron applications since it doesn't bloat the size of the application and you can provide a much friendlier experience like loading the application and download it later when needed.
To install `israeli-bank-scrapers-core`:
```sh
npm install israeli-bank-scrapers-core --save
```## Getting chromium version used by puppeteer-core
When using the `israeli-bank-scrapers-core` it is up to you to make sure the relevant chromium version exists. You must:
1. query for the specific chromium revision required by the `puppeteer-core` library being used.
2. make sure that you have local version of that revision.
3. provide an absolute path to `israeli-bank-scrapers-core` scrapers.Please read the following to learn more about the process:
1. To get the required chromium revision use the following code:
```
import { getPuppeteerConfig } from 'israeli-bank-scrapers-core';const chromiumVersion = getPuppeteerConfig().chromiumRevision;
```2. Once you have the chromium revision, you can either download it manually or use other liraries like [download-chromium](https://www.npmjs.com/package/download-chromium) to fetch that version. The mentioned library is very handy as it caches the download and provide useful helpers like download progress information.
3. provide the path to chromium to the library using the option key `executablePath`.# Specific definitions per scraper
## Bank Hapoalim scraper
This scraper expects the following credentials object:
```node
const credentials = {
userCode: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Bank Leumi scraper
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Discount scraper
This scraper expects the following credentials object:
```node
const credentials = {
id: ,
password: ,
num:
};
```
This scraper supports fetching transaction from up to one year (minus 1 day).## Mercantile scraper
This scraper expects the following credentials object:
```node
const credentials = {
id: ,
password: ,
num:
};
```
This scraper supports fetching transaction from up to one year (minus 1 day).### Known Limitations
- Missing memo field## Mizrahi scraper
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Beinleumi & Massad
These scrapers are essentially identical and expect the following credentials object:
```node
const credentials = {
username: ,
password:
};
```## Bank Otsar Hahayal scraper
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Visa Cal scraper
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Max scraper (Formerly Leumi-Card)
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password:
};
```
This scraper supports fetching transaction from up to one year.## Isracard scraper
This scraper expects the following credentials object:
```node
const credentials = {
id: ,
card6Digits: <6 last digits of card>
password:
};
```
This scraper supports fetching transaction from up to one year.## Amex scraper
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
card6Digits: <6 last digits of card>
password:
};
```
This scraper supports fetching transaction from up to one year.## Yahav
This scraper expects the following credentials object:
```node
const credentials = {
username: ,
password: ,
nationalID:
};
```
This scraper supports fetching transaction from up to six months.## Beyhad Bishvilha
This scraper expects the following credentials object::
```node
const credentials = {
id: ,
password:
};
```# Known projects
These are the projects known to be using this module:
- [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)
- [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
- [Caspion](https://github.com/brafdlog/caspion) - An app for automatically sending transactions from Israeli banks and credit cards to budget tracking apps
- [Finance Notifier](https://github.com/LiranBri/finance-notifier) - A simple script with the ability to send custom financial alerts to multiple contacts and platforms
- [Moneyman](https://github.com/daniel-hauser/moneyman) - Automatically save transactions from all major Israeli banks and credit card companies, using GitHub actions (or a self hosted docker image)
- [Firefly iii Importer](https://github.com/itairaz1/israeli-bank-firefly-importer) - A tool to import your banks data into [Firefly iii](https://www.firefly-iii.org/), a free and open source financial manager.Built something interesting you want to share here? [Let me know](https://goo.gl/forms/5Fb9JAjvzMIpmzqo2).
# License
The MIT License