Revert r70960 "AjaxDispatcher, now ~30 lines shorter and not using $_GET or $_POST"

Broke CategoryTree, see code review for the error message.
This commit is contained in:
Aryeh Gregor 2010-08-13 21:39:51 +00:00
parent 380b6725d5
commit a6aac77d16
2 changed files with 39 additions and 11 deletions

View file

@ -18,23 +18,51 @@ require_once( 'AjaxFunctions.php' );
* @ingroup Ajax
*/
class AjaxDispatcher {
/** The way the request was made, either a 'get' or a 'post' */
private $mode;
/** Name of the requested handler */
private $func_name = null;
private $func_name;
/** Arguments passed */
private $args = array();
private $args;
/** Load up our object with user supplied data */
public function __construct( WebRequest $req ) {
function __construct() {
wfProfileIn( __METHOD__ );
$rs = $req->getVal( 'rs' );
if( $rs !== null ) {
$this->func_name = $rs;
$this->mode = "";
if ( ! empty( $_GET["rs"] ) ) {
$this->mode = "get";
}
$rsargs = $req->getVal( 'rsargs' );
if( $rsargs !== null ) {
$this->args = $rsargs;
if ( !empty( $_POST["rs"] ) ) {
$this->mode = "post";
}
switch( $this->mode ) {
case 'get':
$this->func_name = isset( $_GET["rs"] ) ? $_GET["rs"] : '';
if ( ! empty( $_GET["rsargs"] ) ) {
$this->args = $_GET["rsargs"];
} else {
$this->args = array();
}
break;
case 'post':
$this->func_name = isset( $_POST["rs"] ) ? $_POST["rs"] : '';
if ( ! empty( $_POST["rsargs"] ) ) {
$this->args = $_POST["rsargs"];
} else {
$this->args = array();
}
break;
default:
wfProfileOut( __METHOD__ );
return;
# Or we could throw an exception:
# throw new MWException( __METHOD__ . ' called without any data (mode empty).' );
}
wfProfileOut( __METHOD__ );
@ -48,7 +76,7 @@ class AjaxDispatcher {
function performAction() {
global $wgAjaxExportList, $wgOut;
if ( is_null( $this->func_name ) ) {
if ( empty( $this->mode ) ) {
return;
}

View file

@ -68,7 +68,7 @@ wfProfileOut( 'main-misc-setup' );
#
if( $wgUseAjax && $action == 'ajax' ) {
require_once( $IP . '/includes/AjaxDispatcher.php' );
$dispatcher = new AjaxDispatcher( $wgRequest );
$dispatcher = new AjaxDispatcher();
$dispatcher->performAction();
$mediaWiki->restInPeace();
exit;