Config-driven agent targets replace hardcoded map so new agents
can be added via CLI instead of recompiling. Includes setup script
for bootstrapping agent machines and CLI commands for management.
- Add pkg/agentci with config types and CRUD (LoadAgents, SaveAgent, etc.)
- Add CLI: core ai agent {add,list,status,logs,setup,remove}
- Add scripts/agent-setup.sh (SSH bootstrap: dirs, cron, prereq check)
- Headless loads agents from ~/.core/config.yaml
- Dispatch ticket includes forgejo_user for dynamic clone URLs
- agent-runner.sh reads username from ticket JSON, not hardcoded
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
88 lines
2.1 KiB
Go
88 lines
2.1 KiB
Go
// Package ai provides AI agent task management and Claude Code integration.
|
|
//
|
|
// Commands:
|
|
// - tasks: List tasks from the agentic service
|
|
// - task: View, claim, or auto-select tasks
|
|
// - task:update: Update task status and progress
|
|
// - task:complete: Mark tasks as completed or failed
|
|
// - task:commit: Create commits with task references
|
|
// - task:pr: Create pull requests linked to tasks
|
|
// - claude: Claude Code CLI integration (planned)
|
|
// - rag: RAG tools (ingest, query, collections)
|
|
// - metrics: View AI/security event metrics
|
|
package ai
|
|
|
|
import (
|
|
ragcmd "github.com/host-uk/core/internal/cmd/rag"
|
|
"github.com/host-uk/core/pkg/cli"
|
|
"github.com/host-uk/core/pkg/i18n"
|
|
)
|
|
|
|
func init() {
|
|
cli.RegisterCommands(AddAICommands)
|
|
}
|
|
|
|
var aiCmd = &cli.Command{
|
|
Use: "ai",
|
|
Short: i18n.T("cmd.ai.short"),
|
|
Long: i18n.T("cmd.ai.long"),
|
|
}
|
|
|
|
var claudeCmd = &cli.Command{
|
|
Use: "claude",
|
|
Short: i18n.T("cmd.ai.claude.short"),
|
|
Long: i18n.T("cmd.ai.claude.long"),
|
|
}
|
|
|
|
var claudeRunCmd = &cli.Command{
|
|
Use: "run",
|
|
Short: i18n.T("cmd.ai.claude.run.short"),
|
|
RunE: func(cmd *cli.Command, args []string) error {
|
|
return runClaudeCode()
|
|
},
|
|
}
|
|
|
|
var claudeConfigCmd = &cli.Command{
|
|
Use: "config",
|
|
Short: i18n.T("cmd.ai.claude.config.short"),
|
|
RunE: func(cmd *cli.Command, args []string) error {
|
|
return showClaudeConfig()
|
|
},
|
|
}
|
|
|
|
func initCommands() {
|
|
// Add Claude subcommands
|
|
claudeCmd.AddCommand(claudeRunCmd)
|
|
claudeCmd.AddCommand(claudeConfigCmd)
|
|
|
|
// Add Claude command to ai
|
|
aiCmd.AddCommand(claudeCmd)
|
|
|
|
// Add agentic task commands
|
|
AddAgenticCommands(aiCmd)
|
|
|
|
// Add RAG subcommands (core ai rag ...)
|
|
ragcmd.AddRAGSubcommands(aiCmd)
|
|
|
|
// Add metrics subcommand (core ai metrics)
|
|
addMetricsCommand(aiCmd)
|
|
|
|
// Add agent management commands (core ai agent ...)
|
|
AddAgentCommands(aiCmd)
|
|
}
|
|
|
|
// AddAICommands registers the 'ai' command and all subcommands.
|
|
func AddAICommands(root *cli.Command) {
|
|
initCommands()
|
|
root.AddCommand(aiCmd)
|
|
}
|
|
|
|
func runClaudeCode() error {
|
|
// Placeholder - will integrate with claude CLI
|
|
return nil
|
|
}
|
|
|
|
func showClaudeConfig() error {
|
|
// Placeholder - will show claude configuration
|
|
return nil
|
|
}
|