t-invest-mcp
Enables natural language interaction with your T-Invest brokerage account for portfolio analysis, dividend tracking, and optional trading with safety confirmations.
README
t-invest-mcp
Твой портфель Т-Инвестиций — в диалоге с AI.
MCP-сервер, который подключает Claude (Claude Code, Claude Desktop — и любой другой MCP-клиент) к T-Invest API. Смотри портфель, анализируй бумаги, считай выплаты и ребалансировку — обычными фразами, на русском.

Это не торговый робот и не «сигналы». Решения всегда принимаешь ты — сервер лишь даёт модели безопасный доступ к данным твоего брокерского счёта.
Почему это безопасно
- Read-only по умолчанию. Торговые операции даже не регистрируются, пока ты их явно не включишь. Достаточно токена «только чтение».
- Сделки — только с твоего подтверждения. Если включишь торговлю, перед каждой заявкой сервер показывает диалог «Купить N лотов X?» — без явного «да» заявка не уйдёт, какими бы настройками ни пользовался агент.
- Песочница. Любую идею можно обкатать на виртуальном счёте с реальными котировками.
- Токен живёт только в переменной окружения — не в коде, не в конфиге, не в логах. Для продакшена держи его в системном keychain, а не в shell-профиле — рецепт в docs/secure-token.md.
Быстрый старт (5 минут)
Нужен Node.js ≥ 22 и аккаунт Т-Инвестиций.
-
Токен. В настройках Т-Инвестиций выпусти токен «только чтение». «Подтверждение сделок кодом» должно быть выключено. Токен показывается один раз; живёт 3 месяца с последнего использования.
-
Подключение к Claude Code — одной командой, установка не нужна (пакет
t-invest-mcpподтянется из npm):claude mcp add t-invest \ -e TINKOFF_API_TOKEN=<ваш-токен> \ -- npx -y t-invest-mcpДля Claude Desktop тот же блок добавляется в Settings → Developer → Edit Config. Этот JSON подходит и любому другому MCP-клиенту (Cursor, VS Code, Windsurf и др.) — меняется только место, куда его вписать:
{ "mcpServers": { "t-invest": { "command": "npx", "args": ["-y", "t-invest-mcp"], "env": { "TINKOFF_API_TOKEN": "<ваш-токен>" } } } }<details><summary>Вариант из исходников (для разработки)</summary>
git clone https://github.com/human-turn/t-invest-mcp && cd t-invest-mcp npm install && npm run build # далее в командах выше вместо "npx -y t-invest-mcp" → "node /path/to/t-invest-mcp/dist/index.js"</details>
В такой минимальной конфигурации сервер строго read-only: смотреть и анализировать можно всё, торговать — нельзя (торговые операции даже не регистрируются). Остальные возможности включаются переменными в
env— каждая выключена по умолчанию:Переменная Что включает TINKOFF_SANDBOX=trueПесочница: виртуальный счёт на реальных котировках — безопасная обкатка (нужен отдельный sandbox-токен) TINKOFF_ALLOW_TRADING=trueТорговля: выставление/отмена заявок, каждая сделка — с вашего подтверждения (нужен full-access токен) TINKOFF_OUTPUT_DIR=<путь>Куда складывать файловые выгрузки (по умолчанию — папка проекта) TINKOFF_CONFIRM=offОтключить диалог подтверждения сделок — только для песочницы -
Проверка: спроси «покажи мои счета и портфель».
Готовое из коробки: ритуалы

