Versioning, déploiement et mise à jour automatique
Gestion des versions :
- Fichier VERSION (1.0.0) comme source de vérité
- config/update.php : URL Gitea, AUTO_UPDATE (false par défaut), rétention des sauvegardes
Artisan commands :
- app:check-update : interroge l'API Gitea, cache Redis 1h, déclenche app:update si AUTO_UPDATE=true
- app:update : télécharge l'archive, sauvegarde pg_dump, rsync, composer install, migrate, reload php-fpm
- app:rollback : liste les sauvegardes et restaure via psql
UpdateService :
- Téléchargement via Http::sink() (streaming, pas de charge mémoire)
- Sauvegarde pg_dump dans storage/app/backups/ avant chaque mise à jour
- Rechargement php-fpm gracieux (kill -USR2 1) sans downtime
- Purge automatique des anciennes sauvegardes (configurable)
Docker (refactor pour volume-mount) :
- Dockerfile : runtime seulement (PHP + extensions + composer + rsync + pg_client)
Le code n'est plus copié dans l'image → les mises à jour ne nécessitent pas de rebuild
- entrypoint.sh : composer install + key:generate + caches au démarrage du container
- docker-compose.prod.yml : montage du code comme volume (.:/var/www/html)
Scripts de déploiement :
- bin/build-release.sh : rsync + tar.gz + sha256, exclut vendor/node_modules/tests
- install.sh : guide d'installation Docker complète (première mise en service)
Interface admin :
- Bandeau "mise à jour disponible" dans le dashboard admin (version courante + cible)
- Badge version + icône "à jour" en pied de tableau de bord
- Commande à copier-coller pour appliquer depuis le container
Planification :
- routes/console.php : Schedule::command('app:check-update')->daily()
- .env.example : variables GITEA_*, AUTO_UPDATE, UPDATE_BACKUPS_TO_KEEP
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -7,12 +7,18 @@ use App\Http\Controllers\Controller;
|
||||
use App\Models\Releve;
|
||||
use App\Models\Source;
|
||||
use App\Models\User;
|
||||
use App\Services\UpdateService;
|
||||
use Illuminate\View\View;
|
||||
|
||||
class DashboardController extends Controller
|
||||
{
|
||||
public function index(): View
|
||||
public function index(UpdateService $updates): View
|
||||
{
|
||||
$installedVersion = $updates->getInstalledVersion();
|
||||
$latestRelease = $updates->fetchLatestRelease(); // depuis le cache Redis
|
||||
$updateAvailable = $latestRelease
|
||||
&& version_compare($latestRelease['version'], $installedVersion, '>');
|
||||
|
||||
// Compteurs sources par statut
|
||||
$sourcesByStatus = Source::selectRaw('status, count(*) as total')
|
||||
->groupBy('status')
|
||||
@@ -54,7 +60,8 @@ class DashboardController extends Controller
|
||||
return view('admin.dashboard', compact(
|
||||
'sourcesByStatus', 'totalSources', 'totalReleves',
|
||||
'usersByRole', 'totalUsers',
|
||||
'sourcesAValider', 'relevesRecents', 'activiteMensuelle'
|
||||
'sourcesAValider', 'relevesRecents', 'activiteMensuelle',
|
||||
'installedVersion', 'latestRelease', 'updateAvailable'
|
||||
));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user