diff options
| author | polo <ordipolo@gmx.fr> | 2026-03-29 21:54:40 +0200 |
|---|---|---|
| committer | polo <ordipolo@gmx.fr> | 2026-03-29 21:54:40 +0200 |
| commit | 69981561f83ba3a05217e75cac6c68e8dc671c45 (patch) | |
| tree | b37a266f43c6fbb03530557f47d0f63d606f750a /src/model | |
| parent | bc24cb0e862c66475ac04a4c5fab3eac48bcf4a1 (diff) | |
| download | cms-69981561f83ba3a05217e75cac6c68e8dc671c45.tar.gz cms-69981561f83ba3a05217e75cac6c68e8dc671c45.tar.bz2 cms-69981561f83ba3a05217e75cac6c68e8dc671c45.zip | |
erreur algo le remplissage BDD doit être avant création compte admin, rangement code classe DatabaseSettingUp, erreur mention extension GDHEADmain
Diffstat (limited to 'src/model')
| -rw-r--r-- | src/model/DatabaseSettingUp.php | 152 |
1 files changed, 152 insertions, 0 deletions
diff --git a/src/model/DatabaseSettingUp.php b/src/model/DatabaseSettingUp.php new file mode 100644 index 0000000..9ff7344 --- /dev/null +++ b/src/model/DatabaseSettingUp.php | |||
| @@ -0,0 +1,152 @@ | |||
| 1 | <?php | ||
| 2 | // src/model/DatabaseSettingUp.php | ||
| 3 | |||
| 4 | declare(strict_types=1); | ||
| 5 | |||
| 6 | use App\Entity\AppMetadata; | ||
| 7 | use App\Entity\Page; | ||
| 8 | use App\Entity\Node; | ||
| 9 | use App\Entity\NodeData; | ||
| 10 | use Doctrine\ORM\EntityManager; | ||
| 11 | |||
| 12 | /* création d'un site minimal avec une page d'accueil à la toute 1ère visite du site, ne doit surtout pas être exécutée une seconde fois */ | ||
| 13 | class DatabaseSettingUp | ||
| 14 | { | ||
| 15 | static public function run(EntityManager $entityManager): void | ||
| 16 | { | ||
| 17 | if(!self::isFirstRun($entityManager)){ | ||
| 18 | return; | ||
| 19 | } | ||
| 20 | |||
| 21 | // la BDD n'est pas vierge, on ne touche à rien | ||
| 22 | if(!self::areTablesEmpty($entityManager)){ | ||
| 23 | return; | ||
| 24 | } | ||
| 25 | |||
| 26 | self::fillStartingDatabase($entityManager); | ||
| 27 | |||
| 28 | // empêcher la réutilisation de cette fonction | ||
| 29 | self::preventReinstallation($entityManager); | ||
| 30 | |||
| 31 | // fin de l'installation | ||
| 32 | AppMode::set($entityManager, 'run'); | ||
| 33 | |||
| 34 | // recharger la page? | ||
| 35 | //header('Location: ' . new URL); | ||
| 36 | } | ||
| 37 | |||
| 38 | // protection 1 utilisé à chaque requête | ||
| 39 | static private function isFirstRun(EntityManager $entityManager): bool | ||
| 40 | { | ||
| 41 | $metadata = $entityManager->getRepository(AppMetadata::class)->find('installed'); | ||
| 42 | return !$metadata || $metadata->getValue() !== '1'; | ||
| 43 | } | ||
| 44 | |||
| 45 | // protection 2, qui vérifie vraiment que les tables concernées sont vides | ||
| 46 | static private function areTablesEmpty(EntityManager $entityManager): bool | ||
| 47 | { | ||
| 48 | $empty = true; | ||
| 49 | $entities = ['Page', 'Node', 'NodeData']; | ||
| 50 | foreach($entities as $entity){ | ||
| 51 | $entity = 'App\Entity\\' . $entity; // nécéssaire quand on insère le nom avec une variable | ||
| 52 | |||
| 53 | if($entityManager | ||
| 54 | ->createQuery("SELECT e FROM $entity e") | ||
| 55 | ->setMaxResults(1) | ||
| 56 | ->getOneOrNullResult()){ | ||
| 57 | $empty = false; | ||
| 58 | } | ||
| 59 | } | ||
| 60 | |||
| 61 | // cas anormal détecté, on remet en place la clé "installed" | ||
| 62 | if(!$empty){ | ||
| 63 | self::preventReinstallation($entityManager); | ||
| 64 | } | ||
| 65 | |||
| 66 | return $empty; | ||
| 67 | } | ||
| 68 | |||
| 69 | static private function fillStartingDatabase(EntityManager $entityManager): void | ||
| 70 | { | ||
| 71 | /* -- table page -- */ | ||
| 72 | // paramètres: name_page, end_of_path, reachable, in_menu, hidden, position, parent | ||
| 73 | $accueil = new Page('Accueil', 'accueil', "Page d'accueil", true, true, false, 1, NULL); | ||
| 74 | $article = new Page('Article', 'article', "", true, false, false, NULL, NULL); | ||
| 75 | $connection = new Page('Connexion', 'connection', "Connexion", true, false, false, NULL, NULL); | ||
| 76 | $my_account = new Page('Mon compte', 'user_edit', "Mon compte", true, false, false, NULL, NULL); | ||
| 77 | $menu_paths = new Page("Menu et chemins", 'menu_paths', "Menu et chemins", true, false, false, NULL, NULL); | ||
| 78 | $menu_paths->addCSS('menu'); | ||
| 79 | $menu_paths->addJS('menu'); | ||
| 80 | $new_page = new Page('Nouvelle page', 'new_page', "Nouvelle page", true, false, false, NULL, NULL); | ||
| 81 | $new_page->addCSS('new_page'); | ||
| 82 | $new_page->addJS('new_page'); | ||
| 83 | $emails = new Page("Courriels", 'emails', "Consulter les courriels en base de données", true, false, false, NULL, NULL); | ||
| 84 | $emails->addCSS('show_emails'); | ||
| 85 | $emails->addJS('form'); | ||
| 86 | |||
| 87 | /* -- table node -- */ | ||
| 88 | // paramètres: name_node, article_timestamp, attributes, position, parent, page, article | ||
| 89 | $head = new Node('head', 1, NULL, NULL, NULL); | ||
| 90 | $header = new Node('header', 2, NULL, NULL, NULL); | ||
| 91 | $nav = new Node('nav', 1, $header, NULL, NULL); | ||
| 92 | $main = new Node('main', 3, NULL, NULL, NULL); | ||
| 93 | $footer = new Node('footer', 4, NULL, NULL, NULL); | ||
| 94 | $breadcrumb = new Node('breadcrumb', 2, $header, NULL, NULL); | ||
| 95 | $login = new Node('login', 1, $main, $connection, NULL); | ||
| 96 | $user_edit = new Node('user_edit', 1, $main, $my_account, NULL); | ||
| 97 | $bloc_edit_menu = new Node('menu', 1, $main, $menu_paths, NULL); | ||
| 98 | $bloc_new_page = new Node('new_page', 1, $main, $new_page, NULL); | ||
| 99 | $bloc_emails = new Node('show_emails', 1, $main, $emails, NULL); | ||
| 100 | |||
| 101 | /* -- table node_data -- */ | ||
| 102 | // paramètres: data, node, images | ||
| 103 | $head_data = new NodeData([], $head); | ||
| 104 | $header_data = new NodeData([], $header); | ||
| 105 | $footer_data = new NodeData([], $footer); | ||
| 106 | $emails_data = new NodeData([], $bloc_emails); | ||
| 107 | |||
| 108 | /* -- table page -- */ | ||
| 109 | $entityManager->persist($accueil); | ||
| 110 | $entityManager->persist($article); | ||
| 111 | $entityManager->persist($connection); | ||
| 112 | $entityManager->persist($my_account); | ||
| 113 | $entityManager->persist($menu_paths); | ||
| 114 | $entityManager->persist($new_page); | ||
| 115 | $entityManager->persist($emails); | ||
| 116 | |||
| 117 | /* -- table node -- */ | ||
| 118 | $entityManager->persist($head); | ||
| 119 | $entityManager->persist($header); | ||
| 120 | $entityManager->persist($nav); | ||
| 121 | $entityManager->persist($main); | ||
| 122 | $entityManager->persist($footer); | ||
| 123 | $entityManager->persist($breadcrumb); | ||
| 124 | $entityManager->persist($login); | ||
| 125 | $entityManager->persist($user_edit); | ||
| 126 | $entityManager->persist($bloc_edit_menu); | ||
| 127 | $entityManager->persist($bloc_new_page); | ||
| 128 | $entityManager->persist($bloc_emails); | ||
| 129 | |||
| 130 | /* -- table node_data -- */ | ||
| 131 | $entityManager->persist($head_data); | ||
| 132 | $entityManager->persist($header_data); | ||
| 133 | $entityManager->persist($footer_data); | ||
| 134 | $entityManager->persist($emails_data); | ||
| 135 | |||
| 136 | $entityManager->flush(); | ||
| 137 | } | ||
| 138 | |||
| 139 | // met en place la protection | ||
| 140 | static private function preventReinstallation(EntityManager $entityManager): void | ||
| 141 | { | ||
| 142 | $metadata = $entityManager->getRepository(AppMetadata::class)->find('installed'); | ||
| 143 | if($metadata){ | ||
| 144 | $metadata->setValue('1'); | ||
| 145 | } | ||
| 146 | else{ | ||
| 147 | $metadata = new AppMetadata('installed', '1'); | ||
| 148 | $entityManager->persist($metadata); | ||
| 149 | } | ||
| 150 | $entityManager->flush(); | ||
| 151 | } | ||
| 152 | } \ No newline at end of file | ||
