# Send Proxmox Full to your agent
Hand the extracted package to your coding agent with a concrete install brief instead of figuring it out manually.
## Fast path
- Download the package from Yavira.
- Extract it into a folder your agent can access.
- Paste one of the prompts below and point your agent at the extracted folder.
## Suggested prompts
### New install

```text
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.
```
### Upgrade existing

```text
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.
```
## Machine-readable fields
```json
{
  "schemaVersion": "1.0",
  "item": {
    "slug": "proxmox-full",
    "name": "Proxmox Full",
    "source": "tencent",
    "type": "skill",
    "category": "AI 智能",
    "sourceUrl": "https://clawhub.ai/mSarheed/proxmox-full",
    "canonicalUrl": "https://clawhub.ai/mSarheed/proxmox-full",
    "targetPlatform": "OpenClaw"
  },
  "install": {
    "downloadUrl": "/downloads/proxmox-full",
    "sourceDownloadUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=proxmox-full",
    "sourcePlatform": "tencent",
    "targetPlatform": "OpenClaw",
    "packageFormat": "ZIP package",
    "primaryDoc": "SKILL.md",
    "includedAssets": [
      "SKILL.md"
    ],
    "downloadMode": "redirect",
    "sourceHealth": {
      "source": "tencent",
      "slug": "proxmox-full",
      "status": "healthy",
      "reason": "direct_download_ok",
      "recommendedAction": "download",
      "checkedAt": "2026-05-03T06:39:54.465Z",
      "expiresAt": "2026-05-10T06:39:54.465Z",
      "httpStatus": 200,
      "finalUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=proxmox-full",
      "contentType": "application/zip",
      "probeMethod": "head",
      "details": {
        "probeUrl": "https://wry-manatee-359.convex.site/api/v1/download?slug=proxmox-full",
        "contentDisposition": "attachment; filename=\"proxmox-full-1.0.0.zip\"",
        "redirectLocation": null,
        "bodySnippet": null,
        "slug": "proxmox-full"
      },
      "scope": "item",
      "summary": "Item download looks usable.",
      "detail": "Yavira can redirect you to the upstream package for this item.",
      "primaryActionLabel": "Download for OpenClaw",
      "primaryActionHref": "/downloads/proxmox-full"
    },
    "validation": {
      "installChecklist": [
        "Use the Yavira download entry.",
        "Review SKILL.md after the package is downloaded.",
        "Confirm the extracted package contains the expected setup assets."
      ],
      "postInstallChecks": [
        "Confirm the extracted package includes the expected docs or setup files.",
        "Validate the skill or prompts are available in your target agent workspace.",
        "Capture any manual follow-up steps the agent could not complete."
      ]
    }
  },
  "links": {
    "detailUrl": "https://openagent3.xyz/skills/proxmox-full",
    "downloadUrl": "https://openagent3.xyz/downloads/proxmox-full",
    "agentUrl": "https://openagent3.xyz/skills/proxmox-full/agent",
    "manifestUrl": "https://openagent3.xyz/skills/proxmox-full/agent.json",
    "briefUrl": "https://openagent3.xyz/skills/proxmox-full/agent.md"
  }
}
```
## Documentation

### Proxmox VE - Full Management

Complete control over Proxmox VE hypervisor via REST API.

### Setup

export PVE_URL="https://192.168.1.10:8006"
export PVE_TOKEN="user@pam!tokenid=secret-uuid"

Create API token: Datacenter → Permissions → API Tokens → Add (uncheck Privilege Separation)

### Auth Header

AUTH="Authorization: PVEAPIToken=$PVE_TOKEN"

### Cluster & Nodes

# Cluster status
curl -sk -H "$AUTH" "$PVE_URL/api2/json/cluster/status" | jq

# List nodes
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes" | jq '.data[] | {node, status, cpu: (.cpu*100|round), mem_pct: (.mem/.maxmem*100|round)}'

# Node details
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/status" | jq

### List VMs & Containers

# All VMs on node
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu" | jq '.data[] | {vmid, name, status}'

# All LXC on node
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/lxc" | jq '.data[] | {vmid, name, status}'

# Cluster-wide (all VMs + LXC)
curl -sk -H "$AUTH" "$PVE_URL/api2/json/cluster/resources?type=vm" | jq '.data[] | {node, type, vmid, name, status}'

### VM/Container Control

# Start
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/status/start"

# Stop (immediate)
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/status/stop"

# Shutdown (graceful)
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/status/shutdown"

# Reboot
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/status/reboot"

# For LXC: replace /qemu/ with /lxc/

### Create LXC Container

# Get next available VMID
NEWID=$(curl -sk -H "$AUTH" "$PVE_URL/api2/json/cluster/nextid" | jq -r '.data')

# Create container
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/lxc" \\
  -d "vmid=$NEWID" \\
  -d "hostname=my-container" \\
  -d "ostemplate=local:vztmpl/debian-12-standard_12.2-1_amd64.tar.zst" \\
  -d "storage=local-lvm" \\
  -d "rootfs=local-lvm:8" \\
  -d "memory=1024" \\
  -d "swap=512" \\
  -d "cores=2" \\
  -d "net0=name=eth0,bridge=vmbr0,ip=dhcp" \\
  -d "password=changeme123" \\
  -d "start=1"

LXC Parameters:

ParamExampleDescriptionvmid200Container IDhostnamemyctContainer hostnameostemplatelocal:vztmpl/debian-12-...Template pathstoragelocal-lvmStorage for rootfsrootfslocal-lvm:8Root disk (8GB)memory1024RAM in MBswap512Swap in MBcores2CPU coresnet0name=eth0,bridge=vmbr0,ip=dhcpNetwork configpasswordsecretRoot passwordssh-public-keysssh-rsa ...SSH keys (URL encoded)unprivileged1Unprivileged containerstart1Start after creation

