mirror of
https://github.com/myronblair/jarvis
synced 2026-06-30 17:50:23 -05:00
d77621c8490a7d7adec64b2ce35ab97da50531d8
Root cause: open_basedir restriction prevented lsphp from reading config files on other vhosts (/home/epictravelexpeditions.com/*, etc.) TJJ worked via its own DB; TTG worked because file happened to be readable. Epic, Parker Slingshot, Parker Slingshot Rentals all returned empty. Fix: site_settings table in jarvis_db as primary storage for all sites. - All reads/writes go through JarvisDB (always accessible, no open_basedir) - TJJ still syncs bidirectionally with its own settings table (secondary) - File push attempted best-effort on save (succeeds where writable, silent no-op otherwise) - Seeded existing known values from file grep on table creation - All 5 sites now return and save settings correctly
JARVIS
Iron Man-style AI assistant for home and network management.
Features
- Home Assistant control (lights, climate, scenes, switches)
- Proxmox VM management (start/stop/status)
- 4-tier chat: KB intents > Groq cloud > Ollama local > Claude API
- Real-time status bar (HA, Proxmox, DigitalOcean)
- Iron Man HUD at jarvis.orbishosting.com
Stack
- PHP 8.x / Apache / MySQL on Ubuntu 24.04
- Ollama VM at 10.48.200.95 (llama3.2:1b)
- Groq API (llama-3.3-70b / compound-mini with web search)
- Claude API (Anthropic) final fallback
Setup
cp api/config.example.php api/config.php Fill in all credentials in config.php before running.
Key Files
- public/index.html Iron Man HUD frontend
- public/api.php API router
- api/config.example.php Config template
- api/endpoints/chat.php 4-tier chat handler
- api/endpoints/facts_collector.php HA entity sync cron
- api/lib/kb_engine.php KB intent engine
- api/lib/db.php PDO database wrapper
Description
Languages
PHP
43.3%
Python
29.9%
JavaScript
14.9%
CSS
6.2%
Shell
2.2%
Other
3.5%