Localisation updates from https://translatewiki.net.
[mediawiki.git] / includes / api / ApiClearHasMsg.php
blobec26c7cf373e86de3119627bf72f363653e5a0dd
1 <?php
3 /**
4 * Copyright © 2014 Petr Bena (benapetr@gmail.com)
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along
17 * with this program; if not, write to the Free Software Foundation, Inc.,
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
19 * http://www.gnu.org/copyleft/gpl.html
21 * @file
24 namespace MediaWiki\Api;
26 use MediaWiki\User\TalkPageNotificationManager;
28 /**
29 * API module that clears the hasmsg flag for current user
30 * @ingroup API
32 class ApiClearHasMsg extends ApiBase {
34 private TalkPageNotificationManager $talkPageNotificationManager;
36 public function __construct(
37 ApiMain $main,
38 string $action,
39 TalkPageNotificationManager $talkPageNotificationManager
40 ) {
41 parent::__construct( $main, $action );
42 $this->talkPageNotificationManager = $talkPageNotificationManager;
45 public function execute() {
46 $this->talkPageNotificationManager->removeUserHasNewMessages( $this->getUser() );
48 $this->getResult()->addValue( null, $this->getModuleName(), 'success' );
51 public function isWriteMode() {
52 return true;
55 public function mustBePosted() {
56 return true;
59 protected function getExamplesMessages() {
60 return [
61 'action=clearhasmsg'
62 => 'apihelp-clearhasmsg-example-1',
66 public function getHelpUrls() {
67 return 'https://www.mediawiki.org/wiki/Special:MyLanguage/API:ClearHasMsg';
71 /** @deprecated class alias since 1.43 */
72 class_alias( ApiClearHasMsg::class, 'ApiClearHasMsg' );