forked from extern/egroupware
the external SyncML interface
This commit is contained in:
parent
5d1b2102de
commit
34741ec70c
84
rpc.php
Normal file
84
rpc.php
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* $Horde: horde/rpc.php,v 1.31 2005/01/03 14:34:43 jan Exp $
|
||||||
|
*
|
||||||
|
* Copyright 2002-2005 Jan Schneider <jan@horde.org>
|
||||||
|
*
|
||||||
|
* 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;
|
Loading…
Reference in New Issue
Block a user