data-engineering

claude-plugins-official

OtherClaude Codeby anthropics

Summary

Data engineering plugin - warehouse exploration, pipeline authoring, Airflow integration

Install to Claude Code

/plugin install data-engineering@claude-plugins-official

Run in Claude Code. Add the marketplace first with /plugin marketplace add anthropics/claude-plugins-official if you haven't already.

README.md

agents

AI agent tooling for data engineering workflows. Includes an MCP server for Airflow, a CLI tool (af) for interacting with Airflow from your terminal, and skills that extend AI coding agents with specialized capabilities for working with Airflow and data warehouses. Works with Claude Code, Cursor, and other agentic coding tools.

Built by Astronomer. Apache 2.0 licensed and compatible with open-source Apache Airflow.

Table of Contents

<!-- START doctoc generated TOC please keep comment here to allow auto update --> <!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->

<!-- END doctoc generated TOC please keep comment here to allow auto update -->

Installation

Quick Start

npx skills add astronomer/agents --skill '*'

This installs all Astronomer skills into your project via skills.sh. You'll be prompted to select which agents to install to. To also select skills individually, omit the --skill flag.

> [!IMPORTANT] > Claude Code users: We recommend using the plugin instead (see Claude Code section below) for better integration with MCP servers and hooks.

Compatibility

Skills: Works with 25+ AI coding agents including Claude Code, Cursor, VS Code (GitHub Copilot), Windsurf, Cline, and more.

MCP Server: Works with any MCP-compatible client including Claude Desktop, VS Code, and others.

> [!NOTE] > Open-source Airflow users: The MCP server works with any Airflow 2.x/3.x REST API. Set AIRFLOW_API_URL to your self-hosted instance. Skills are tool-agnostic and work with any Airflow deployment.

Claude Code

# Add the marketplace and install the plugin
claude plugin marketplace add astronomer/agents
claude plugin install astronomer-data@astronomer

# Upgrading from the old plugin name? Uninstall first:
# claude plugin uninstall data@astronomer && claude plugin marketplace update && claude plugin install astronomer-data@astronomer

The plugin includes the Airflow MCP server that runs via uvx from PyPI. Data warehouse queries are handled by the analyzing-data skill using a background Jupyter kernel.

Cursor

Cursor supports both MCP servers and skills.

MCP Server - Click to install:

<a href="https://cursor.com/en-US/install-mcp?name=astro-airflow-mcp&config=eyJjb21tYW5kIjoidXZ4IiwiYXJncyI6WyJhc3Ryby1haXJmbG93LW1jcCIsIi0tdHJhbnNwb3J0Iiwic3RkaW8iXX0"><img src="https://cursor.com/deeplink/mcp-install-dark.svg" alt="Add Airflow MCP to Cursor" height="32"></a>

Skills - Install to your project:

npx skills add astronomer/agents --skill '*' -a cursor

This installs skills to .cursor/skills/ in your project.

<details> <summary>Manual MCP configuration</summary>

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "airflow": {
      "command": "uvx",
      "args": ["astro-airflow-mcp", "--transport", "stdio"]
    }
  }
}

</details>

<details> <summary>Enable hooks (session management)</summary>

Create .cursor/hooks.json in your project:

{
  "version": 1,
  "hooks": {
    "stop": [
      {
        "command": "uv run $CURSOR_PROJECT_DIR/.cursor/skills/analyzing-data/scripts/cli.py stop",
        "timeout": 10
      }
    ]
  }
}

What these hooks do:

  • stop: Cleans up kernel when session ends

</details>

Other MCP Clients

For any MCP-compatible client (Claude Desktop, VS Code, etc.):

# Airflow MCP
uvx astro-airflow-mcp --transport stdio

# With remote Airflow
AIRFLOW_API_URL=https://your-airflow.example.com \
AIRFLOW_USERNAME=admin \
AIRFLOW_PASSWORD=admin \
uvx astro-airflow-mcp --transport stdio

Features

The astronomer-data plugin bundles an MCP server and skills into a single installable package.

MCP Server

| Server | Description | |--------|-------------| | Airflow | Full Airflow REST API integration via astro-airflow-mcp: DAG management, triggering, task logs, system health |

