sphere-framework
SKILL.md
Sphere Framework Development Guide
Purpose
This skill turns Sphere tasks into executable steps:
- Identify the correct layer first (protocol/codegen, runtime packages, templates, supporting libraries).
- Execute with the standard workflow (define -> generate -> implement -> validate).
- Strictly separate editable source files from generated artifacts.
Progressive Disclosure Strategy
Keep this file focused on decisions and guardrails. Load detailed docs from references/ only when needed:
- Framework overview:
references/00-sphere-overview.md - Project setup:
references/01-getting-started.md - API development:
references/02-api-development.md - Database and ORM:
references/03-database-orm.md - Authentication and permissions:
references/04-auth-permissions.md - Sphere package selection:
references/05-sphere-packages.md - Commands and troubleshooting:
references/99-quick-reference.md
Fast Decision Path
- New project setup ->
01-getting-started.md - Add or change API ->
02-api-development.md - Add schema/model/query ->
03-database-orm.md - Implement auth or permissions ->
04-auth-permissions.md - Choose Sphere runtime package ->
05-sphere-packages.md - Resolve build/runtime issues ->
99-quick-reference.md
Parameterized Templates (No Placeholder Style)
Use explicit parameters in commands:
<project_name>: project directory name (for example,order-service)<module_path>: Go module path (for example,github.com/acme/order-service)
sphere-cli create --name <project_name> --module <module_path>
cd <project_name>
make gen/all
make run
Monorepo Component Selection
Protocol and Codegen
protoc-gen-sphere: proto -> HTTP service codeprotoc-gen-sphere-binding: binding tagsprotoc-gen-sphere-errors: business error definitionsprotoc-gen-route: custom route generation
Runtime Packages (sphere/)
cache/*,mq/*,storage/*,logserver/httpz,server/middleware/*,server/auth/*core/boot,core/task,core/pool,core/safesearch/*,infra/*,utils/*
Templates and Supporting Libraries
- Templates:
sphere-layout,sphere-simple-layout,sphere-bun-layout - Libraries:
httpx,confstore,entc-extensions
Standard Workflow (Aligned with sphere-layout)
API changes
# 1) Edit proto
# 2) Generate
make gen/proto
# 3) Implement service and route registration
# 4) Run
make run
Data model changes
# 1) Edit ent schema
make gen/db
# 2) Regenerate proto-related code if API is affected
make gen/proto
# 3) Refresh DI
make gen/wire
Full generation
make gen/all
Note: in sphere-layout, gen/proto depends on gen/db. Across different repos/templates, still prefer explicit order: gen/db -> gen/proto -> gen/wire.
Code Boundaries
Do not edit (generated)
api/internal/pkg/database/ent/cmd/app/wire_gen.goswagger/
Edit (source/business)
proto/**/*.protointernal/pkg/database/schema/*.gointernal/service/**/*.gointernal/server/**/web.go*/wire.go- runtime config (for example,
config.json)
sphere-cli Scope
- Supported:
sphere-cli create,sphere-cli rename - Limited:
sphere-cli serviceonly prints template content to stdout
Recommended usage: use sphere-cli service for scaffolding text, then create and edit target files manually.
When Not to Force sphere-layout Paths
If the target repo does not match the standard layout, do not assume fixed paths like:
internal/server/api/web.gointernal/pkg/database/schema/cmd/app/wire.go
Read the real repository structure first, then map Sphere workflow onto it.
Troubleshooting Entry
For these issues, go to references/99-quick-reference.md first:
- code generators missing
- route 404
- auth 401
- Wire DI errors
- DB/cache connectivity issues
Documentation Entry Points
- Concepts:
references/00-sphere-overview.md - Implementation flow:
references/01-getting-started.mdtoreferences/04-auth-permissions.md - Package selection:
references/05-sphere-packages.md - Commands/troubleshooting:
references/99-quick-reference.md
Weekly Installs
1
Repository
go-sphere/sphereFirst Seen
Feb 9, 2026
Security Audits
Installed on
amp1
opencode1
kimi-cli1
codex1
github-copilot1
gemini-cli1