Requirements
- Target platform
- OpenClaw
- Install method
- Manual import
- Extraction
- Extract archive
- Prerequisites
- OpenClaw
- Primary doc
- SKILL.md
Control Minecraft bots through a Mineflayer controller API using JSON actions and cron-driven autonomy.
Control Minecraft bots through a Mineflayer controller API using JSON actions and cron-driven autonomy.
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
I downloaded a skill package from Yavira. Read SKILL.md from the extracted folder and install it by following the included instructions. Tell me what you changed and call out any manual steps you could not complete.
I downloaded an updated skill package from Yavira. Read SKILL.md from the extracted folder, compare it with my current installation, and upgrade it while preserving any custom configuration unless the package docs explicitly say otherwise. Summarize what changed and any follow-up checks I should run.
Use this skill to create and control Minecraft bots via a controller API. The controller executes only JSON actions. Do not send API keys or other secrets to the controller. The agent performs LLM reasoning locally and only sends actions.
If open registration is enabled, the agent can self-issue a token: curl -sS -X POST "https://56eb-125-246-120-211.ngrok-free.app/v1/auth/open/register" \ -H "Content-Type: application/json" \ -d '{"agentName":"andy"}' Recommended: store the response in memory/mc-auth.json and reuse the accessToken for future calls.
Base URL: https://56eb-125-246-120-211.ngrok-free.app/v1 MC_CONTROLLER_TOKEN (agent-specific JWT) To obtain a JWT, an operator should call POST /v1/auth/register with the master issuer secret and share the returned accessToken with the agent. Refresh tokens can be rotated via POST /v1/auth/refresh. If you don't want to share the master secret, the controller can expose POST /v1/auth/proxy/register with allowlist + rate-limit. In that mode, the agent requests an access token using a proxyKey. If open registration is enabled (POST /v1/auth/open/register), the agent can request an access token without a proxy key. This is less secure and should only be used when you accept open access.
Never send LLM API keys to the controller. Only control bots owned by your token. Prefer queue: queue unless you must interrupt a running task.
Ensure the bot exists; create it if missing. Connect the bot to the Minecraft server. Read state for current context. Send an action request. Poll task status or subscribe to events.
For autonomous behavior, repeat: GET /bots/{botId}/state If metadata.currentTaskId is set, wait briefly and loop. Decide a safe action bundle (5 to 10 actions) and send it via POST /bots/{botId}/act-batch. Use mode: until or mode: loop with timeoutMs per action.
This project uses Gateway cron (not heartbeat) for autonomous loops. After installing this skill, ensure: Overwrite the workspace root CRON_PROMPT.md with skills/openclaw-minecraft/CRON_PROMPT.md (always, regardless of existing file). A cron job runs every 30 seconds and instructs the agent to follow CRON_PROMPT.md.
curl -sS -X POST "https://56eb-125-246-120-211.ngrok-free.app/v1/bots" \ -H "Authorization: Bearer $MC_CONTROLLER_TOKEN" \ -H "Content-Type: application/json" \ -d '{"botId":"<botId>","username":"<botId>"}'
curl -sS -X POST "https://56eb-125-246-120-211.ngrok-free.app/v1/bots/<botId>/connect" \ -H "Authorization: Bearer $MC_CONTROLLER_TOKEN" \ -H "Content-Type: application/json" \ -d '{"host":"127.0.0.1","port":25565,"version":"1.21.9"}'
curl -sS -X GET "https://56eb-125-246-120-211.ngrok-free.app/v1/bots/<botId>/state" \ -H "Authorization: Bearer $MC_CONTROLLER_TOKEN"
curl -sS -X POST "https://56eb-125-246-120-211.ngrok-free.app/v1/bots/<botId>/act-batch" \ -H "Authorization: Bearer $MC_CONTROLLER_TOKEN" \ -H "Content-Type: application/json" \ -d '{ "actions":[ { "action":"chat", "params":{"message":"hello"}, "mode":"loop", "intervalMs":2000, "maxIterations":3 } ] }'
curl -sS -X POST "https://56eb-125-246-120-211.ngrok-free.app/v1/bots/<botId>/act-batch" \ -H "Authorization: Bearer $MC_CONTROLLER_TOKEN" \ -H "Content-Type: application/json" \ -d '{ "actions":[ { "action":"move_to", "params":{"x":10,"y":64,"z":-12}, "mode":"until", "stopCondition":{"type":"reach_position","radius":1.5}, "timeoutMs":60000 } ] }'
Convert natural-language goals to a batch of JSON actions. If the goal requires multiple steps, include them in order in one batch. Each batch must include 5 to 10 actions. Use mode: until for navigation or repeated tasks. Use mode: loop for periodic actions (e.g., scanning, chat). Use only supported actions: chat, move_to, move_relative, move, dig, place, equip, use_item, attack, follow, jump.
JSON-only payloads for now. Media/attachments are not supported yet. Actions are best-effort and may fail if the bot is not connected or lacks items.
Workflow acceleration for inboxes, docs, calendars, planning, and execution loops.
Largest current source with strong distribution and engagement signals.