Skip to content

Commit ba544f9

Browse files
HQJaTuJari Turkia
and
Jari Turkia
authored
bugfix: Made comment token clean-up work in PostgreSQL also (#826)
* bugfix: Made comment token clean-up work in PostgreSQL also * feat: Improvement on comment token -cleanup * feat: Improved serendipity_db_cast() to support unsigned. Using proper cast in autologin. --------- Co-authored-by: Jari Turkia <jmjt@jari.turkia.name>
1 parent 78d4d10 commit ba544f9

File tree

3 files changed

+58
-41
lines changed

3 files changed

+58
-41
lines changed

include/db/db.inc.php

+23
Original file line numberDiff line numberDiff line change
@@ -183,4 +183,27 @@ function serendipity_db_implode($string, &$array, $type = 'int') {
183183
return $string;
184184
}
185185

186+
/**
187+
* @access public
188+
* @param string Database table column name
189+
* @param string Database column type
190+
* @return string Column CAST() to chosen database
191+
*/
192+
function serendipity_db_cast($columnName, $type) {
193+
global $serendipity;
194+
195+
if (stristr($serendipity['dbType'], 'sqlite')) {
196+
return $columnName;
197+
}
198+
199+
// MySQL (and variants) have unsigned integer. ANSI SQL does not.
200+
if ($type == 'unsigned') {
201+
if (!stristr($serendipity['dbType'], 'mysqli'))
202+
$type = 'integer';
203+
}
204+
205+
// Adds explicits casting for ANSI SQL -compliant DBs, like mysql and postgresql.
206+
return "cast($columnName as $type)";
207+
}
208+
186209
/* vim: set sts=4 ts=4 expandtab : */

include/functions_comments.inc.php

+26-20
Original file line numberDiff line numberDiff line change
@@ -19,9 +19,8 @@ function serendipity_checkCommentToken($token, $cid) {
1919

2020
$goodtoken = false;
2121
if ($serendipity['useCommentTokens']) {
22-
// Delete any comment tokens older than 1 week.
23-
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}options
24-
WHERE okey LIKE 'comment_%' AND name < " . (time() - 604800) );
22+
serendipity_cleanCTokens();
23+
2524
// Get the token for this comment id
2625
$tokencheck = serendipity_db_query("SELECT * FROM {$serendipity['dbPrefix']}options
2726
WHERE okey = 'comment_" . (int)$cid . "' LIMIT 1", true, 'assoc');
@@ -964,16 +963,11 @@ function serendipity_insertComment($id, $commentInfo, $type = 'NORMAL', $source
964963
function serendipity_commentSubscriptionConfirm($hash) {
965964
global $serendipity;
966965

967-
// Delete possible current cookie. Also delete any confirmation hashs that smell like 3-week-old, dead fish.
968-
if (stristr($serendipity['dbType'], 'sqlite')) {
969-
$cast = "name";
970-
} else {
971-
// Adds explicits casting for mysql, postgresql and others.
972-
$cast = "cast(name as integer)";
973-
}
974-
966+
// Delete possible current cookie. Also delete any confirmation hashes that smell like dead fish.
967+
$threeWeeksAgo = time() - 1814400;
968+
$nameCast = serendipity_db_cast('name', 'integer');
975969
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}options
976-
WHERE okey LIKE 'commentsub_%' AND $cast < (" . (time() - 1814400) . ")");
970+
WHERE okey LIKE 'commentsub_%' AND $nameCast < {$threeWeeksAgo}");
977971

978972
$hashinfo = serendipity_db_query("SELECT value
979973
FROM {$serendipity['dbPrefix']}options
@@ -1226,15 +1220,27 @@ function serendipity_generateCToken($cid) {
12261220

12271221
global $serendipity;
12281222

1223+
serendipity_cleanCTokens();
1224+
1225+
// Issue new comment moderation hash
12291226
$ctoken = bin2hex(random_bytes(16));
1230-
1231-
//Delete any comment tokens older than 1 week.
1232-
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}options
1233-
WHERE okey LIKE 'comment_%' AND name < " . (time() - 604800) );
1227+
serendipity_db_query("INSERT INTO {$serendipity['dbPrefix']}options (name, value, okey)
1228+
VALUES ('" . time() . "', '" . $ctoken . "', 'comment_" . $cid ."')");
12341229

1235-
// Issue new comment moderation hash
1236-
serendipity_db_query("INSERT INTO {$serendipity['dbPrefix']}options (name, value, okey)
1237-
VALUES ('" . time() . "', '" . $ctoken . "', 'comment_" . $cid ."')");
12381230
return $ctoken;
1239-
1231+
}
1232+
1233+
/**
1234+
* Clean over week-old comment tokens from DB
1235+
*
1236+
* @return null
1237+
*/
1238+
function serendipity_cleanCTokens() {
1239+
global $serendipity;
1240+
1241+
//Delete any comment tokens older than 1 week.
1242+
$oneWeekAgo = time() - 604800;
1243+
$nameCast = serendipity_db_cast('name', 'integer');
1244+
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}options
1245+
WHERE okey LIKE 'comment_%' AND $nameCast < {$oneWeekAgo}");
12401246
}

include/functions_config.inc.php

+9-21
Original file line numberDiff line numberDiff line change
@@ -445,19 +445,11 @@ function serendipity_issueAutologin($user) {
445445

446446

447447
// Delete possible current cookie. Also delete any autologin keys that smell like 3-week-old, dead fish.
448-
if (stristr($serendipity['dbType'], 'sqlite')) {
449-
$cast = "okey";
450-
} elseif (stristr($serendipity['dbType'], 'mysqli')) {
451-
// Adds explicit casting for mysql.
452-
$cast = "cast(okey as unsigned)";
453-
} else {
454-
// Adds explicit casting for postgresql and others.
455-
$cast = "cast(okey as integer)";
456-
}
457-
448+
$threeWeeksAgo = time() - 1814400;
449+
$okeyCast = serendipity_db_cast('okey', 'unsigned');
458450
serendipity_db_query("DELETE FROM {$serendipity['dbPrefix']}options
459451
WHERE name = 'autologin_" . serendipity_db_escape_string($user) . "'
460-
OR (name LIKE 'autologin_%' AND $cast < " . (time() - 1814400) . ")");
452+
OR (name LIKE 'autologin_%' AND $okeyCast < {$threeWeeksAgo}");
461453

462454
// Issue new autologin cookie
463455
serendipity_db_query("INSERT INTO {$serendipity['dbPrefix']}options (name, value, okey) VALUES ('autologin_" . serendipity_db_escape_string($user) . "', '" . $rnd . "', '" . time() . "')");
@@ -473,18 +465,14 @@ function serendipity_issueAutologin($user) {
473465
function serendipity_checkAutologin($user) {
474466
global $serendipity;
475467

476-
if (stristr($serendipity['dbType'], 'sqlite')) {
477-
$cast = "okey";
478-
} elseif (stristr($serendipity['dbType'], 'mysqli')) {
479-
// Adds explicit casting for mysql.
480-
$cast = "cast(okey as unsigned)";
481-
} else {
482-
// Adds explicit casting for postgresql and others.
483-
$cast = "cast(okey as integer)";
484-
}
468+
$threeWeeksAgo = time() - 1814400;
469+
$okeyCast = serendipity_db_cast('okey', 'unsigned');
485470

486471
// Fetch autologin data from DB
487-
$autologin_stored = serendipity_db_query("SELECT name, value, okey FROM {$serendipity['dbPrefix']}options WHERE name = 'autologin_" . serendipity_db_escape_string($user) . "' AND $cast > " . (time() - 1814400) . " LIMIT 1", true, 'assoc');
472+
$autologin_stored = serendipity_db_query("SELECT name, value, okey FROM {$serendipity['dbPrefix']}options
473+
WHERE name = 'autologin_" . serendipity_db_escape_string($user) . "'
474+
AND $okeyCast > {$threeWeeksAgo} LIMIT 1",
475+
true, 'assoc');
488476

489477
if (!is_array($autologin_stored)) {
490478
return false;

0 commit comments

Comments
 (0)