diff options
author | Petr Bena <benapetr@gmail.com> | 2014-08-26 15:06:12 +0200 |
---|---|---|
committer | Merlijn van Deen <valhallasw@arctus.nl> | 2014-09-06 21:26:40 +0000 |
commit | 2077a43b5a9660080fc7916c3128e877a41c13c9 (patch) | |
tree | 423a4b662d8dfc3cd2f9b51a4173f30330aabce3 /includes/api/ApiClearHasMsg.php | |
parent | 823e8c97e776d38a65214fcaed2d607082915279 (diff) | |
download | mediawikicore-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.php | 58 |
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'; + } +} |