npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

etoro-mcp-server

v1.1.4

Published

MCP server wrapping the eToro public API

Readme

eToro MCP Server

Connect any MCP-compatible AI assistant (Claude, Cursor, and others) to your eToro account for portfolio analysis, market research, and trading.

CI Node.js TypeScript MCP SDK License: MIT

OverviewInstallationConfigurationTools


Overview

MCP server wrapping the eToro public API, exposing 35 tools for AI assistants (Claude Desktop, Cursor, Claude Code, etc.). Built for investment research and portfolio analysis — assess positions, research instruments and themes, vet popular investors for copy-trading, backtest DCA strategies against historical data. Trading is fully supported, but use care: letting an AI agent place real-money orders is genuinely risky, and you should treat it as such.

What Can You Do With It?

The server is built around research workflows first. The examples below show real multi-tool conversations — the assistant chains several etoro_* calls together to answer a single question. Numbers are representative; actual responses draw from live eToro data.

1. Portfolio health check

The assistant calls etoro_get_portfolio to pull your open positions, then etoro_get_instruments to resolve instrument IDs to names and sectors, and etoro_get_rates for live prices. It assembles a full snapshot from the raw data.

You: How is my portfolio doing? Break it down by sector and flag any trouble spots.

Assistant: I pulled your portfolio (98 open positions), resolved each instrument, and fetched live rates. Here's the picture:

  • Cash: $22,265 • Invested: $45,782 • Positions: 98 open

Sector breakdown:

| Sector | % of invested | Top holdings | | --- | --- | --- | | Technology | 38% | GOOG, META, MSFT, NVDA, AMZN | | ETFs & Index | 22% | VOO, QQQ, SOXX, ARGT, IEUR | | Crypto | 15% | BTC, ETH | | Healthcare | 10% | UNH | | Financials | 8% | SAP | | Other | 7% | LDO + others |

Trouble spot: Your tech sleeve is 38% of invested capital and concentrated in 5 mega-caps. A single sector drawdown hits hard — consider whether the ETF overlap (QQQ, SOXX) is intentional diversification or accidental doubling-down.

Tools used: etoro_get_portfolioetoro_get_instrumentsetoro_get_rates


2. Instrument research

Search is keyword-based — etoro_search_instruments finds instruments by ticker or company name, then you chain etoro_get_instruments for full details and etoro_get_candles for price history.

You: Pull up NVDA — I want the current price and a weekly chart for the last month.

Assistant: Searching for "NVDA" and pulling candle data:

  • NVIDIA Corporation (NVDA) — InstrumentID 1545
  • Live rate: Bid $208.14 / Ask $208.40
  • Exchange: NASDAQ • Type: Stock • Sector: Semiconductors

Weekly candles (last 5 weeks):

| Week of | Open | High | Low | Close | | --- | --- | --- | --- | --- | | Mar 22 | $172.65 | $181.20 | $167.01 | $167.61 | | Mar 29 | $165.26 | $177.47 | $162.95 | $176.72 | | Apr 5 | $176.12 | $189.98 | $173.66 | $188.53 | | Apr 12 | $184.15 | $201.69 | $183.98 | $201.64 | | Apr 19 | $199.02 | $210.92 | $197.23 | $208.26 |

NVDA rallied +27% off the March low ($162.95 → $208.26), with each weekly candle printing a higher low. Momentum is strong but the move is getting extended.

Tools used: etoro_search_instrumentsetoro_get_instrumentsetoro_get_ratesetoro_get_candles


3. Copy-trading due diligence

Vet popular investors using real public data. The assistant calls etoro_get_user_profile for identity and stats, then etoro_get_user_performance for the full yearly return history.

You: Vet user jeppekirkbonde for a long-term copy allocation. I want the honest risk picture.

Assistant: Here's what the data says on jeppekirkbonde:

  • Name: Jeppe Kirk Bonde • PI Level: 6 (highest tier)
  • Copiers: 25,000+ • AUM: $200M+
  • Background: MSc Finance, Copenhagen Business School

Year-by-year performance (real data):

| Year | Return | | Year | Return | | --- | --- | --- | --- | --- | | 2013 | +8.9% | | 2020 | +36.9% | | 2014 | −14.3% | | 2021 | +15.9% | | 2015 | +22.4% | | 2022 | −19.2% | | 2016 | +81.1% | | 2023 | +23.9% | | 2017 | +150.9% | | 2024 | +21.0% | | 2018 | −10.9% | | 2025 | +37.7% | | 2019 | +45.1% | | | |

Average annual return: +30.7% across 13 full years. Three down years (2014, 2018, 2022) with a max drawdown of −19.2% in the 2022 tech selloff.

