[MediaWiki-commits] [Gerrit] Fix bug that's ben breaking chat - change (mediawiki...MediaWikiChat)
UltrasonicNXT has uploaded a new change for review. https://gerrit.wikimedia.org/r/152019 Change subject: Fix bug that's ben breaking chat .. Fix bug that's ben breaking chat Caused by two messages with identical timestamps. Couple of other cleanups Change-Id: I0927636920ec3e289a8cb4b8235591d650f35cb1 --- M MediaWikiChat.php M MediaWikiChatClass.php M Send.api.php 3 files changed, 17 insertions(+), 4 deletions(-) git pull ssh://gerrit.wikimedia.org:29418/mediawiki/extensions/MediaWikiChat refs/changes/19/152019/1 diff --git a/MediaWikiChat.php b/MediaWikiChat.php index d577baf..d167b9b 100644 --- a/MediaWikiChat.php +++ b/MediaWikiChat.php @@ -16,7 +16,7 @@ $wgExtensionCredits['specialpage'][] = array( 'path' = __FILE__, 'name' = 'MediaWikiChat', - 'version' = '2.12.0', + 'version' = '2.12.1', 'author' = 'Adam Carter/UltrasonicNXT', 'url' = 'https://www.mediawiki.org/wiki/Extension:MediaWikiChat', 'descriptionmsg' = 'chat-desc', diff --git a/MediaWikiChatClass.php b/MediaWikiChatClass.php index 06faa9e..7fdc1e0 100644 --- a/MediaWikiChatClass.php +++ b/MediaWikiChatClass.php @@ -13,10 +13,10 @@ const TYPE_KICK = 4; /** -* Get the current UNIX time with microseconds (i.e. 138524180871). +* Get the current UNIX time with 100th seconds (i.e. 138524180871). * Standard UNIX timestamp contains only 10 digits. * -* @return Integer: current UNIX timestamp + microseconds +* @return Integer: current UNIX timestamp + 100th seconds */ static function now() { $m = explode( ' ', microtime() ); diff --git a/Send.api.php b/Send.api.php index 334bde5..dbc8356 100644 --- a/Send.api.php +++ b/Send.api.php @@ -14,6 +14,7 @@ if ( $message != '' ) { $dbw = wfGetDB( DB_MASTER ); + $dbr = wfGetDB( DB_SLAVE ); $id = $user-getId(); $timestamp = MediaWikiChat::now(); @@ -24,7 +25,7 @@ } // Flood check - $res = $dbw-selectField( + $res = $dbr-selectField( 'chat', array( 'count(*)' ), array( chat_timestamp . ( $timestamp - ( $wgChatFloodSeconds * 100 ) ), chat_user_id = . $id ), @@ -35,6 +36,18 @@ return true; } + $lastTimestamp = $dbr-selectField( + 'chat', + 'chat_timestamp', + array(), + __METHOD__, + array( 'ORDER BY' = 'chat_timestamp DESC', 'LIMIT' = 1 ) + ); + + if ( $timestamp == $lastTimestamp ) { + $timestamp += 1; // prevent two messages with the same timestamp + } + $dbw-insert( 'chat', array( -- To view, visit https://gerrit.wikimedia.org/r/152019 To unsubscribe, visit https://gerrit.wikimedia.org/r/settings Gerrit-MessageType: newchange Gerrit-Change-Id: I0927636920ec3e289a8cb4b8235591d650f35cb1 Gerrit-PatchSet: 1 Gerrit-Project: mediawiki/extensions/MediaWikiChat Gerrit-Branch: master Gerrit-Owner: UltrasonicNXT adamr_car...@btinternet.com ___ MediaWiki-commits mailing list MediaWiki-commits@lists.wikimedia.org https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits
[MediaWiki-commits] [Gerrit] Fix bug that's ben breaking chat - change (mediawiki...MediaWikiChat)
UltrasonicNXT has submitted this change and it was merged. Change subject: Fix bug that's ben breaking chat .. Fix bug that's ben breaking chat Caused by two messages with identical timestamps. Couple of other cleanups Change-Id: I0927636920ec3e289a8cb4b8235591d650f35cb1 --- M MediaWikiChat.php M MediaWikiChatClass.php M Send.api.php 3 files changed, 17 insertions(+), 4 deletions(-) Approvals: UltrasonicNXT: Verified; Looks good to me, approved diff --git a/MediaWikiChat.php b/MediaWikiChat.php index d577baf..d167b9b 100644 --- a/MediaWikiChat.php +++ b/MediaWikiChat.php @@ -16,7 +16,7 @@ $wgExtensionCredits['specialpage'][] = array( 'path' = __FILE__, 'name' = 'MediaWikiChat', - 'version' = '2.12.0', + 'version' = '2.12.1', 'author' = 'Adam Carter/UltrasonicNXT', 'url' = 'https://www.mediawiki.org/wiki/Extension:MediaWikiChat', 'descriptionmsg' = 'chat-desc', diff --git a/MediaWikiChatClass.php b/MediaWikiChatClass.php index 06faa9e..7fdc1e0 100644 --- a/MediaWikiChatClass.php +++ b/MediaWikiChatClass.php @@ -13,10 +13,10 @@ const TYPE_KICK = 4; /** -* Get the current UNIX time with microseconds (i.e. 138524180871). +* Get the current UNIX time with 100th seconds (i.e. 138524180871). * Standard UNIX timestamp contains only 10 digits. * -* @return Integer: current UNIX timestamp + microseconds +* @return Integer: current UNIX timestamp + 100th seconds */ static function now() { $m = explode( ' ', microtime() ); diff --git a/Send.api.php b/Send.api.php index 334bde5..dbc8356 100644 --- a/Send.api.php +++ b/Send.api.php @@ -14,6 +14,7 @@ if ( $message != '' ) { $dbw = wfGetDB( DB_MASTER ); + $dbr = wfGetDB( DB_SLAVE ); $id = $user-getId(); $timestamp = MediaWikiChat::now(); @@ -24,7 +25,7 @@ } // Flood check - $res = $dbw-selectField( + $res = $dbr-selectField( 'chat', array( 'count(*)' ), array( chat_timestamp . ( $timestamp - ( $wgChatFloodSeconds * 100 ) ), chat_user_id = . $id ), @@ -35,6 +36,18 @@ return true; } + $lastTimestamp = $dbr-selectField( + 'chat', + 'chat_timestamp', + array(), + __METHOD__, + array( 'ORDER BY' = 'chat_timestamp DESC', 'LIMIT' = 1 ) + ); + + if ( $timestamp == $lastTimestamp ) { + $timestamp += 1; // prevent two messages with the same timestamp + } + $dbw-insert( 'chat', array( -- To view, visit https://gerrit.wikimedia.org/r/152019 To unsubscribe, visit https://gerrit.wikimedia.org/r/settings Gerrit-MessageType: merged Gerrit-Change-Id: I0927636920ec3e289a8cb4b8235591d650f35cb1 Gerrit-PatchSet: 1 Gerrit-Project: mediawiki/extensions/MediaWikiChat Gerrit-Branch: master Gerrit-Owner: UltrasonicNXT adamr_car...@btinternet.com Gerrit-Reviewer: UltrasonicNXT adamr_car...@btinternet.com ___ MediaWiki-commits mailing list MediaWiki-commits@lists.wikimedia.org https://lists.wikimedia.org/mailman/listinfo/mediawiki-commits