diff --git a/rpc.php b/rpc.php new file mode 100644 index 0000000000..b37d22d7bb --- /dev/null +++ b/rpc.php @@ -0,0 +1,84 @@ + + * + * See the enclosed file COPYING for license information (LGPL). If you + * did not receive this file, see http://www.fsf.org/copyleft/lgpl.html. + */ + +@define('AUTH_HANDLER', true); +@define('HORDE_BASE', dirname(__FILE__).'/phpgwapi/inc/horde/'); +require_once HORDE_BASE . '/lib/core.php'; +require_once 'Horde/RPC.php'; + +$GLOBALS['phpgw_info'] = array(); +$GLOBALS['phpgw_info']['flags'] = array( + 'currentapp' => 'login', + 'noheader' => True, + 'disable_Template_class' => True +); +include('./header.inc.php'); + + +/* Look at the Content-type of the request, if it is available, to try + * and determine what kind of request this is. */ +$input = null; +$params = null; + +if (!empty($_SERVER['CONTENT_TYPE'])) { + if (strpos($_SERVER['CONTENT_TYPE'], 'application/vnd.syncml+xml') !== false) { + $serverType = 'syncml'; + } elseif (strpos($_SERVER['CONTENT_TYPE'], 'application/vnd.syncml+wbxml') !== false) { + $serverType = 'syncml_wbxml'; + } elseif (strpos($_SERVER['CONTENT_TYPE'], 'text/xml') !== false) { + $input = Horde_RPC::getInput(); + /* Check for SOAP namespace URI. */ + if (strpos($input, 'http://schemas.xmlsoap.org/soap/envelope/') !== false) { + $serverType = 'soap'; + } else { + $serverType = 'xmlrpc'; + } + } else { + header('HTTP/1.0 501 Not Implemented'); + exit; + } +} else { + $serverType = 'soap'; +} + +if ($serverType == 'soap' && + (!isset($_SERVER['REQUEST_METHOD']) || + $_SERVER['REQUEST_METHOD'] != 'POST')) { + $session_control = 'none'; + if (isset($_GET['wsdl'])) { + $params = 'wsdl'; + } else { + $params = 'disco'; + } +} + +/* Load base libraries. */ +require_once HORDE_BASE . '/lib/base.php'; + +/* Load the RPC backend based on $serverType. */ +$server = &Horde_RPC::singleton($serverType, $params); + +/* Let the backend check authentication. By default, we look for HTTP + * basic authentication against Horde, but backends can override this + * as needed. */ +$server->authorize(); + +/* Get the server's response. We call $server->getInput() to allow + * backends to handle input processing differently. */ +if ($input === null) { + $input = $server->getInput(); +} +$out = $server->getResponse($input, $params); + +/* Return the response to the client. */ +header('Content-Type: ' . $server->getResponseContentType()); +header('Content-length: ' . strlen($out)); +header('Accept-Charset: UTF-8'); +echo $out;