What you should know:

  1. This is a concentrated, long-only US tech strategy. The +150.9% in 2017 and +81.1% in 2016 are outliers — don't expect those every year.
  2. Down years are real: 2022 cost −19.2%. If you can't stomach a 20% paper loss, this isn't the right copy.
  3. 25K+ copiers and $200M+ AUM means his moves have market impact in smaller names. Slippage is a factor.

Reasonable for multi-year capital if you accept the volatility. Not appropriate for money you need inside 18 months.

Tools used: etoro_get_user_profileetoro_get_user_performance


4. Watchlist management

The full watchlist lifecycle — create, populate, rename, and curate — all through natural language.

You: Create a "Semiconductor" watchlist and add NVDA, AMD, ASML, TSM, and AVGO to it.

Assistant: Done:

  1. Created watchlist "Semiconductor" (ID: 48291)
  2. Searched and resolved all 5 tickers to instrument IDs
  3. Added: NVDA (1545), AMD (2842), ASML (5765), TSM (3901), AVGO (6192)

Your watchlists now:

| Watchlist | Items | | --- | --- | | Recently Invested | 38 | | My Watchlist | 34 | | Stocks pre-screening | 69 | | ETFs | 54 | | Semiconductor ← new | 5 | | People & Smart Portfolios | 26 | | Crypto | 6 | | Commodities | 5 |

Tools used: etoro_create_watchlistetoro_search_instrumentsetoro_add_watchlist_itemsetoro_get_watchlists


5. DCA backtest with historical candles

Use etoro_get_candles to pull years of OHLCV data, then simulate a dollar-cost averaging strategy — no orders placed, pure research.

You: Backtest a $500/month DCA into QQQ over the last 3 years. What would I have today?

Assistant: Pulling weekly QQQ candles (156 weeks) and simulating $500 on the first trading day of each month:

  • Total invested: $18,000 (36 months × $500)
  • Units accumulated: ~38.2 QQQ
  • Current value: $25,365 (at $664.01/share)
  • Gain: +$7,365 (+40.9% on invested capital)
  • Approx. IRR: ~12.8%/year

Worst stretch: Nov 2022 – Mar 2023, paper drawdown of −22% on the accumulated stack. You bought through it — those discounted shares are now your biggest winners.

No orders placed. This is research only.

Tools used: etoro_get_candlesetoro_get_rates (for current price)


6. Macro-aware portfolio review

Combine portfolio data with the assistant's general knowledge to get a risk assessment tied to your actual holdings.

You: My portfolio is heavy on tech. Flag any risks from this week's macro calendar.

Assistant: Your tech exposure totals ~$17,400 (38% of invested capital) across GOOG, META, MSFT, NVDA, AMZN and the SOXX/QQQ ETFs. This week's watch-list:

  • Wed — CPI print (core consensus +0.3% MoM). A hot number re-prices rate-cut odds → tech multiples compress first.
  • Thu — Fed speakers (Williams, Waller). Hawkish language strengthens USD, pressuring mega-cap international revenue.
  • Fri — NVDA earnings (after close). Binary event for your largest single-stock position.

What this means for you:

  • A hot CPI + hawkish Fed combo could knock 3–5% off your tech sleeve short-term.
  • NVDA earnings will drive ~8% of your portfolio's week-over-week change. Know your thesis before it prints.

