summaryrefslogtreecommitdiff
path: root/internal/api/elaborate.go
diff options
context:
space:
mode:
authorPeter Stone <thepeterstone@gmail.com>2026-03-10 09:33:55 +0000
committerPeter Stone <thepeterstone@gmail.com>2026-03-10 09:33:55 +0000
commite392f99727aa2f399033896f2cda5b22e3277700 (patch)
tree4c4f445b90a5c1402aacf6d809984bb395255b4d /internal/api/elaborate.go
parent63ccc3380df10cab066e08b40ea41ee1b51bb651 (diff)
feat: append verbatim user input to docs/RAW_NARRATIVE.md
The elaborator now logs every user prompt to docs/RAW_NARRATIVE.md within the project directory. This is done in a background goroutine to ensure it doesn't delay the response.
Diffstat (limited to 'internal/api/elaborate.go')
-rw-r--r--internal/api/elaborate.go26
1 files changed, 26 insertions, 0 deletions
diff --git a/internal/api/elaborate.go b/internal/api/elaborate.go
index 5954e29..eb686bf 100644
--- a/internal/api/elaborate.go
+++ b/internal/api/elaborate.go
@@ -105,6 +105,29 @@ func readProjectContext(workDir string) string {
return sb.String()
}
+func (s *Server) appendRawNarrative(workDir, prompt string) {
+ if workDir == "" {
+ return
+ }
+ docsDir := filepath.Join(workDir, "docs")
+ if err := os.MkdirAll(docsDir, 0755); err != nil {
+ s.logger.Error("elaborate: failed to create docs directory", "error", err, "path", docsDir)
+ return
+ }
+ path := filepath.Join(docsDir, "RAW_NARRATIVE.md")
+ f, err := os.OpenFile(path, os.O_APPEND|os.O_CREATE|os.O_WRONLY, 0644)
+ if err != nil {
+ s.logger.Error("elaborate: failed to open RAW_NARRATIVE.md", "error", err, "path", path)
+ return
+ }
+ defer f.Close()
+
+ entry := fmt.Sprintf("\n--- %s ---\n%s\n", time.Now().Format(time.RFC3339), prompt)
+ if _, err := f.WriteString(entry); err != nil {
+ s.logger.Error("elaborate: failed to write to RAW_NARRATIVE.md", "error", err, "path", path)
+ }
+}
+
func (s *Server) handleElaborateTask(w http.ResponseWriter, r *http.Request) {
if s.elaborateLimiter != nil && !s.elaborateLimiter.allow(realIP(r)) {
writeJSON(w, http.StatusTooManyRequests, map[string]string{"error": "rate limit exceeded"})
@@ -129,6 +152,9 @@ func (s *Server) handleElaborateTask(w http.ResponseWriter, r *http.Request) {
workDir = input.ProjectDir
}
+ // Append verbatim user input to RAW_NARRATIVE.md in the background (best effort).
+ go s.appendRawNarrative(workDir, input.Prompt)
+
projectContext := readProjectContext(workDir)
fullPrompt := input.Prompt
if projectContext != "" {