return Ajax-y XML on exceptions

This commit is contained in:
Evan Prodromou 2011-03-16 18:53:46 -04:00
parent 29a4bb4d91
commit 0791d0034f
3 changed files with 44 additions and 1 deletions

View File

@ -83,6 +83,11 @@ class Action extends HTMLOutputter // lawsuit
function prepare($argarray) function prepare($argarray)
{ {
$this->args =& common_copy_args($argarray); $this->args =& common_copy_args($argarray);
if ($this->boolean('ajax')) {
StatusNet::setAjax(true);
}
return true; return true;
} }

View File

@ -68,7 +68,11 @@ class ErrorAction extends InfoAction
function showPage() function showPage()
{ {
if ($this->minimal) { if (StatusNet::isAjax()) {
$this->extraHeaders();
$this->ajaxErrorMsg();
exit();
} if ($this->minimal) {
// Even more minimal -- we're in a machine API // Even more minimal -- we're in a machine API
// and don't want to flood the output. // and don't want to flood the output.
$this->extraHeaders(); $this->extraHeaders();
@ -94,4 +98,27 @@ class ErrorAction extends InfoAction
function showNoticeForm() function showNoticeForm()
{ {
} }
/**
* Show an Ajax-y error message
*
* Goes back to the browser, where it's shown in a popup.
*
* @param string $msg Message to show
*
* @return void
*/
function ajaxErrorMsg()
{
$this->startHTML('text/xml;charset=utf-8', true);
$this->elementStart('head');
// TRANS: Page title after an AJAX error occurs on the send notice page.
$this->element('title', null, _('Ajax Error'));
$this->elementEnd('head');
$this->elementStart('body');
$this->element('p', array('id' => 'error'), $this->message);
$this->elementEnd('body');
$this->elementEnd('html');
}
} }

View File

@ -31,6 +31,7 @@ class StatusNet
{ {
protected static $have_config; protected static $have_config;
protected static $is_api; protected static $is_api;
protected static $is_ajax;
protected static $plugins = array(); protected static $plugins = array();
/** /**
@ -230,6 +231,16 @@ class StatusNet
self::$is_api = $mode; self::$is_api = $mode;
} }
public function isAjax()
{
return self::$is_ajax;
}
public function setAjax($mode)
{
self::$is_ajax = $mode;
}
/** /**
* Build default configuration array * Build default configuration array
* @return array * @return array