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.4.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.4-py3-none-any.whl (34.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: imbi_slackbot-2.11.4.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.4.tar.gz
Algorithm Hash digest
SHA256 eaee629538f2c329e14c26a09129191075d624684a8f58fa55e04aacdbc25300
MD5 25cc5970b6145d40e86dad6b4f3641c3
BLAKE2b-256 1e3e9991e1e34e6fcb6750f16e9d66b37e9ad49d464e40d1c2ef49e4ebf09f4a

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_slackbot-2.11.4.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.4-py3-none-any.whl.

File metadata

  • Download URL: imbi_slackbot-2.11.4-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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c16952bd30775839893f26edd79a92a1cc93ab9ccd642409a83d62ad0bcc157a
MD5 f506cbe4a1dcc8d37722f47e20bfb870
BLAKE2b-256 f8bf381ba9aad30dca4ec4096b7232ef79cea470060447dec464aa5edd4e958f

See more details on using hashes here.

Provenance

The following attestation bundles were made for imbi_slackbot-2.11.4-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