@insforge/cli
v0.1.62
Published
InsForge CLI - Command line tool for InsForge platform
Downloads
8,573
Readme
@insforge/cli
Command line tool for the InsForge platform. Manage your databases, edge functions, storage, deployments, payments, secrets, and more — directly from the terminal.
Designed to be both human-friendly (interactive prompts, formatted tables) and agent-friendly (structured JSON output, non-interactive mode, semantic exit codes).
Requires Node.js >= 18. We recommend running via npx so you always get the latest version — no global install needed.
Quick Start
# Login via browser (OAuth)
npx @insforge/cli login
# Or login with email/password
npx @insforge/cli login --email
# Check current user
npx @insforge/cli whoami
# List all organizations and projects
npx @insforge/cli list
# Link current directory to a project
npx @insforge/cli link
# Query the database
npx @insforge/cli db tables
npx @insforge/cli db query "SELECT * FROM users LIMIT 10"Authentication
If you run any command without being logged in, the CLI will automatically open your browser and start the login flow — no need to run npx @insforge/cli login first.
Browser Login (default)
npx @insforge/cli loginOpens your browser to the InsForge authorization page using OAuth 2.0 Authorization Code + PKCE. A local callback server receives the authorization code and exchanges it for tokens. Credentials are stored in ~/.insforge/credentials.json.
Email/Password Login
npx @insforge/cli login --emailPrompts for email and password interactively, or reads from environment variables in non-interactive mode:
[email protected] INSFORGE_PASSWORD=secret npx @insforge/cli login --email --jsonLogout
npx @insforge/cli logoutGlobal Options
All commands support the following flags:
| Flag | Description |
|------|-------------|
| --json | Output in JSON format (useful for scripts and AI agents) |
| --project-id <id> | Override the linked project ID |
| --api-url <url> | Override the Platform API URL |
| -y, --yes | Skip confirmation prompts |
Commands
Top-Level
npx @insforge/cli whoami
Show the current authenticated user.
npx @insforge/cli whoami
npx @insforge/cli whoami --jsonnpx @insforge/cli list
List all organizations and their projects in a grouped table.
npx @insforge/cli list
npx @insforge/cli list --jsonnpx @insforge/cli create
Create a new InsForge project interactively.
npx @insforge/cli create
npx @insforge/cli create --name "my-app" --org-id <org-id> --region us-eastnpx @insforge/cli link
Link the current directory to an InsForge project. Creates .insforge/project.json with the project ID, API key, and OSS host URL.
# Interactive: select from a list
npx @insforge/cli link
# Non-interactive (platform login)
npx @insforge/cli link --project-id <id> --org-id <org-id>
# OSS / self-hosted: link via host URL + API key (no platform login required)
npx @insforge/cli link \
--api-base-url https://<app-key>.<region>.insforge.app \
--api-key <your-project-api-key>For OSS or self-hosted deployments, you can link directly using the host URL and API key — the CLI skips the platform OAuth flow and writes the credentials straight into .insforge/project.json. The host URL format is https://{app_key}.{region}.insforge.app (e.g. https://uhzx8md3.us-east.insforge.app).
npx @insforge/cli current
Show current CLI context (authenticated user, linked project).
npx @insforge/cli current
npx @insforge/cli current --jsonnpx @insforge/cli metadata
Show backend metadata including auth configuration, database tables, storage buckets, edge functions, AI models, and realtime channels.
npx @insforge/cli metadata
npx @insforge/cli metadata --jsonnpx @insforge/cli logs
Fetch backend container logs.
npx @insforge/cli logs <source> [options]Sources: insforge.logs, postgREST.logs, postgres.logs, function.logs
Options:
--limit <n>: Number of log entries to return (default: 20)
Examples:
npx @insforge/cli logs insforge.logs
npx @insforge/cli logs postgres.logs --limit 50
npx @insforge/cli logs function.logs --jsonnpx @insforge/cli docs
Browse InsForge SDK documentation.
npx @insforge/cli docs [feature] [language]Features: db, storage, functions, auth, ai, realtime, instructions
Languages: typescript, swift, kotlin, rest-api
Examples:
# List all available docs
npx @insforge/cli docs
# Specific feature/language docs
npx @insforge/cli docs instructions # Show backend setup instructions
npx @insforge/cli docs db typescript # Show TypeScript database SDK docs
npx @insforge/cli docs auth swift # Show Swift auth SDK docs
npx @insforge/cli docs storage rest-api # Show REST API storage docsDatabase — npx @insforge/cli db
npx @insforge/cli db query <sql>
Execute a raw SQL query.
npx @insforge/cli db query "SELECT * FROM users LIMIT 10"
npx @insforge/cli db query "SELECT count(*) FROM orders" --json
npx @insforge/cli db query "SELECT * FROM pg_tables" --unrestrictednpx @insforge/cli db tables
List all database tables.
npx @insforge/cli db tables
npx @insforge/cli db tables --jsonnpx @insforge/cli db functions
List all database functions.
npx @insforge/cli db functionsnpx @insforge/cli db indexes
List all database indexes.
npx @insforge/cli db indexesnpx @insforge/cli db policies
List all RLS policies.
npx @insforge/cli db policiesnpx @insforge/cli db triggers
List all database triggers.
npx @insforge/cli db triggersnpx @insforge/cli db rpc <functionName>
Call a database function via RPC.
npx @insforge/cli db rpc my_function --data '{"param1": "value"}'npx @insforge/cli db export
Export database schema and/or data.
npx @insforge/cli db export --output schema.sql
npx @insforge/cli db export --data-only --output data.sqlnpx @insforge/cli db import <file>
Import database from a local SQL file.
npx @insforge/cli db import schema.sqlFunctions — npx @insforge/cli functions
npx @insforge/cli functions list
List all edge functions.
npx @insforge/cli functions list
npx @insforge/cli functions list --jsonnpx @insforge/cli functions code <slug>
View the source code of an edge function.
npx @insforge/cli functions code my-function
npx @insforge/cli functions code my-function --jsonnpx @insforge/cli functions deploy <slug>
Deploy an edge function. Creates the function if it doesn't exist, or updates it.
npx @insforge/cli functions deploy my-function --file ./handler.ts
npx @insforge/cli functions deploy my-function --file ./handler.ts --name "My Function" --description "Does something"npx @insforge/cli functions invoke <slug>
Invoke an edge function.
npx @insforge/cli functions invoke my-function --data '{"key": "value"}'
npx @insforge/cli functions invoke my-function --method GET
npx @insforge/cli functions invoke my-function --data '{"key": "value"}' --jsonnpx @insforge/cli functions delete <slug>
Delete an edge function.
npx @insforge/cli functions delete my-function
npx @insforge/cli functions delete my-function -y # skip confirmationStorage — npx @insforge/cli storage
npx @insforge/cli storage buckets
List all storage buckets.
npx @insforge/cli storage buckets
npx @insforge/cli storage buckets --jsonnpx @insforge/cli storage create-bucket <name>
Create a new storage bucket.
npx @insforge/cli storage create-bucket images
npx @insforge/cli storage create-bucket private-docs --privatenpx @insforge/cli storage delete-bucket <name>
Delete a storage bucket and all its objects.
npx @insforge/cli storage delete-bucket images
npx @insforge/cli storage delete-bucket images -y # skip confirmationnpx @insforge/cli storage list-objects <bucket>
List objects in a storage bucket.
npx @insforge/cli storage list-objects images
npx @insforge/cli storage list-objects images --prefix "avatars/" --limit 50npx @insforge/cli storage upload <file>
Upload a file to a storage bucket.
npx @insforge/cli storage upload ./photo.png --bucket images
npx @insforge/cli storage upload ./photo.png --bucket images --key "avatars/user-123.png"npx @insforge/cli storage download <objectKey>
Download a file from a storage bucket.
npx @insforge/cli storage download avatars/user-123.png --bucket images
npx @insforge/cli storage download avatars/user-123.png --bucket images --output ./downloaded.pngDeployments — npx @insforge/cli deployments
npx @insforge/cli deployments deploy [directory]
Deploy a frontend project. Zips the source, uploads it, and polls for build completion (up to 2 minutes).
npx @insforge/cli deployments deploy
npx @insforge/cli deployments deploy ./my-app
npx @insforge/cli deployments deploy --env '{"API_URL": "https://api.example.com"}'npx @insforge/cli deployments list
List all deployments.
npx @insforge/cli deployments list
npx @insforge/cli deployments list --limit 5 --jsonnpx @insforge/cli deployments status <id>
Get deployment details and status.
npx @insforge/cli deployments status abc-123
npx @insforge/cli deployments status abc-123 --sync # sync status from Vercel firstnpx @insforge/cli deployments cancel <id>
Cancel a running deployment.
npx @insforge/cli deployments cancel abc-123Payments — npx @insforge/cli payments
Manage the Stripe payments foundation for the linked InsForge project. These commands are intended for developers and agents configuring Stripe keys, syncing catalog state, and managing products/prices. Runtime checkout and customer portal calls should usually be made from the app via the SDK.
npx @insforge/cli payments status
Show Stripe key, account, sync, and webhook status for test/live environments.
npx @insforge/cli payments status
npx @insforge/cli payments status --jsonnpx @insforge/cli payments config
List, set, or remove Stripe secret keys.
npx @insforge/cli payments config
npx @insforge/cli payments config set test sk_test_xxx
npx @insforge/cli payments config set live # prompts securely
npx @insforge/cli payments config remove test -ynpx @insforge/cli payments sync
Sync Stripe products, prices, and subscriptions from configured environments.
npx @insforge/cli payments sync
npx @insforge/cli payments sync --environment test
npx @insforge/cli payments sync --environment live --jsonnpx @insforge/cli payments webhooks configure <environment>
Create or recreate the InsForge-managed Stripe webhook endpoint for an environment.
npx @insforge/cli payments webhooks configure testnpx @insforge/cli payments products
List, inspect, create, update, or delete Stripe products.
npx @insforge/cli payments products list --environment test
npx @insforge/cli payments products get prod_123 --environment test
npx @insforge/cli payments products create --environment test --name "Pro Plan"
npx @insforge/cli payments products update prod_123 --environment test --description "Updated"
npx @insforge/cli payments products delete prod_123 --environment test -ynpx @insforge/cli payments prices
List, inspect, create, update, or archive Stripe prices.
npx @insforge/cli payments prices list --environment test
npx @insforge/cli payments prices create --environment test --product prod_123 --currency usd --unit-amount 2000
npx @insforge/cli payments prices create --environment test --product prod_123 --currency usd --unit-amount 2000 --interval month
npx @insforge/cli payments prices update price_123 --environment test --active false
npx @insforge/cli payments prices archive price_123 --environment testnpx @insforge/cli payments subscriptions
List mirrored Stripe subscriptions for admin/debugging workflows.
npx @insforge/cli payments subscriptions --environment test
npx @insforge/cli payments subscriptions --environment test --subject-type team --subject-id team_123npx @insforge/cli payments history
List mirrored payment history for admin/debugging workflows.
npx @insforge/cli payments history --environment test
npx @insforge/cli payments history --environment test --limit 20 --jsonSecrets — npx @insforge/cli secrets
npx @insforge/cli secrets list
List all secrets (metadata only, values are hidden). Inactive (deleted) secrets are hidden by default.
npx @insforge/cli secrets list
npx @insforge/cli secrets list --all # include inactive secrets
npx @insforge/cli secrets list --jsonnpx @insforge/cli secrets get <key>
Get the decrypted value of a secret.
npx @insforge/cli secrets get STRIPE_API_KEY
npx @insforge/cli secrets get STRIPE_API_KEY --jsonnpx @insforge/cli secrets add <key> <value>
Create a new secret.
npx @insforge/cli secrets add STRIPE_API_KEY sk_live_xxx
npx @insforge/cli secrets add STRIPE_API_KEY sk_live_xxx --reserved
npx @insforge/cli secrets add TEMP_TOKEN abc123 --expires "2025-12-31T00:00:00Z"npx @insforge/cli secrets update <key>
Update an existing secret.
npx @insforge/cli secrets update STRIPE_API_KEY --value sk_live_new_xxx
npx @insforge/cli secrets update STRIPE_API_KEY --active false
npx @insforge/cli secrets update STRIPE_API_KEY --reserved true
npx @insforge/cli secrets update STRIPE_API_KEY --expires null # remove expirationnpx @insforge/cli secrets delete <key>
Delete a secret (soft delete — marks as inactive).
npx @insforge/cli secrets delete STRIPE_API_KEY
npx @insforge/cli secrets delete STRIPE_API_KEY -y # skip confirmationSchedules — npx @insforge/cli schedules
Manage scheduled tasks (cron jobs).
npx @insforge/cli schedules list
List all schedules in the current project.
npx @insforge/cli schedules list
npx @insforge/cli schedules list --jsonnpx @insforge/cli schedules create
Create a new scheduled task.
npx @insforge/cli schedules create --name "daily-cleanup" --cron "0 0 * * *" --url "https://api.example.com/cleanup" --method POST
npx @insforge/cli schedules create --name "hourly-sync" --cron "0 * * * *" --url "https://api.example.com/sync" --method GET --headers '{"Authorization": "Bearer xxx"}'npx @insforge/cli schedules get <id>
Get details of a specific schedule.
npx @insforge/cli schedules get <id>
npx @insforge/cli schedules get 123 --jsonnpx @insforge/cli schedules update <id>
Update an existing schedule.
npx @insforge/cli schedules update <id> --name "weekly-cleanup" --cron "0 0 * * 0"
npx @insforge/cli schedules update 123 --active falsenpx @insforge/cli schedules delete <id>
Delete a schedule.
npx @insforge/cli schedules delete <id>
npx @insforge/cli schedules delete 123 -ynpx @insforge/cli schedules logs <id>
Fetch execution logs for a specific schedule.
npx @insforge/cli schedules logs <id>
npx @insforge/cli schedules logs 123 --limit 100Project Configuration
Running npx @insforge/cli link creates a .insforge/ directory in your project:
.insforge/
└── project.json # project_id, org_id, appkey, region, api_key, oss_hostAdd .insforge/ to your .gitignore — it contains your project API key.
Global configuration is stored in ~/.insforge/:
~/.insforge/
├── credentials.json # access_token, refresh_token, user profile
└── config.json # default_org_id, platform_api_urlAgent Skills
When you run npx @insforge/cli create or npx @insforge/cli link, the CLI automatically installs a set of InsForge agent skills into your project for all supported AI coding agents (Claude Code, Cursor, Windsurf, Cline, Roo, Gemini CLI, GitHub Copilot, Qwen, Qoder, Trae, Kilo, Codex, Augment, Antigravity). These skills teach your coding agent how to work with InsForge — database queries, auth, storage, edge functions, realtime, etc. — so it can generate correct code for your backend without you copy-pasting docs.
It also installs find-skills so agents can discover available skills on demand.
Skill files are written to per-agent directories (e.g. .claude/, .cursor/, .windsurf/) and are automatically added to your .gitignore. You can re-run npx @insforge/cli link at any time to reinstall or update skills.
Analytics
The CLI reports anonymous usage events to PostHog so we can understand which features are being used and prioritize improvements.
Analytics are enabled by default in the published npm package. If you build the CLI from source without setting POSTHOG_API_KEY at build time, analytics become a no-op automatically.
Environment Variables
| Variable | Description |
|----------|-------------|
| INSFORGE_ACCESS_TOKEN | Override the stored access token |
| INSFORGE_PROJECT_ID | Override the linked project ID |
| INSFORGE_API_URL | Override the Platform API URL |
| INSFORGE_EMAIL | Email for non-interactive login |
| INSFORGE_PASSWORD | Password for non-interactive login |
Non-Interactive / CI Usage
All commands support --json for structured output and -y to skip confirmation prompts:
# Login in CI
INSFORGE_EMAIL=$EMAIL INSFORGE_PASSWORD=$PASSWORD npx @insforge/cli login --email --json
# Link a project
npx @insforge/cli link --project-id $PROJECT_ID --org-id $ORG_ID -y
# Query and pipe results
npx @insforge/cli db query "SELECT * FROM users" --json | jq '.rows[].email'
# Deploy frontend
npx @insforge/cli deployments deploy ./dist --json
# Upload a build artifact
npx @insforge/cli storage upload ./dist/bundle.js --bucket assets --key "v1.2.0/bundle.js" --jsonExit Codes
| Code | Meaning |
|------|---------|
| 0 | Success |
| 1 | General error |
| 2 | Authentication failure |
| 3 | Project not linked (run npx @insforge/cli link first) |
| 4 | Resource not found |
| 5 | Permission denied |
Development
git clone <repo-url>
cd insforge-CLI
npm install
npm run build
npm link # makes `insforge` available globally
npm run dev # watch mode for developmentTesting
Unit tests
npm run test:unitReal project integration tests
Run locally:
INTEGRATION_TEST_ENABLED=true \
INTEGRATION_LOG_SOURCE=insforge.logs \
npm run test:integration:realPrerequisites:
- Logged in (
npx @insforge/cli login) so~/.insforge/credentials.jsonexists - Linked project in this repo (
npx @insforge/cli link) so.insforge/project.jsonexists
Optional environment variables:
INSFORGE_API_URL: Platform API URL override (defaults tohttps://api.insforge.dev)INTEGRATION_LOG_SOURCE: Log source forlogstest (defaultinsforge.logs)
Current real-project checks:
whoami --jsonmetadata --jsonlogs <source> --jsondocs instructions --json
Releasing
Bump the version, push the tag, and create a GitHub Release — the CI will publish to npm automatically.
# Bump version (creates commit + tag)
npm version patch # 0.1.3 → 0.1.4
# or
npm version minor # 0.1.3 → 0.2.0
# Push commit and tag
git push && git push --tagsThen go to GitHub → Releases → Draft a new release, select the tag (e.g. v0.1.4), and publish. The publish workflow will run npm publish automatically.
License
Apache-2.0
