From opnsense-mgmt
First-run onboarding for the opnsense-mgmt plugin. Interview the user about their OPNsense router — host/IP, SSH user, whether the OPNsense API is enabled, and where API credentials live — and persist the result to `$CLAUDE_USER_DATA/opnsense-mgmt/config.json`. Run this before any other skill in this plugin, or whenever the connection details change. Triggers on phrases like "set up opnsense", "onboard opnsense", "configure opnsense plugin".
npx claudepluginhub danielrosehill/claude-code-plugins --plugin opnsense-mgmtThis skill uses the workspace's default tool permissions.
Establish the persistent connection profile for an OPNsense host. The same plugin install can serve multiple environments — only the values in `config.json` are environment-specific. No host details should ever be hard-coded into other skills in this plugin.
Guides Next.js Cache Components and Partial Prerendering (PPR): 'use cache' directives, cacheLife(), cacheTag(), revalidateTag() for caching, invalidation, static/dynamic optimization. Auto-activates on cacheComponents: true.
Guides building MCP servers enabling LLMs to interact with external services via tools. Covers best practices, TypeScript/Node (MCP SDK), Python (FastMCP).
Share bugs, ideas, or general feedback.
Establish the persistent connection profile for an OPNsense host. The same plugin install can serve multiple environments — only the values in config.json are environment-specific. No host details should ever be hard-coded into other skills in this plugin.
Resolve the plugin's data directory as $CLAUDE_USER_DATA/opnsense-mgmt/ if CLAUDE_USER_DATA is set; otherwise $XDG_DATA_HOME/claude-plugins/opnsense-mgmt/ if XDG_DATA_HOME is set; otherwise ~/.local/share/claude-plugins/opnsense-mgmt/. Create the directory if it doesn't exist. See the canonical convention in the claude-rudder:plugin-data-storage skill.
Shell form:
PLUGIN_DATA_DIR="${CLAUDE_USER_DATA:-${XDG_DATA_HOME:-$HOME/.local/share}/claude-plugins}/opnsense-mgmt"
mkdir -p "$PLUGIN_DATA_DIR"
The config file is $PLUGIN_DATA_DIR/config.json.
config.json at the resolved path — offer to run onboarding first.Load existing config from $PLUGIN_DATA_DIR/config.json if present. Show the current values back. Offer Update vs Replace vs Cancel.
Interview the user. Ask each question; default sensibly when the user just hits enter:
| Field | Prompt | Notes |
|---|---|---|
host | "What's the LAN address of your OPNsense router?" | Default: 10.0.0.1. Accept hostname or IP. |
ssh_user | "SSH username?" | Default: root (OPNsense default admin). Accept anything. |
ssh_port | "SSH port?" | Default: 22. |
ssh_key_path | "Path to the SSH private key (or leave blank for default agent)?" | Optional. Expand ~. |
web_url | "Web UI URL?" | Default: https://<host>. |
api_enabled | "Is the OPNsense API enabled? (y/n)" | If yes, ask for the next two. |
api_key_ref | "Where is the API key stored? (e.g. 1password://OPNsense API/key, env var name, or file path)" | Store the reference, not the secret itself. |
api_secret_ref | "Where is the API secret stored?" | Same — reference only. |
notes | "Any free-text notes about this router?" | Optional. |
Test connectivity (best-effort, don't block on failure):
ssh -o ConnectTimeout=5 -o BatchMode=yes -p "$SSH_PORT" "$SSH_USER@$HOST" "uname -a" 2>&1
If the command fails, surface the error to the user but still write the config — they may want to fix SSH separately.
Write $PLUGIN_DATA_DIR/config.json with this schema (pretty-printed, 2-space indent):
{
"schema_version": 1,
"host": "10.0.0.1",
"ssh_user": "root",
"ssh_port": 22,
"ssh_key_path": null,
"web_url": "https://10.0.0.1",
"api": {
"enabled": false,
"key_ref": null,
"secret_ref": null
},
"notes": null,
"updated_at": "<ISO-8601 timestamp>"
}
Summarise: print every field and its final value. Show the path to config.json. List the sibling skills the user can now invoke (opnsense-maintenance).
If config.json already exists, never silently overwrite. Always confirm. If the user picks Replace, back up the existing file with .bak suffix first.
config.json. Only store a reference (1Password item path, env var name, file path). The seed skill resolves the reference at runtime.config.json.