- emitStartEvent fires when agent spawns (dispatch.go) - Monitor detects new "running" workspaces and pushes agent.started channel notification with repo and agent info - agent.complete already included blocked/failed status — no change - Both old and new workspace layouts supported Co-Authored-By: Virgil <virgil@lethean.io>
60 lines
1.5 KiB
Go
60 lines
1.5 KiB
Go
// SPDX-License-Identifier: EUPL-1.2
|
|
|
|
package agentic
|
|
|
|
import (
|
|
"encoding/json"
|
|
"io"
|
|
"time"
|
|
|
|
core "dappco.re/go/core"
|
|
)
|
|
|
|
// CompletionEvent is emitted when a dispatched agent finishes.
|
|
// Written to ~/.core/workspace/events.jsonl as append-only log.
|
|
//
|
|
// event := agentic.CompletionEvent{Type: "agent_completed", Agent: "codex", Workspace: "go-io-123", Status: "completed"}
|
|
type CompletionEvent struct {
|
|
Type string `json:"type"`
|
|
Agent string `json:"agent"`
|
|
Workspace string `json:"workspace"`
|
|
Status string `json:"status"`
|
|
Timestamp string `json:"timestamp"`
|
|
}
|
|
|
|
// emitEvent appends an event to the events log.
|
|
func emitEvent(eventType, agent, workspace, status string) {
|
|
eventsFile := core.JoinPath(WorkspaceRoot(), "events.jsonl")
|
|
|
|
event := CompletionEvent{
|
|
Type: eventType,
|
|
Agent: agent,
|
|
Workspace: workspace,
|
|
Status: status,
|
|
Timestamp: time.Now().UTC().Format(time.RFC3339),
|
|
}
|
|
|
|
data, err := json.Marshal(event)
|
|
if err != nil {
|
|
return
|
|
}
|
|
|
|
// Append to events log
|
|
r := fs.Append(eventsFile)
|
|
if !r.OK {
|
|
return
|
|
}
|
|
wc := r.Value.(io.WriteCloser)
|
|
defer wc.Close()
|
|
wc.Write(append(data, '\n'))
|
|
}
|
|
|
|
// emitStartEvent logs that an agent has been spawned.
|
|
func emitStartEvent(agent, workspace string) {
|
|
emitEvent("agent_started", agent, workspace, "running")
|
|
}
|
|
|
|
// emitCompletionEvent logs that an agent has finished.
|
|
func emitCompletionEvent(agent, workspace, status string) {
|
|
emitEvent("agent_completed", agent, workspace, status)
|
|
}
|