Skip to content

kevin1chun/robinhood-for-agents

robinhood-for-agents

CI npm version ClawHub License: MIT

Robinhood for AI agents — MCP server with 18 tools + TypeScript client library.

  • 18 MCP tools for any MCP-compatible AI agent
  • Unified trading skill for guided workflows (Claude Code, OpenClaw, ClawHub)
  • TypeScript client library (~50 async methods) for programmatic use
  • Pluggable token storage — OS keychain (default) or encrypted file (Docker/headless)

Compatible with Claude Code, Codex, OpenClaw, and any MCP-compatible agent.

Prerequisites

  • Bun v1.0+
  • Google Chrome (used by playwright-core for browser-based login — no bundled browser)
  • A Robinhood account

Quick Start

Guided setup (recommended)

# Requires Bun runtime — see Prerequisites
npx robinhood-for-agents onboard

The interactive setup detects your agent, registers the MCP server, installs skills (where supported), and walks you through Robinhood login. It handles both local and Docker deployments — just pick "This machine" or "Docker container / remote host" when prompted.

You can also specify your agent directly:

robinhood-for-agents onboard --agent claude-code
robinhood-for-agents onboard --agent codex
robinhood-for-agents onboard --agent openclaw

From source

git clone https://github.com/kevin1chun/robinhood-for-agents.git
cd robinhood-for-agents
bun install
bun run onboard

Manual setup

Claude Code
# Register MCP server (global — available in all projects)
claude mcp add -s user robinhood-for-agents -- bun run /path/to/bin/robinhood-for-agents.ts

# Install skills (per-project, optional)
cd your-project
robinhood-for-agents install --skills

Restart Claude Code to pick up the changes. Claude Code supports the unified trading skill in addition to the 18 MCP tools — see Skill.

Codex
codex mcp add robinhood-for-agents -- bun run /path/to/bin/robinhood-for-agents.ts

Restart Codex to pick up the changes. Codex uses all 18 MCP tools directly.

OpenClaw

Via ClawHub (recommended):

clawhub install robinhood-for-agents

Via onboard CLI:

robinhood-for-agents onboard --agent openclaw

Both install the unified robinhood-for-agents skill to ~/.openclaw/workspace/skills/. No MCP server required — the skill uses the TypeScript client API directly via bun.

Other MCP clients (Claude Desktop, etc.)

Add to your MCP client's config (e.g. ~/Library/Application Support/Claude/claude_desktop_config.json for Claude Desktop):

{
  "mcpServers": {
    "robinhood-for-agents": {
      "command": "bun",
      "args": ["run", "/absolute/path/to/robinhood-for-agents/bin/robinhood-for-agents.ts"]
    }
  }
}

Example

"Buy 1 50-delta SPX call expiring tomorrow"

SPX options chain with greeks and order summary

Authenticate

Start your agent and say "setup robinhood" (or call robinhood_browser_login directly). Chrome will open to the real Robinhood login page — log in with your credentials and MFA. The session is cached and auto-restores for ~24 hours.

MCP Tools (18)

All 18 tools work with every MCP-compatible agent.

Tool Description
robinhood_browser_login Authenticate via Chrome browser
robinhood_check_session Check if cached session is valid
robinhood_get_portfolio Portfolio: positions, P&L, equity, cash
robinhood_get_accounts List all brokerage accounts
robinhood_get_account Account details and profile
robinhood_get_stock_quote Stock quotes and fundamentals
robinhood_get_historicals OHLCV price history
robinhood_get_news News, analyst ratings, earnings
robinhood_get_movers Market movers and popular stocks
robinhood_get_options Options chain with greeks
robinhood_get_crypto Crypto quotes, history, positions
robinhood_place_stock_order Place stock orders (market/limit/stop/trailing)
robinhood_place_option_order Place option orders
robinhood_place_crypto_order Place crypto orders
robinhood_get_orders View order history
robinhood_cancel_order Cancel an order by ID
robinhood_get_order_status Get status of a specific order by ID
robinhood_search Search stocks or browse categories

Skill

A single unified skill (robinhood-for-agents) provides guided workflows for auth, portfolio, research, trading, and options. Available on ClawHub and supported by Claude Code and OpenClaw.

# Install via ClawHub
clawhub install robinhood-for-agents
Domain Example Triggers
Setup "setup robinhood", "connect to robinhood"
Portfolio "show my portfolio", "my holdings"
Research "research AAPL", "analyze TSLA"
Trading "buy 10 AAPL", "sell my position"
Options "show AAPL options", "SPX calls"

Dual-mode: The skill works with MCP tools (Claude Code) or standalone via the TypeScript client API and bun (OpenClaw, any agent with shell access). No MCP server required.

The skill uses progressive disclosure — SKILL.md is the compact router, with domain-specific files (portfolio.md, trade.md, etc.) and a full client-api.md reference loaded on demand.

Agent Compatibility

Feature Claude Code Codex OpenClaw Other MCP
18 MCP tools Yes Yes Yes
Trading skill Yes Yes
ClawHub install Yes
onboard setup Yes Yes Yes
Browser auth Yes Yes Yes Yes

Client Library (standalone)