Tools used: etoro_get_portfolioetoro_get_instrumentsetoro_get_rates (+ assistant's macro knowledge)


⚠️ Letting an AI execute real-money trades is risky. The same natural-language interface that makes research fast also makes it easy to misinterpret intent — a typo, an ambiguous number, a stale context from earlier in the conversation. Mitigations: start in ETORO_TRADING_MODE=demo, use read-only API keys for anything that doesn't need write access, and require explicit confirmation in your conversation before any real order.

All examples above are research-only. When you're ready to execute, the same interface places orders. Orders always respect the configured ETORO_TRADING_MODE (demo for paper, real for live).

You: Buy $500 of NVDA at market.

Assistant: Confirmed — opening a market position:

  • Instrument: NVDA (1545)
  • Amount: $500
  • Rate: $208.40 (ask)
  • Mode: demo

Position opened — ID 3418072. This is a demo trade, no real money involved.

Full trading coverage includes: open position by amount or units (etoro_open_position), close or partially close (etoro_close_position), limit/entry orders (etoro_place_limit_order), cancel pending orders (etoro_cancel_order), and listing pending orders (etoro_get_orders).


Composing with Other MCP Servers

MCP servers are designed to be composed. The eToro server handles portfolio data, live rates, candles, and trading — but an AI assistant can call tools from multiple servers in a single conversation, filling in the gaps that no single API covers.

Example: earnings risk check across two servers

With eToro + a financial data server (e.g. Financial Datasets, Alpha Vantage, or similar):

You: Do any of my open positions have earnings this week? Flag the ones I should watch.

Assistant: Pulling your portfolio from eToro (98 positions), then checking the earnings calendar:

  • NVDA — reports Thursday after close. Your position: $4,200 (9.2% of invested). This is a binary event — expect ±8% move.
  • GOOGL — reports Tuesday after close. Your position: $3,100 (6.8%). Consensus is +12% YoY revenue; ad revenue mix is the swing factor.
  • UNH — reported Monday pre-market (already priced in). Beat on EPS, slight miss on membership growth.

The rest of your holdings have no earnings this week. Your biggest event risk is NVDA Thursday — it's your largest single-stock position.

This isn't possible with the eToro server alone — it knows your positions but not the earnings calendar. The financial data server knows the calendar but not your portfolio. Together, the assistant connects both.

Natural pairings

| Pair with | What it adds | Example workflow | | --- | --- | --- | | Research & ratings (Morningstar) | Analyst research, fair value estimates, moat ratings, fund data | "What's Morningstar's fair value for my tech holdings?" — pull portfolio, fetch ratings | | News & web search (Brave Search, Tavily) | Breaking news, sentiment, event context | "Any news on my holdings today?" — pull portfolio, search each ticker | | Financial data (Financial Datasets, Alpha Vantage) | Fundamentals, earnings, SEC filings, economic calendar | "Show me P/E ratios for my tech positions" — pull holdings, fetch fundamentals | | Market data (Polygon.io, Twelve Data, Massive) | Real-time streaming, options chains, screener universes | "Screen the S&P 500 for momentum setups, then add the top 5 to my watchlist" | | Free alternative (Yahoo Finance) | Prices, financials, options, market news (no API key needed) | "Compare earnings growth for NVDA vs AMD over the last 4 quarters" |

Configuration

Just add multiple servers to your MCP config — the assistant sees all tools from all servers:

{
  "mcpServers": {
    "etoro": {
      "command": "npx",
      "args": ["-y", "etoro-mcp-server"],
      "env": {
        "ETORO_API_KEY": "your-api-key",
        "ETORO_USER_KEY": "your-user-key",
        "ETORO_TRADING_MODE": "demo"
      }
    },
    "financial-data": {
      "command": "npx",
      "args": ["-y", "financial-datasets-mcp-server"],
      "env": {
        "FINANCIAL_DATASETS_API_KEY": "your-key"
      }
    },
    "news": {
      "command": "npx",
      "args": ["-y", "tavily-mcp-server"],
      "env": {
        "TAVILY_API_KEY": "your-key"
      }
    }
  }
}

The assistant will automatically chain tools across servers when a question requires it — no extra wiring needed.


Installation

Claude Desktop (recommended)

Download the latest .mcpb file from the Releases page and drag it into Claude Desktop:

Extensions → drag etoro-{version}.mcpb into the window

You'll be prompted for your API Key, User Key, and trading mode. That's it.

[!TIP] Get your keys at eToro → Settings → Trading → Create New Key. Choose your environment (Demo or Real) and the permissions you need (Read or Write).


Via npm (Claude Code, Cursor, Continue, Cody, …)

Add this to your client's MCP config — it'll launch the server from the published npm package on demand, no local install needed:

{
  "mcpServers": {
    "etoro": {
      "command": "npx",
      "args": ["-y", "etoro-mcp-server"],
      "env": {
        "ETORO_API_KEY": "your-api-key",
        "ETORO_USER_KEY": "your-user-key",
        "ETORO_TRADING_MODE": "demo"
      }
    }
  }
}

For Claude Code, the equivalent CLI command:

claude mcp add etoro \
  -e ETORO_API_KEY=your-api-key \
  -e ETORO_USER_KEY=your-user-key \
  -e ETORO_TRADING_MODE=demo \
  -- npx -y etoro-mcp-server

Pin a specific version with [email protected] in the args if you want stability over auto-updates.


From source (developers)

If you want to hack on the server locally, clone the repo and build:

npm install
npm run build

Then point your MCP client at the built file (dist/index.js):

claude mcp add etoro-mcp \
  -e ETORO_API_KEY=your-api-key \
  -e ETORO_USER_KEY=your-user-key \
  -e ETORO_TRADING_MODE=demo \
  -- node /path/to/etoro-mcp/dist/index.js

Or in claude_desktop_config.json / equivalent:

{
  "mcpServers": {
    "etoro-mcp": {
      "command": "node",
      "args": ["/path/to/etoro-mcp/dist/index.js"],
      "env": {
        "ETORO_API_KEY": "your-api-key",
        "ETORO_USER_KEY": "your-user-key",
        "ETORO_TRADING_MODE": "demo"
      }
    }
  }
}

MCP Registry

This server is listed on the MCP Registry under the name io.github.gabrielcerutti/etoro-mcp-server. The registry is the public index of MCP servers — think of it as a package registry for AI tools, analogous to what npm is for JavaScript libraries. MCP-compatible clients use it to discover and install servers programmatically without users having to hand-copy configuration.

Each tagged release of this repository is auto-published to the registry by GitHub Actions (via OIDC), so the entry always tracks the latest npm version.


Configuration

| Setting | Env var | CLI arg | Default | | --- | --- | --- | --- | | API Key | ETORO_API_KEY | --api-key | (none) | | User Key | ETORO_USER_KEY | --user-key | (none) | | Trading Mode | ETORO_TRADING_MODE | --trading-mode | demo |

Trading mode: demo routes all trading calls through eToro's virtual account. Set to real only when you're ready to trade with real money.

[!WARNING] trading_mode must match the environment of your API key. A demo key used with real mode (or vice versa) will cause authentication errors.


Tools (35 total)

All tools are prefixed with etoro_ for namespace isolation when composed with other MCP servers.

Market Data (8)

| Tool | Description | | --- | --- | | etoro_search_instruments | Search instruments by keyword (e.g. "AAPL", "Bitcoin") or exact ticker | | etoro_get_instruments | Get full instrument details by IDs (1–100) | | etoro_get_instrument_types | List all instrument types (stocks, crypto, ETFs…) | | etoro_get_industries | List industry classifications | | etoro_get_exchanges | List stock exchanges | | etoro_get_candles | Get OHLCV candle data for technical analysis and backtesting | | etoro_get_closing_prices | Get historical daily closing prices | | etoro_get_rates | Get live bid/ask rates |

Portfolio & Trading (7)

| Tool | Description | | --- | --- | | etoro_get_portfolio | Get portfolio + P&L: positions, unrealized P&L, exposure summary, longest holding | | etoro_get_orders | List all pending orders (limit / entry) | | etoro_get_trade_history | Closed-trade history (entry/exit, P&L, duration). Primary source for performance research | | etoro_open_position | Open position by USD amount or units (unified tool) | | etoro_close_position | Close an open position fully, or partially via unitsToDeduct | | etoro_place_limit_order | Place a limit / entry order | | etoro_cancel_order | Cancel a pending order |

User & Discovery (7)

| Tool | Description | | --- | --- | | etoro_get_current_user | Get the authenticated user's identity (GCID, real / demo CIDs) | | etoro_get_user_profile | Get a user's public profile | | etoro_get_user_performance | Get performance summary (optionally by time period) | | etoro_get_user_trades | Get a user's trade info for a period | | etoro_get_user_portfolio | Get a user's live public portfolio holdings | | etoro_discover_users | Discover popular investors filtered by gain, risk score, period | | etoro_get_copiers | Get info about users copying your portfolio |

Watchlists (9)

| Tool | Description | | --- | --- | | etoro_get_watchlists | List your watchlists | | etoro_create_watchlist | Create a watchlist | | etoro_delete_watchlist | Delete a watchlist | | etoro_rename_watchlist | Rename a watchlist | | etoro_add_watchlist_items | Add instruments to a watchlist | | etoro_remove_watchlist_item | Remove an instrument from a watchlist | | etoro_set_default_watchlist | Set default watchlist | | etoro_get_curated_lists | Get eToro's curated lists | | etoro_get_public_watchlists | Browse a user's public watchlists |

Social Feeds (4)

| Tool | Description | | --- | --- | | etoro_get_instrument_feed | Get social feed for an instrument | | etoro_get_user_feed | Get social feed for a user | | etoro_create_post | Create a social feed post | | etoro_create_comment | Comment on a post |


Disclaimer

This project is an unofficial, community-built integration. It is not affiliated with, endorsed by, or supported by eToro. Use it at your own risk.

  • Not financial advice. Nothing in this server, its documentation, or its example outputs constitutes investment advice, a recommendation, or a solicitation to buy or sell any financial instrument.
  • You are responsible for your trades. The server can place real-money orders when configured in real mode. Verify every order before confirming, and understand that AI assistants can misinterpret intent.
  • API changes may break things. This server depends on eToro's public API, which can change without notice. Always pin a version in production.
  • Demo first. Start with ETORO_TRADING_MODE=demo and only switch to real after you're confident in your setup.

Contributing

Contributions are welcome — bug reports, feature requests, and pull requests.

  1. Fork the repo and create a branch from main
  2. Run npm install && npm run build to verify your changes compile
  3. Run npm test to make sure existing tests pass
  4. Open a PR with a clear description of what changed and why

License

MIT — use it, fork it, build on it.