Skills

Data Discovery & Analysis

| Skill | Description | |-------|-------------| | warehouse-init | Initialize schema discovery - generates .astro/warehouse.md for instant lookups | | analyzing-data | SQL-based analysis to answer business questions (uses background Jupyter kernel) | | checking-freshness | Check how current your data is | | profiling-tables | Comprehensive table profiling and quality assessment |

Data Lineage

| Skill | Description | |-------|-------------| | tracing-downstream-lineage | Analyze what breaks if you change something | | tracing-upstream-lineage | Trace where data comes from | | annotating-task-lineage | Add manual lineage to tasks using inlets/outlets | | creating-openlineage-extractors | Build custom OpenLineage extractors for operators |

DAG Development

| Skill | Description | |-------|-------------| | airflow | Main entrypoint - routes to specialized Airflow skills | | setting-up-astro-project (Astro) | Initialize and configure new Astro/Airflow projects | | managing-astro-local-env (Astro) | Manage local Airflow environment (start, stop, logs, troubleshoot) | | authoring-dags | Create and validate Airflow DAGs with best practices | | blueprint | Compose DAGs from YAML using reusable templates with Pydantic validation (airflow-blueprint) | | testing-dags | Test and debug Airflow DAGs locally | | debugging-dags | Deep failure diagnosis and root cause analysis | | deploying-airflow | Deploy Airflow DAGs and projects (Astro, Docker Compose, Kubernetes) | | airflow-hitl | Human-in-the-loop workflows: approval gates, form input, branching (Airflow 3.1+) |

dbt Integration

| Skill | Description | |-------|-------------| | cosmos-dbt-core | Run dbt Core projects as Airflow DAGs using Astronomer Cosmos | | cosmos-dbt-fusion | Run dbt Fusion projects with Cosmos (Snowflake/Databricks only) |

Migration

| Skill | Description | |-------|-------------| | migrating-airflow-2-to-3 | Migrate DAGs from Airflow 2.x to 3.x |

Why Astro?

Astro is Astronomer's managed Airflow platform. It's optional, but a good fit if you want managed deployments, built-in alerting, and centralized observability across environments. If you run open-source Airflow, everything in this repo still applies—you'll just configure your own Airflow URL and infrastructure.

User Journeys

Data Analysis Flow

flowchart LR
    init["/astronomer-data:warehouse-init"] --> analyzing["/astronomer-data:analyzing-data"]
    analyzing --> profiling["/astronomer-data:profiling-tables"]
    analyzing --> freshness["/astronomer-data:checking-freshness"]

1. Initialize (/astronomer-data:warehouse-init) - One-time setup to generate warehouse.md with schema metadata 2. Analyze (/astronomer-data:analyzing-data) - Answer business questions with SQL 3. Profile (/astronomer-data:profiling-tables) - Deep dive into specific tables for statistics and quality 4. Check freshness (/astronomer-data:checking-freshness) - Verify data is up to date before using

DAG Development Flow

For open-source Airflow, use Docker Compose for local dev and the Helm chart for production (see deploying-airflow) instead of Astro setup skills.

flowchart LR
    setup["/astronomer-data:setting-up-astro-project"] --> authoring["/astronomer-data:authoring-dags"]
    setup --> env["/astronomer-data:managing-astro-local-env"]
    authoring --> testing["/astronomer-data:testing-dags"]
    testing --> debugging["/astronomer-data:debugging-dags"]

1. Setup (/astronomer-data:setting-up-astro-project) - Initialize project structure and dependencies 2. Environment (/astronomer-data:managing-astro-local-env) - Start/stop local Airflow for development 3. Author (/astronomer-data:authoring-dags) - Write DAG code following best practices 4. Test (/astronomer-data:testing-dags) - Run DAGs and fix issues iteratively 5. Debug (/astronomer-data:debugging-dags) - Deep investigation for complex failures

Airflow CLI (af)

The af command-line tool lets you interact with Airflow directly from your terminal. Install it with:

uvx --from astro-airflow-mcp af --help

For frequent use, add an alias to your shell config (~/.bashrc or ~/.zshrc):

