# Installation ## Debian packages (no install.sh) Jabali ships as two Debian packages: - `jabali-deps` — system dependencies (nginx, PHP, DB, mail, DNS, etc.) - `jabali-panel` — the panel application + systemd services ### Build the packages From the repository root: ``` ./scripts/build-jabali-deps-deb.sh ./scripts/build-jabali-panel-deb.sh ``` This produces: ``` jabali-deps__all.deb jabali-panel__all.deb ``` ### Install on a server ``` sudo dpkg -i ./jabali-deps__all.deb sudo apt-get -f install -y sudo dpkg -i ./jabali-panel__all.deb ``` After install, systemd services are enabled and started: - `jabali-agent` - `jabali-queue` - `jabali-health-monitor` ## Demo Docker (single container) Demo images run the panel in read-only mode with demo data preloaded. Key requirements: - `JABALI_DEMO=1` - `DB_DATABASE` must point to the demo SQLite file: `database/database-demo.sqlite` - Trust reverse proxy so Livewire update URLs are HTTPS Example container run (port 5555): ``` docker run -d --name jabali-panel-demo \ --restart unless-stopped \ -p 5555:5555 \ -e APP_URL=https://demo.jabali-panel.com \ -e ASSET_URL=https://demo.jabali-panel.com \ -e DB_DATABASE=/var/www/jabali/database/database-demo.sqlite \ -e JABALI_DEMO=1 \ -e JABALI_DEMO_ADMIN_EMAIL=admin@jabali-panel.com \ -e JABALI_DEMO_ADMIN_PASSWORD=demo1234 \ -e JABALI_DEMO_USER_EMAIL=demo@jabali-panel.com \ -e JABALI_DEMO_USER_PASSWORD=demo1234 \ jabali-panel-demo-current ``` Nginx reverse proxy (HTTPS): ``` server { listen 443 ssl http2; server_name demo.jabali-panel.com; ssl_certificate /etc/letsencrypt/live/demo.jabali-panel.com/fullchain.pem; ssl_certificate_key /etc/letsencrypt/live/demo.jabali-panel.com/privkey.pem; location / { proxy_pass http://127.0.0.1:5555; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection upgrade; } } ``` Reverse proxy trust (required for Livewire HTTPS): - Ensure `bootstrap/app.php` includes `trustProxies(at: '*')`. Demo limitations: - No agent socket in the container: pages that rely on the agent should use static demo data to avoid 500s. ## Panel notifications (admin + user) Jabali ships with a hardened Filament notifications setup that prevents Livewire success hooks from breaking after the first toast. What is included: - `public/js/filament/notifications/notifications.js` is patched to guard the animation callback (prevents `TypeError: e is not a function`). - `resources/views/vendor/filament-notifications/notifications.blade.php` adds a lightweight `wire:poll.2s` so toasts keep flowing even if a Livewire event is dropped. If you update or rebuild assets, keep the guard in place and hard‑refresh the browser (Ctrl+Shift+R) after deployment. ## Deploy script The repository ships with a deploy helper at `scripts/deploy.sh`. It syncs the project to a remote server over SSH, then runs composer/npm, migrations, and cache rebuilds as the web user. Defaults (override via flags or env vars): - Host: `192.168.100.50` - User: `root` - Path: `/var/www/jabali` - Web user: `www-data` Common usage: ``` # Basic deploy to the default host scripts/deploy.sh # Target a different host/path/user scripts/deploy.sh --host 192.168.100.50 --user root --path /var/www/jabali --www-user www-data # Dry-run rsync only scripts/deploy.sh --dry-run # Skip npm build and cache steps scripts/deploy.sh --skip-npm --skip-cache ``` Push to Git remotes (optional): ``` # Push to Gitea and/or GitHub before deploying scripts/deploy.sh --push-gitea --push-github # Push to explicit URLs scripts/deploy.sh --push-gitea --gitea-url http://192.168.100.100:3001/shukivaknin/jabali-panel.git \ --push-github --github-url git@github.com:shukiv/jabali-panel.git ``` Notes: - `--push-gitea` / `--push-github` require a clean worktree. - When pushing, the script bumps `VERSION`, updates the `install.sh` fallback, and commits the version bump before pushing. - Rsync excludes `.env`, `storage/`, `vendor/`, `node_modules/`, `public/build/`, `bootstrap/cache/`, and SQLite DB files. Handle those separately if needed. - `--delete` passes `--delete` to rsync (dangerous). ## Testing after changes After every change, run a test to make sure there are no errors.