Skip to main content

Imbi Slack bot

Project description

imbi-slackbot

A Slack bot for the Imbi DevOps service management platform. It behaves like the Imbi assistant — giving Claude live access to Imbi data and actions through tools — but speaks Slack and acts as the Slack user who asked, so every answer and action respects that user's Imbi permissions.

How It Works

The bot connects to Slack over Socket Mode (an outbound websocket, so no public ingress is required). When a user mentions the bot or DMs it, the bot:

  1. Resolves the Slack user to an Imbi user. It looks up the Slack user's email (users.info), finds the matching active Imbi User in the graph, and mints a short-lived per-user JWT access token signed with the shared IMBI_AUTH_JWT_SECRET — exactly the token the Imbi API issues at login. The resolution is cached with a TTL. Users with no matching Imbi account get a friendly explanation instead.
  2. Reconstructs the thread context from Slack (conversations.replies) so follow-up questions in a thread keep their history. Nothing is persisted server-side; the Slack thread is the conversation.
  3. Runs Claude with the Imbi toolset. Tools are built at startup from the Imbi API's openapi.json via an in-process FastMCP server, using the shared imbi_common.mcp exclusion policy (auth/MFA/status/thumbnail and any x-imbi-ai-tool: false operations are filtered out). The user's minted token is forwarded on every tool call, so the API enforces their permissions.
  4. Replies in-thread with Claude's answer.

A tiny FastAPI app exposes /status (port 8004) for health checks; the Socket Mode connection runs as a background task alongside it.

Configuration

Environment variable Purpose
SLACK_BOT_TOKEN Slack bot token (xoxb-…)
SLACK_APP_TOKEN Slack app-level token for Socket Mode (xapp-…)
ANTHROPIC_API_KEY Anthropic API key (enables the bot when set)
IMBI_AUTH_JWT_SECRET Shared HS256 secret used to mint per-user tokens
IMBI_INTERNAL_API_URL In-cluster base URL of the Imbi API
IMBI_UI_URL Public base URL of the Imbi UI, used to build deep links
IMBI_INTERNAL_UI_URL In-cluster UI address for fetching llms.txt (e.g. the Caddy frontend); falls back to IMBI_UI_URL
POSTGRES_URL Imbi graph (Apache AGE) connection URL
IMBI_SLACKBOT_MODEL Claude model (default claude-sonnet-4-6)

See src/imbi_slackbot/settings.py for the full set.

Development

just setup    # install deps + pre-commit hooks
just test     # run the test suite with coverage
just lint     # ruff + mypy + basedpyright
just serve    # run the bot against .env

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

imbi_slackbot-2.11.3.tar.gz (150.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

imbi_slackbot-2.11.3-py3-none-any.whl (34.5 kB view details)

Uploaded Python 3

File details

Details for the file imbi_slackbot-2.11.3.tar.gz.

File metadata

  • Download URL: imbi_slackbot-2.11.3.tar.gz
  • Upload date:
  • Size: 150.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for imbi_slackbot-2.11.3.tar.gz
Algorithm Hash digest
SHA256 fee499c9378ba6ae6f2e7a3afaf40cc600951e478028c2fa48283104559bfc27
MD5 a8687254fb00e55ce486579425bc3eae
BLAKE2b-256 774baba689437c6c999b69dca8e265087367b38066fdc214f9fadc9f5eb60328

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_slackbot-2.11.3.tar.gz:

Publisher: publish.yml on AWeber-Imbi/imbi-slackbot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file imbi_slackbot-2.11.3-py3-none-any.whl.

File metadata

  • Download URL: imbi_slackbot-2.11.3-py3-none-any.whl
  • Upload date:
  • Size: 34.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for imbi_slackbot-2.11.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d36f703dd7b9ce4e5a6ca7aca20d8a4bb8a663f2862db573111579c65638760e
MD5 b11a16cde1f1570d16808b8c7712d8a7
BLAKE2b-256 abf60b0d08c9f4e3fd7d4db11d2c7672fb923e736924c9f5395f4b2b9f0ca0f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_slackbot-2.11.3-py3-none-any.whl:

Publisher: publish.yml on AWeber-Imbi/imbi-slackbot

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page