- $query = $Db->set('comments', $reply + [
- 'page' => "{$Page->handler}/{$Issue->id}",
- 'author' => $User->login,
- ]);
- if (!$query->rowCount()) {
- throw new Exception('Fout bij opslaan');
+
+ if (isset($input['id'])) {
+ $newcomment = $input['id'];
+ $filter = ['id = ?', $newcomment];
+ $oldcomment = $Db->query("SELECT * FROM comments WHERE $filter[0]", [$filter[1]])->fetch();
+ if (empty($oldcomment)) {
+ throw new Exception('Antwoord niet gevonden');
+ }
+
+ $reply += [
+ 'updated' => ['now()'],
+ ];
+ $query = $Db->set('comments', $reply, $filter);
+ if (!$query->rowCount()) {
+ throw new Exception('Fout bij aanpassen');
+ }
+
+ if ($updated = $query->fetch()) {
+ foreach (array_keys(get_object_vars($updated)) as $col) {
+ if ($updated->$col === $oldcomment->$col) {
+ continue; # unaltered
+ }
+ $Db->set('journal', [
+ 'comment_id' => $newcomment,
+ 'property' => 'col',
+ 'col' => $col,
+ 'old_value' => $oldcomment->$col,
+ 'value' => $updated->$col,
+ ]);
+ }
+ }
+ }
+ else {
+ $reply += [
+ 'page' => "{$Page->handler}/{$Issue->id}",
+ 'author' => $User->login,
+ ];
+ $query = $Db->set('comments', $reply);
+ if (!$query->rowCount()) {
+ throw new Exception('Fout bij opslaan');
+ }
+ $newcomment = $Db->dbh->lastInsertId('comments_id_seq');