Skip to main content

AI assistant for Grafana Cloud

Project description

Grafana Assistant CLI

[!NOTE] This package is currently in public preview. APIs and features may change without notice.

CLI for interacting with Grafana Assistant via the A2A (Agent-to-Agent) API.

Interactive chat session with Grafana Assistant CLI

Installation

uvx / pip (Recommended)

Run directly without installing:

uvx grafana-assistant

Or install globally:

pip install grafana-assistant

Homebrew (macOS / Linux)

brew install grafana/grafana/grafana-assistant

Or, if you prefer to tap first:

brew tap grafana/grafana
brew install grafana-assistant

Manual download

Download the latest pre-built binary for your platform from the latest release page, extract it, and add the grafana-assistant binary to a directory in your PATH.

On Windows, download the .zip archive instead and add grafana-assistant.exe to your PATH.

Quick Start

# Add your Grafana instance
grafana-assistant config set-instance mystack \
  --url https://mystack.grafana.net

# Set it as the default
grafana-assistant config use-instance mystack

# Authenticate via browser
grafana-assistant auth

# Start interactive chat
grafana-assistant chat

The auth command opens your browser for a one-time login. After that, the CLI manages short-lived tokens that auto-refresh — no service account needed.

[!IMPORTANT] The Assistant CLI User role is required to obtain access tokens via grafana-assistant auth. This role is automatically granted to users with the Editor role or above. For custom roles, the grafana-assistant-app.tokens:access permission must be included.

For non-interactive environments (CI/CD, scripts), you can use a service account token instead:

grafana-assistant config set-instance mystack \
  --url https://mystack.grafana.net \
  --token '${GRAFANA_SA_TOKEN}'

Configuration is stored in ~/.config/grafana-assistant/config.yaml by default, or ./grafana-assistant.yaml for project-specific configs. Session state (last context ID for --continue) is stored in ~/.config/grafana-assistant/state.yaml.

For detailed setup instructions, see docs/SETUP.md. For the full config file reference, see docs/CONFIGURATION.md.

Usage

For detailed usage guides, see Setup & Auth, Chat & Prompt, and Tunnel.

Interactive Chat (Recommended)

Start a full-screen interactive chat session with real-time streaming responses and conversation continuation.

# Start interactive chat
grafana-assistant chat

# With a specific agent
grafana-assistant chat --agent investigation_agent

# Resume a previous conversation by context ID
grafana-assistant chat --context "previous-context-id"

# Continue the last chat session
grafana-assistant chat --continue

# Using a specific instance
grafana-assistant chat --instance prod

Commands:

  • /clear or /new - Start a new conversation
  • /exit, /quit, or /q - Exit
  • /help - Show help

Keyboard Shortcuts:

  • Enter - Send message
  • Ctrl+C - Cancel current request or exit
  • Ctrl+D - Exit

Single-Shot Prompt (for Scripting)

Send a single message and receive the response. Useful for automation and scripting.

# Send a single prompt
grafana-assistant prompt "Analyze my dashboard"

# Using a specific instance from config
grafana-assistant prompt "Analyze my dashboard" --instance prod

# Using explicit URL and token
grafana-assistant prompt "Analyze my dashboard" \
  --url https://your-stack.grafana.net \
  --token $GRAFANA_SA_TOKEN

# Set a custom timeout (default: 300 seconds)
grafana-assistant prompt "Query error rates from Prometheus" --timeout 600

# Continue a conversation with context ID
grafana-assistant prompt "Now show me the last 24 hours" --context "previous-context-id"

# Continue the most recent chat/prompt session
grafana-assistant prompt "Now show me the last 24 hours" --continue

# Output as JSON (for scripting)
grafana-assistant prompt "Analyze my dashboard" --json

# Generate an AGENTS.md file for the current directory
grafana-assistant agents-md

CLI Reference

Chat Command (Interactive)

Option Description Default
--url, -u Grafana instance URL -
--token, -t Service account token -
--instance, -i Instance name from config -
--context, -c Context ID for conversation continuation -
--continue Continue the previous chat session false
--timeout Timeout in seconds per request 300

Prompt Command (Non-Interactive)

Option Description Default
--url, -u Grafana instance URL -
--token, -t Service account token -
--instance, -i Instance name from config -
--wait, -w Wait for completion true
--timeout Timeout in seconds 300
--context, -c Context ID for conversation threading auto-generated
--continue Continue the previous chat session false
--json Output as JSON false

Auth Command

