mirror of
https://github.com/diegosouzapw/OmniRoute.git
synced 2026-05-31 21:50:12 +00:00
Adds plugin discovery, loading, and management to the omniroute CLI. - bin/cli/plugins.mjs: discoverPlugins / loadPlugins / buildPluginContext - bin/cli/commands/plugin.mjs: list / install / remove / info / search / update / scaffold - examples/omniroute-cmd-hello/: minimal working plugin example - docs/dev/plugins.md: plugin API contract and authoring guide - .env.example + ENVIRONMENT.md: document OMNIROUTE_PLUGIN_PATH
3.3 KiB
3.3 KiB
OmniRoute CLI Plugin System
Extend the omniroute CLI without modifying its core. Plugins follow the omniroute-cmd-* naming convention, similar to gh extension or kubectl plugin.
Quick start
# Install a plugin from npm
omniroute plugin install stripe
# Install a local plugin in development
omniroute plugin install ./my-plugin
# List installed plugins
omniroute plugin list
# Scaffold a new plugin
omniroute plugin scaffold myplugin
cd omniroute-cmd-myplugin
omniroute plugin install .
Plugin anatomy
A plugin is an npm package named omniroute-cmd-<name> (or @scope/omniroute-cmd-<name>).
omniroute-cmd-myplugin/
├── package.json # must have "type": "module" and "main": "index.mjs"
├── index.mjs # exports register(program, ctx) + optional meta
└── README.md
package.json
{
"name": "omniroute-cmd-myplugin",
"version": "0.1.0",
"type": "module",
"main": "index.mjs",
"engines": { "omniroute": ">=4.0.0" },
"keywords": ["omniroute-plugin", "omniroute-cmd"]
}
index.mjs
export const meta = {
name: "myplugin",
version: "0.1.0",
description: "My plugin for OmniRoute",
omnirouteApi: ">=4.0.0",
};
export function register(program, ctx) {
program
.command("myplugin")
.description(meta.description)
.option("-n, --name <name>")
.action(async (opts, cmd) => {
const gOpts = cmd.optsWithGlobals();
const res = await ctx.apiFetch("/api/combos", {
baseUrl: gOpts.baseUrl,
apiKey: gOpts.apiKey,
});
const data = await res.json();
ctx.emit(data, gOpts);
});
}
Plugin context API
The ctx object passed to register(program, ctx):
| Property | Type | Description |
|---|---|---|
ctx.apiFetch(path, opts) |
async function |
Authenticated fetch to the OmniRoute server |
ctx.emit(data, opts) |
function |
Output in table/json/jsonl/csv per --output flag |
ctx.t(key) |
async function |
i18n translation lookup |
ctx.withSpinner(label, fn) |
async function |
Wraps async fn with ora spinner |
ctx.baseUrl |
string |
Resolved base URL |
ctx.apiKey |
string | null |
API key if provided |
Discovery
Plugins are discovered from:
~/.omniroute/plugins/<name>/— user-local installsOMNIROUTE_PLUGIN_PATHenv var — custom directory
Loading errors are caught and printed as warnings — a broken plugin never crashes the CLI.
Security
Plugins run with the same Node.js process privileges as omniroute. Only install plugins from sources you trust. omniroute plugin install shows an explicit warning and requires --yes or interactive confirmation.
Publishing
- Ensure
package.jsonhas"keywords": ["omniroute-plugin"] npm publishas normal- Users discover via
omniroute plugin search <query>(searches npm registry)
Example plugin
See examples/omniroute-cmd-hello/ for a minimal working example.