import { RobinhoodClient } from "robinhood-for-agents";

const client = new RobinhoodClient();
await client.restoreSession();

const quotes = await client.getQuotes("AAPL");
const portfolio = await client.buildHoldings();

Docker / Headless Deployment

When deploying in Docker, headless servers, or cloud environments where no OS keychain is available, use the EncryptedFileTokenStore:

Setup

The guided setup handles Docker — pick "Docker container / remote host" when prompted:

npx robinhood-for-agents onboard

This will:

  1. Open Chrome for Robinhood login (on the host)
  2. Encrypt tokens and export to ./tokens.enc
  3. Print the encryption key and env vars to set in your container

Manual setup

# 1. Login on the host
npx robinhood-for-agents onboard

# 2. In your container, set env vars:
export ROBINHOOD_TOKENS_FILE=/path/to/tokens.enc
export ROBINHOOD_TOKEN_KEY=<base64-key-from-step-1>
# docker-compose.yml
services:
  agent:
    image: your-agent-image
    volumes:
      - ./tokens.enc:/app/tokens.enc:rw
    environment:
      ROBINHOOD_TOKENS_FILE: "/app/tokens.enc"
      ROBINHOOD_TOKEN_KEY: "${ROBINHOOD_TOKEN_KEY}"

Token refresh writes re-encrypted tokens back to the file automatically.

Security warning: The encrypted file protects against casual disk access (image leaks, accidental exposure) but NOT against a malicious agent with shell access in the container — it can read the env var and decrypt. Only run agents you trust. See docs/SECURITY.md for the full threat model.

Safety

  • Pluggable token storageKeychainTokenStore (OS keychain, default) or EncryptedFileTokenStore (AES-256-GCM, for Docker/headless). See SECURITY.md for the threat model.
  • Fund transfers and bank operations are blocked — never exposed
  • Bulk cancel operations are blocked
  • All order placements require explicit parameters (no dangerous defaults)
  • Skills always confirm with the user before placing orders
  • See ACCESS_CONTROLS.md for the full risk matrix

Authentication

Login: Call robinhood_browser_login (MCP) or say "setup robinhood" (skills) to open Chrome. Log in normally with your credentials and MFA. Playwright passively intercepts the OAuth token response — it never clicks buttons or fills forms.

Token storage uses pluggable TokenStore adapters:

Store When to use Config
KeychainTokenStore (default) Local dev, macOS/Linux with desktop Nothing — works out of the box
EncryptedFileTokenStore Docker, headless servers, CI, cloud Set ROBINHOOD_TOKENS_FILE + ROBINHOOD_TOKEN_KEY env vars
Direct accessToken Serverless, testing, short-lived scripts Pass accessToken to constructor or set ROBINHOOD_ACCESS_TOKEN env var

How it works: restoreSession() loads tokens from the configured TokenStore, injects Authorization: Bearer headers directly into API requests, and registers automatic token refresh on 401.

import { RobinhoodClient, EncryptedFileTokenStore } from "robinhood-for-agents";

// Default: KeychainTokenStore
const client = new RobinhoodClient();

// Docker/headless: EncryptedFileTokenStore (auto-detected from ROBINHOOD_TOKENS_FILE env)
const client = new RobinhoodClient({ tokenStore: new EncryptedFileTokenStore() });

// Direct token (no refresh)
const client = new RobinhoodClient({ accessToken: "..." });

See docs/ARCHITECTURE.md for the full auth flow and docs/SECURITY.md for the threat model.

Development

bun install                    # Install deps
bun run typecheck              # tsc --noEmit
bun run check                  # Biome lint + format
npx vitest run                 # Run all tests

Integration tests (verify local setup)

Integration tests hit the real Robinhood API (read-only). Use them to confirm your local dev environment is working end-to-end.

# 1. Login (opens Chrome — one-time)
robinhood-for-agents onboard

# 2. Run integration tests
bun run test:integration

These are excluded from CI and the default test commands since they require real credentials.

Architecture

See docs/ARCHITECTURE.md for full system design, authentication flow, HTTP pipeline, and exception hierarchy.

Contributing

See docs/CONTRIBUTING.md for how to add new tools, create skills, and run tests.

Disclaimer

This project is not affiliated with, endorsed by, or sponsored by Robinhood Markets, Inc. "Robinhood" is a trademark of Robinhood Markets, Inc. This software interacts with Robinhood's services through publicly accessible interfaces but is an independent, third-party tool.

USE AT YOUR OWN RISK. This software enables AI agents to read data from and place orders on your Robinhood brokerage account. Automated and AI-assisted trading carries inherent risks, including but not limited to:

  • Unintended order execution due to AI misinterpretation
  • Financial losses from erroneous trades
  • Stale or inaccurate market data
  • Software bugs or unexpected behavior

You are solely responsible for all activity on your brokerage account, whether initiated manually or through this software. The authors and contributors assume no liability for any financial losses, damages, or other consequences arising from the use of this software. Review all AI-proposed actions before confirming, and never grant unsupervised trading authority to any automated system.

This software is provided "as is" without warranty of any kind. See LICENSE for full terms.

License

MIT — see LICENSE.

About

AI-native tooling for robinhood integration

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Contributors