> bitrix24-agent
Design, implement, debug, and harden integrations between AI agents and Bitrix24 REST API (webhooks, OAuth 2.0, scopes, events, batch, limits, and REST 3.0). Use when asked to connect AI assistants/agents to Bitrix24, automate CRM/tasks/chats, process Bitrix24 events, choose an auth model, or resolve Bitrix24 API errors and performance issues.
curl "https://skillshub.wtf/vrtalex/bitrix24-skill/bitrix24-agent?format=md"Bitrix24 Agent (Lean + Reliable)
Use this skill to deliver correct Bitrix24 integrations with low token usage and production-safe defaults.
Quick Start
Use this flow unless the user asks for a different one:
- Pick intent + one minimal pack (
coreby default). - Run a read probe first.
- For writes, use plan then execute with confirmation.
Read probe:
python3 skills/bitrix24-agent/scripts/bitrix24_client.py user.current --params '{}'
Safer write flow:
python3 skills/bitrix24-agent/scripts/bitrix24_client.py crm.lead.add \
--params '{"fields":{"TITLE":"Plan demo"}}' \
--packs core \
--plan-only
python3 skills/bitrix24-agent/scripts/bitrix24_client.py \
--execute-plan <plan_id> \
--confirm-write
Runtime Prerequisites
Required environment:
B24_DOMAINB24_AUTH_MODE=webhookoroauth
Webhook mode:
B24_WEBHOOK_USER_IDB24_WEBHOOK_CODE
OAuth mode:
B24_ACCESS_TOKENB24_REFRESH_TOKENB24_CLIENT_IDandB24_CLIENT_SECRET(for--auto-refresh)
Useful safety/reliability flags:
B24_REQUIRE_PLAN=1for mandatory plan->execute on write/destructive callsB24_PACKS=core,...for default pack setB24_RATE_LIMITER=filewithB24_RATE_LIMITER_RATEandB24_RATE_LIMITER_BURST
Default Mode: Lean
Apply these limits unless the user asks for deep detail:
- Load at most 2 reference files before first actionable step.
- Start from
references/packs.md. - Then open only one target file:
references/catalog-<pack>.md. - Open
references/chains-<pack>.mdonly if the user needs workflow steps. - Open
references/bitrix24.mdonly for auth architecture, limits, event reliability, or unknown errors.
Response limits:
- Use concise output (goal + next action + one command).
- Do not retell documentation.
- Do not dump large JSON unless requested.
- Return only delta if guidance was already given.
Routing Workflow
- Determine intent:
- method call
- troubleshooting
- architecture decision
- event/reliability setup
- Normalize product vocabulary:
- "collabs", "workgroups", "projects", "social network groups" ->
collab(andboardsfor scrum). - "Copilot", "CoPilot", "BitrixGPT", "AI prompts" ->
platform(ai.*). - "open lines", "contact center connectors", "line connectors" ->
comms(imopenlines.*,imconnector.*). - "feed", "live feed", "news feed" ->
collab(log.*). - "sites", "landing pages", "landing" ->
sites(landing.*). - "booking", "calendar", "work time", "time tracking" ->
services(booking.*,calendar.*,timeman.*). - "orders", "payments", "catalog", "products" ->
commerce(sale.*,catalog.*). - "consents", "consent", "e-signature", "sign" ->
compliance(userconsent.*,sign.*).
- Choose auth quickly:
- one portal/internal integration: webhook
- app or multi-portal lifecycle: OAuth
- Select minimal packs:
- default
core - add only required packs:
comms,automation,collab,content,boards,commerce,services,platform,sites,compliance,diagnostics
Execution Flow (Safe by Default)
Command template:
python3 skills/bitrix24-agent/scripts/bitrix24_client.py <method> \
--params '<json>' \
--packs core
Guardrails to enforce:
- allowlist via packs and
--method-allowlist - write gate with
--confirm-write - destructive gate with
--confirm-destructive - optional two-phase write with
--plan-onlyand--execute-plan - idempotency for writes (auto or
--idempotency-key) - audit trail unless
--no-auditis explicitly needed
Reliability and Performance
Pagination and sync safety:
- Never stop after first
*.listpage. - Keep deterministic ordering and persist checkpoints after successful page persistence.
Batch rules:
- Maximum 50 commands per
batch. - No nested
batch. - Split oversized batches and parse per-command errors.
Limits and retries:
- Treat
QUERY_LIMIT_EXCEEDEDand5xxas transient. - Use exponential backoff with jitter (client default).
- Use shared rate limiter keyed by portal in multi-worker setups.
Events:
- Online events are not guaranteed delivery.
- For no-loss pipelines, use offline flow:
event.offline.get(clear=0)- process idempotently with retry budget
event.offline.errorfor failed itemsevent.offline.clearonly for successful/DLQ'ed items
- Use
scripts/offline_sync_worker.pyas baseline.
Error Handling
Fast mapping:
| Error code | Typical cause | Immediate action |
|---|---|---|
WRONG_AUTH_TYPE | method called with wrong auth model | switch webhook/OAuth model for this method |
insufficient_scope | missing scope | add scope and reinstall/reissue auth |
expired_token | OAuth token expired | refresh token (--auto-refresh or external refresh flow) |
QUERY_LIMIT_EXCEEDED | burst above portal budget | backoff, queue, tune limiter, reduce concurrency |
ERROR_BATCH_LENGTH_EXCEEDED | batch payload too large | split batch |
ERROR_BATCH_METHOD_NOT_ALLOWED | unsupported method in batch | call directly |
Escalate to deep reference (references/bitrix24.md) on:
- unknown auth/permission behavior
- recurring limit failures
- offline event loss concerns
- OAuth refresh race or tenant isolation issues
Quality Guardrails
- Never expose webhook/OAuth secrets.
- Enforce least-privilege scopes and tenant isolation.
- Keep writes idempotent where possible.
- Validate
application_tokenin event handlers. - Prefer REST v3 where compatible; fallback to v2 where needed.
Reference Loading Map
references/packs.mdfor pack and loading strategy.references/catalog-<pack>.mdfor method shortlist.references/chains-<pack>.mdfor implementation chains.references/bitrix24.mdfor protocol-level troubleshooting and architecture decisions.
Useful search shortcuts:
rg -n "^# Catalog|^# Chains" references/catalog-*.md references/chains-*.md
rg -n "WRONG_AUTH_TYPE|insufficient_scope|QUERY_LIMIT_EXCEEDED|expired_token" references/bitrix24.md
rg -n "offline|event\\.bind|event\\.offline|application_token" references/bitrix24.md
Scripts
scripts/bitrix24_client.py: method calls, packs, allowlist, confirmations, plans, idempotency, audit, rate limiting, retries.scripts/offline_sync_worker.py: offline queue polling, bounded retries, DLQ handling, safe clear flow, graceful shutdown.