### Create VM

# Get next VMID
NEWID=$(curl -sk -H "$AUTH" "$PVE_URL/api2/json/cluster/nextid" | jq -r '.data')

# Create VM
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu" \\
  -d "vmid=$NEWID" \\
  -d "name=my-vm" \\
  -d "memory=2048" \\
  -d "cores=2" \\
  -d "sockets=1" \\
  -d "cpu=host" \\
  -d "net0=virtio,bridge=vmbr0" \\
  -d "scsi0=local-lvm:32" \\
  -d "scsihw=virtio-scsi-pci" \\
  -d "ide2=local:iso/ubuntu-22.04.iso,media=cdrom" \\
  -d "boot=order=scsi0;ide2;net0" \\
  -d "ostype=l26"

VM Parameters:

ParamExampleDescriptionvmid100VM IDnamemyvmVM namememory2048RAM in MBcores2CPU cores per socketsockets1CPU socketscpuhostCPU typenet0virtio,bridge=vmbr0Networkscsi0local-lvm:32Disk (32GB)ide2local:iso/file.iso,media=cdromISOostypel26 (Linux), win11OS typebootorder=scsi0;ide2Boot order

### Clone VM/Container

# Clone VM
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/clone" \\
  -d "newid=201" \\
  -d "name=cloned-vm" \\
  -d "full=1" \\
  -d "storage=local-lvm"

# Clone LXC
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/lxc/{vmid}/clone" \\
  -d "newid=202" \\
  -d "hostname=cloned-ct" \\
  -d "full=1" \\
  -d "storage=local-lvm"

Clone Parameters:

ParamDescriptionnewidNew VMIDname/hostnameNew namefull1=full clone, 0=linked clonestorageTarget storagetargetTarget node (for migration)

### Convert to Template

# Convert VM to template
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/template"

# Convert LXC to template
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/lxc/{vmid}/template"

### Snapshots

# List snapshots
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/snapshot" | jq '.data[] | {name, description}'

# Create snapshot
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/snapshot" \\
  -d "snapname=before-update" \\
  -d "description=Snapshot before system update"

# Rollback
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/snapshot/{snapname}/rollback"

# Delete snapshot
curl -sk -X DELETE -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}/snapshot/{snapname}"

### Backups

# Start backup
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/vzdump" \\
  -d "vmid={vmid}" \\
  -d "storage=local" \\
  -d "mode=snapshot" \\
  -d "compress=zstd"

# List backups
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/storage/{storage}/content?content=backup" | jq

# Restore backup
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu" \\
  -d "vmid=300" \\
  -d "archive=local:backup/vzdump-qemu-100-2024_01_01-12_00_00.vma.zst" \\
  -d "storage=local-lvm"

### Storage & Templates

# List storage
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/storage" | jq '.data[] | {storage, type, avail, used}'

# List available templates
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/storage/local/content?content=vztmpl" | jq '.data[] | .volid'

# List ISOs
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/storage/local/content?content=iso" | jq '.data[] | .volid'

# Download template
curl -sk -X POST -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/aplinfo" \\
  -d "storage=local" \\
  -d "template=debian-12-standard_12.2-1_amd64.tar.zst"

### Tasks

# Recent tasks
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/tasks?limit=10" | jq '.data[] | {upid, type, status}'

# Task status
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/tasks/{upid}/status" | jq

# Task log
curl -sk -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/tasks/{upid}/log" | jq -r '.data[].t'

### Delete VM/Container

# Delete VM (must be stopped)
curl -sk -X DELETE -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}"

# Delete LXC
curl -sk -X DELETE -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/lxc/{vmid}"

# Force delete (purge)
curl -sk -X DELETE -H "$AUTH" "$PVE_URL/api2/json/nodes/{node}/qemu/{vmid}?purge=1&destroy-unreferenced-disks=1"

### Quick Reference

ActionEndpointMethodList nodes/nodesGETList VMs/nodes/{node}/qemuGETList LXC/nodes/{node}/lxcGETCreate VM/nodes/{node}/qemuPOSTCreate LXC/nodes/{node}/lxcPOSTClone/nodes/{node}/qemu/{vmid}/clonePOSTStart/nodes/{node}/qemu/{vmid}/status/startPOSTStop/nodes/{node}/qemu/{vmid}/status/stopPOSTSnapshot/nodes/{node}/qemu/{vmid}/snapshotPOSTDelete/nodes/{node}/qemu/{vmid}DELETENext ID/cluster/nextidGET

### Notes

Use -k for self-signed certs
API tokens don't need CSRF
Replace {node} with node name (e.g., pve)
Replace {vmid} with VM/container ID
Use qemu for VMs, lxc for containers
All create/clone operations return task UPID for tracking
## Trust
- Source: tencent
- Verification: Indexed source record
- Publisher: mSarheed
- Version: 1.0.0
## Source health
- Status: healthy
- Item download looks usable.
- Yavira can redirect you to the upstream package for this item.
- Health scope: item
- Reason: direct_download_ok
- Checked at: 2026-05-03T06:39:54.465Z
- Expires at: 2026-05-10T06:39:54.465Z
- Recommended action: Download for OpenClaw
## Links
- [Detail page](https://openagent3.xyz/skills/proxmox-full)
- [Send to Agent page](https://openagent3.xyz/skills/proxmox-full/agent)
- [JSON manifest](https://openagent3.xyz/skills/proxmox-full/agent.json)
- [Markdown brief](https://openagent3.xyz/skills/proxmox-full/agent.md)
- [Download page](https://openagent3.xyz/downloads/proxmox-full)