Some checks failed
CI Pipeline / Rust Format Check (push) Failing after 36s
CI Pipeline / Clippy Lints (push) Successful in 45s
CI Pipeline / Rust Unit Tests (push) Successful in 1m1s
CI Pipeline / Security Audit (push) Successful in 4s
CI Pipeline / Frontend Lint & Type Check (push) Successful in 11s
CI Pipeline / Build .deb & Release (push) Has been skipped
BUG-6: Add TLS support via axum-server + rustls
- Added axum-server with tls-rustls feature to workspace and pm-web
- pm-web now serves HTTPS when TLS certs exist, falls back to HTTP with warning
- setup.sh generates self-signed ECDSA P-256 TLS cert with SANs
- Config already had web_tls_cert_path/web_tls_key_path fields
BUG-7: Fix audit chain integrity errors
- Migration 005 now TRUNCATEs audit_log after adding prev_hash column
- Existing rows had broken hash chains (inserted before prev_hash existed)
BUG-8: Disable WatchdogSec in patch-manager-web.service
- pm-web does not implement sd_notify, causing systemd to kill the service
BUG-9: Disable WatchdogSec in patch-manager-worker.service
- Same issue as BUG-8, worker does not implement sd_notify
Previous fixes (BUG-1 through BUG-5) also included:
- setup.sh: PostgreSQL 15+ schema GRANTs
- Axum route syntax :param → {param} (19 routes)
- DbUser struct role: String → UserRole enum mapping
- UserRole/AuthProvider Display trait implementations
- Seed admin password hash (Argon2id)
62 lines
1.5 KiB
Desktop File
62 lines
1.5 KiB
Desktop File
[Unit]
|
|
Description=Linux Patch Manager — Web Server
|
|
Documentation=https://gitea.moon-dragon.us/echo/linux_patch_manager
|
|
After=network-online.target postgresql.service
|
|
Wants=network-online.target
|
|
Requires=postgresql.service
|
|
PartOf=patch-manager.target
|
|
|
|
[Service]
|
|
Type=simple
|
|
User=patch-manager
|
|
Group=patch-manager
|
|
WorkingDirectory=/opt/patch-manager
|
|
|
|
# Configuration
|
|
Environment="PATCH_MANAGER_CONFIG=/etc/patch-manager/config.toml"
|
|
# Override individual settings via environment if needed:
|
|
# Environment="PATCH_MANAGER__DATABASE__URL=postgres://..."
|
|
|
|
ExecStart=/usr/local/bin/pm-web
|
|
|
|
# Restart policy — aggressive restart for production availability
|
|
Restart=always
|
|
RestartSec=5s
|
|
StartLimitIntervalSec=60
|
|
StartLimitBurst=5
|
|
|
|
# Timeouts
|
|
TimeoutStartSec=90s
|
|
TimeoutStopSec=30s
|
|
|
|
# Watchdog disabled — pm-web does not currently implement sd_notify
|
|
# WatchdogSec=120s
|
|
|
|
# Security hardening
|
|
NoNewPrivileges=true
|
|
ProtectSystem=strict
|
|
ProtectHome=true
|
|
ReadWritePaths=/var/log/patch-manager /etc/patch-manager/ca /etc/patch-manager/certs /etc/patch-manager/tls /etc/patch-manager/jwt /usr/share/patch-manager/frontend
|
|
PrivateTmp=true
|
|
PrivateDevices=true
|
|
ProtectKernelTunables=true
|
|
ProtectKernelModules=true
|
|
ProtectControlGroups=true
|
|
RestrictNamespaces=true
|
|
RestrictSUIDSGID=true
|
|
|
|
# Allow binding to port 443 without root
|
|
AmbientCapabilities=CAP_NET_BIND_SERVICE
|
|
CapabilityBoundingSet=CAP_NET_BIND_SERVICE
|
|
|
|
# File descriptor limits
|
|
LimitNOFILE=65536
|
|
|
|
# Logging
|
|
StandardOutput=journal
|
|
StandardError=journal
|
|
SyslogIdentifier=patch-manager-web
|
|
|
|
[Install]
|
|
WantedBy=multi-user.target
|