From: Evan Prodromou Date: Wed, 31 Mar 2010 19:54:35 +0000 (-0400) Subject: don't insert the same notice twice into an inbox X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=650074c648d98f81674c6e2b0ebf052c473ada6e;p=quix0rs-gnu-social.git don't insert the same notice twice into an inbox --- diff --git a/classes/Inbox.php b/classes/Inbox.php index 014ba3d829..0d807946d5 100644 --- a/classes/Inbox.php +++ b/classes/Inbox.php @@ -114,6 +114,16 @@ class Inbox extends Memcached_DataObject return false; } + $ids = unpack('N*', $inbox->notice_ids); + + // bulk inserts sometimes fail and get restarted. + // Skip if this one has been inserted before. + + if (in_array($notice_id, $ids)) { + // effectively successful + return true; + } + $result = $inbox->query(sprintf('UPDATE inbox '. 'set notice_ids = concat(cast(0x%08x as binary(4)), '. 'substr(notice_ids, 1, %d)) '.