fix(brain): Timer in 2min funktioniert wieder — Zeit im Prompt + in_seconds-Param

ARIA wusste nicht wieviel Uhr es ist (kein Bash, kein Time-Tool, kein
Timestamp im System-Prompt) und konnte fires_at als ISO-UTC schlicht
nicht ausrechnen. Zwei Fixes:

1. prompts.py: build_time_section() injiziert UTC + lokale Zeit
   (Europa/Berlin Sommer/Winter-Heuristik) als '## Aktuelle Zeit'-Block
   oben in den System-Prompt. Hilft auch beim Einordnen von
   Watcher-Conditions wie hour_of_day == 8.

2. agent.py trigger_timer-Tool: neuer Parameter `in_seconds` als
   Alternative zu fires_at. Bei relativen Angaben ('in 2 Minuten')
   rechnet jetzt der Server den absoluten Timestamp aus — keine
   Rechnerei in der LLM noetig. fires_at bleibt fuer feste Termine.
   required nur noch name + message.

Diagnostic-API (/triggers/timer) bleibt absolute-only, da der Browser
selbst datetime hat.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
2026-05-12 01:21:23 +02:00
parent c3fefc60c0
commit 8c74b3fed8
2 changed files with 56 additions and 10 deletions
+25 -1
View File
@@ -15,10 +15,34 @@ mit dem Conversation-Loop in spaeteren Phasen.
from __future__ import annotations
from datetime import datetime, timezone, timedelta
from typing import List
from memory import MemoryPoint
def build_time_section() -> str:
"""Aktueller Zeitstempel — damit ARIA Timer korrekt anlegen kann
und Watcher-Conditions mit hour_of_day etc. einordenbar bleiben."""
now_utc = datetime.now(timezone.utc)
# Europa/Berlin: Sommerzeit CEST = UTC+2, Winterzeit CET = UTC+1.
# Wir nehmen den simplen Fall (kein zoneinfo-Import noetig im Brain-Image):
# Stefans VM laeuft auf UTC, die Bridge in der Wohnung — Anzeige reicht.
local_offset_h = 2 if 3 <= now_utc.month <= 10 else 1
local = now_utc + timedelta(hours=local_offset_h)
lines = [
"## Aktuelle Zeit",
f"- UTC: {now_utc.isoformat(timespec='seconds')}",
f"- Lokal (Europa/Berlin, UTC+{local_offset_h}): "
f"{local.strftime('%Y-%m-%d %H:%M:%S')} ({local.strftime('%A')})",
"",
"Nutze das fuer Trigger-Timestamps und um Watcher-Conditions wie "
"`hour_of_day == 8` einzuordnen. Fuer relative Angaben "
"('in 10min', 'in 2 Stunden') nutze beim `trigger_timer` den "
"`in_seconds`-Parameter — Server rechnet dann selbst.",
]
return "\n".join(lines)
TYPE_HEADINGS = {
"identity": "## Wer du bist",
"rule": "## Sicherheitsregeln & Prinzipien",
@@ -177,7 +201,7 @@ def build_system_prompt(
condition_funcs: List[dict] | None = None,
) -> str:
"""Kompletter System-Prompt: Hot + Cold + Skills + Triggers."""
parts = [build_hot_memory_section(pinned)]
parts = [build_hot_memory_section(pinned), "", build_time_section()]
if skills:
parts.append("")
parts.append(build_skills_section(skills))