58 lines
1.6 KiB
Go
58 lines
1.6 KiB
Go
// internal/skills/spec/skill.go
|
|
package spec
|
|
|
|
import (
|
|
"context"
|
|
"encoding/json"
|
|
|
|
iexec "github.com/mathiasbq/supervisor/internal/exec"
|
|
"github.com/mathiasbq/supervisor/internal/registry"
|
|
)
|
|
|
|
// ExecutorFn is the function signature for running a worker subprocess.
|
|
type ExecutorFn func(ctx context.Context, req iexec.Request) (iexec.Result, error)
|
|
|
|
// Config holds dependencies for the spec skill.
|
|
type Config struct {
|
|
SkillPrompt string
|
|
DefaultModel string
|
|
ExecutorFn ExecutorFn
|
|
SessionsDir string
|
|
IngestBaseURL string // optional: base URL of ingestion server for brain context
|
|
}
|
|
|
|
// Skill implements the spec MCP tool.
|
|
type Skill struct{ cfg Config }
|
|
|
|
// New creates a new spec Skill.
|
|
func New(cfg Config) *Skill { return &Skill{cfg: cfg} }
|
|
|
|
// Name returns the skill identifier.
|
|
func (s *Skill) Name() string { return "spec" }
|
|
|
|
// Tools returns the MCP tool definitions for this skill.
|
|
func (s *Skill) Tools() []registry.ToolDef {
|
|
schema := func(required []string, props map[string]any) json.RawMessage {
|
|
b, _ := json.Marshal(map[string]any{"type": "object", "required": required, "properties": props})
|
|
return b
|
|
}
|
|
str := map[string]any{"type": "string"}
|
|
return []registry.ToolDef{
|
|
{
|
|
Name: "spec",
|
|
Description: "Generate a structured implementation spec from requirements. Writes the spec to output_path in the project.",
|
|
InputSchema: schema(
|
|
[]string{"project_root", "requirements"},
|
|
map[string]any{
|
|
"project_root": str,
|
|
"requirements": str,
|
|
"output_path": str,
|
|
"context": str,
|
|
"model": str,
|
|
"session_id": str,
|
|
},
|
|
),
|
|
},
|
|
}
|
|
}
|