Biznet Gio Cloud Management - Agent Skill Guide
Skill Metadata
| 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 |
Credential Sources (resolution order — highest priority first)
| 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.
Environment Variables
| 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. |
Required Binaries
| 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. |
Runtime Note
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:
- Pre-install with
npm install -g @biznetgio/cliand verify the package before use - Use the pre-built standalone binaries from the GitHub releases
- Pin to a specific version:
npx @biznetgio/cli@1.0.0instead of@latest - Run in a sandboxed environment
You are an agent that can manage Biznet Gio cloud infrastructure using the CLI tool @biznetgio/cli and/or MCP server @biznetgio/mcp.
Authentication
Always check auth status before running any other command. Follow these steps exactly:
Step 1 — Check if already logged in
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 |
Step 2 — Guide the user to log in (only if not logged in)
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.
Step 3 — Confirm identity after login
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.
Logging out
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.
Important Instructions
- Check auth first. Before any other command, run
whoamias described above. Do not skip this step. - Always use
npxto run the CLI. No installation required. - Read-only commands run without confirmation. Commands like
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. - Confirm before create, update, or delete actions. Before running any command that creates, modifies, or deletes a resource, show the user the full command with all values and ask for confirmation. The user may want to revise parameter values before execution.
- For destructive actions (delete, rebuild, state changes), double confirm. Clearly warn the user about the impact and ask explicitly: "Are you sure?"
- For create operations, list all parameters and let the user review and adjust before executing. Show product options, OS choices, and pricing when available.
How to Run
# 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]
- Auth: credential file
~/.biznetgio.json(preferred) →BIZNETGIO_API_KEYenv →--api-keyflag - Base URL:
https://api.portal.biznetgio.com/v1(override withBIZNETGIO_BASE_URLenv) - Output format: default
table, use--output jsonfor JSON output
Available Services
| 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 |
General Pattern
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
Output Behavior
- Default: table — List data is displayed as formatted tables. Nested objects (billing, specs, options) are automatically flattened. Billing is summarized as
price/mo. --output json— Raw JSON from the API.datafield.- Primitive responses (e.g. delete, update-label) return plain text like
successortrue. - Empty lists show
No data found.
Valid Enum Values
- Billing cycle (
--cycle):m(monthly),q(quarterly),s(semi-annual),a(annual),b(biennial),t(triennial),p4,p5 - Metal states:
on,off,reset - VM states (neolite/neolite-pro):
stop,suspend,resume,shutdown,start,reset - Object ACL:
private,public-read,public-read-write,authenticated-read,log-delivery-write - Console password: must match
^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)[a-zA-Z\d]{8,}$(min 8 chars, uppercase + lowercase + digit, alphanumeric only — no special characters) - Label: max 16 characters
Workflow & Best Practices
Before Creating Resources
-
List products first to get valid
product_idvalues: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>
Creating Resources
# 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
Deleting Resources
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>
Managing Server State
# 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
Object Storage Operations
# 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>
Snapshot & Disk Management (NEO Lite / Pro)
# 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>
Keypair Management
# 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 & Scaling
# 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>
Rebuild / Reinstall OS
# 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 & Rename
# 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>
Additional IP Assignment
# 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>
Detail & Info Commands
# 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
Destructive Actions - Use With Caution!
The following commands are destructive and cannot be undone. ALWAYS confirm with the user before running:
- All
deletecommands (server, VM, storage, IP, bucket, object, snapshot, disk, keypair) rebuildcommands (reinstalls OS, wipes data)set-state off/shutdown/reset(may cause downtime)
MCP Server Tools Reference
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"
}
}
}
}
Troubleshooting
| 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 |