MCP сервер для взаимодействия с Bitrix24 rest api на основе fast-bitrix24
Project description
MCP сервер для взаимодействия с Bitrix24 rest api на основе fast-bitrix24
Сервер находится в стадии разработки и тестирования. Рекомендуется использовать только в локальной частной сети.
На данный момент сервер поддерживает следsующие сущности:
-
сделки
list_deal- Список сделок по фильтрам
-
пользовательские поля
get_all_info_fields- Получение всех ID, названий и значений полей сделки, контакта, компании, задач, лида
-
контакты
list_contact- Список контактов по фильтрам
-
компании
list_company- Список компаний по фильтрам
-
пользователи
list_user- Список пользователей по фильтрам
-
лиды
list_lead- Список лидов по фильтрам
-
задачи
list_task- Список задач по фильтрамget_task_time_tracking- Получение времени выполнения задачи по idget_task- Получение задачи по idget_task_comments_list- Получение списка комментариев к задаче по idget_task_checklist_items- Получение списка пунктов чеклиста задачи по id
-
хелпер
export_entities_to_json- Экспорт элементов сущности в JSON (сделки, контакты, компании, лиды)analyze_export_file- Анализ экспортированных данных (сумма, количество, среднее значение, минимальное значение, максимальное значение)analyze_tasks_export- Анализ экспортированных данных для задач (сумма, количество, среднее значение, минимальное значение, максимальное значение)export_task_fields_to_json- Экспорт описания полей задачdatetime_now- Получение текущей даты и времени в московской зоне
поддержка человеческого названия полей даже для полей типа список например:
- какая сумма сделок где поле 'этаж доставки' равно 'в подвал'?
- какая сумма сделок которые нужно доставить в подвал
- как называется поле у сделки с id UF_CRM_1749724770090?
- у каких пользователях есть просроченные задачи?
Установка и запуск сервера
установите переменные окружения из файла .env.example
cp .env.example .env
установите зависимости
uv sync
или установите пакет
uv add fast-bitrix24-mcp
создайте файл для запуска сервера
from fast_bitrix24_mcp.main import mcp
if __name__ == "__main__":
mcp.run(transport="http", host="0.0.0.0", port=8000)
# mcp.run(transport="streamable-http", host="127.0.0.1", port=9000)
запустите сервер
uv run main.py
Авторизация запросов
Сервер принимает только авторизованные запросы. Токен берётся из переменной окружения AUTH_TOKEN (файл .env).
- Установите токен в
.env:
AUTH_TOKEN=ваш_секретный_токен
- Пример авторизованного запроса к HTTP MCP эндпоинту (по умолчанию путь
/mcp):
curl -X POST \
-H "Content-Type: application/json" \
-H "Authorization: Bearer $AUTH_TOKEN" \
http://localhost:8000/mcp \
inspector
ui для тестирования сервера
npx @modelcontextprotocol/inspector
Пример использования в langchain
from langchain_mcp_adapters.client import MultiServerMCPClient
from langgraph.prebuilt import create_react_agent
from dotenv import load_dotenv
from pprint import pprint
load_dotenv()
client = MultiServerMCPClient(
{
"bitrix24-main": {
"url": "http://localhost:8000/mcp",
"transport": "http",
"headers": {
"Authorization": f"Bearer {os.getenv('AUTH_TOKEN')}"
}
},
}
)
async def main():
tools = await client.get_tools()
promts = await client.get_prompt('bitrix24-main', 'main_prompt')
promts=promts[0].content
# agent = create_react_agent("openai:gpt-4.1-nano-2025-04-14", tools, prompt=promt)
agent = create_react_agent("openai:gpt-4.1-nano-2025-04-14", tools, prompt=promts, debug=True)
# math_response = await agent.ainvoke({"messages": "сколько сделок с названием Обновленная тестовая сделка ?"})
# math_response = await agent.ainvoke({"messages": "как называется поле у сделки с id UF_CRM_1749724770090?"})
# math_response = await agent.ainvoke({"messages": "какая сумма сделок где поле 'этаж доставки' равно 'в подвал'"})
# math_response = await agent.ainvoke({"messages": "какая сумма сделок у которых этаж доставки 'в подвал'?"})
math_response = await agent.ainvoke({"messages": "покажи статистику по сделкам за сегодня и позавчера"})
token=0
for message in math_response["messages"]:
print(message.content + "\n\n")
# pprint(math_response)
token=math_response["messages"][-1].usage_metadata['total_tokens']
print(f'token: {token}')
while True:
message = input("Введите сообщение: ")
math_response["messages"].append({"role": "user", "content": message})
math_response = await agent.ainvoke(math_response)
for message in math_response["messages"]:
print(message.content + "\n\n")
if __name__ == "__main__":
import asyncio
asyncio.run(main())
)
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fast_bitrix24_mcp-1.0.0.tar.gz.
File metadata
- Download URL: fast_bitrix24_mcp-1.0.0.tar.gz
- Upload date:
- Size: 24.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d374a52303f9be0298b73272956a222e4c2542d8920e58a9870bbbc1c11d69fa
|
|
| MD5 |
d4fffa93e7364c974af18e4fa2c498b0
|
|
| BLAKE2b-256 |
9aa7b98117dfb62fa719df88830b98761a4d3c5d86e5446efaa10faf408cc12c
|
Provenance
The following attestation bundles were made for fast_bitrix24_mcp-1.0.0.tar.gz:
Publisher:
python-publish.yml on darkClaw921/fast-bitrix24-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fast_bitrix24_mcp-1.0.0.tar.gz -
Subject digest:
d374a52303f9be0298b73272956a222e4c2542d8920e58a9870bbbc1c11d69fa - Sigstore transparency entry: 465217342
- Sigstore integration time:
-
Permalink:
darkClaw921/fast-bitrix24-mcp@d24762fb0113612b2a766c860f8e80e60daa9d1a -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/darkClaw921
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@d24762fb0113612b2a766c860f8e80e60daa9d1a -
Trigger Event:
release
-
Statement type:
File details
Details for the file fast_bitrix24_mcp-1.0.0-py3-none-any.whl.
File metadata
- Download URL: fast_bitrix24_mcp-1.0.0-py3-none-any.whl
- Upload date:
- Size: 30.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3fac4148059f86920b85f5b9350eb3e4d2c58f811ce71197e99104e7f68f685
|
|
| MD5 |
58f322990e33afcb81cc3c957baf3758
|
|
| BLAKE2b-256 |
fd8f244ca7b69d55ddcc0bcc74b009cca255eebaa4ac3fd412e08055a0eec22e
|
Provenance
The following attestation bundles were made for fast_bitrix24_mcp-1.0.0-py3-none-any.whl:
Publisher:
python-publish.yml on darkClaw921/fast-bitrix24-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fast_bitrix24_mcp-1.0.0-py3-none-any.whl -
Subject digest:
b3fac4148059f86920b85f5b9350eb3e4d2c58f811ce71197e99104e7f68f685 - Sigstore transparency entry: 465217357
- Sigstore integration time:
-
Permalink:
darkClaw921/fast-bitrix24-mcp@d24762fb0113612b2a766c860f8e80e60daa9d1a -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/darkClaw921
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@d24762fb0113612b2a766c860f8e80e60daa9d1a -
Trigger Event:
release
-
Statement type: