1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
|
<?php
// src/controller/ArticleController.php
declare(strict_types=1);
use App\Entity\Node;
use App\Entity\Article;
use Doctrine\ORM\EntityManager;
use Symfony\Component\HttpFoundation\Response;
class ArticleController
{
static public function editorSubmit(EntityManager $entityManager, array $json): void
{
if(json_last_error() === JSON_ERROR_NONE)
{
$id = $json['id'];
$director = new Director($entityManager);
$content = $json['content'];
// nettoyage
if(is_array($content)){ // cas d'une nouvelle "news"
foreach($content as $one_input){
$one_input = Security::secureHTML($one_input);
}
}
else{ // autres cas
$content = Security::secureHTML($json['content']);
}
// nouvel article
if($id[0] === 'n')
{
$section_id = (int)substr($id, 1); // id du bloc <section>
if(!$director->findNodeById($section_id)){
echo json_encode(['success' => false, 'error' => 'article_not_saved']);
die;
}
$director->makeSectionNode();
$node = $director->getNode(); // = <section>
if(is_array($content)){ // cas d'une nouvelle "news"
$date = new \DateTime($content['d']);
$article = new Article($content['i'], $date, $content['t'], $content['p']);
$article_node = new Node('new', 'i' . (string)$date->getTimestamp(), [], count($node->getChildren()) + 1, $node, $node->getPage(), $article);
}
else{ // autres cas
$timestamp = time();
$date = new \DateTime;
$date->setTimestamp($timestamp);
$article = new Article($content, $date); // le "current" timestamp est obtenu par la BDD
$placement = $json['placement'] === 'first' ? 0 : count($node->getChildren()) + 1; //
$article_node = new Node('post', 'i' . (string)$timestamp, [], $placement, $node, $node->getPage(), $article);
if($json['placement'] === 'first'){
$node->addChild($article_node);
$node->reindexPositions(); // régénère les positions (0 devient 1, 1 devient 2...)
}
}
$entityManager->persist($article_node);
$entityManager->flush();
echo json_encode(['success' => true, 'article_id' => $article_node->getArticleTimestamp()]);
die;
}
// modification article
else{
$id[0] = 'i'; // id de l'article node
}
if($director->makeArticleNode($id)) // une entrée est trouvée
{
$node = $director->getArticleNode(); // article
switch($json['id'][0]){
case 'i':
$node->getArticle()->setContent($content);
break;
case 'p':
$node->getArticle()->setPreview($content); // html de l'éditeur
break;
case 't':
$node->getArticle()->setTitle($content); // html de l'éditeur
break;
case 'd':
echo json_encode(['success' => false, 'message' => 'l\'action editor_submit ne supporte pas les dates, utiliser date_submit.']);
die;
default:
echo json_encode(['success' => false, 'message' => 'identifiant non utilisable']);
die;
}
$entityManager->flush();
echo json_encode(['success' => true]);
}
else
{
echo json_encode(['success' => false, 'message' => 'article non identifié']);
}
}
else{
echo json_encode(['success' => false, 'message' => 'Erreur de décodage JSON']);
}
die;
}
static public function deleteArticle(EntityManager $entityManager, array $json): Response
{
$director = new Director($entityManager);
if(!$director->makeArticleNode($json['id'], true)){
return new Response(
'{"success": false, "message": "Erreur: pas d\'article à supprimer"}',
Response::HTTP_INTERNAL_SERVER_ERROR); // 500
}
$article = $director->getArticleNode();
$section = $director->getNode();
$entityManager->remove($article);
$section->removeChild($article);
$section->sortChildren(true); // régénère les positions
try{
$entityManager->flush();
return new Response(
'{"success": true, "message": "Article supprimé avec succès"}',
Response::HTTP_OK); // 200
}
catch(Exception $e){
return new Response(
'{"success": false, "message": "Erreur: ' . $e->getMessage() . '"}',
Response::HTTP_INTERNAL_SERVER_ERROR); // 500
}
}
static public function switchPositions(EntityManager $entityManager, array $json): void
{
$director = new Director($entityManager);
$director->makeArticleNode($json['id1'], true);
$article1 = $director->getArticleNode();
$section = $director->getNode();
$section->sortChildren(true); // régénère les positions avant inversion
$article2 = null;
foreach($section->getChildren() as $child){
if($child->getArticleTimestamp() === $json['id2']) // type string
{
$article2 = $child;
break;
}
}
// inversion
$tmp = $article1->getPosition();
$article1->setPosition($article2->getPosition());
$article2->setPosition($tmp);
$entityManager->flush();
echo json_encode(['success' => true]);
die;
}
static public function dateSubmit(EntityManager $entityManager, array $json): void
{
$id = $json['id'];
$id[0] = 'i';
$date = new DateTime($json['date']);
$director = new Director($entityManager);
$director->makeArticleNode($id);
$node = $director->getArticleNode();
$node->getArticle()->setDateTime($date);
$entityManager->flush();
echo json_encode(['success' => true]);
die;
}
}
|