Compare commits

...

4 Commits

2 changed files with 65 additions and 0 deletions

View File

@@ -0,0 +1,39 @@
#!/usr/bin/env python3
import json
import os
import time
import subprocess
from pathlib import Path
# Allegro Failover Monitor
# Health-checking the VPS fleet for Timmy's resilience.
FLEET = {
"ezra": "143.198.27.163", # Placeholder
"bezalel": "167.99.126.228"
}
STATUS_FILE = Path.home() / ".timmy" / "failover_status.json"
def check_health(host):
try:
subprocess.check_call(["ping", "-c", "1", "-W", "2", host], stdout=subprocess.DEVNULL)
return "ONLINE"
except:
return "OFFLINE"
def main():
print("--- Allegro Failover Monitor ---")
status = {}
for name, host in FLEET.items():
status[name] = check_health(host)
print(f"{name.upper()}: {status[name]}")
STATUS_FILE.parent.mkdir(parents=True, exist_ok=True)
STATUS_FILE.write_text(json.dumps({
"timestamp": time.time(),
"fleet": status
}, indent=2))
if __name__ == "__main__":
main()

View File

@@ -0,0 +1,26 @@
#!/usr/bin/env python3
import json
import os
import sys
from pathlib import Path
# Sovereign Review Gate
# Aggregates remote state from Allegro's bridge for local Timmy judgment.
def main():
print("--- Timmy's Sovereign Review Gate ---")
print("Fetching pending artifacts from Allegro...")
# In a real scenario, this would call Allegro's GiteaBridge API
print("1. [PR #472] Sovereign Social (Evennia)")
print("2. [PR #417] Sovereign Health Dashboard")
print("3. [Issue #246] Gemma Scout Redaction")
print("\nPending Decision: PR #472")
print("Context: Multi-agent life in Evennia.")
print("Recommendation: APPROVE. Aligns with 'Agents play and live together' vision.")
# Decision logic would go here
print("\nDecision Record: Awaiting Timmy's local voice/input...")
if __name__ == "__main__":
main()