Skip to main content

Paste a target-weights CSV, preview the rebalance, execute it on your brokerage account. Tastytrade + Alpaca + paper.

Project description

msts-trader

Paste a target-weights CSV, preview the rebalance, execute it on your own brokerage account. Multi-broker, local-only, no key custody.

$ msts-trader
Paste CSV (ticker,weight), then Ctrl+D:
ticker,weight
SPY,0.42
GLD,0.18
SHV,0.20
EEM,0.20
^D
✓ loaded 4 targets.

tastytrade · account 5W******  ·  NAV $48,213.42  ·  cash $2,150.00  ·  BP $46,290.00
Market: open  ·  closes in 23 min

           Rebalance preview
┃ Symbol ┃ Current % ┃ Target % ┃   Δ $ ┃ Action                  ┃ Note ┃
┃ SPY    ┃    18.2%  ┃   42.0%  ┃ +$11k ┃ BUY  22.00 @ ~$521.34   ┃      ┃
┃ EEM    ┃    31.5%  ┃   20.0%  ┃  -$5k ┃ SELL 119.00 @ ~$47.21   ┃      ┃
...

Execute 4 orders on tastytrade? [y/N]: y
[1/4] SPY  BUY  22.00 @ MKT ...  ROUTED  id=4f8...

Done.  sent: 4  ·  failed: 0  ·  log: ~/.msts-trader/fills/

Supported brokers

Broker Status Auth Notes
Paper shipped local file $100k starting cash, no real fills
Tastytrade shipped OAuth refresh token indefinite token, BYO OAuth app
Alpaca shipped API key + secret paper or live, fractional supported
IBKR planned TWS / IB Gateway socket works with your local Gateway / Docker
Schwab planned OAuth2 PKCE 7-day refresh, browser callback

Open a GitHub issue if you want one bumped up the queue.

Install

pip install msts-trader

Python ≥3.11 required.

Install from source:

git clone https://github.com/markudevelop/msts-trader.git
cd msts-trader
pip install -e .

One-time setup

You provide your own broker credentials. They are stored in your OS keychain (macOS Keychain / Windows Credential Manager / libsecret on Linux) and never leave your machine.

Tastytrade

  1. Sign in at https://developer.tastytrade.comMy Apps
  2. Create an OAuth application — copy the provider secret
  3. Run their OAuth authorization flow to obtain a refresh token
  4. Look up your account number in the Tastytrade web dashboard (optional)
  5. Run:
msts-trader login --broker tastytrade

Alpaca

  1. Sign in at https://alpaca.markets (paper or live)
  2. Account → API keys → generate a new pair
  3. Run:
msts-trader login --broker alpaca

You choose paper vs live at login time.

Paper (offline simulator)

msts-trader login --broker paper

No real money, no broker connection. The book persists in ~/.msts-trader/paper_state.json between sessions. Reset any time with msts-trader paper-reset.

The first login you complete becomes the default broker. Override per command with --broker NAME, or change the default by logging in again.

Daily usage

  1. Get your CSV. Click Copy CSV on the supported weights site, or build your own:

    ticker,weight
    SPY,0.42
    GLD,0.18
    EEM,0.20
    SHV,0.20
    
    • weight is a fraction (0–1), not a percent.
    • Sum should be ≤ 1.0 (the remainder is held as cash).
    • Comments starting with # are ignored.
  2. Run:

msts-trader                       # uses default broker
msts-trader --broker alpaca       # explicit broker
  1. Paste the CSV, hit Ctrl+D (Ctrl+Z then Enter on Windows).
  2. Review the preview carefully.
  3. Type y to execute, anything else to cancel.

Useful flags

msts-trader rebalance --dry-run                       # preview only, never sends
msts-trader rebalance --yes                           # skip the confirm prompt
msts-trader rebalance --threshold 0.02                # tighter rebalance (default 4%)
msts-trader rebalance --csv-file targets.csv          # read from a file
msts-trader --broker paper rebalance --csv-file ...   # test against paper

Other commands

msts-trader status                  # NAV, positions, market status (default broker)
msts-trader --broker alpaca status  # other broker
msts-trader brokers                 # list supported + configured brokers
msts-trader logout --broker alpaca  # clear stored creds for one broker
msts-trader paper-reset             # reset paper book to starting cash
msts-trader --version

What it does

  • Parses your CSV into {ticker: target_weight}.
  • Pulls live NAV, cash, buying power, and current positions from your broker.
  • Quotes every relevant symbol via the broker's market-data API.
  • Computes the dollar delta per ticker, skips anything within the drift threshold (default 4% of NAV).
  • Sells tickers no longer in your targets.
  • Sizes buys at the current quote, rounded to 2 decimals where the broker supports fractional MARKET orders.
  • Shows the full plan and waits for y before sending anything.
  • Submits MARKET DAY orders. Logs results to ~/.msts-trader/fills/.

What it does NOT do (v0.2)

  • Pre-market or after-hours execution. Refuses outside 09:30–16:00 ET.
  • Shorting. Negative weights are rejected.
  • Options, futures, crypto.
  • Multi-account or per-strategy ledger.
  • Active stop management (Hydra/Fusion-style watchers).
  • Automatic CSV polling. You paste each rebalance manually.

Security

  • Your broker credentials live only in your OS keychain on your own machine. The app does not phone home, does not log credentials, and is not connected to any service operated by the author.
  • The author of this app cannot view, recover, or revoke your broker access. Revoke via your own broker's API-app dashboard if a key leaks.
  • Trades are user-initiated: every execution requires you to paste a CSV and confirm with y. There is no background trading loop.

Disclaimer

This tool sends real orders to your live brokerage account. You are responsible for the CSV you paste and the rebalance you confirm. Past performance of any signal source is not indicative of future results. The author makes no warranty of any kind; use at your own risk.

License

PolyForm Noncommercial License 1.0.0.

You may use, modify, and share this software for any noncommercial purpose — personal trading, research, education, hobby projects. Selling, hosting as a paid service, or otherwise commercializing this software or derivative works is not permitted without a separate commercial license. Contact the author if you need one.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

msts_trader-0.2.0.tar.gz (24.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

msts_trader-0.2.0-py3-none-any.whl (26.0 kB view details)

Uploaded Python 3

File details

Details for the file msts_trader-0.2.0.tar.gz.

File metadata

  • Download URL: msts_trader-0.2.0.tar.gz
  • Upload date:
  • Size: 24.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for msts_trader-0.2.0.tar.gz
Algorithm Hash digest
SHA256 bd41f22106355ce53b4b4cb6a35ceb2cc2df4022ac0de00cd304a98ba907bf44
MD5 8a3399b591f67ea66e157e9e141261ff
BLAKE2b-256 c7a38d6eb52ff088c6574a41a5f10f585442375f11669e6e0eea41cc2cf56353

See more details on using hashes here.

Provenance

The following attestation bundles were made for msts_trader-0.2.0.tar.gz:

Publisher: release.yml on markudevelop/msts-trader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file msts_trader-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: msts_trader-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 26.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for msts_trader-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 59af133ae6f67b12102baacdfff70600b95f9a8c0950cf4ad52f5cc5338856a2
MD5 0edf6df8a320c6ccacf2caa7aea765c7
BLAKE2b-256 94e71311475e3acb2da281f9464c710df015f3dbb03845c24239bdea40366a70

See more details on using hashes here.

Provenance

The following attestation bundles were made for msts_trader-0.2.0-py3-none-any.whl:

Publisher: release.yml on markudevelop/msts-trader

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page