alias af='uvx --from astro-airflow-mcp af'

Then use it for quick operations like af health, af dags list, or af runs trigger <dag_id>.

See the full CLI documentation for all commands and instance management.

> Telemetry: The af CLI collects anonymous usage telemetry to help improve the tool. Only the command name is collected (e.g., dags list), never the arguments or their values. Opt out with af telemetry disable.

Configuration

Warehouse Connections

Configure data warehouse connections at ~/.astro/agents/warehouse.yml:

my_warehouse:
  type: snowflake
  account: ${SNOWFLAKE_ACCOUNT}
  user: ${SNOWFLAKE_USER}
  auth_type: private_key
  private_key_path: ~/.ssh/snowflake_key.p8
  private_key_passphrase: ${SNOWFLAKE_PRIVATE_KEY_PASSPHRASE}
  warehouse: COMPUTE_WH
  role: ANALYST
  query_tag: claude-code
  databases:
    - ANALYTICS
    - RAW

> [!IMPORTANT] > How the databases list works: > - Optional for most connectors (snowflake, postgres, bigquery) but required for sqlalchemy > - For schema discovery (/astronomer-data:warehouse-init): Determines which databases are scanned and included in the generated .astro/warehouse.md. Only databases listed here will be discovered. If omitted, no schema discovery will occur. > - For query execution (/astronomer-data:analyzing-data): The first database in the list becomes the default database context for the connection, but does NOT restrict which databases you can query. You can still access any database you have permissions for using fully-qualified table names (e.g., OTHER_DB.SCHEMA.TABLE). > > Example: If you configure databases: [ANALYTICS, RAW]: > - ANALYTICS becomes the default database for queries > - You can still query PROD with SELECT * FROM PROD.PUBLIC.USERS > - Only ANALYTICS and RAW will appear in warehouse schema documentation (run /astronomer-data:warehouse-init --refresh after adding PROD to include it)

> [!NOTE] > The account field requires your Snowflake account identifier (e.g., orgname-accountname or xy12345.us-east-1), not your account name. Find this in your Snowflake console under Admin > Accounts.

Store credentials in ~/.astro/agents/.env:

SNOWFLAKE_ACCOUNT=myorg-myaccount  # Use your Snowflake account identifier (format: orgname-accountname or accountname.region)
SNOWFLAKE_USER=myuser
SNOWFLAKE_PRIVATE_KEY_PASSPHRASE=your-passphrase-here  # Only required if using an encrypted private key

Supported databases:

| Type | Package | Description | |------|---------|-------------| | snowflake | Built-in | Snowflake Data Cloud | | postgres | Built-in | PostgreSQL | | bigquery | Built-in | Google BigQuery | | sqlalchemy | Any SQLAlchemy driver | Auto-detects packages for 25+ databases (see below) |

<details> <summary>Auto-detected SQLAlchemy databases</summary>

The connector automatically installs the correct driver packages for:

| Database | Dialect URL | |----------|-------------| | PostgreSQL | postgresql:// or postgres:// | | MySQL | mysql:// or mysql+pymysql:// | | MariaDB | mariadb:// | | SQLite | sqlite:/// | | SQL Server | mssql+pyodbc:// | | Oracle | oracle:// | | Redshift | redshift:// | | Snowflake | snowflake:// | | BigQuery | bigquery:// | | DuckDB | duckdb:/// | | Trino | trino:// | | ClickHouse | clickhouse:// | | CockroachDB | cockroachdb:// | | Databricks | databricks:// | | Amazon Athena | awsathena:// | | Cloud Spanner | spanner:// | | Teradata | teradata:// | | Vertica | vertica:// | | SAP HANA | hana:// | | IBM Db2 | db2:// |

For unlisted databases, install the driver manually and use standard SQLAlchemy URLs.

</details>

<details> <summary>Example configurations</summary>

# PostgreSQL
my_postgres:
  type: postgres
  host: localhost
  port: 5432
  user: analyst
  password: ${POSTGRES_PASSWORD}
  database: analytics
  application_name: claude-code

# BigQuery
my_bigquery:
  type: bigquery
  project: my-gcp-project
  credentials_path: ~/.config/gcloud/service_account.json
  location: US
  labels:
    team: data-eng
    env: prod