Command Description
auth Authenticate via browser (recommended)
auth --instance <name> Authenticate a specific instance

Agent MD Command

Generate an AGENTS.md file with practical guidance for using grafana-assistant in a project. When run interactively it reads configured instances and lets you choose which ones to include with their real URLs pre-filled.

# Generate AGENTS.md in the current directory (interactive)
grafana-assistant agents-md

# Generate into a specific directory and overwrite existing files
grafana-assistant agents-md ~/projects/my-app --force

# Skip interactive prompts (CI / scripting)
grafana-assistant agents-md --non-interactive
Option Description Default
--output, -o Output filename to create in target directory AGENTS.md
--force, -f Overwrite output file if it already exists false
--dry-run Print generated content to stdout instead of writing a file false
--non-interactive Skip interactive prompts (use generic placeholders) false

Config Commands

Command Description
config set-instance <name> Add or update an instance
config use-instance <name> Set the current instance
config list List all configured instances
config current Show the current instance
config delete-instance <name> Remove an instance
config add-project <name> <path> Add a project directory
config list-projects List all configured projects
config remove-project <name> Remove a project

Tunnel Command

Run a tunnel that allows Grafana Assistant to execute tools on your machine.

# Authenticate (includes tunnel access)
grafana-assistant auth

# Add a project for the assistant to access
grafana-assistant config add-project my-app ~/projects/my-app

# Start tunnel with filesystem access (default)
grafana-assistant tunnel connect

# Start tunnel with terminal access (use with caution)
grafana-assistant tunnel connect --terminal

The auth command includes the tunnel:connect scope, so no separate tunnel auth step is needed.

The tunnel provides:

  • Filesystem tool: Read-only access to local files with project-based configuration
    • Configure named projects (e.g., my-app~/projects/my-app)
    • Access files with project-relative paths (e.g., src/main.go)
    • Search code with grep and find_path actions
    • Add/remove projects dynamically mid-session
  • Terminal tool: Execute shell commands (with configurable allow/deny lists)

For security, the tunnel:

  • Blocks access to sensitive files (.ssh, .env, private keys, etc.) by default
  • Blocks dangerous commands (rm -rf /, mkfs, fork bombs, etc.) by default
  • Runs commands with a minimal environment (only PATH, HOME, USER, etc.)
  • Requires explicit project configuration before accessing codebases

See docs/TUNNEL.md for the full tunnel usage guide and docs/CONFIGURATION.md for tunnel configuration options.

Environment Variables

Variable Description
GRAFANA_URL Grafana instance URL
GRAFANA_SA_TOKEN Service account token
GRAFANA_ASSISTANT_CONFIG Override config file path

JSON Output

When using --json with the prompt command, the output format is:

Prompt Response

{
  "taskId": "a2a-task-123",
  "contextId": "uuid-for-threading",
  "status": "completed",
  "response": "The agent's response text..."
}

Possible status values: completed, failed, timeout, canceled, unknown

Tool Approval Flow

When the Grafana Assistant needs to execute certain tools that require user confirmation (such as running queries or modifying resources), the CLI will prompt you for approval.

How It Works

  1. During a chat session, when a tool requires approval, you'll see a prompt:
Approve execute_query - Execute a database query? [y]/[n]
  1. Press y or Y to approve and allow the tool to execute
  2. Press n, N, or Esc to deny and skip the tool execution

Approval Keys

Key Action
y or Y Approve the tool execution
n or N Deny the tool execution
Esc Deny the tool execution

When you deny a tool, the assistant will be informed and will continue the conversation without executing that tool.

A2A Protocol

This CLI uses the A2A (Agent-to-Agent) Protocol v0.3.0 for communication:

  • Streaming: Real-time SSE streaming of agent responses
  • Context threading: Continue conversations with context IDs
  • Standard protocol: JSON-RPC 2.0 over HTTP with SSE

For more details, see the A2A Protocol Specification.

Prerequisites

  1. A Grafana instance with the Assistant plugin enabled
  2. A Grafana user account for browser-based authentication (recommended)

For non-interactive use (CI/CD, automation), create a service account with the Editor role and generate a token instead.

Contributing

See CONTRIBUTING.md for development setup, testing, and snapshot test instructions.

License

This software is licensed under the Grafana Enterprise Plugin License Agreement.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

grafana_assistant-0.0.21-py3-none-win_arm64.whl (17.9 MB view details)

Uploaded Python 3Windows ARM64

