wiki.techinc.nl/includes/api/ApiEmailUser.php

136 lines
3.2 KiB
PHP
Raw Normal View History

2008-06-01 17:58:27 +00:00
<?php
/**
2008-06-01 17:58:27 +00:00
* API for MediaWiki 1.8+
*
* Created on June 1, 2008
*
* Copyright © 2008 Bryan Tong Minh <Bryan.TongMinh@Gmail.com>
2008-06-01 17:58:27 +00:00
*
* 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.
2008-06-01 17:58:27 +00:00
* http://www.gnu.org/copyleft/gpl.html
*
* @file
2008-06-01 17:58:27 +00:00
*/
if ( !defined( 'MEDIAWIKI' ) ) {
2008-06-01 17:58:27 +00:00
// Eclipse helper - will be ignored in production
require_once( "ApiBase.php" );
2008-06-01 17:58:27 +00:00
}
/**
* API Module to facilitate sending of emails to users
2008-06-01 17:58:27 +00:00
* @ingroup API
*/
class ApiEmailUser extends ApiBase {
public function __construct( $main, $action ) {
parent::__construct( $main, $action );
2008-06-01 17:58:27 +00:00
}
public function execute() {
global $wgUser;
2008-06-01 17:58:27 +00:00
$params = $this->extractRequestParams();
// Validate target
2010-07-27 18:33:04 +00:00
$targetUser = SpecialEmailUser::getTarget( $params['target'] );
if ( !( $targetUser instanceof User ) ) {
$this->dieUsageMsg( array( $targetUser ) );
}
// Check permissions and errors
2010-07-27 18:33:04 +00:00
$error = SpecialEmailUser::getPermissionsError( $wgUser, $params['token'] );
if ( $error ) {
$this->dieUsageMsg( array( $error ) );
}
$data = array(
2010-04-17 20:58:04 +00:00
'Target' => $targetUser->getName(),
'Text' => $params['text'],
'Subject' => $params['subject'],
'CCMe' => $params['ccme'],
);
2010-07-27 18:33:04 +00:00
$retval = SpecialEmailUser::submit( $data );
if ( $retval === true ) {
2008-06-02 20:11:11 +00:00
$result = array( 'result' => 'Success' );
} else {
$result = array(
'result' => 'Failure',
'message' => $retval
);
}
2008-06-01 17:58:27 +00:00
$this->getResult()->addValue( null, $this->getModuleName(), $result );
}
public function mustBePosted() {
return true;
}
2008-06-01 17:58:27 +00:00
public function isWriteMode() {
return true;
}
2008-06-01 17:58:27 +00:00
public function getAllowedParams() {
return array(
'target' => array(
ApiBase::PARAM_TYPE => 'string',
ApiBase::PARAM_REQUIRED => true
),
2008-06-01 17:58:27 +00:00
'subject' => null,
'text' => array(
ApiBase::PARAM_TYPE => 'string',
ApiBase::PARAM_REQUIRED => true
),
2008-06-01 17:58:27 +00:00
'token' => null,
'ccme' => false,
);
}
public function getParamDescription() {
return array(
2008-06-01 17:58:27 +00:00
'target' => 'User to send email to',
'subject' => 'Subject header',
'text' => 'Mail body',
'token' => 'A token previously acquired via prop=info',
'ccme' => 'Send a copy of this mail to me',
);
}
public function getDescription() {
return 'Email a user.';
2008-06-01 17:58:27 +00:00
}
public function getPossibleErrors() {
return array_merge( parent::getPossibleErrors(), array(
array( 'usermaildisabled' ),
) );
}
public function getTokenSalt() {
return '';
}
2008-06-01 17:58:27 +00:00
protected function getExamples() {
return array(
'api.php?action=emailuser&target=WikiSysop&text=Content'
2008-06-01 17:58:27 +00:00
);
}
public function getVersion() {
2008-09-04 22:20:32 +00:00
return __CLASS__ . ': $Id$';
2008-06-01 17:58:27 +00:00
}
}