# SQLAlchemy (any supported database)
my_duckdb:
  type: sqlalchemy
  url: duckdb:///path/to/analytics.duckdb
  databases: [main]

# SQLAlchemy with connect_args (passed to the DBAPI driver)
my_pg_sqlalchemy:
  type: sqlalchemy
  url: postgresql://${PG_USER}:${PG_PASSWORD}@localhost/analytics
  databases: [analytics]
  connect_args:
    application_name: claude-code

# Redshift (via SQLAlchemy)
my_redshift:
  type: sqlalchemy
  url: redshift+redshift_connector://${REDSHIFT_USER}:${REDSHIFT_PASSWORD}@${REDSHIFT_HOST}:5439/${REDSHIFT_DATABASE}
  databases: [my_database]

</details>

Airflow

The Airflow MCP auto-discovers your project when you run Claude Code from an Airflow project directory (contains airflow.cfg or dags/ folder).

For remote instances, set environment variables:

| Variable | Description | |----------|-------------| | AIRFLOW_API_URL | Airflow webserver URL | | AIRFLOW_USERNAME | Username | | AIRFLOW_PASSWORD | Password | | AIRFLOW_AUTH_TOKEN | Bearer token (alternative to username/password) |

Usage

Skills are invoked automatically based on what you ask. You can also invoke them directly with /astronomer-data:<skill-name>.

Getting Started

1. Initialize your warehouse (recommended first step):

   /astronomer-data:warehouse-init

This generates .astro/warehouse.md with schema metadata for faster queries.

2. Ask questions naturally:

  • "What tables contain customer data?"
  • "Show me revenue trends by product"
  • "Create a DAG that loads data from S3 to Snowflake daily"
  • "Why did my etl_pipeline DAG fail yesterday?"

Development

See CLAUDE.md for plugin development guidelines.

Local Development Setup

# Clone the repo
git clone https://github.com/astronomer/agents.git
cd agents

# Test with local plugin
claude --plugin-dir .

# Or install from local marketplace
claude plugin marketplace add .
claude plugin install astronomer-data@astronomer

Adding Skills

Create a new skill in skills/<name>/SKILL.md with YAML frontmatter:

---
name: my-skill
description: When to invoke this skill
---

# Skill instructions here...

After adding skills, reinstall the plugin:

claude plugin uninstall astronomer-data@astronomer && claude plugin marketplace update && claude plugin install astronomer-data@astronomer

Troubleshooting

Common Issues

| Issue | Solution | |-------|----------| | Skills not appearing | Reinstall plugin: claude plugin uninstall astronomer-data@astronomer && claude plugin marketplace update && claude plugin install astronomer-data@astronomer | | Installed as data@astronomer (old name) | Uninstall old name and reinstall: claude plugin uninstall data@astronomer && claude plugin marketplace update && claude plugin install astronomer-data@astronomer | | Warehouse connection errors | Check credentials in ~/.astro/agents/.env and connection config in warehouse.yml | | Airflow not detected | Ensure you're running from a directory with airflow.cfg or a dags/ folder |

Contributing

Contributions welcome! Please read our Code of Conduct and Contributing Guide before getting started.

Roadmap

Skills we're likely to build:

DAG Operations

  • CI/CD pipelines for DAG deployment
  • Performance optimization and tuning
  • Monitoring and alerting setup
  • Data quality and validation workflows

Astronomer Open Source

  • DAG Factory - Generate DAGs from YAML
  • Other open source projects we maintain

Conference Learnings

  • Reviewing talks from Airflow Summit, Coalesce, Data Council, and other conferences to extract reusable skills and patterns

Broader Data Practitioner Skills

  • Churn prediction, data modeling, ML training, and other workflows that span DE/DS/analytics roles

Don't see a skill you want? Open an issue or submit a PR!

License

Apache 2.0

---

Made with :heart: by Astronomer <img referrerpolicy="no-referrer-when-downgrade" src="https://static.scarf.sh/a.png?x-pxid=f1c1d270-334e-45ec-b711-77385036cff9" />

Related plugins

Browse all →