Compare commits
8 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| d685c2211e | |||
| a400b7cc66 | |||
| ed5cfcd275 | |||
| 4110caa25a | |||
| 9225abc804 | |||
| 56dbd8a0bf | |||
| 79b831367c | |||
| 715aad58e1 |
@@ -5,6 +5,38 @@ Format : [Keep a Changelog](https://keepachangelog.com/fr/1.0.0/) — versionnag
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
## [1.0.4] — 2026-06-05
|
||||||
|
|
||||||
|
### Corrigé
|
||||||
|
|
||||||
|
- **Assistant d'installation — APP_KEY vide après installation** : `key:generate` remplace `APP_KEY=<clé_en_mémoire>` par regex dans le `.env`. Mais `writeEnv()` écrit `APP_KEY=` (vide) alors que la clé en mémoire est celle de l'auto-création (clé temporaire) — le pattern ne matche pas, la clé reste vide. Correction : la clé est générée directement en PHP (`random_bytes`), écrite dans le `.env` sans regex, puis propagée en mémoire (`config(['app.key'])`) et dans l'env OS (`putenv`).
|
||||||
|
- **Assistant d'installation — `MissingAppKeyException` lors de l'optimisation** : `optimize` appelle en interne `config:cache`, qui re-boostrappe une seconde instance de l'application depuis `bootstrap/app.php`. Ce second boot passe par tous les ServiceProviders et peut résoudre l'Encrypter avant que la clé soit accessible, levant `MissingAppKeyException` et renvoyant une erreur 500. Correction : `optimize` est supprimé de la procédure d'installation ; seul `optimize:clear` est conservé pour purger tout cache résiduel. Laravel reconstruit ses caches paresseusement à la première requête.
|
||||||
|
- **Assistant d'installation — connexion PostgreSQL forcée après login (MySQL)** : `putenv()` n'était appelé que pour les variables `DB_*` mais pas pour `APP_KEY`. Correction : tous les `putenv()` (dont `APP_KEY`) sont regroupés en un bloc cohérent, garantissant que tout sous-processus futur hérite des valeurs correctes.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## [1.0.3] — 2026-06-04
|
||||||
|
|
||||||
|
### Ajouté
|
||||||
|
|
||||||
|
- **Numéro de version dans l'assistant d'installation** — affiché sous le titre « Assistant d'installation » dans le layout du wizard (lu depuis le fichier `VERSION`)
|
||||||
|
|
||||||
|
### Corrigé
|
||||||
|
|
||||||
|
- **Assistant d'installation — conflit pgsql/mysql (correctif partiel, voir 1.0.4)** : identification de la cause racine (`phpdotenv` immutable + héritage `putenv` par les sous-processus `exec()`). Les migrations sont migrées vers `Artisan::call()` avec reconfiguration en mémoire (`config()` + `DB::purge()`), mais `key:generate` et `optimize` restaient des sous-processus — corrigé complètement en 1.0.4.
|
||||||
|
- **`.htaccess`** — suppression des directives `php_flag display_errors on` ajoutées temporairement pour déboguer l'erreur 500 sur hébergement mutualisé.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
## [1.0.2] — 2026-06-04
|
||||||
|
|
||||||
|
### Corrigé
|
||||||
|
|
||||||
|
- **Assistant d'installation — conflit de connexion pgsql/mysql** *(correctif partiel, voir 1.0.3 et 1.0.4)* : ajout d'un appel à `config:clear` entre l'écriture du `.env` et l'exécution des migrations, et exclusion de `bootstrap/cache/*.php` des archives de déploiement pour ne pas embarquer un cache de configuration de développement.
|
||||||
|
- **Archives de déploiement** : `bootstrap/cache/*.php` exclu du build rsync.
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
## [1.0.1] — 2026-06-04
|
## [1.0.1] — 2026-06-04
|
||||||
|
|
||||||
### Ajouté
|
### Ajouté
|
||||||
|
|||||||
@@ -3,6 +3,8 @@
|
|||||||
namespace App\Http\Controllers;
|
namespace App\Http\Controllers;
|
||||||
|
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
|
use Illuminate\Support\Facades\Artisan;
|
||||||
|
use Illuminate\Support\Facades\DB;
|
||||||
use Illuminate\Support\Facades\Hash;
|
use Illuminate\Support\Facades\Hash;
|
||||||
use PDO;
|
use PDO;
|
||||||
use PDOException;
|
use PDOException;
|
||||||
@@ -126,8 +128,6 @@ class SetupController extends Controller
|
|||||||
|
|
||||||
$steps = [];
|
$steps = [];
|
||||||
$success = true;
|
$success = true;
|
||||||
$php = $this->phpBinary();
|
|
||||||
$artisan = $php . ' ' . escapeshellarg(base_path('artisan'));
|
|
||||||
|
|
||||||
// 1. Écriture du .env
|
// 1. Écriture du .env
|
||||||
try {
|
try {
|
||||||
@@ -138,18 +138,74 @@ class SetupController extends Controller
|
|||||||
$success = false;
|
$success = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. Génération de la clé APP_KEY
|
// 2. Génération de la clé APP_KEY — directement en PHP, sans passer par key:generate.
|
||||||
|
//
|
||||||
|
// Artisan key:generate remplace APP_KEY=<clé_en_mémoire> dans le .env grâce à un
|
||||||
|
// pattern regex. Mais writeEnv() vient d'écrire APP_KEY= (vide) alors qu'en mémoire
|
||||||
|
// la clé est celle de l'auto-création (TEMP_KEY) → le pattern ne matche pas → la
|
||||||
|
// clé reste vide dans le .env et la config:cache en hérite.
|
||||||
|
// Solution : générer la clé nous-mêmes, l'écrire directement dans le .env, et la
|
||||||
|
// propager en mémoire + env OS dès maintenant.
|
||||||
|
$appKey = null;
|
||||||
if ($success) {
|
if ($success) {
|
||||||
[$ok, $out] = $this->artisanRun($artisan, 'key:generate --force');
|
try {
|
||||||
$steps[] = ['ok' => $ok, 'label' => 'Génération de la clé de chiffrement (APP_KEY)', 'error' => $ok ? null : $out];
|
$appKey = 'base64:' . base64_encode(random_bytes(32));
|
||||||
if (! $ok) $success = false;
|
$envPath = base_path('.env');
|
||||||
|
$env = file_get_contents($envPath);
|
||||||
|
$env = preg_replace('/^APP_KEY=.*/m', 'APP_KEY=' . $appKey, $env);
|
||||||
|
file_put_contents($envPath, $env);
|
||||||
|
config(['app.key' => $appKey]);
|
||||||
|
$steps[] = ['ok' => true, 'label' => 'Génération de la clé de chiffrement (APP_KEY)'];
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$steps[] = ['ok' => false, 'label' => 'Génération de la clé de chiffrement (APP_KEY)', 'error' => $e->getMessage()];
|
||||||
|
$success = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 3. Migrations
|
// 2b. Reconfiguration de la connexion BDD — processus courant ET sous-processus.
|
||||||
|
//
|
||||||
|
// putenv() écrase l'env OS hérité au boot (pgsql + TEMP_KEY) pour que tous les
|
||||||
|
// sous-processus futurs (config:cache interne à optimize…) reçoivent les bonnes
|
||||||
|
// valeurs. config() + DB::purge() reconfigure le processus courant en mémoire.
|
||||||
if ($success) {
|
if ($success) {
|
||||||
[$ok, $out] = $this->artisanRun($artisan, 'migrate --force');
|
putenv("APP_KEY={$appKey}");
|
||||||
$steps[] = ['ok' => $ok, 'label' => 'Migration de la base de données', 'error' => $ok ? null : $out];
|
putenv("DB_CONNECTION={$dbData['driver']}");
|
||||||
if (! $ok) $success = false;
|
putenv("DB_HOST={$dbData['host']}");
|
||||||
|
putenv("DB_PORT={$dbData['port']}");
|
||||||
|
putenv("DB_DATABASE={$dbData['database']}");
|
||||||
|
putenv("DB_USERNAME={$dbData['username']}");
|
||||||
|
putenv('DB_PASSWORD=' . ($dbData['password'] ?? ''));
|
||||||
|
|
||||||
|
$connConfig = $dbData['driver'] === 'pgsql'
|
||||||
|
? ['driver' => 'pgsql', 'host' => $dbData['host'], 'port' => (int) $dbData['port'],
|
||||||
|
'database' => $dbData['database'], 'username' => $dbData['username'],
|
||||||
|
'password' => $dbData['password'] ?? '', 'charset' => 'utf8', 'prefix' => '',
|
||||||
|
'schema' => 'public', 'sslmode' => 'prefer']
|
||||||
|
: ['driver' => 'mysql', 'host' => $dbData['host'], 'port' => (int) $dbData['port'],
|
||||||
|
'database' => $dbData['database'], 'username' => $dbData['username'],
|
||||||
|
'password' => $dbData['password'] ?? '', 'charset' => 'utf8mb4',
|
||||||
|
'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true];
|
||||||
|
|
||||||
|
config([
|
||||||
|
'database.default' => $dbData['driver'],
|
||||||
|
"database.connections.{$dbData['driver']}" => $connConfig,
|
||||||
|
]);
|
||||||
|
|
||||||
|
DB::purge($dbData['driver']);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 3. Migrations (dans le processus courant, config BDD déjà écrasée ci-dessus)
|
||||||
|
if ($success) {
|
||||||
|
try {
|
||||||
|
$exitCode = Artisan::call('migrate', ['--force' => true]);
|
||||||
|
$out = trim(Artisan::output());
|
||||||
|
$ok = $exitCode === 0;
|
||||||
|
$steps[] = ['ok' => $ok, 'label' => 'Migration de la base de données', 'error' => $ok ? null : $out];
|
||||||
|
if (! $ok) $success = false;
|
||||||
|
} catch (\Exception $e) {
|
||||||
|
$steps[] = ['ok' => false, 'label' => 'Migration de la base de données', 'error' => $e->getMessage()];
|
||||||
|
$success = false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 4. Création du compte administrateur
|
// 4. Création du compte administrateur
|
||||||
@@ -176,10 +232,14 @@ class SetupController extends Controller
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 6. Optimisation des caches
|
// 6. Nettoyage des caches
|
||||||
|
// optimize:clear supprime tout cache résiduel (config, routes, vues, events).
|
||||||
|
// On n'appelle PAS optimize : config:cache re-boostrappe l'app depuis bootstrap/app.php
|
||||||
|
// dans un contexte qui peut ne pas avoir accès à notre APP_KEY via putenv, ce qui
|
||||||
|
// provoque MissingAppKeyException. Laravel reconstruit ses caches à la première
|
||||||
|
// requête — pas besoin de les préchauffer pendant l'installation.
|
||||||
if ($success) {
|
if ($success) {
|
||||||
$this->artisanRun($artisan, 'optimize:clear');
|
Artisan::call('optimize:clear');
|
||||||
$this->artisanRun($artisan, 'optimize');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 7. Marquage installation
|
// 7. Marquage installation
|
||||||
|
|||||||
@@ -16,7 +16,14 @@
|
|||||||
<div class="text-center mb-8">
|
<div class="text-center mb-8">
|
||||||
<div class="inline-flex items-center justify-center w-14 h-14 rounded-2xl bg-blue-600 text-white text-2xl font-bold mb-3 select-none">M</div>
|
<div class="inline-flex items-center justify-center w-14 h-14 rounded-2xl bg-blue-600 text-white text-2xl font-bold mb-3 select-none">M</div>
|
||||||
<h1 class="text-2xl font-bold text-slate-800">MesRelevés</h1>
|
<h1 class="text-2xl font-bold text-slate-800">MesRelevés</h1>
|
||||||
<p class="text-slate-500 text-sm mt-1">Assistant d'installation</p>
|
<p class="text-slate-500 text-sm mt-1">
|
||||||
|
Assistant d'installation
|
||||||
|
@php $version = trim(@file_get_contents(base_path('VERSION')) ?: ''); @endphp
|
||||||
|
@if($version)
|
||||||
|
<span class="mx-1.5 text-slate-300">·</span>
|
||||||
|
<span class="font-mono text-slate-400">v{{ $version }}</span>
|
||||||
|
@endif
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{{-- Indicateur d'étapes --}}
|
{{-- Indicateur d'étapes --}}
|
||||||
|
|||||||
Reference in New Issue
Block a user