Initial commit - mini cms final

This commit is contained in:
Aya Tess tess
2025-11-03 21:53:58 +01:00
parent a366336dc1
commit a01f620ef9
14 changed files with 422 additions and 197 deletions

View File

@@ -1,19 +1,24 @@
<?php
session_start();
require_once 'config.php';
// ✅ Vérification que l'utilisateur est connecté
if (!isset($_SESSION['user']) || !isset($_SESSION['user']['id'])) {
header("Location: login.php");
exit;
}
$author_id = $_SESSION['user']['id'];
$message = '';
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
$title = trim($_POST['title'] ?? '');
$content = trim($_POST['content'] ?? '');
$author_id = $_SESSION['user_id'] ?? null;
if (!$author_id) {
echo "❌ Erreur : utilisateur non connecté.";
exit;
}
$imageUrl = null;
global $s3Client, $bucketName;
// ✅ Upload de l'image sur MinIO
if (isset($_FILES['image']) && $_FILES['image']['error'] === UPLOAD_ERR_OK) {
$fileName = time() . '_' . basename($_FILES['image']['name']);
$tmpPath = $_FILES['image']['tmp_name'];
@@ -27,19 +32,27 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST') {
]);
$imageUrl = "http://localhost:9000/$bucketName/$fileName";
} catch (Exception $e) {
echo "❌ Erreur upload MinIO : " . $e->getMessage();
exit;
$message = "❌ Erreur upload MinIO : " . $e->getMessage();
}
}
try {
$stmt = $pdo->prepare("INSERT INTO posts (title, content, image_url, user_id, date_creation)
VALUES (?, ?, ?, ?, NOW())");
$stmt->execute([$title, $content, $imageUrl, $author_id]);
header("Location: dashboard.php");
exit;
} catch (PDOException $e) {
echo "❌ Erreur base de données : " . $e->getMessage();
// ✅ Insertion de l'article dans la base de données
if ($title && $content) {
try {
$stmt = $pdo->prepare("
INSERT INTO posts (title, content, image_url, user_id, date_creation)
VALUES (?, ?, ?, ?, NOW())
");
$stmt->execute([$title, $content, $imageUrl, $author_id]);
// ✅ Redirection vers la page d'accueil
header("Location: index.php");
exit;
} catch (PDOException $e) {
$message = "❌ Erreur base de données : " . $e->getMessage();
}
} else {
$message = "⚠️ Tous les champs doivent être remplis.";
}
}
?>
@@ -140,6 +153,10 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST') {
<div class="container">
<h2>📝 Publier un nouvel article</h2>
<?php if ($message): ?>
<p style="color:red;"><?= htmlspecialchars($message) ?></p>
<?php endif; ?>
<form method="POST" enctype="multipart/form-data">
<label for="title">Titre :</label>
<input type="text" id="title" name="title" required>
@@ -153,7 +170,11 @@ if ($_SERVER['REQUEST_METHOD'] === 'POST') {
<button type="submit">Publier larticle</button>
</form>
<a href="dashboard.php" class="retour">⬅ Retour au tableau de bord</a>
<?php if ($_SESSION['user']['role'] === 'admin'): ?>
<a href="dashboard.php" class="retour">⬅ Retour au tableau de bord</a>
<?php else: ?>
<a href="index.php" class="retour">⬅ Retour à laccueil</a>
<?php endif; ?>
</div>
<footer>🕒 <?= date('Y') ?> — Mini CMS by Aya 💖</footer>