Build or update the BlueBubbles external channel plugin for Moltbot (extension package, REST...
npx skills add zonghui1968/clawd-skills --skill "portainer"
Install specific skill from multi-skill repository
# Description
Control Docker containers and stacks via Portainer API. List containers, start/stop/restart, view logs, and redeploy stacks from git.
# SKILL.md
name: portainer
description: Control Docker containers and stacks via Portainer API. List containers, start/stop/restart, view logs, and redeploy stacks from git.
metadata: {"clawdbot":{"emoji":"π³","requires":{"bins":["curl","jq"],"env":["PORTAINER_API_KEY"]},"primaryEnv":"PORTAINER_API_KEY"}}
π³ Portainer Skill
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
β β
β π³ P O R T A I N E R C O N T R O L C L I π³ β
β β
β Manage Docker containers via Portainer API β
β Start, stop, deploy, redeploy β
β β
βββββββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
"Docker containers? I'll handle them from my lily pad." πΈ
π What Does This Skill Do?
The Portainer Skill gives you control over your Docker infrastructure through Portainer's REST API. Manage containers, stacks, and deployments without touching the web UI.
Features:
- π Status β Check Portainer server status
- π₯οΈ Endpoints β List all Docker environments
- π¦ Containers β List, start, stop, restart containers
- π Stacks β List and manage Docker Compose stacks
- π Redeploy β Pull from git and redeploy stacks
- π Logs β View container logs
βοΈ Requirements
| What | Details |
|---|---|
| Portainer | Version 2.x with API access |
| Tools | curl, jq |
| Auth | API Access Token |
Setup
- Get API Token from Portainer:
- Log into Portainer web UI
- Click username β My Account
- Scroll to "Access tokens" β Add access token
-
Copy the token (you won't see it again!)
-
Configure credentials:
bash # Add to ~/.clawdbot/.env PORTAINER_URL=https://your-portainer-server:9443 PORTAINER_API_KEY=ptr_your_token_here -
Ready! π
π οΈ Commands
status β Check Portainer Server
./portainer.sh status
Output:
Portainer v2.27.3
endpoints β List Environments
./portainer.sh endpoints
Output:
3: portainer (local) - β online
4: production (remote) - β online
containers β List Containers
# List containers on default endpoint (4)
./portainer.sh containers
# List containers on specific endpoint
./portainer.sh containers 3
Output:
steinbergerraum-web-1 running Up 2 days
cora-web-1 running Up 6 weeks
minecraft running Up 6 weeks (healthy)
stacks β List All Stacks
./portainer.sh stacks
Output:
25: steinbergerraum - β active
33: cora - β active
35: minecraft - β active
4: pulse-website - β inactive
stack-info β Stack Details
./portainer.sh stack-info 25
Output:
{
"Id": 25,
"Name": "steinbergerraum",
"Status": 1,
"EndpointId": 4,
"GitConfig": "https://github.com/user/repo",
"UpdateDate": "2026-01-25T08:44:56Z"
}
redeploy β Pull & Redeploy Stack π
./portainer.sh redeploy 25
Output:
β Stack 'steinbergerraum' redeployed successfully
This will:
1. Pull latest code from git
2. Rebuild containers if needed
3. Restart the stack
start / stop / restart β Container Control
# Start a container
./portainer.sh start steinbergerraum-web-1
# Stop a container
./portainer.sh stop steinbergerraum-web-1
# Restart a container
./portainer.sh restart steinbergerraum-web-1
# Specify endpoint (default: 4)
./portainer.sh restart steinbergerraum-web-1 4
Output:
β Container 'steinbergerraum-web-1' restarted
logs β View Container Logs
# Last 100 lines (default)
./portainer.sh logs steinbergerraum-web-1
# Last 50 lines
./portainer.sh logs steinbergerraum-web-1 4 50
π― Example Workflows
π "Deploy Website Update"
# After merging PR
./portainer.sh redeploy 25
./portainer.sh logs steinbergerraum-web-1 4 20
π§ "Debug Container"
./portainer.sh containers
./portainer.sh logs cora-web-1
./portainer.sh restart cora-web-1
π "System Overview"
./portainer.sh status
./portainer.sh endpoints
./portainer.sh containers
./portainer.sh stacks
π§ Troubleshooting
β "Authentication required / Repository not found"
Problem: Stack redeploy fails with git auth error
Solution: The stack needs repositoryGitCredentialID parameter. The script handles this automatically by reading from the existing stack config.
β "Container not found"
Problem: Container name doesn't match
Solution: Use exact name from ./portainer.sh containers:
- Include the full name: steinbergerraum-web-1 not steinbergerraum
- Names are case-sensitive
β "PORTAINER_URL and PORTAINER_API_KEY must be set"
Problem: Credentials not configured
Solution:
# Add to ~/.clawdbot/.env
echo "PORTAINER_URL=https://your-server:9443" >> ~/.clawdbot/.env
echo "PORTAINER_API_KEY=ptr_your_token" >> ~/.clawdbot/.env
π Integration with Clawd
"Redeploy the website"
β ./portainer.sh redeploy 25
"Show me running containers"
β ./portainer.sh containers
"Restart the Minecraft server"
β ./portainer.sh restart minecraft
"What stacks do we have?"
β ./portainer.sh stacks
π Changelog
| Version | Date | Changes |
|---|---|---|
| 1.0.0 | 2026-01-25 | Initial release |
πΈ Credits
@..@
(----)
( >__< ) "Containers are just fancy lily pads
^^ ^^ for your code to hop around!"
Author: Andy Steinberger (with help from his Clawdbot Owen the Frog πΈ)
Powered by: Portainer API
Part of: Clawdbot Skills Collection
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.