-
-
Notifications
You must be signed in to change notification settings - Fork 2
plugin sdk
The nSelf Plugin SDK is available in four languages. Each SDK provides the same core contracts — lifecycle hooks, schema migration helpers, metrics, health checks, and structured logging — adapted to the idioms of its language.
All four SDKs are MIT-licensed and published to their respective registries.
| Language | Package | Registry | Import |
|---|---|---|---|
| Go | github.com/nself-org/cli/sdk/go/v2 |
pkg.go.dev | "github.com/nself-org/cli/sdk/go/v2/plugin" |
| TypeScript | @nself/plugin-sdk |
npm | import { Plugin } from '@nself/plugin-sdk' |
| Python | nself-plugin-sdk |
PyPI | from nself_plugin import Plugin |
| Flutter/Dart | nself_plugin_sdk |
pub.dev | package:nself_plugin_sdk/nself_plugin_sdk.dart |
Go is the reference implementation. All other SDKs maintain behavioral parity with the Go SDK.
go get github.com/nself-org/cli/sdk/go/v2Source: cli/sdk/go/ — published automatically when a sdk-go/v* tag is pushed.
Targets Node.js 18+ with ESM and CJS exports. Full TypeScript types included.
npm install @nself/plugin-sdkSource: cli/sdk/ts/ — published automatically when a sdk-ts/v* tag is pushed.
Targets Python 3.11+. Built on FastAPI and asyncpg. Published as a wheel and sdist.
pip install nself-plugin-sdk
# with optional Postgres support:
pip install nself-plugin-sdk[db]Source: cli/sdk/py/ — published automatically when a sdk-py/v* tag is pushed.
Targets Flutter 3.19+ and Dart 3.0+. Provides auth, GraphQL, storage, realtime, push, and functions helpers.
dependencies:
nself_plugin_sdk: ^2.0.0Source: cli/sdk/flutter/ — published automatically when a sdk-flutter/v* tag is pushed.
All four SDKs follow Semantic Versioning.
| Bump | When |
|---|---|
| MAJOR | Breaking changes to public API, hook signatures, or wire formats |
| MINOR | New optional fields, new hooks with defaults, new helper utilities |
| PATCH | Bug fixes with no API changes |
MAJOR versions are synchronized across all four SDKs. When one SDK ships a breaking change, all four bump to the same MAJOR in the same release cycle. MINOR and PATCH versions may diverge.
Before any breaking change ships:
-
Deprecation notice — mark the old API deprecated in the current MINOR release. Keep the old API working. Use
//Deprecated:in Go,@deprecatedJSDoc in TypeScript, Python deprecation warnings, and Dart@Deprecated. -
Migration guide — commit
MIGRATION.mdto the SDK directory before the MAJOR release tag. - 30-day minimum notice — publish a deprecation notice in the changelog and announce to plugin authors at least 30 days before the MAJOR release.
-
RC tags required — tag at least one release candidate (e.g.
sdk-go/v3.0.0-rc.1) and allow a two-week soak window before promoting to final.
Full policy: sdk/breaking-change-policy
Each SDK publishes via a dedicated GitHub Actions workflow triggered by a scoped tag:
| SDK | Tag pattern | Workflow |
|---|---|---|
| Go | sdk-go/vX.Y.Z |
cli/sdk/go/.github/workflows/sdk-go-publish.yml |
| TypeScript | sdk-ts/vX.Y.Z |
cli/sdk/ts/.github/workflows/sdk-ts-publish.yml |
| Python | sdk-py/vX.Y.Z |
cli/sdk/py/.github/workflows/sdk-py-publish.yml |
| Flutter | sdk-flutter/vX.Y.Z |
cli/sdk/flutter/.github/workflows/sdk-flutter-publish.yml |
Required repository secrets:
| Secret | Used by |
|---|---|
NPM_TOKEN |
TypeScript SDK — npm publish |
PUB_DEV_CREDENTIALS |
Flutter SDK — pub.dev publish |
Go and Python publish via OIDC Trusted Publisher — no long-lived secret required.
Plugin SDKs version independently of the CLI. Compatibility is determined by the plugin protocol major version, not the CLI version.
| CLI version | Plugin protocol | Compatible SDK major |
|---|---|---|
| v1.0.x | v1 | SDK v1.x |
| v1.1.x | v1 | SDK v1.x or v2.x |
- sdk/breaking-change-policy — full deprecation cycle, migration guide requirements, RC process
- Home
ɳSelf CLI v1.0.9. MIT licensed. Docs CC BY 4.0.
GitHub · Issues · Discussions · nself.org · docs.nself.org
Getting Started
Commands
- Commands, Overview
- Lifecycle: cmd-init · cmd-build · cmd-start · cmd-stop · cmd-restart · cmd-dev
- Monitoring: cmd-status · cmd-logs · cmd-health · cmd-urls · cmd-doctor · cmd-monitor · cmd-alerts · cmd-watchdog · cmd-dogfood
- Data: cmd-db · cmd-backup · cmd-dr · cmd-queue · cmd-webhooks
- Config: cmd-config · cmd-service · cmd-env · cmd-promote
- Networking: cmd-ssl · cmd-trust · cmd-dns-setup
- Security: cmd-security · cmd-secrets · cmd-waf
- Tenancy: cmd-tenant · cmd-billing
- Plugins: cmd-plugin · cmd-license
- AI: cmd-ai · cmd-claw · cmd-model
- Templates: cmd-template
- Utilities: cmd-exec · cmd-clean · cmd-reset · cmd-update · cmd-upgrade · cmd-version · cmd-admin · cmd-migrate · cmd-migrate-firebase · cmd-migrate-supabase · cmd-completion
Features
- Features, Overview
- Feature-Auth
- Feature-Storage
- Feature-Search
- Feature-Functions
- Feature-Email
- Feature-Monitoring
- Feature-Plugins
- Feature-ɳClaw, AI Assistant
- Feature-ɳChat, Messaging
- Feature-ɳTV, Media Player
- Feature-ɳFamily, Family Social
- Feature-ɳCloud, Managed Hosting
- Feature-Memory-Rooms, Knowledge Organization
- Feature-Agent-Dashboard, Agent Metrics
- Feature-Image-Generation, AI Image Generation
Configuration
- Configuration, Overview
- Config-Env-Vars
- Config-Postgres
- Config-Hasura
- Config-Auth
- Config-Nginx
- Config-Optional-Services
- Config-Custom-Services
- Config-System
Plugins (87 + 10 monitoring)
Free (25)
- plugin-backup
- plugin-content-acquisition
- plugin-content-progress
- plugin-cron
- plugin-donorbox
- plugin-feature-flags
- plugin-github
- plugin-github-runner
- plugin-invitations
- plugin-jobs
- plugin-link-preview
- plugin-mdns
- plugin-mlflow
- plugin-monitoring
- plugin-notifications
- plugin-notify
- plugin-paypal
- plugin-search
- plugin-shopify
- plugin-stripe
- plugin-subtitle-manager
- plugin-tokens
- plugin-torrent-manager
- plugin-vpn
- plugin-webhooks
Pro (62)
- plugin-access-controls
- plugin-activity-feed
- plugin-admin-api
- plugin-ai
- plugin-analytics
- plugin-auth
- plugin-backup-pro
- plugin-bots
- plugin-browser
- plugin-calendar
- plugin-cdn
- plugin-chat
- plugin-claw
- plugin-claw-budget
- plugin-claw-news
- plugin-claw-web
- plugin-cloudflare
- plugin-cms
- plugin-compliance
- plugin-cron-pro
- plugin-ddns
- plugin-devices
- plugin-documents
- plugin-donorbox-pro
- plugin-entitlements
- plugin-epg
- plugin-file-processing
- plugin-game-metadata
- plugin-geocoding
- plugin-geolocation
- plugin-google
- plugin-home
- plugin-idme
- plugin-knowledge-base
- plugin-linkedin
- plugin-livekit
- plugin-media-processing
- plugin-meetings
- plugin-moderation
- plugin-mux
- plugin-notify-pro
- plugin-object-storage
- plugin-observability
- plugin-paypal-pro
- plugin-photos
- plugin-podcast
- plugin-post
- plugin-realtime
- plugin-recording
- plugin-retro-gaming
- plugin-rom-discovery
- plugin-shopify-pro
- plugin-social
- plugin-sports
- plugin-stream-gateway
- plugin-streaming
- plugin-stripe-pro
- plugin-support
- plugin-tmdb
- plugin-voice
- plugin-web3
- plugin-workflows
Planned (26)
plugin-auditplugin-blogplugin-checkoutplugin-commerceplugin-drmplugin-exportplugin-flowplugin-importplugin-ldapplugin-mailgunplugin-mediaplugin-oauth-providersplugin-pagesplugin-postmarkplugin-rate-limitplugin-reportsplugin-samlplugin-schedulerplugin-sendgridplugin-ssoplugin-subscriptionplugin-thumbplugin-transcoderplugin-twilioplugin-wafplugin-watermark
Guides
- Guide-Production-Deployment
- Guide-SSL-Setup
- Guide-Multi-Tenancy
- Guide-Security-Hardening
- Guide-Monitoring-Setup
- Guide-Backup-Restore
- Guide-Custom-Services
- Guide-Migration-from-v1
Architecture
Reference
- API-Reference
- reference-error-codes, Error Codes
Licensing
Security
Brand
Operations
- operations/release-cascade, Release Cascade
- operations/self-healing, Self-Healing Schema
- operations/redis-tuning, Redis Pool Tuning
- operations/meilisearch-warmup, MeiliSearch Warm-Up
- operations/jwt-rotation, JWT Key Rotation
- operations/windows-wsl2-setup, Windows / WSL2 Setup
- operations/gemini-oauth-reauth, Gemini OAuth Reauth
Contributing
Admin
- USER-ACTION-QUEUE, Pending Admin Actions