Не хочешь придумывать запросы — в сервер зашиты готовые рецепты. В Claude Code они
появляются как slash-команды /t-invest:<имя>:
| Ритуал | Что делает |
|---|---|
weekly [сумма] |
Дайджест недели: что выросло/упало и почему, события впереди; если указать сумму пополнения — план докупок |
monthly |
Итоги месяца: честная доходность (XIRR с учётом пополнений), выплаты, комиссии + календарь выплат |
quarterly |
Обзор портфеля + проверка, не пора ли ребалансировать |
И отдельные команды под конкретные задачи:
| Команда | Что делает |
|---|---|
portfolio_review |
Полный обзор: структура, концентрация, риски |
payout_calendar |
Купоны и дивиденды на N месяцев вперёд, средняя выплата в месяц |
bond_picker <сумма> <горизонт> |
Подбор облигаций: доходность с НКД, фильтр оферт, лесенка |
rebalance_check |
Дрейф от целевых долей + план сделок в лотах (без исполнения) |
invest_cash <сумма> |
Пришла зарплата: куда докупить, чтобы приблизиться к целям |
position_deep_dive <тикер> |
Разбор бумаги: фундаментал, прогнозы, выплаты, динамика |
tax_helper [год] |
Налоги за год + кандидаты на льготу долгосрочного владения |
div_screener [мин. %] |
Скрининг дивидендных акций MOEX |
monthly_report, weekly_digest, fire_progress |
Составные части ритуалов — можно вызывать отдельно |
feedback [тема] |
Что-то не работает? Соберёт репорт с диагностикой для разработчиков (без токена и личных данных) |
Все команды анализируют и предлагают — ни одна не совершает сделок сама.
Нашли проблему? /t-invest:feedback
Команда сама собирает репорт для разработчиков: диагностику сервера
(get_server_info — версия, режимы, окружение), шаги воспроизведения и точные
тексты ошибок из диалога. Перед сохранением покажет вам текст и спросит,
маскировать ли номера счетов и суммы — токен не попадает в репорт никогда.
Результат ложится в feedback/FEEDBACK-<дата>-<тема>.md; дальше по желанию —
GitHub issue в один шаг или отправьте файл сами.
Своя стратегия
Главное свойство сервера: он не навязывает методологию. Команды выше — это бонус, а не рамки. Под капотом — 20+ инструментов-кирпичиков (портфель, операции, котировки, купоны, фундаментал, прогнозы…), из которых модель собирает ответ на любой твой вопрос:
-
Просто спрашивай. «Какая у меня доля валютных активов?», «сравни мои нефтяные бумаги по P/E», «что будет с купонами, если продам половину ОФЗ?» — без всяких команд.
-
Опиши свои правила текстом. Положи свою стратегию в
CLAUDE.mdпроекта («не больше 10% на эмитента», «дивиденды реинвестирую в облигации», «новые позиции — только после разбора отчётности») — и агент будет учитывать её в каждом ответе. -
Целевые доли — если нужны. Файл
portfolio-target.jsonв корне проекта включает ребалансировку и план докупок. Минимум — только доли классов;byTickerи финансовые цели (goals) — опциональные надстройки. Эталон: MCP-ресурсt-invest://portfolio-target/example.{ "targets": { "shares": 55, "bonds": 30, "etf": 10, "cash": 5 } } -
Данные — в свои руки. Каждый инструмент умеет выгружать результат в файл (
outputPath, CSV/JSON) — сырые данные не съедают контекст диалога, а попадают на диск для pandas/Excel/чего угодно.get_operationsпри этом выкачивает всю историю операций,get_candles— годы свечей, аdownload_history_archiveзабирает минутки целыми годами (1 запрос = 1 год; доступные годы покажетget_history_archive_years). Дальше — любая своя аналитика: бэктесты, графики, отчёты.
Торговля (опционально, по умолчанию выключена)
Если хочешь не только анализировать, но и исполнять — включи явно:
TINKOFF_ALLOW_TRADING=true # регистрирует place_order / cancel_order
Понадобится full-access токен. Защита трёхслойная:
-
Подтверждение в самом сервере (включено по умолчанию): перед заявкой — диалог человеку через MCP elicitation; клиенты без поддержки elicitation получают отказ. Отключение —
TINKOFF_CONFIRM=off(рекомендуется только для песочницы). -
Ask-правила Claude Code (клиентский слой, срабатывает ещё до вызова):
{ "permissions": { "allow": ["mcp__t-invest"], "ask": ["mcp__t-invest__place_order", "mcp__t-invest__cancel_order"] } }Приоритет deny → ask → allow гарантирует промпт в любом режиме, включая
bypassPermissions. MCP tool annotations (destructiveHint) — лишь подсказки, Claude Code их не учитывает. -
Песочница для обкатки:
TINKOFF_API_TOKEN=<sandbox-токен> TINKOFF_SANDBOX=true TINKOFF_ALLOW_TRADING=trueСчета/портфель/заявки уходят в песочницу (виртуальные деньги, реальные котировки), появляются
sandbox_*инструменты. Попроси агента: «открой sandbox-счёт, положи миллион и собери модельный портфель 60/40».
Справочник
Переменные окружения
| Переменная | Значение | Описание |
|---|---|---|
TINKOFF_API_TOKEN |
обязательна | Токен T-Invest API (read-only достаточно для базового режима) |
TINKOFF_SANDBOX |
true/false |
Песочница: счета/портфель/заявки идут в sandbox, регистрируются sandbox_* tools. Нужен sandbox-токен |
TINKOFF_ALLOW_TRADING |
true/false |
Регистрирует place_order/cancel_order. В боевом режиме — реальные деньги! |
TINKOFF_CONFIRM |
off |
Отключает встроенное elicitation-подтверждение сделок (по умолчанию включено) |
TINKOFF_OUTPUT_DIR |
путь | Корень для файловых выгрузок outputPath (по умолчанию — cwd сервера, т.е. корень проекта) |
Tools
Read-only (всегда):
| Tool | Описание |
|---|---|
get_accounts |
Список брокерских счетов |
get_portfolio |
Портфель: суммы по классам активов, доходность, позиции с тикерами |
get_operations |
Операции (сделки, дивиденды, купоны, комиссии); с outputPath — вся история |
find_instrument |
Поиск инструмента по тикеру/ISIN/FIGI/названию |
get_instrument |
Карточка инструмента (лот, валюта, биржа, assetUid; для облигаций — номинал, погашение, НКД) |
get_last_prices |
Последние цены (батч), с признаком единицы котировки |
get_candles |
Свечи OHLCV (1min…month); с outputPath — весь период чанками |
get_order_book |
Стакан заявок |
get_dividends |
Дивиденды: история и анонсы |
get_bond_coupons |
Купонный календарь облигации |
get_accrued_interests |
НКД облигации |
get_bond_events |
События облигации: купоны, оферты, погашение |
get_asset_fundamentals |
Фундаментал: P/E, EV/EBITDA, ROE, долги, дивдоходность и др. |
get_forecasts |
Консенсус-прогнозы и таргеты аналитиков |
get_trading_schedules |
Расписание торгов на неделю |
get_active_orders |
Активные заявки |
download_history_archive |
Годовые архивы минутных свечей (1 запрос = 1 год) → единый CSV |
get_history_archive_years |
Какие годы архивов доступны по инструменту (и их размер) |
download_trades_archive |
Обезличенные сделки за торговый день → CSV |
get_server_info |
Диагностика сервера: версия, режимы, окружение (для фидбэка) |
Торговые (TINKOFF_ALLOW_TRADING=true): place_order, cancel_order.
Песочница (TINKOFF_SANDBOX=true): sandbox_open_account, sandbox_pay_in, sandbox_close_account.
Выгрузка в файл — детали
Каждый read-tool принимает outputPath (путь относительно TINKOFF_OUTPUT_DIR)
и outputFormat (json/csv). Сервер пишет результат на диск, в диалог
возвращает summary (savedTo, records, bytes, sample). Запись возможна
строго внутри корня выгрузок; прогресс долгих выгрузок виден в клиенте.
portfolio-target.json — полный формат
{
"targets": { "shares": 55, "bonds": 30, "etf": 10, "cash": 5 },
"byTicker": { "SBER": 10 },
"goals": [
{ "name": "FIRE", "targetAmount": 30000000, "targetDate": "2035-01-01",
"monthlyContribution": 100000, "expectedAnnualReturnPct": 8 }
]
}
Классы targets суммируются к 100; фонды денежного рынка (LQDT и т.п.) допустимо
относить к cash. goals — массив, целей может быть несколько; нужен только
командам прогресса (fire_progress, ритуал monthly).
Построен на официальном SDK @tinkoff/invest-js (gRPC).
Disclaimer
Не является индивидуальной инвестиционной рекомендацией. Все торговые решения вы
принимаете самостоятельно. В боевом режиме place_order оперирует реальными
деньгами — используйте TINKOFF_ALLOW_TRADING=true осознанно и держите
подтверждение сделок включённым.
License
Apache 2.0
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.