Install
openclaw skills install biznetgioManage Biznet Gio cloud infrastructure (servers, VMs, storage, IPs) via CLI and MCP server
openclaw skills install biznetgio| Field | Value |
|---|---|
| Name | Biznet Gio Cloud Management |
| Description | Manage Biznet Gio cloud infrastructure (servers, VMs, storage, IPs) via CLI and MCP |
| Homepage | https://github.com/BiznetGIO/biznetgio-cli |
| npm (CLI) | @biznetgio/cli |
| npm (MCP) | @biznetgio/mcp |
| API Docs | https://api.portal.biznetgio.com/v1/openapi.json |
| License | MIT |
| Primary Credential | BIZNETGIO_API_KEY |
| Priority | Source | Field / Var | Notes |
|---|---|---|---|
| 1 | ~/.biznetgio.json | api_key | Written by biznetgio login. Mode 0600. |
| 2 | Environment variable | BIZNETGIO_API_KEY | Legacy / CI fallback. |
| 3 | CLI flag | --api-key <key> | Per-command override, beats everything. |
After biznetgio login succeeds, no env var setup is needed — all commands read from the credential file automatically.
| Variable | Required | Description |
|---|---|---|
BIZNETGIO_API_KEY | No (preferred: biznetgio login) | Fallback API token when ~/.biznetgio.json is absent. |
BIZNETGIO_PORTAL_URL | No | Override portal host. Defaults to portal.biznetgio.com. Ignored if credential file already has portal_url. |
BIZNETGIO_BASE_URL | No | Override API base URL. Defaults to https://api.portal.biznetgio.com/v1. |
| Binary | Version | Required | Description |
|---|---|---|---|
node | >= 18 | Yes | Node.js runtime for the CLI and MCP server. |
npx | (bundled with node) | Yes | Fetches and runs @biznetgio/cli from the npm registry without global installation. |
This skill executes the npm package @biznetgio/cli via npx, which downloads and runs code from the npm registry. The package is published under the @biznetgio npm scope by Biznet Gio. Source code is available at github.com/BiznetGIO/biznetgio-cli. If you require stronger guarantees, you can:
npm install -g @biznetgio/cli and verify the package before usenpx @biznetgio/cli@1.0.0 instead of @latestYou are an agent that can manage Biznet Gio cloud infrastructure using the CLI tool @biznetgio/cli and/or MCP server @biznetgio/mcp.
Always check auth status before running any other command. Follow these steps exactly:
npx @biznetgio/cli@latest whoami
Interpret the result:
| Result | Meaning | Action |
|---|---|---|
Exit 0, shows email / client_id | Already logged in | Note the identity and proceed to the task |
Exit non-zero, Not logged in error | No credentials | Go to Step 2 |
Exit non-zero, invalid JSON error | Corrupt credential file | Tell user to delete ~/.biznetgio.json then re-run biznetgio login |
Do not ask the user to paste their API key. The CLI has a secure browser-based login. Tell the user:
"You're not logged in. Please open a terminal and run:
biznetgio loginA browser URL will be displayed. Open it, log in, and the CLI will save your credentials automatically. Let me know when it completes."
Wait for the user to confirm login is done before continuing.
Staging / alternate portal: If the user needs to target a different portal, they can run
BIZNETGIO_PORTAL_URL=staging.biznetgio.com biznetgio login— the override is written into~/.biznetgio.jsonand used for all subsequent commands automatically.
After the user confirms login, run whoami again and report the result to the user:
npx @biznetgio/cli@latest whoami
Tell the user: "Logged in as <email> (client_id: <client_id>) — credentials saved to ~/.biznetgio.json."
Then proceed to the original task.
To remove saved credentials:
biznetgio logout
Deletes ~/.biznetgio.json. If the file is already absent, prints "Already logged out" and exits cleanly. After logout, commands that require authentication will fail until the user runs biznetgio login again.
whoami as described above. Do not skip this step.npx to run the CLI. No installation required.list, detail, products, product-os, product-ip, state, info, usage, regions, openvpn, vm-details, url, credential list, bucket list, object list, keypair list, snapshot list, disk list, and other read-only queries can be executed directly without asking for user approval.# After `biznetgio login` — no env vars needed, credentials come from ~/.biznetgio.json
npx @biznetgio/cli@latest <service> <action> [arguments] [options]
# Fallback: API key via env var (if credential file is absent)
BIZNETGIO_API_KEY=<YOUR_KEY> npx @biznetgio/cli@latest <service> <action> [arguments] [options]
# Per-command override (beats credential file and env var)
npx @biznetgio/cli@latest <service> <action> --api-key <YOUR_KEY> [arguments] [options]
~/.biznetgio.json (preferred) → BIZNETGIO_API_KEY env → --api-key flaghttps://api.portal.biznetgio.com/v1 (override with BIZNETGIO_BASE_URL env)table, use --output json for JSON output| Service | CLI Command | MCP Tool Prefix | Description |
|---|---|---|---|
| NEO Metal | metal | metal_* | Bare metal servers |
| Elastic Storage | elastic-storage | elastic_storage_* | Storage for bare metal |
| Additional IP | additional-ip | additional_ip_* | Additional IPs for bare metal |
| NEO Lite | neolite | neolite_* | Virtual machines (lightweight) |
| NEO Lite Pro | neolite-pro | neolite_pro_* | Virtual machines (pro-tier) |
| Object Storage | object-storage | object_storage_* | S3-compatible object storage |
npx @biznetgio/cli@latest <service> <action> [arguments] [options]
npx @biznetgio/cli@latest <service> <subgroup> <action> [arguments] [options]
Global options: --api-key <key>, --output table|json
price/mo.--output json — Raw JSON from the API .data field.success or true.No data found.--cycle): m (monthly), q (quarterly), s (semi-annual), a (annual), b (biennial), t (triennial), p4, p5on, off, resetstop, suspend, resume, shutdown, start, resetprivate, public-read, public-read-write, authenticated-read, log-delivery-write^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[a-zA-Z\d]{8,}$ (min 8 chars, uppercase + lowercase + digit, alphanumeric only — no special characters)List products first to get valid product_id values:
npx @biznetgio/cli@latest metal products
npx @biznetgio/cli@latest neolite products
npx @biznetgio/cli@latest object-storage products
Check available OS for a product:
npx @biznetgio/cli@latest metal product-os <product_id>
npx @biznetgio/cli@latest neolite product-os <product_id>
Check available keypairs (or create one first):
npx @biznetgio/cli@latest neolite keypair list
npx @biznetgio/cli@latest neolite keypair create --name "my-key"
Check IP availability (neolite):
npx @biznetgio/cli@latest neolite product-ip <product_id>
# Create a bare metal server
npx @biznetgio/cli@latest metal create \
--product-id <id> --cycle m --keypair-id <id> \
--label "my-server" --public-ip 1 --select-os "ubuntu-22.04"
# Create a NEO Lite instance
npx @biznetgio/cli@latest neolite create \
--product-id <id> --cycle m --select-os "Ubuntu-20.04" \
--keypair-id <id> --ssh-and-console-user myuser \
--console-password TestPass123
# Create a NEO Lite Pro instance
npx @biznetgio/cli@latest neolite-pro create \
--product-id <id> --cycle m --select-os "Ubuntu-20.04" \
--keypair-id <id> --ssh-and-console-user myuser \
--console-password TestPass123
# Create object storage (label max 16 chars)
npx @biznetgio/cli@latest object-storage create \
--product-id <id> --cycle m --label "my-storage"
# Create elastic storage (requires metal_account_id)
npx @biznetgio/cli@latest elastic-storage create \
--product-id <id> --cycle m --storage-name "data-vol" \
--metal-account-id <id>
# Create additional IP
npx @biznetgio/cli@latest additional-ip create --product-id <id> --cycle m
npx @biznetgio/cli@latest metal delete <account_id>
npx @biznetgio/cli@latest neolite delete <account_id>
npx @biznetgio/cli@latest neolite-pro delete <account_id>
npx @biznetgio/cli@latest elastic-storage delete <account_id>
npx @biznetgio/cli@latest additional-ip delete <account_id>
npx @biznetgio/cli@latest object-storage delete <account_id>
npx @biznetgio/cli@latest object-storage bucket delete <account_id> <bucket_name>
npx @biznetgio/cli@latest object-storage object delete <account_id> <bucket_name> <path>
npx @biznetgio/cli@latest neolite snapshot delete <account_id>
npx @biznetgio/cli@latest neolite disk delete <account_id>
npx @biznetgio/cli@latest <service> keypair delete <keypair_id>
# NEO Metal: on / off / reset
npx @biznetgio/cli@latest metal set-state <account_id> on
npx @biznetgio/cli@latest metal set-state <account_id> off
# NEO Lite / Pro: start / stop / shutdown / suspend / resume / reset
npx @biznetgio/cli@latest neolite set-state <account_id> start
npx @biznetgio/cli@latest neolite set-state <account_id> stop
npx @biznetgio/cli@latest neolite-pro set-state <account_id> shutdown
# Credential management
npx @biznetgio/cli@latest object-storage credential list <account_id>
npx @biznetgio/cli@latest object-storage credential create <account_id>
npx @biznetgio/cli@latest object-storage credential update <account_id> <access_key> --active
npx @biznetgio/cli@latest object-storage credential delete <account_id> <access_key>
# Bucket operations
npx @biznetgio/cli@latest object-storage bucket list <account_id>
npx @biznetgio/cli@latest object-storage bucket create <account_id> --name my-bucket
npx @biznetgio/cli@latest object-storage bucket info <account_id> <bucket_name>
npx @biznetgio/cli@latest object-storage bucket usage <account_id> <bucket_name>
npx @biznetgio/cli@latest object-storage bucket set-acl <account_id> <bucket_name> --acl public-read
npx @biznetgio/cli@latest object-storage bucket delete <account_id> <bucket_name>
# Object operations
npx @biznetgio/cli@latest object-storage object list <account_id> <bucket_name>
npx @biznetgio/cli@latest object-storage object list <account_id> <bucket_name> <directory>
npx @biznetgio/cli@latest object-storage object info <account_id> <bucket_name> <path>
npx @biznetgio/cli@latest object-storage object download <account_id> <bucket_name> <object_name>
npx @biznetgio/cli@latest object-storage object url <account_id> <bucket_name> <object_name> --expiry 3600
npx @biznetgio/cli@latest object-storage object copy <account_id> <bucket_name> <to_bucket> <object_name>
npx @biznetgio/cli@latest object-storage object move <account_id> <bucket_name> <to_bucket> <object_name>
npx @biznetgio/cli@latest object-storage object mkdir <account_id> <bucket_name> <directory>
npx @biznetgio/cli@latest object-storage object set-acl <account_id> <bucket_name> <path> --acl private
npx @biznetgio/cli@latest object-storage object delete <account_id> <bucket_name> <path>
# Snapshots
npx @biznetgio/cli@latest neolite snapshot create <account_id> --cycle m
npx @biznetgio/cli@latest neolite snapshot list
npx @biznetgio/cli@latest neolite snapshot detail <account_id>
npx @biznetgio/cli@latest neolite snapshot restore <account_id>
npx @biznetgio/cli@latest neolite snapshot create-instance <snapshot_account_id> \
--product-id <id> --cycle m --keypair-id <id> --name "from-snap" \
--ssh-and-console-user myuser --console-password TestPass123
npx @biznetgio/cli@latest neolite snapshot delete <account_id>
npx @biznetgio/cli@latest neolite snapshot products
npx @biznetgio/cli@latest neolite snapshot product <product_id>
# Additional disks
npx @biznetgio/cli@latest neolite disk create \
--product-id <id> --cycle m --neolite-account-id <id>
npx @biznetgio/cli@latest neolite disk list
npx @biznetgio/cli@latest neolite disk detail <account_id>
npx @biznetgio/cli@latest neolite disk upgrade <account_id> --additional-size 20
npx @biznetgio/cli@latest neolite disk delete <account_id>
npx @biznetgio/cli@latest neolite disk products
npx @biznetgio/cli@latest neolite disk product <product_id>
# Available for: metal, neolite, neolite-pro
npx @biznetgio/cli@latest <service> keypair list
npx @biznetgio/cli@latest <service> keypair create --name "my-key"
npx @biznetgio/cli@latest <service> keypair import --name "my-key" --public-key "ssh-rsa AAAA..."
npx @biznetgio/cli@latest <service> keypair delete <keypair_id>
# Upgrade neolite/neolite-pro storage
npx @biznetgio/cli@latest neolite upgrade-storage <account_id> --disk-size 50
npx @biznetgio/cli@latest neolite-pro upgrade-storage <account_id> --disk-size 100
# Change package (upgrade plan) — check options first
npx @biznetgio/cli@latest neolite change-package-options <account_id>
npx @biznetgio/cli@latest neolite change-package <account_id> --new-product-id <id>
# Upgrade elastic storage
npx @biznetgio/cli@latest elastic-storage upgrade <account_id> --size 100
# Change elastic storage package
npx @biznetgio/cli@latest elastic-storage change-package <account_id> --new-product-id <id>
# Upgrade object storage quota
npx @biznetgio/cli@latest object-storage upgrade-quota <account_id> --add-quota 50
# Migrate neolite to pro — check options first
npx @biznetgio/cli@latest neolite migrate-to-pro-products <account_id>
npx @biznetgio/cli@latest neolite migrate-to-pro <account_id> --neolitepro-product-id <id>
# Check available OS for rebuild
npx @biznetgio/cli@latest metal rebuild-os <account_id>
# Rebuild
npx @biznetgio/cli@latest metal rebuild <account_id> --os "ubuntu-22.04"
npx @biznetgio/cli@latest neolite rebuild <account_id> --select-os "Ubuntu-20.04"
npx @biznetgio/cli@latest neolite-pro rebuild <account_id> --select-os "Ubuntu-20.04"
# Update metal label (max 16 chars)
npx @biznetgio/cli@latest metal update-label <account_id> --label "new-label"
# Rename neolite/neolite-pro VM
npx @biznetgio/cli@latest neolite rename <account_id> --name "new-name"
npx @biznetgio/cli@latest neolite-pro rename <account_id> --name "new-name"
# Change keypair
npx @biznetgio/cli@latest neolite change-keypair <account_id> --keypair-id <id>
npx @biznetgio/cli@latest neolite-pro change-keypair <account_id> --keypair-id <id>
# List and create IPs
npx @biznetgio/cli@latest additional-ip list
npx @biznetgio/cli@latest additional-ip regions
npx @biznetgio/cli@latest additional-ip create --product-id <id> --cycle m
# Assign IP to bare metal
npx @biznetgio/cli@latest additional-ip assign <ip_account_id> --metal-account-id <metal_id>
npx @biznetgio/cli@latest additional-ip assigns <ip_account_id>
npx @biznetgio/cli@latest additional-ip assignments <metal_account_id>
npx @biznetgio/cli@latest additional-ip assign-detail <ip_account_id> <metal_account_id>
# Unassign
npx @biznetgio/cli@latest additional-ip unassign <ip_account_id> <metal_account_id>
# Account details
npx @biznetgio/cli@latest metal detail <account_id>
npx @biznetgio/cli@latest neolite detail <account_id>
npx @biznetgio/cli@latest neolite-pro detail <account_id>
npx @biznetgio/cli@latest elastic-storage detail <account_id>
npx @biznetgio/cli@latest additional-ip detail <account_id>
npx @biznetgio/cli@latest object-storage detail <account_id>
# VM details
npx @biznetgio/cli@latest neolite vm-details <account_id>
npx @biznetgio/cli@latest neolite-pro vm-details <account_id>
# Server state
npx @biznetgio/cli@latest metal state <account_id>
# OpenVPN config
npx @biznetgio/cli@latest metal openvpn
The following commands are destructive and cannot be undone. ALWAYS confirm with the user before running:
delete commands (server, VM, storage, IP, bucket, object, snapshot, disk, keypair)rebuild commands (reinstalls OS, wipes data)set-state off/shutdown/reset (may cause downtime)When using the MCP server, all endpoints are exposed as tools with naming convention <service>_<action>. Examples:
| CLI Command | MCP Tool |
|---|---|
metal list | metal_list |
metal detail 123 | metal_detail {account_id: 123} |
metal set-state 123 on | metal_set_state {account_id: 123, state: "on"} |
neolite create ... | neolite_create {product_id, cycle, ...} |
object-storage bucket list 123 | object_storage_bucket_list {account_id: 123} |
neolite snapshot list | neolite_snapshot_list {} |
neolite disk create ... | neolite_disk_create {product_id, cycle, ...} |
object-storage delete 123 | object_storage_delete {account_id: 123} |
Total: 131 tools available in the MCP server.
MCP server configuration for Claude Desktop / Claude Code:
{
"mcpServers": {
"biznetgio": {
"command": "npx",
"args": ["-y", "@biznetgio/mcp@latest"],
"env": {
"BIZNETGIO_API_KEY": "your_api_key_here"
}
}
}
}
| Error | Solution |
|---|---|
Not logged in | Run biznetgio login (browser-based), or set BIZNETGIO_API_KEY env var |
invalid JSON in ~/.biznetgio.json | Delete ~/.biznetgio.json and re-run biznetgio login |
API key not set | Run biznetgio login, or set BIZNETGIO_API_KEY=xxx env var |
API Error 401 | API key is invalid or expired — run biznetgio login again to refresh |
API Error 404 | Resource not found, check the account_id |
API Error 422 | Validation error — check password regex, label max 16 chars, required fields |
API Error 500 | Server error — retry or check if the resource exists |
No data found. | The list is empty, no resources of this type exist yet |