mirror of
https://github.com/Tencent/WeKnora.git
synced 2026-06-04 13:30:32 +08:00
AGENTS.md gains three sections for the v0.8 surfaces:
- Stream recovery — session continue-stream replay-from-0 semantics
and the dedupe contract agents must implement
- Dry-run contract — when --dry-run applies, the meta.{dry_run,plan}
envelope shape, exit-code semantics (no exit 10
on destructive + --dry-run), the GET-reject rule
for `weknora api`, and the validation-parity
guarantee with the live path
- Risk metadata — what the Risk: prefix in --help means and how
cobra.Annotations["risk.{level,action}"] are
populated
README.md gains user-facing Dry-run preview and Resuming streams
sections.
CHANGELOG.md adds the v0.8 entry covering the new --dry-run flag,
MCP Tool.Annotations, session continue-stream, and the Risk: line.
383 lines
14 KiB
Markdown
383 lines
14 KiB
Markdown
# weknora — WeKnora CLI
|
||
|
||
A command-line interface for the WeKnora RAG knowledge-base server. Lets you
|
||
authenticate, manage knowledge bases and documents, run hybrid search, and
|
||
ask streaming RAG questions from your terminal or from an AI agent.
|
||
|
||
```bash
|
||
$ weknora --help
|
||
Command-line client for the WeKnora RAG server. Manage knowledge bases
|
||
and documents, run hybrid search, chat with grounded answers, or expose
|
||
a curated read-only MCP tool surface for AI agents.
|
||
|
||
Available Commands:
|
||
agent Manage custom agents (CRUD + status/check)
|
||
api Make a raw API request to the WeKnora server
|
||
auth Manage authentication credentials and profiles
|
||
chat Ask a streaming RAG question against a knowledge base
|
||
chunk Manage document chunks (RAG retrieval debug)
|
||
completion Generate the autocompletion script for the specified shell
|
||
profile Manage CLI profiles (named connection targets)
|
||
doc Manage documents in a knowledge base
|
||
doctor Run 4 self-checks: base URL, auth, server version, credential storage
|
||
help Help about any command
|
||
kb Manage knowledge bases
|
||
link Bind the current directory to a knowledge base
|
||
mcp Run weknora as a Model Context Protocol server
|
||
search Search across chunks, knowledge bases, documents, or sessions
|
||
session Manage chat sessions
|
||
unlink Remove the directory's knowledge-base binding
|
||
version Show CLI build metadata
|
||
```
|
||
|
||
The wire contract for AI agents is documented [below](#wire-contract).
|
||
For contributing to the CLI source, see [AGENTS.md](AGENTS.md).
|
||
|
||
---
|
||
|
||
## Install
|
||
|
||
### From source
|
||
|
||
Requires Go 1.26+.
|
||
|
||
```bash
|
||
git clone https://github.com/Tencent/WeKnora.git
|
||
cd WeKnora/cli
|
||
go build -o weknora .
|
||
sudo mv weknora /usr/local/bin/ # or anywhere on $PATH
|
||
```
|
||
|
||
### Pre-built binaries
|
||
|
||
Pre-built binaries for Linux / macOS / Windows are produced by CI on each
|
||
release. Grab the latest from the [Releases page](https://github.com/Tencent/WeKnora/releases).
|
||
|
||
---
|
||
|
||
## 5-minute quickstart
|
||
|
||
```bash
|
||
# 1. Log in to your WeKnora server (interactive password prompt)
|
||
weknora auth login --host https://kb.example.com
|
||
|
||
# 2. Or pipe an API key from stdin (for CI / AI agents)
|
||
echo "sk-..." | weknora auth login --host https://kb.example.com --with-token
|
||
|
||
# 3. List knowledge bases
|
||
weknora kb list
|
||
|
||
# 4. Bind this directory to a knowledge base — subsequent commands auto-resolve --kb
|
||
weknora link --kb my-knowledge-base
|
||
|
||
# 5. Upload a document, then block until parsing finishes
|
||
weknora doc upload notes.md
|
||
weknora doc wait doc_abc # exit 0 completed, 1 failed, 124 --timeout, 130 ^C
|
||
|
||
# 6. Search
|
||
weknora search chunks "what is reciprocal rank fusion?"
|
||
|
||
# 7. Ask the LLM (streams to terminal)
|
||
weknora chat "summarise the design doc"
|
||
|
||
# 8. Manage custom agents and run them (see `weknora agent --help` / `weknora session --help`)
|
||
weknora agent list
|
||
weknora session ask --agent ag_abc "what's our q4 retention plan?"
|
||
|
||
# 9. Inspect a document's chunks for RAG retrieval debug
|
||
weknora chunk list --doc doc_xyz
|
||
|
||
# 10. Health & verification verbs
|
||
weknora kb status kb_abc # fast snapshot: reachable / counts / processing flag (1 HTTP)
|
||
weknora kb check kb_abc # deep verify: also aggregates failed_count via doc list (1+N HTTP)
|
||
weknora agent status ag_abc # fast: reachable / model_id
|
||
weknora agent check ag_abc # deep: probes every KB in the agent's scope
|
||
```
|
||
|
||
---
|
||
|
||
### Agent quick start
|
||
|
||
For AI agents (Claude Code, Cursor, Gemini CLI, etc.) integrating WeKnora:
|
||
|
||
1. Install: `brew install weknora` or `go install github.com/Tencent/WeKnora/cli@latest`
|
||
2. Authenticate (background; extract login URL for the user):
|
||
```bash
|
||
weknora auth login --host <server-url>
|
||
```
|
||
3. Register MCP in the host's MCP config:
|
||
```json
|
||
{"mcpServers": {"weknora": {"command": "weknora", "args": ["mcp", "serve"]}}}
|
||
```
|
||
4. Read the [wire contract](AGENTS.md#wire-contract-for-ai-agents) before
|
||
parsing `--format json` output.
|
||
5. Read the [exit-10 anti-patterns](AGENTS.md#exit-10-anti-patterns) before
|
||
any destructive call.
|
||
|
||
---
|
||
|
||
## Multi-profile
|
||
|
||
Switch between several WeKnora servers (or several tenants on the same server)
|
||
without re-logging in:
|
||
|
||
```bash
|
||
weknora auth login --host https://prod.example.com --name prod
|
||
weknora auth login --host https://staging.example.com --name staging --with-token < .staging-key
|
||
weknora auth list
|
||
weknora profile use prod
|
||
```
|
||
|
||
Credentials are persisted to your OS keyring (Keychain on macOS, libsecret on
|
||
Linux, Wincred on Windows) when available, otherwise to a 0600-mode file
|
||
under `$XDG_CONFIG_HOME/weknora/secrets/`. The active profile lives in
|
||
`~/.config/weknora/config.yaml`.
|
||
|
||
To remove a profile's stored credentials:
|
||
|
||
```bash
|
||
weknora auth logout # current profile
|
||
weknora auth logout --name staging # specific
|
||
weknora auth logout --all
|
||
```
|
||
|
||
---
|
||
|
||
## Wire contract
|
||
|
||
Designed to be AI-agent-first. Stable across minor releases; breaking
|
||
changes announced in the changelog and the corresponding
|
||
`weknora --version` bump.
|
||
|
||
### Streams
|
||
|
||
- **stdout** is the data channel: bare JSON with `--format json`, or
|
||
human-formatted output. Never carries error text.
|
||
- **stderr** is logs, progress, warnings, and errors. A non-empty
|
||
stderr does **not** mean failure — read the exit code.
|
||
|
||
### JSON output
|
||
|
||
Every command supports `--format json`, emitting bare JSON for the
|
||
resource it produces — an array for `list` / `search`, a single object
|
||
for `view` and write outcomes:
|
||
|
||
```bash
|
||
weknora kb list --format json # [{ "id": "kb_x", "name": "Eng" }, …]
|
||
weknora kb view kb_x --format json # { "id": "kb_x", "name": "Eng", … }
|
||
weknora kb list --format json --jq '.[] | {id, name}' # project to listed fields
|
||
weknora kb list --format json --jq '.[].id' # jq over the bare data
|
||
```
|
||
|
||
`--format ndjson` is also accepted for streaming list commands; each
|
||
element is emitted as its own JSON line. `--format json` is the default
|
||
regardless of TTY — running `weknora kb list | jq` works without an
|
||
explicit flag. Use `--format text` for human-readable output.
|
||
|
||
### Errors
|
||
|
||
On failure, stdout stays empty and the typed error goes to stderr in
|
||
this format:
|
||
|
||
```
|
||
<code.namespace>: <message>[: <wrapped cause>]
|
||
hint: <actionable next-step>
|
||
```
|
||
|
||
Example:
|
||
|
||
```
|
||
auth.unauthenticated: fetch current user: HTTP error 401: ...
|
||
hint: run `weknora auth login`
|
||
```
|
||
|
||
The full code registry is in `cli/internal/cmdutil/errors.go`
|
||
(`AllCodes()`). Code namespaces: `auth.*` / `resource.*` / `input.*` /
|
||
`server.*` / `network.*` / `local.*` / `mcp.*` / `operation.*` (CLI-level
|
||
wait/poll outcomes: `operation.timeout`, `operation.failed`, `operation.cancelled`).
|
||
|
||
### Exit codes
|
||
|
||
| Code | Meaning | Agent action |
|
||
|---|---|---|
|
||
| `0` | success | continue |
|
||
| `1` | typed `local.*` / `operation.failed` / unclassified | read stderr, decide retry/abort |
|
||
| `2` | flag / argument validation error | re-check `weknora <cmd> --help` |
|
||
| `3` | `auth.*` (token missing / expired / forbidden) | re-auth, then retry |
|
||
| `4` | `resource.not_found` | verify the resource id |
|
||
| `5` | `input.*` (other than `confirmation_required`) | adjust args, retry |
|
||
| `6` | `server.rate_limited` | back off, retry |
|
||
| `7` | `server.*` / `network.*` | transient — retry with backoff |
|
||
| `10` | **`input.confirmation_required`** (high-risk write) | ask the human, retry with `-y` only after explicit approval |
|
||
| `124` | `operation.timeout` (e.g. `doc wait --timeout` reached) | raise `--timeout` or check the underlying job |
|
||
| `130` | `operation.cancelled` (SIGINT / SIGTERM) | stop, do not retry |
|
||
|
||
**Exit 10** is the wire-level signal for "destructive write needs
|
||
explicit confirmation". Pass `-y/--yes` on `kb delete` /
|
||
`doc delete` (including `--all --kb=<id>`) / `session delete` /
|
||
`profile remove` (on the current profile) / `agent delete` /
|
||
`chunk delete` when running headless.
|
||
**Never auto-add `-y` without the user's explicit go-ahead** — exit 10
|
||
is the guard against unintended writes.
|
||
|
||
### Other AI-agent ergonomics
|
||
|
||
- For chat / session ask in AI-agent contexts, pass `--format json` —
|
||
streaming tokens to stdout makes JSON parsing impossible.
|
||
- `--format json` composes with the global `--profile <name>` for
|
||
single-shot profile overrides without disk writes.
|
||
- `weknora mcp serve` exposes a curated read-only tool surface over
|
||
stdio MCP for any MCP-compatible client.
|
||
|
||
---
|
||
|
||
## Advanced operations not exposed as flags
|
||
|
||
WeKnora CLI exposes top use cases as polished commands; deep
|
||
configuration goes through the raw HTTP passthrough. CLI flag coverage
|
||
targets common workflows, not 1:1 API parity. Examples of deep
|
||
operations that intentionally go through `weknora api`:
|
||
|
||
- **Tuning a KB's nested config** — chunking strategy, summary model,
|
||
multimodal extraction defaults, FAQ thresholds, VLM model. Use
|
||
`weknora api PUT /api/v1/knowledge-bases/<id> --input -` with a JSON
|
||
body matching the server's `UpdateKnowledgeBaseRequest`. (Note: the
|
||
storage provider is set once at create time via
|
||
`kb create --storage-provider <name>` and is not updatable.)
|
||
- **Per-request `chat` parameters** — multi-KB scope, summary model
|
||
override, image attachments, web search toggle. Use `weknora api POST
|
||
/api/v1/knowledge-chat/<session-id> --input -`.
|
||
- **Per-request `session ask --agent` overrides** — same shape via
|
||
`weknora api POST /api/v1/agent-chat/<session-id> --input -`.
|
||
- **Operations without a CLI verb** — register / change-password /
|
||
OIDC flows, organization / sharing endpoints, tenant management.
|
||
|
||
`weknora api --help` documents the raw passthrough. Run
|
||
`weknora doctor` first to verify auth and base URL.
|
||
|
||
---
|
||
|
||
## Dry-run preview
|
||
|
||
Add `--dry-run` to any mutation command to preview the would-be action without executing it. Useful for verifying flag/arg parsing before committing to a destructive operation, or for agent-side action planning.
|
||
|
||
```bash
|
||
# Preview a kb create without actually creating
|
||
weknora kb create --name "test-kb" --description "for review" --dry-run
|
||
|
||
# Output (single line; pretty-printed here for readability):
|
||
# {
|
||
# "ok": true,
|
||
# "meta": {
|
||
# "dry_run": true,
|
||
# "plan": {
|
||
# "action": "kb.create",
|
||
# "args": {"name": "test-kb", "description": "for review"}
|
||
# }
|
||
# }
|
||
# }
|
||
# Exit code: 0
|
||
```
|
||
|
||
dry-run is **offline**: no network calls, no file IO, no credential touches. Works without an active profile.
|
||
|
||
For destructive commands, dry-run does NOT trigger the exit-10 confirmation flow:
|
||
|
||
```bash
|
||
weknora kb delete kb_xxxx --dry-run # exit 0, no prompt
|
||
weknora kb delete kb_xxxx # exit 10, prompts for -y
|
||
```
|
||
|
||
For the `api` command, dry-run requires explicit write method (POST/PUT/PATCH/DELETE); GET returns FlagError:
|
||
|
||
```bash
|
||
echo '{"name":"foo"}' | weknora api -X POST /api/v1/knowledge-bases --input - --dry-run # OK
|
||
weknora api /api/v1/knowledge-bases --dry-run # exit 2: requires explicit -X
|
||
```
|
||
|
||
---
|
||
|
||
## Resuming streams
|
||
|
||
The `weknora session continue-stream` command resumes an SSE event stream for an existing assistant message. Useful for network-blip recovery or polling long-running agent invocations:
|
||
|
||
```bash
|
||
# Original streaming call captures session_id + message_id from init event:
|
||
weknora session ask "..." --kb kb_xxxx --format ndjson | tee /tmp/stream.ndjson
|
||
# {"event":"init","session_id":"sess_abc","message_id":"msg_xyz"}
|
||
# ... events flow ...
|
||
# [network blip]
|
||
|
||
# Resume the same stream:
|
||
weknora session continue-stream sess_abc --message msg_xyz
|
||
# Server REPLAYS all stored events from the start, then tails new ones.
|
||
# Agent must dedupe (by message_id or event hash) to avoid double-processing.
|
||
```
|
||
|
||
Server-side buffer TTL: 1 hour for redis mode; process lifetime for memory mode (default). After TTL, expect `local.sse_stream_aborted` typed error.
|
||
|
||
See `cli/AGENTS.md` "Stream recovery" section for the full agent contract.
|
||
|
||
---
|
||
|
||
## Health check
|
||
|
||
Run `weknora doctor` for a 4-status diagnostic (OK / warn / fail /
|
||
skip) covering base URL reachability, authentication, server-CLI
|
||
version skew, and credential storage backend. Add `--format json` for
|
||
machine-readable output, `--offline` to skip network checks.
|
||
|
||
For per-resource verification, the `status` / `check` verb pair gives
|
||
a fast vs deep choice:
|
||
|
||
| Verb | Cost | Use |
|
||
|---|---|---|
|
||
| `weknora kb status <kb-id>` | 1 HTTP | live counts / processing flag |
|
||
| `weknora kb check <kb-id>` | 1+N HTTP | adds `failed_count` via doc-list page-walk |
|
||
| `weknora agent status <agent-id>` | 1 HTTP | reachable / model_id |
|
||
| `weknora agent check <agent-id>` | 1+N HTTP | also probes every KB in the agent's scope |
|
||
|
||
`weknora doc wait <doc-id> [<doc-id>...]` blocks until each document
|
||
reaches a terminal `parse_status` (completed or failed). Exit codes:
|
||
0 (all completed), 1 (any failed), 124 (`--timeout` reached), 130
|
||
(Ctrl-C / SIGTERM). Multi-target is polled concurrently (max 5 in
|
||
flight; pipe through `xargs -P` for more).
|
||
|
||
---
|
||
|
||
## Development
|
||
|
||
```bash
|
||
# Run unit + contract tests
|
||
go test ./...
|
||
|
||
# Run the real-server e2e suite (requires WEKNORA_E2E_HOST + token env vars)
|
||
go test -tags acceptance_e2e ./acceptance/e2e/...
|
||
|
||
# Static analysis
|
||
go vet ./...
|
||
```
|
||
|
||
CI (`.github/workflows/cli.yml`) runs build + unit + contract tests on Linux /
|
||
macOS / Windows × Go 1.26, path-filtered to changes under `cli/`.
|
||
|
||
---
|
||
|
||
## Contributing / Reporting issues
|
||
|
||
- **Bugs and feature requests**: file an issue at
|
||
[github.com/Tencent/WeKnora/issues](https://github.com/Tencent/WeKnora/issues).
|
||
- **Security disclosures**: see the repository-level
|
||
[SECURITY.md](../SECURITY.md). Do not file public issues for
|
||
security findings.
|
||
- **Pull requests**: the developer guide for editing the CLI lives in
|
||
[AGENTS.md](AGENTS.md) (build / test / command-surface design SOP /
|
||
CRUD flag conventions). Run `go test ./... -race -count=1` and `go vet ./...`
|
||
before submitting.
|
||
|
||
---
|
||
|
||
## License
|
||
|
||
MIT — see the repository [LICENSE](../LICENSE).
|