Added migration file

This commit is contained in:
julien
2026-03-09 16:22:23 +01:00
parent 03ce72ce00
commit 888096996a
5 changed files with 83 additions and 33 deletions

View File

@@ -12,6 +12,8 @@ use Medoo\Medoo;
use App\Controllers\PostController; use App\Controllers\PostController;
use App\Repositories\PostRepository; use App\Repositories\PostRepository;
use App\Services\HtmlSanitizer; use App\Services\HtmlSanitizer;
use App\Services\HtmlPurifierFactory;
use App\Database\Migration;
use App\Routes; use App\Routes;
use App\Config; use App\Config;
@@ -46,20 +48,15 @@ $db = new Medoo([
'database' => $dbFile, 'database' => $dbFile,
]); ]);
// Créer la table si elle n'existe pas // Exécuter les migrations
$db->pdo->exec(" Migration::run($db);
CREATE TABLE IF NOT EXISTS post (
id INTEGER PRIMARY KEY AUTOINCREMENT,
title TEXT NOT NULL,
content TEXT NOT NULL,
slug TEXT UNIQUE NOT NULL DEFAULT '',
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
)
");
// HtmlSanitizer // HtmlPurifier (créé via la factory)
$htmlSanitizer = new HtmlSanitizer(); $htmlPurifierCacheDir = __DIR__ . '/../var/cache/htmlpurifier';
$htmlPurifier = HtmlPurifierFactory::create($htmlPurifierCacheDir);
// HtmlSanitizer (reçoit HTMLPurifier injecté)
$htmlSanitizer = new HtmlSanitizer($htmlPurifier);
// PostRepository // PostRepository
$postRepository = new PostRepository($db); $postRepository = new PostRepository($db);

View File

@@ -0,0 +1,24 @@
<?php
declare(strict_types=1);
namespace App\Database;
use Medoo\Medoo;
final class Migration
{
public static function run(Medoo $db): void
{
$db->pdo->exec("
CREATE TABLE IF NOT EXISTS post (
id INTEGER PRIMARY KEY AUTOINCREMENT,
title TEXT NOT NULL,
content TEXT NOT NULL,
slug TEXT UNIQUE NOT NULL DEFAULT '',
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP
)
");
}
}

View File

@@ -0,0 +1,44 @@
<?php
declare(strict_types=1);
namespace App\Services;
use HTMLPurifier;
use HTMLPurifier_Config;
/**
* Factory pour créer et configurer une instance HTMLPurifier.
* Centralise toute la logique de configuration.
*/
final class HtmlPurifierFactory
{
/**
* Crée une instance HTMLPurifier préconfigurée.
*
* @param string $cacheDir Répertoire de cache pour HTMLPurifier
* @return HTMLPurifier
*/
public static function create(string $cacheDir): HTMLPurifier
{
// Créer le répertoire de cache s'il n'existe pas
if (!is_dir($cacheDir)) {
@mkdir($cacheDir, 0755, true);
}
// Créer et configurer HTMLPurifier
$config = HTMLPurifier_Config::createDefault();
// Balises HTML autorisées
$config->set('HTML.Allowed', 'p,br,strong,em,u,h1,h2,h3,h4,h5,h6,ul,ol,li,blockquote,a[href],img[src|alt|width|height]');
// Attributs autorisés
$config->set('HTML.AllowedAttributes', 'href,src,alt,width,height,title');
// Configuration du cache
$config->set('Cache.DefinitionImpl', 'Serializer');
$config->set('Cache.SerializerPath', $cacheDir);
return new HTMLPurifier($config);
}
}

View File

@@ -5,30 +5,14 @@ declare(strict_types=1);
namespace App\Services; namespace App\Services;
use HTMLPurifier; use HTMLPurifier;
use HTMLPurifier_Config;
final class HtmlSanitizer final class HtmlSanitizer
{ {
private HTMLPurifier $purifier; /**
* @param HTMLPurifier $purifier Instance préconfigurée d'HTMLPurifier
public function __construct() */
public function __construct(private HTMLPurifier $purifier)
{ {
// Créer le répertoire de cache s'il n'existe pas
$cacheDir = __DIR__ . '/../../var/cache/htmlpurifier';
if (!is_dir($cacheDir)) {
@mkdir($cacheDir, 0755, true);
}
$config = HTMLPurifier_Config::createDefault();
// Autoriser les balises courantes de formatage
$config->set('HTML.Allowed', 'p,br,strong,em,u,h1,h2,h3,h4,h5,h6,ul,ol,li,blockquote,a[href],img[src|alt|width|height]');
// Désactiver les attributs dangereux
$config->set('HTML.AllowedAttributes', 'href,src,alt,width,height,title');
// Activer le cache
$config->set('Cache.DefinitionImpl', 'Serializer');
$config->set('Cache.SerializerPath', $cacheDir);
$this->purifier = new HTMLPurifier($config);
} }
public function sanitize(string $html): string public function sanitize(string $html): string

View File

@@ -18,6 +18,7 @@
{% endif %} {% endif %}
<div class="post-content"> <div class="post-content">
{# Le contenu est déjà sanitisé par HtmlSanitizer #}
{{ post.content }} {{ post.content }}
</div> </div>