Chapter 27 — thClaws.cloud
thClaws.cloud is the catalog + hosted runtime for thClaws agents. It
turns the folder-is-an-agent model (Chapter 8) into something you
can browse, publish, install on someone else’s machine, or rent a
hosted workspace for. From your desktop thClaws, the cloud feels like
git for AI agents — paste a CLI token once in Settings, then every
catalog op (/cloud get, /cloud publish, /cloud list, …) runs as
a slash command inside an open thClaws session.
What this chapter covers (client side). Browsing the catalog, publishing your own agents, getting agents into a local folder, and the new
agent.{name, description, uuid}block insettings.json. The operator-side runbook for running your own catalog server lives in the dev plan (dev-plan/34) and the workspace-privatethclaws-cloud/source tree.
The folder-is-an-agent model — recap
Anywhere thClaws runs, an AI agent is a folder. Three files at the root of that folder make it complete:
AGENTS.md— the agent’s instructions (system prompt + persona).manifest.json— catalog metadata (slug, license, icon, tags). Only needed to publish../.thclaws/— local state (settings, KMS, sessions, memory).
When you cd into the folder and run thClaws, you’re “running that
agent”. When you publish, the catalog packages those files into a
tarball; when someone else runs /cloud get <slug> from inside their
own thClaws session, they get the same folder. The cloud is just a
way to move folders between machines.
Setting the catalog URL + a CLI token
Two things bind your desktop to a catalog server:
- Cloud URL —
settings.json::cloud.url. Defaults to the public instance (https://thclaws.cloud); point athttp://localhostor your own self-hosted instance by overriding it. - CLI token — a
thc_…string from the catalog dashboard, stored in the OS keychain (never insettings.json).
Settings → thClaws.cloud has fields for both. Paste the URL, paste the token from your dashboard’s Mint CLI token button, hit Save — every slash command in the rest of this chapter works immediately.
The token never goes through a shell argument or environment variable —
the GUI stores it directly in the OS keychain (macOS Keychain / Windows
Credential Manager / Linux Secret Service), and every catalog request
sends it as a Bearer header from inside the engine process. No ps
or shell-history leak.
Why no CLI subcommand? Earlier releases had a
thclaws cloud login --token …flow. Removed because tokens threaded throughargvended up in shell histories and anyps-style tool dump. Settings UI + keychain is the only way now. Running any oldthclaws cloud …command prints an error that points at the new flow.
Browsing the catalog
From inside any thClaws session (REPL or Chat tab):
❯ /cloud status
thClaws.cloud — https://thclaws.cloud (token: ✓ stored)
❯ /cloud list
- hello-world v0.1.0 Hello-world demo agent (jimmy)
- legal-doc-reviewer v0.4.2 Reviews contracts paragraph-by-paragraph (acme)
- weekly-research v1.0.0 Saturday-morning newsletter writer (rin)
...
❯ /cloud list --mine
- weekly-research v1.0.0 Saturday-morning newsletter writer (you)
Each row is a single agent in the catalog. The slug is what you pass
to /cloud get.
Installing an agent into a folder
/cloud get always installs into the current session’s working
directory. The typical flow:
# 1. From a shell — make an empty folder for the agent and cd into it.
mkdir my-hello && cd my-hello
# 2. Start a thClaws session there.
thclaws # GUI default; --cli for the REPL
Then inside the session:
❯ /cloud get hello-world
Downloading hello-world (v0.1.0) …
Extracted to /Users/jimmy/my-hello/
✓ AGENTS.md
✓ manifest.json
✓ skills/greet.md
Done. /reload to pick up the new AGENTS.md.
The engine downloads the tarball, extracts every file into the cwd, and
the next /reload reads the new AGENTS.md. No shell tab-out needed.
The folder-safety check
/cloud get refuses to overwrite a non-empty folder unless the folder
already holds the same agent (matched by UUID, see below) or you
pass --force. The check works like this:
| Target folder state | Behaviour |
|---|---|
| Empty | Fresh install. |
Has AGENTS.md / manifest.json with a matching agent.uuid |
Safe update — overwrites in place, preserves your .thclaws/ session state. |
Has AGENTS.md / manifest.json with a mismatched UUID |
Abort with an error. The folder belongs to another agent. |
| Other random files (notes, scratch, etc.) | Abort unless --force. |
This is intentional — it prevents a typo from clobbering an in-progress agent or someone else’s work in the same directory.
Publishing an agent
When you’ve built an agent in a folder and want it in the catalog, start a thClaws session in that folder and use the slash command:
❯ /cloud publish # uploads the cwd
❯ /cloud publish --dry-run # preview the tarball contents, no upload
/cloud publish does three things:
- Tar + gzip the folder. Secrets, sessions, KMS pages, and the
./.thclaws/state directory are stripped automatically — you can re-publish daily without leaking conversation history. - Upload to the catalog using your CLI token.
- Stamp the agent identity back into
settings.json(see the next section).
If manifest.json is missing or invalid, publish aborts with a clear
error. Minimum required fields: id, name, description, version.
Agent identity in settings.json
A new top-level agent block in ./.thclaws/settings.json carries
this folder’s catalog identity:
{
"agent": {
"id": "my-research-bot",
"name": "My Research Bot",
"description": "Saturday-morning newsletter writer",
"uuid": "1f9c1d70-3a26-43c4-9c40-1b1b6e3e3a01"
}
}
- id / name / description — copied from
manifest.jsonat publish time. Used by the catalog UI and by/cloud get’s safety check. - uuid — assigned by the catalog the first time you publish
from this folder, written back into
settings.json. Subsequent publishes hit the same catalog row (version bump). The UUID is what/cloud getmatches against to decide “is this folder the same agent?”
You normally don’t edit this by hand. The GUI Settings → Agent
identity panel lets you tweak name / description (handy before
publishing — the description shows up in catalog listings) but
intentionally hides uuid.
Forking a downloaded agent
If you /cloud get-ed someone else’s agent and want to fork it under
your own name, from inside the agent’s folder session:
❯ /cloud unbind # clears settings.json::agent.uuid
❯ # in the same session: edit AGENTS.md, manifest.json — change `id` to something free
❯ /cloud publish # gets a fresh UUID
Without /cloud unbind, the next publish would try to update the
original author’s catalog row (and fail with a permission error — the
catalog gates publishes by author).
Hosted workspaces (rent, don’t install)
If you don’t want to install agents on your laptop, the catalog also runs them as hosted workspaces — one container per workspace, a URL you open in any browser, a real chat UI backed by the same engine you’d run locally.
From the catalog web UI:
- Browse to an agent’s detail page.
- Click Install on hosted.
- The catalog spins up a workspace, copies the agent’s files in, and
redirects you to the chat UI at
/u/<your-handle>/<slug>/.
Hosted workspaces support both BYOK (paste your own provider keys under Settings → Hosted keys) and the thClaws.cloud gateway (pay-per-use proxy with credit billing — see below). The choice is a radio toggle when you create the workspace.
Pay-per-use gateway (alternative to BYOK)
For users who don’t want to manage Anthropic / OpenAI / Gemini
accounts, thClaws.cloud offers a gateway: top up credits once,
then call any model through gateway.thclaws.cloud/<provider>/...
with a gw_v1_… token. The gateway forwards to upstream, meters the
response, and debits your balance.
To use the gateway from a desktop thClaws:
- Mint a gateway access key in the catalog UI: /gateway/keys →
Mint new gateway key → copy the
gw_v1_…string. - Top up: /credit → pick a pack ($5 / $20 / $100). Bonus credit on the larger packs.
- Configure thClaws to point at the gateway:
bash export ANTHROPIC_API_KEY=gw_v1_… export ANTHROPIC_BASE_URL=https://thclaws.cloud/gateway/anthropic export OPENAI_API_KEY=gw_v1_… export OPENAI_BASE_URL=https://thclaws.cloud/gateway/openai/v1 # …same for GEMINI_*, OPENROUTER_*(Or set the matching*_API_KEY/*_BASE_URLfields in the GUI Settings → Providers panel.) - Run thClaws normally. Calls go via the gateway; spend lands in /credit/usage.
For hosted workspaces, the gateway is auto-wired when you pick Gateway at workspace-create time — the runner gets the env vars injected, no copy-paste needed.
Tier gating
Models are split into three tiers — starter, pro, enterprise.
Your account’s model_tier (set in the catalog dashboard) controls
which models the gateway accepts. Starter accounts get Haiku /
gpt-4o-mini / Gemini Flash; calling Sonnet on starter returns a 403
from the gateway with an upgrade link. Tiers are independent of
balance — having $100 in credit doesn’t unlock enterprise models on
a starter account.
Quick reference
All catalog ops happen inside an open thClaws session — every old
thclaws cloud … CLI form prints an error pointing at the
slash-command equivalent.
| Command | Where | What it does |
|---|---|---|
| Settings → thClaws.cloud | GUI | Cloud URL + CLI token (paste / clear). The only path for login/logout. |
/cloud status |
In-session slash | Show resolved URL + token state |
/cloud list [--mine] |
In-session slash | Browse the catalog |
/cloud get <slug> [--force] |
In-session slash | Install into the session’s cwd |
/cloud publish [--dry-run] |
In-session slash | Upload the session’s cwd |
/cloud unbind |
In-session slash | Clear agent.uuid so the next publish creates a new catalog row |
| Settings → Agent identity | GUI | Edit this folder’s agent.name / description |
/credit (web) |
Catalog UI | Top up + view balance + browse pricing |
/gateway/keys (web) |
Catalog UI | Mint gw_v1_… access keys |
/credit/usage (web) |
Catalog UI | Per-call spend + per-workspace breakdown |
What thClaws.cloud is not
A few things to set expectations:
- Not a model host. Catalog agents still call out to Anthropic / OpenAI / Gemini for inference — either via your own BYOK keys or via the cloud gateway as a billing proxy. thClaws.cloud doesn’t train or serve LLMs itself.
- Not session storage. Conversation history stays in
./.thclaws/sessions/on the machine that ran the agent. The cloud stores agent files, not conversations. - Not required. Every chapter before this one works with no
network at all. The cloud is additive — install thClaws, write
AGENTS.md, and you have a useful agent without ever signing up.