aboutsummaryrefslogtreecommitdiffstats
path: root/includes/api/ApiClearHasMsg.php
diff options
context:
space:
mode:
authorPetr Bena <benapetr@gmail.com>2014-08-26 15:06:12 +0200
committerMerlijn van Deen <valhallasw@arctus.nl>2014-09-06 21:26:40 +0000
commit2077a43b5a9660080fc7916c3128e877a41c13c9 (patch)
tree423a4b662d8dfc3cd2f9b51a4173f30330aabce3 /includes/api/ApiClearHasMsg.php
parent823e8c97e776d38a65214fcaed2d607082915279 (diff)
downloadmediawikicore-2077a43b5a9660080fc7916c3128e877a41c13c9.tar.gz
mediawikicore-2077a43b5a9660080fc7916c3128e877a41c13c9.zip
API: created a new api to flag messages as read
New api is called "ClearHasMsg" and does nothing but erase a new message flag from currently logged in user. This is useful for tools that can read the new messages using some api, or some other way (loading the text using different session, preload the text using a buffer where it's unrevealed later if user actually did read it, or closed the application before), so it can be useful in situations when you need to flag new messages as read in a different time than that when you actually read them. Bug: 64238 Change-Id: Ife575711c32bb8e3bcac789de4a6b37e1888d032
Diffstat (limited to 'includes/api/ApiClearHasMsg.php')
-rw-r--r--includes/api/ApiClearHasMsg.php58
1 files changed, 58 insertions, 0 deletions
diff --git a/includes/api/ApiClearHasMsg.php b/includes/api/ApiClearHasMsg.php
new file mode 100644
index 000000000000..32e20e80f319
--- /dev/null
+++ b/includes/api/ApiClearHasMsg.php
@@ -0,0 +1,58 @@
+<?php
+
+/**
+ * Created on August 26, 2014
+ *
+ * Copyright © 2014 Petr Bena (benapetr@gmail.com)
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * http://www.gnu.org/copyleft/gpl.html
+ *
+ * @file
+ */
+
+/**
+ * API module that clears the hasmsg flag for current user
+ * @ingroup API
+ */
+class ApiClearHasMsg extends ApiBase {
+ public function execute() {
+ $user = $this->getUser();
+ $user->setNewtalk( false );
+ $this->getResult()->addValue( null, $this->getModuleName(), 'success' );
+ }
+
+ public function isWriteMode() {
+ return true;
+ }
+
+ public function mustBePosted() {
+ return false;
+ }
+
+ public function getDescription() {
+ return array( 'Clears the hasmsg flag for current user.' );
+ }
+
+ public function getExamples() {
+ return array(
+ 'api.php?action=clearhasmsg' => 'Clears the hasmsg flag for current user',
+ );
+ }
+
+ public function getHelpUrls() {
+ return 'https://www.mediawiki.org/wiki/API:ClearHasMsg';
+ }
+}