Skip to main content

Agent-native MaxCompute CLI for external coding agents

Project description

maxc-cli

MaxCompute CLI — 不是 Agent,而是给 Agent 调用的结构化工具层。

快速开始

pip install maxc-cli

# 认证
maxc auth login --from-env --json          # 从环境变量
maxc auth login --access-id ID --secret-access-key KEY --project PROJ --endpoint URL --json

# 确认就绪
maxc auth whoami --json
maxc agent context --json

# 用
maxc meta search "销售" --json
maxc meta describe schema.table --json
maxc query cost "SELECT * FROM schema.table WHERE ds='20260415'" --json
maxc query "SELECT * FROM schema.table WHERE ds='20260415'" --json

命令一览

家族 命令 说明
query query [run], query cost, query explain SQL 执行、成本估算、执行计划
job submit, status, wait, result, cancel, diagnose, list 异步任务全生命周期
meta list-tables, describe, search, search-columns, partitions, latest-partition, freshness, list-projects, list-schemas, semantic set/get/list-missing 元数据发现与语义管理
data sample, profile 数据采样与画像
auth login, login-external, whoami, can-i 认证与权限
session set, show, unset 项目/Schema 切换
diff schema, partition, data 表结构/分区/数据对比
cache build, build-status, status, clear 元数据缓存管理
agent context, skill, install-skill Agent 集成与 SKILL 安装

所有命令支持 --json 输出 Envelope v2.0 结构化响应。

Agent 集成

方式 1:SKILL HUB(主路径)

SKILL HUB 安装 SKILL → Agent 读 SKILL.md → Agent 自己 pip install maxc-cli

方式 2:install-skill(内网兜底)

先 pip install,再一键注册到 Agent 平台:

pip install maxc-cli
maxc agent install-skill claude-code    # 或 cursor / windsurf / codex / qwen

install-skill 从包内 skills/ 目录拷贝 SKILL.md + references/ 到目标平台目录,写入 .maxc-skill-version 标记版本。同版本跳过,版本变化覆盖。

preflight 检查

Agent 启动时应先运行:

maxc agent context --json   # 版本、认证状态、后端可达性、能力矩阵
maxc agent skill --json     # SKILL.md 路径与 min_cli_version

Envelope v2.0

所有 --json 输出遵循统一结构:

{
  "version": "2.0",
  "command": "meta.describe",
  "command_id": "meta.describe",
  "status": "success | failure",
  "data": { ... },
  "metadata": { ... },
  "error": null | { "code": "...", "message": "...", "recovery_steps": [...] },
  "agent_hints": {
    "next_actions": ["maxc meta search --json", ...],
    "action_ids": ["meta.search", ...],
    "insights": [...],
    "warnings": [...]
  }
}
  • action_ids:稳定 dot-notation,用于程序化路由(meta.describejob.wait
  • next_actions:可直接 copy-paste 的 CLI 命令
  • error.recovery_steps:错误码对应的恢复步骤

详见 docs/ENVELOPE_SPEC.md

项目结构

src/maxc_cli/
├── cli.py               # argparse 命令注册
├── app.py               # MaxCApp 业务逻辑
├── models.py            # Envelope / AgentHints / QueryResult
├── exceptions.py        # ErrorPayload + 9 个异常子类 + recovery_steps
├── config.py            # YAML 配置加载
├── cache.py             # LocalCache (SQLite)
├── store.py             # JobStore (SQLite)
├── output.py            # Rich / 纯文本渲染
├── auth_providers.py    # AK-SK / NCS / 环境变量认证
├── backend/             # ODPS 后端(query / meta / catalog / data / diff 五个 mixin)
└── skills/              # SKILL.md + references/ + agents/(随 pip 包安装,唯一源)

文档

文档 内容
docs/ARCHITECTURE.md 三层架构、核心数据流、缓存/认证架构
docs/ENVELOPE_SPEC.md Envelope v2.0 规范、pagination、error codes
docs/ODPS_BACKEND.md ODPS 后端 API 映射、限制与回退行为
docs/design.md 产品定位与命令体系
docs/implementation.md 当前代码的真实行为和输出契约
docs/roadmap.md 路线图

限制

  • 只读:CLI 强制 SELECT-only,不支持 DDL/DML
  • auth login:AK/SK 明文存储于 ~/.maxc/config.yaml(文件权限 0600)
  • list-tables 分页:CLI 侧 offset token,非服务端游标
  • diff data:按主键快照对比,非全量 diff

开发

pip install -e .
pytest tests/ -m unit    # 142 个单元测试

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

maxc_cli-0.1.3.tar.gz (136.2 kB view details)

Uploaded Source

Built Distribution

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

maxc_cli-0.1.3-py3-none-any.whl (112.8 kB view details)

Uploaded Python 3

File details

Details for the file maxc_cli-0.1.3.tar.gz.

File metadata

  • Download URL: maxc_cli-0.1.3.tar.gz
  • Upload date:
  • Size: 136.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for maxc_cli-0.1.3.tar.gz
Algorithm Hash digest
SHA256 0122fe8f505aeb8b67acd9d1362b21774824c10c41377b058a5188e5e4b14f74
MD5 4b6a0bfc5cf7246e39e0d60499730905
BLAKE2b-256 243e62d33f76eab4522be693a38370c254e69bd84e77a44f5a28a77e4c1db463

See more details on using hashes here.

File details

Details for the file maxc_cli-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: maxc_cli-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 112.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.7

File hashes

Hashes for maxc_cli-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 875eacf6685176d26c374316f2b0ce59dc0f33690b65a168ecc005ded1020893
MD5 519a3427d0df432b862d7d5574b4b185
BLAKE2b-256 42c96da73fc99a6fdfa3102dffb23abb176e298735226dcbbc3dc613c2b53dc8

See more details on using hashes here.

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