grafana_assistant-0.0.21-py3-none-win_amd64.whl (19.4 MB view details)

Uploaded Python 3Windows x86-64

grafana_assistant-0.0.21-py3-none-musllinux_1_2_x86_64.whl (19.2 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

grafana_assistant-0.0.21-py3-none-musllinux_1_2_aarch64.whl (18.0 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

grafana_assistant-0.0.21-py3-none-manylinux_2_17_x86_64.whl (19.2 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ x86-64

grafana_assistant-0.0.21-py3-none-manylinux_2_17_aarch64.whl (18.0 MB view details)

Uploaded Python 3manylinux: glibc 2.17+ ARM64

grafana_assistant-0.0.21-py3-none-macosx_11_0_arm64.whl (18.0 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

grafana_assistant-0.0.21-py3-none-macosx_10_9_x86_64.whl (19.2 MB view details)

Uploaded Python 3macOS 10.9+ x86-64

File details

Details for the file grafana_assistant-0.0.21-py3-none-win_arm64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-win_arm64.whl
Algorithm Hash digest
SHA256 b84e87ff54c4ade1345512ff7a6548e2977626c1242879228256e325208a97f7
MD5 a0d6e3b4fbb23aa4d5a516d405c3ab04
BLAKE2b-256 699da5b059c18aeb4ac560dcdf717712945c2453a65fe7b496a0aef13de21c0c

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-win_arm64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 6ff10e92add1723e5bbe55656b72a864c19b0d5794b8e215f2a97aeb477097cb
MD5 e282a5ea129bf925e48dcd7dc203bbac
BLAKE2b-256 9b4740f81014b25b2ee0fe4997001438e7d957b393c76b25b7e346a6447a6684

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-win_amd64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-musllinux_1_2_x86_64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 19a510460127a0385afcd8902d1ff1af9f86d41e220f0b97007af7c760f5845b
MD5 fb205fed7aca4966959521dabe2b9063
BLAKE2b-256 ca5f227cb34e5c157ca2614aa69c979206a9d2a07cd19dc455bff17058114cec

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-musllinux_1_2_x86_64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-musllinux_1_2_aarch64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 ae3bd6318e63b8aaf02d99e3e3187f326c458d099ba61dfde744cd9496ed4cd0
MD5 05c3b66ef8702b1cfeb32f33ce285be7
BLAKE2b-256 0e0fcafb358728e93b5ee6b4495157a7f5e93e8ed7b64f1d251b72c5d69c8d7d

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-musllinux_1_2_aarch64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-manylinux_2_17_x86_64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-manylinux_2_17_x86_64.whl
Algorithm Hash digest
SHA256 67cfca190588b94dc81ab1b658770b2f3bad19f6441115a930a834e4fa0c9a8d
MD5 e97b8183f3b8e37e3c240afc65200adc
BLAKE2b-256 853c43bf5f5e9e34979b5f63d61f48c69d84a8a2b133e6e7f73507708f262e0c

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-manylinux_2_17_x86_64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-manylinux_2_17_aarch64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-manylinux_2_17_aarch64.whl
Algorithm Hash digest
SHA256 ecf27c4e8abec2f24a6d006ead5cd7ce48f6b5c6ec2a8199453eeb9bad42a8cd
MD5 28c3417c211157cb94acfa239e3120ec
BLAKE2b-256 65ce966ff164847d22958ce34898d8e1fa88ff04fde35f9aa7e8b73d6369bf5b

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-manylinux_2_17_aarch64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 9a8e2fc25247e59f407ef245cef8730dd8945cebe0fb923dea6cfca293db4d89
MD5 d43e5af0a1ac915bcda9d6b05395f25e
BLAKE2b-256 0da41a77793e59331f5b245a5e19ef822e62e7c666b8158d5fa28747106b9665

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-macosx_11_0_arm64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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

File details

Details for the file grafana_assistant-0.0.21-py3-none-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for grafana_assistant-0.0.21-py3-none-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 3fb9acb86ab46cb9348591df35aba0368a2d7ec7166d999f2bad9f575e9f9ab7
MD5 0c8aa02dac79b808e1c53fc2f1ba43e2
BLAKE2b-256 f593f8cc3acdfb98e962e4a746144f5dcfb75cc208b523bed92818533a096165

See more details on using hashes here.

Provenance

The following attestation bundles were made for grafana_assistant-0.0.21-py3-none-macosx_10_9_x86_64.whl:

Publisher: release.yml on grafana/assistant-cli-internal

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