X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/d96a8550867531e92b109a0a675cd12ce1ff7843..2d7b510a9d33a552b024e1db00212658f21afce6:/upload.inc.php diff --git a/upload.inc.php b/upload.inc.php index ff4ecd3..77fa846 100644 --- a/upload.inc.php +++ b/upload.inc.php @@ -94,7 +94,9 @@ function createcomment($input, &$Issue = NULL) } $target .= '/' . $User->login; if ($result = userupload($_FILES['image'], $target)) { + $reply['raw'] = $reply['raw'] ?? ''; $reply['raw'] .= "/$result"; + $reply['message'] = $reply['message'] ?? ''; if (preg_match('(^image/)', $_FILES['image']['type'])) { $reply['message'] .= sprintf('

', $result); } @@ -105,14 +107,49 @@ function createcomment($input, &$Issue = NULL) } } } - $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'); } - $newcomment = $Db->dbh->lastInsertId('comments_id_seq'); if (isset($Issue)) { $row = []; @@ -127,12 +164,14 @@ function createcomment($input, &$Issue = NULL) } } $derived = ['updated' => ['now()']]; - $filter = ['id = ? RETURNING *', $Issue->id]; + $filter = ['id = ?', $Issue->id]; $subquery = $Db->set('issues', $row + $derived, $filter); if ($updated = $subquery->fetch()) { foreach (array_keys($row) as $col) { - if ($updated->$col === $Issue->$col) continue; # unaltered + if ($updated->$col === $Issue->$col) { + continue; # unaltered + } $Db->set('journal', [ 'comment_id' => $newcomment, 'property' => 'attr',