Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nelsondane/auto-rsa
A Discord bot and CLI tool for automating Reverse Split Arbitrage stock trading!
https://github.com/nelsondane/auto-rsa
api arbitrage auto-trading automation bot bot-trading brokerage discord finance multiple-accounts pip python python3 reverse reverse-split rsa split stock-market stocks trading
Last synced: 1 day ago
JSON representation
A Discord bot and CLI tool for automating Reverse Split Arbitrage stock trading!
- Host: GitHub
- URL: https://github.com/nelsondane/auto-rsa
- Owner: NelsonDane
- License: gpl-3.0
- Created: 2022-07-23T17:55:07.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2025-01-15T15:20:07.000Z (7 days ago)
- Last Synced: 2025-01-15T19:46:46.847Z (6 days ago)
- Topics: api, arbitrage, auto-trading, automation, bot, bot-trading, brokerage, discord, finance, multiple-accounts, pip, python, python3, reverse, reverse-split, rsa, split, stock-market, stocks, trading
- Language: Python
- Homepage:
- Size: 1.84 MB
- Stars: 67
- Watchers: 10
- Forks: 45
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# β¨ AutoRSA β¨
## Discord Bot and CLI Tool
A CLI tool and Discord bot to buy, sell, and monitor holdings across multiple brokerage accounts!
This program uses APIs to interface with your brokerages. When available, official APIs are always used. If an official API is not available, then a third-party API is used. As a last resort, Selenium or Playwright Stealth are used to automate the browser.
## DISCLAIMER π³
DISCLAIMER: I am not a financial advisor and not affiliated with any of the brokerages listed below. Use this tool at your own risk. I am not responsible for any losses or damages you may incur by using this project. This tool is provided as-is with no warranty.## Having an Issue? π€
I am not responding to issues on this repository. If you have an issue, please Sponsor me below and I will help you directly on Discord (for Sponsors and Contributors only).[![Sponsor](https://img.shields.io/badge/sponsor-30363D?style=for-the-badge&logo=GitHub-Sponsors&logoColor=#white)](https://github.com/sponsors/NelsonDane)
[![ko-fi](https://img.shields.io/badge/Ko--fi-F16061?style=for-the-badge&logo=ko-fi&logoColor=white
)](https://ko-fi.com/X8X6LFCI0)However, if you fix the issue yourself, please submit a pull request and I will review it.
## Installation π
There are two ways to use this program: as a Discord bot or as a CLI tool. The setup instructions will be a little different depending on which method you choose. However, both methods require the same pre-setup steps, and the same `.env` file format.### Pre-Setup π οΈ
1. Install `git` for your operating system.
2. Clone this repository and cd into it:
```bash
git clone https://github.com/NelsonDane/auto-rsa.git
cd auto-rsa
```
3. Copy the `.env.example` file to a new file called `.env`:
#### MacOS & Linux
```bash
cp .env.example .env
```
#### Windows
```powershell
copy .env.example .env
```
4. Fill in the `.env` file with your brokerage credentials. See the [Supported Brokerages](#-supported-brokerages-) section for more information.Now follow the instructions for either the Discord Bot or CLI Tool. Once setup is complete, see the [Usage](#-usage-) section for how to use the program.
### Discord Bot Installation π€
To create your Discord bot and get your `DISCORD_TOKEN` for your `.env`, follow this [guide](guides/discordBot.md).There are two ways to run the Discord bot: using Docker or running the Python script. When running the bot using the Python script, the bot will only be online when the script is running. With Docker, the bot will run in the background, restarting and updating automatically.
### Discord Bot: Docker π³
1. Add `DISCORD_TOKEN` and `DISCORD_CHANNEL` to your `.env` file.
2. Create the container using the provided [docker-compose.yml](docker-compose.yml) file:
```bash
docker compose up -d
```
3. The bot should appear online in Discord (You can also do `!ping` to check).Docker Note: If you make any changes to your `.env` file, you will need to restart the container by running `docker-compose up -d` again. The bot will also automatically stay up to date thanks to the included [Watchtower](https://containrrr.dev/watchtower/).
### Discord Bot: Python Script πββοΈ
1. Install Python 3.10 or higher
2. Create a Python virtual environment:
```bash
python -m venv autorsa-venv
```
3. Activate the virtual environment:
#### MacOS & Linux
```bash
source ./autorsa-venv/bin/activate
```
#### Windows
```powershell
.\autorsa-venv\Scripts\activate
```
You should see `(autorsa-venv)` in your terminal prompt now. You will need to activate this virtual environment every time you close and reopen your terminal.4. Install the required packages:
```bash
pip install -r requirements.txt
```
5. Install Playwright's dependencies:
```bash
playwright install
```
6. Add `DISCORD_TOKEN` and `DISCORD_CHANNEL` to your `.env` file.
7. Start the bot using the following command:
```bash
python autoRSA.py discord
```
8. The bot should appear online in Discord (You can also do `!ping` to check).### CLI Tool Installation π»
To run the CLI tool, follow these steps:
1. Install Python 3.10 or higher
2. Create a Python virtual environment:
```bash
python -m venv autorsa-venv
```
3. Activate the virtual environment:
#### MacOS & Linux
```bash
source ./autorsa-venv/bin/activate
```
#### Windows
```powershell
.\autorsa-venv\Scripts\activate
```
You should see `(autorsa-venv)` in your terminal prompt now. You will need to activate this virtual environment every time you close and reopen your terminal.4. Install the required packages:
```bash
pip install -r requirements.txt
```
5. Run the script using `python autoRSA.py`. It should say that no arguments were given, then exit. This is expected, and means everything was installed and set up correctly.## Usage π
To buy and sell stocks, use this command:
` `
(Parameter explanation below)
For example, to buy 1 AAPL in all accounts:
` buy 1 AAPL all false`
For a dry run of the above command in Robinhood only:
` buy 1 AAPL robinhood true`
For a real run on Fidelity and Robinhood, but not Schwab:
` buy 1 AAPL fidelity,robinhood not schwab false`
For a real run on Fidelity and Robinhood but not Schwab buying both AAPL and GOOG:
` buy 1 AAPL,GOOG fidelity,robinhood not schwab false`
To check your account holdings:
` holdings `
For example, to check your account holdings on Chase and Vanguard, but not Robinhood:
` holdings chase,vanguard not robinhood`
To restart the Discord bot:
`!restart` (without appending `!rsa` or prefix)
For help:
`!help` (without appending `!rsa` or prefix)
### Parameters Explanation βοΈ
- ``: string, The prefix for the command. For the Discord bot, this is `!rsa`. For the CLI tool, this is `python autoRSA.py`.
- ``: string, "buy" or "sell"
- ``: integer, Amount to buy or sell.
- ``: string, The stock ticker to buy or sell. Separate multiple tickers with commas and no spaces.
- ``: string, What brokerage to run command in (robinhood, schwab, etc, or all). Separate multiple brokerages with commas and no spaces.
- ``: string proceeding `not`, What brokerages to exclude from command. Separate multiple brokerages with commas and no spaces.
- ``: boolean, Whether to run in `dry` mode (in which no transactions are made. Useful for testing). Set to `True`, `False`, or just write `dry` for`True`. Defaults to `True`, so if you want to run a real transaction, you must set this explicitly.Note: There are two special keywords you can use when specifying accounts: `all` and `day1`. `all` will use every account that you have set up. `day1` will use "day 1" brokers, which are:
- BBAE
- Chase
- DSPAC
- Fennel
- Firstrade
- Public
- Schwab
- SoFi
- Tastytrade
- Tradier
- WebullThis is useful for brokers that provide quick turnaround times, hence the nickname "day 1".
A couple other keywords that can be used:
- `most`: will use every account you have setup except for vanguard.
- `fast`: will use every "day 1" broker + robinhood.## πΊοΈ Other Guides πΊοΈ
More detailed guides for some of the difficult setups:
- [Discord Bot Setup](guides/discordBot.md)
- [Robinhood 2FA Setup](guides/robinhoodSetup.md)
- [Schwab 2FA Setup](guides/schwabSetup.md)## Supported brokerages π
All brokers: separate account credentials with a colon (":"). For example, `SCHWAB_USERNAME:SCHWAB_PASSWORD`. Separate multiple logins with the same broker with a comma (","). For example, `SCHWAB_USERNAME:SCHWAB_PASSWORD,SCHWAB_USERNAME2:SCHWAB_PASSWORD2`.
Some brokerages require `Playwright` to run. On Windows, the `playwright install` command might not be recognized. If this is the case, run `python -m playwright install` instead.
#### BBAE
Made by [ImNotOssy](https://github.com/ImNotOssy) using the [BBAE_investing_API](https://github.com/ImNotOssy/BBAE_investing_API). Go give them a β
- `BBAE_USERNAME`
- `BBAE_PASSWORD`
`.env` file format:
- `BBAE=BBAE_USERNAME:BBAE_PASSWORD`Note: `BBAE_USERNAME` can either be email or phone number.
#### Chase
Made by [MaxxRK](https://github.com/MaxxRK/) using the [chaseinvest-api](https://github.com/MaxxRK/chaseinvest-api). Go give them a β
- `CHASE_USERNAME`
- `CHASE_PASSWORD`
- `CELL_PHONE_LAST_FOUR`
Optional .env variables:
- `DEBUG` (Set to `True` to enable debug mode)``.env` file format:
- `CHASE=CHASE_USERNAME:CHASE_PASSWORD:CELL_PHONE_LAST_FOUR:DEBUG`Note 1: Chase MUST be set to "classic trading experience". In order to do so navigate to `Trade` > `Stocks & ETFs` > click on a `trading account` > then click on `Switch back to classic trading experience`.
#### DSPAC
Made by [ImNotOssy](https://github.com/ImNotOssy) using the [dSPAC_investing_api](https://github.com/ImNotOssy/dSPAC_investing_API). Go give them a β
- `DSPAC_USERNAME`
- `DSPAC_PASSWORD`
`.env` file format:
- `DSPAC=DSPAC_USERNAME:DSPAC_PASSWORD`Note: `DSPAC_USERNAME` can either be email or phone number.
### Fennel
Made by yours truly using the [fennel-invest-api](https://github.com/NelsonDane/fennel-invest-api). Consider giving me a βRequired `.env` variables:
- `FENNEL_EMAIL``.env` file format:
- `FENNEL=FENNEL_EMAIL`Fennel accounts don't have passwords, so you need to login by inputting the code sent to your email. The script will then save your session credentials for future use.
### Fidelity
Made by [kennyboy106](https://github.com/kennyboy106) using the [fidelity-api](https://github.com/kennyboy106/fidelity-api). Go give them a βRequired `.env` variables:
- `FIDELITY_USERNAME`
- `FIDELITY_PASSWORD`
- `FIDELITY_TOTP` (If 2fa enabled, else NA)`.env` file format:
- `FIDELITY=FIDELITY_USERNAME:FIDELITY_PASSWORD:FIDELITY_TOTP`### Firstrade
Made by [MaxxRK](https://github.com/MaxxRK/) using the [firstrade-api](https://github.com/MaxxRK/firstrade-api). Go give them a βRequired `.env` variables:
- `FIRSTRADE_USERNAME`
- `FIRSTRADE_PASSWORD`
- `FIRSTRADE_OTP``.env` file format:
- `FIRSTRADE=FIRSTRADE_USERNAME:FIRSTRADE_PASSWORD:FIRSTRADE_OTP`- Note: You may now use any firstrade supported 2fa method, including pin, SMS, Email, or an Authenticator. Place any ONE of the below in the `FIRSTRADE_OTP` field:
- Pin: Use the login pin you created when setting up the account.
- Phone: Enter your 10 digit phone number with no spaces. I.E. 1234567890
- Email: Enter your full email address. I.E. [email protected]
- Authenticator: Use the code generated by Firstrade when adding an authenticator. Click on "Can't scan it?" to get the code.If you get errors after upgrading, try clearing your cookies in the `creds` folder and then trying again.
### Public
Made by yours truly using using [public-invest-api](https://github.com/NelsonDane/public-invest-api). Consider giving me a βRequired `.env` variables:
- `PUBLIC_USERNAME`
- `PUBLIC_PASSWORD``.env` file format:
- `PUBLIC_BROKER=PUBLIC_USERNAME:PUBLIC_PASSWORD`Note: Because Windows already has a `PUBLIC` environment variable, you will need to use `PUBLIC_BROKER` instead.
### Robinhood
Made using [robin_stocks](https://github.com/jmfernandes/robin_stocks). Go give them a βRequired `.env` variables:
- `ROBINHOOD_USERNAME`
- `ROBINHOOD_PASSWORD`
- `ROBINHOOD_TOTP` (If 2fa enabled, else NA)`.env` file format:
- With 2fa: `ROBINHOOD=ROBINHOOD_USERNAME:ROBINHOOD_PASSWORD:ROBINHOOD_TOTP`
- Without 2fa: `ROBINHOOD=ROBINHOOD_USERNAME:ROBINHOOD_PASSWORD:NA`Configuring 2fa can be tricky, so follow this [guide](guides/robinhoodSetup.md).
Note: Robinhood saves token cookies in the `creds` folder. These take precedence over the username/password set in the `.env` file. If you want to change accounts, you will need to delete the cookies in the `creds` folder for it to update.
### Schwab
Made using the [schwab-api](https://github.com/itsjafer/schwab-api). Go give them a βRequired `.env` variables:
- `SCHWAB_USERNAME`
- `SCHWAB_PASSWORD`
- `SCHWAB_TOTP_SECRET` (If 2fa is enabled, else NA)Optional `.env` variables:
- `SCHWAB_ACCOUNT_NUMBERS=ACCOUNT#1:ACCOUNT#2` (Optional, to specify the single account numbers the bot should use when buying. If not specified, all accounts will be used)`.env` file format:
- With 2fa: `SCHWAB=SCHWAB_USERNAME:SCHWAB_PASSWORD:SCHWAB_TOTP_SECRET`
- Without 2fa: `SCHWAB=SCHWAB_USERNAME:SCHWAB_PASSWORD:NA`To get your TOTP secret, follow this [guide](guides/schwabSetup.md).
Note 1: Think or Swim must be enabled on all accounts. To enable, go to `Trade` > `Trading Platforms` > `Learn how to enable thinkorswim`. Then press `Continue` and expand the `thinkorswim Access Agreement` and accept it. Then press `Continue` again. Then select the checkbox for all available accounts and press `Submit`. It may take a day or two for the accounts to be enabled.
### SoFi
Made by [ImNotOssy](https://github.com/ImNotOssy) using Playwright. Go give them a βRequired `.env` variables:
- `SOFI_USERNAME`
- `SOFI_PASSWORD`
Optional `.env` variables:
- `SOFI_TOTP_SECRET` (Optional, leave blank if not needed)`.env` file format:
- `SOFI=SOFI_USERNAME:SOFI_PASSWORD:SOFI_TOTP_SECRET`### Tornado
Made by [ImNotOssy](https://github.com/ImNotOssy) using Selenium. Go give them a βRequired `.env` variables:
- `TORNADO_EMAIL`
- `TORNADO_PASSWORD``.env` file format:
- `TORNADO=TORNADO_EMAIL:TORNADO_PASSWORD`### Tradier
Made by yours truly using the official [Tradier API](https://documentation.tradier.com/brokerage-api/trading/getting-started). Consider giving me a βRequired `.env` variables:
- `TRADIER_ACCESS_TOKEN``.env` file format:
- `TRADIER=TRADIER_ACCESS_TOKEN`To get your access token, go to your [Tradier API settings](https://dash.tradier.com/settings/api).
### Tastytrade
Made by [MaxxRK](https://github.com/MaxxRK/) using the [tastytrade-api](https://github.com/tastyware/tastytrade). Go give them a βRequired `.env` variables:
- `TASTYTRADE_USERNAME`
- `TASTYTRADE_PASSWORD``.env` file format:
- `TASTYTRADE=TASTYTRADE_USERNAME:TASTYTRADE_PASSWORD`### Webull
Made using the [webull](https://github.com/tedchou12/webull) library. Go give them a βRequired `.env` variables:
- `WEBULL_USERNAME`
- `WEBULL_PASSWORD`
- `WEBULL_DID`
- `WEBULL_TRADING_PIN``.env` file format:
- `WEBULL=WEBULL_USERNAME:WEBULL_PASSWORD:WEBULL_DID:WEBULL_TRADING_PIN`Your `WEBULL_USERNAME` can be your email or phone number. If using a phone number, it must be formatted as: +1-XXXXXXXXXX or +86-XXXXXXXXXXX.
To get your Webull DID, follow this [guide](https://github.com/tedchou12/webull/wiki/Workaround-for-Login-%E2%80%90-Method-2).
### Vanguard
Made by [MaxxRK](https://github.com/MaxxRK/) using the [vanguard-api](https://github.com/MaxxRK/vanguard-api). Go give them a βRequired `.env` variables:
- `VANGUARD_USERNAME`
- `VANGUARD_PASSWORD`
- `CELL_PHONE_LAST_FOUR`Optional `.env` variables:
- `DEBUG` (Set to `True` to enable debug mode, otherwise `False`)
- `VG_ACCOUNT_NUMBERS=ACCOUNT#1:ACCOUNT#2` (Optional, to specify the single account numbers the bot should use when buying. If not specified, all accounts will be used)`.env` file format:
- `VANGUARD=VANGUARD_USERNAME:VANGUARD_PASSWORD:PHONE_LAST_FOUR:DEBUG`### Wells Fargo
Made by [PZES](https://github.com/PZES) using Selenium. Go give them a βRequired `.env` variables:
- `WELLSFARGO_USERNAME`
- `WELLSFARGO_PASSWORD`
- `WELLSFARGO_PHONE_LAST_FOUR``.env` file format:
- `WELLSFARGO=WELLSFARGO_USERNAME:WELLSFARGO_PASSWORD:WELLSFARGO_PHONE_LAST_FOUR`