mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-11-26 01:43:47 +01:00
uncommited changes
This commit is contained in:
parent
d4d0c13876
commit
af8f7b2c35
@ -30,6 +30,15 @@ class ischedule_server extends groupdav
|
|||||||
*/
|
*/
|
||||||
const VERSION = '1.0';
|
const VERSION = '1.0';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Supported versions for capablities
|
||||||
|
*
|
||||||
|
* Might be more then current version above
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
static $supported_versions = array(self::VERSION);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Required headers in DKIM signature (DKIM-Signature is always a required header!)
|
* Required headers in DKIM signature (DKIM-Signature is always a required header!)
|
||||||
*/
|
*/
|
||||||
@ -80,12 +89,52 @@ class ischedule_server extends groupdav
|
|||||||
if (self::$request_starttime) self::log_request();
|
if (self::$request_starttime) self::log_request();
|
||||||
}
|
}
|
||||||
|
|
||||||
static $supported_components = array('VEVENT', 'VFREEBUSY', 'VTODO');
|
/**
|
||||||
|
* List of supported components and methods
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
static $supported_components = array(
|
||||||
|
'VFREEBUSY' => array('REQUEST'),
|
||||||
|
'VEVENT' => array('REQUEST', 'REPLY', 'CANCEL'),
|
||||||
|
//'VTODO' => array('REQUEST', 'REPLY', 'CANCEL'),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of supported calendar-data-types
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
static $supported_calendar_data_types = array(
|
||||||
|
array('content-type' => 'text/calendar', 'version' => '2.0'),
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Supported attachment types for capabilities
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
static $supported_attachments = array('external', 'inline');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Other capablities
|
||||||
|
*
|
||||||
|
* @var array name => value pairs
|
||||||
|
*/
|
||||||
|
static $capablities = array(
|
||||||
|
'max-content-length' => 102400,
|
||||||
|
'min-date-time' => '19910101T000000Z',
|
||||||
|
'max-date-time' => '20381231T000000Z',
|
||||||
|
'max-instances' => 150,
|
||||||
|
'max-recipients' => 250,
|
||||||
|
// for server config: 'administrator' => 'mailto:ischedule-admin@example.com</administrator',
|
||||||
|
);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Requiremnt for originator to match depending on method
|
* Requiremnt for originator to match depending on method
|
||||||
*
|
*
|
||||||
* @var array method => array('ORGANIZER','ATTENDEE')
|
* @var array method => array('ORGANIZER','ATTENDEE')
|
||||||
* @link https://tools.ietf.org/html/draft-desruisseaux-ischedule-01#section-6.1
|
* @link https://tools.ietf.org/html/draft-desruisseaux-ischedule-03#section-6.1
|
||||||
*/
|
*/
|
||||||
static $supported_method2origin_requirement = array(
|
static $supported_method2origin_requirement = array(
|
||||||
//'PUBLISH' => null, // no requirement
|
//'PUBLISH' => null, // no requirement
|
||||||
@ -147,8 +196,9 @@ class ischedule_server extends groupdav
|
|||||||
}
|
}
|
||||||
// check if recipient is a user
|
// check if recipient is a user
|
||||||
// todo: multiple recipients, currently we use last recipient for EGroupware enviroment
|
// todo: multiple recipients, currently we use last recipient for EGroupware enviroment
|
||||||
foreach(preg_split('/, */', $headers['recipient']) as $recipient)
|
// it is no error, to not specify a correct user, in that case we return just a request-status of "3.7;Invalid Calendar User"!
|
||||||
{
|
//foreach(preg_split('/, */', $headers['recipient']) as $recipient)
|
||||||
|
/*{
|
||||||
if (!stripos($recipient, 'mailto:') === 0 ||
|
if (!stripos($recipient, 'mailto:') === 0 ||
|
||||||
!($account_id = $GLOBALS['egw']->accounts->name2id(substr($recipient, 7), 'account_email')))
|
!($account_id = $GLOBALS['egw']->accounts->name2id(substr($recipient, 7), 'account_email')))
|
||||||
{
|
{
|
||||||
@ -161,11 +211,13 @@ class ischedule_server extends groupdav
|
|||||||
//$GLOBALS['egw']->session->account_domain = $domain;
|
//$GLOBALS['egw']->session->account_domain = $domain;
|
||||||
$GLOBALS['egw_info']['user'] = $GLOBALS['egw']->session->read_repositories();
|
$GLOBALS['egw_info']['user'] = $GLOBALS['egw']->session->read_repositories();
|
||||||
translation::init();
|
translation::init();
|
||||||
|
*/
|
||||||
|
|
||||||
// check originator is allowed to iSchedule with recipient
|
// check originator is allowed to iSchedule with recipient
|
||||||
// ToDo: preference for user/admin to specify with whom to iSchedule: $allowed_origins
|
// ToDo: preference for user/admin to specify with whom to iSchedule: $allowed_origins
|
||||||
$allowed_origins = preg_split('/, ?/', $GLOBALS['egw_info']['user']['groupdav']['ischedule_allowed_origins']);
|
$allowed_origins = preg_split('/, ?/', $GLOBALS['egw_info']['user']['preferences']['groupdav']['ischedule_allowed_origins']);
|
||||||
/* disabled 'til UI is ready to specifiy
|
/* disabled 'til UI is ready to specifiy
|
||||||
|
* ToDo: this should be no error but a response-status of "3.8;No authority"
|
||||||
list(,$originator_domain) = explode('@', $headers['Originator']);
|
list(,$originator_domain) = explode('@', $headers['Originator']);
|
||||||
if (!in_array($headers['Originator'], $allowed_orgins) && !in_array($originator_domain, $allowed_origins))
|
if (!in_array($headers['Originator'], $allowed_orgins) && !in_array($originator_domain, $allowed_origins))
|
||||||
{
|
{
|
||||||
@ -173,6 +225,8 @@ class ischedule_server extends groupdav
|
|||||||
}*/
|
}*/
|
||||||
|
|
||||||
// check method and component of Content-Type are valid
|
// check method and component of Content-Type are valid
|
||||||
|
// ToDo: no component or method in Content-Type should give an "invalid-scheduling-message" error
|
||||||
|
// only unsupported (not in capablities) component should give "invalid-caledar-data-type"
|
||||||
if (!preg_match('/component=([^;]+)/i', $headers['content-type'], $matches) ||
|
if (!preg_match('/component=([^;]+)/i', $headers['content-type'], $matches) ||
|
||||||
(!in_array($component=strtoupper($matches[1]), self::$supported_components)))
|
(!in_array($component=strtoupper($matches[1]), self::$supported_components)))
|
||||||
{
|
{
|
||||||
@ -190,7 +244,7 @@ class ischedule_server extends groupdav
|
|||||||
$vcal = new Horde_iCalendar();
|
$vcal = new Horde_iCalendar();
|
||||||
if (!$vcal->parsevCalendar($this->request, 'VCALENDAR', 'utf-8'))
|
if (!$vcal->parsevCalendar($this->request, 'VCALENDAR', 'utf-8'))
|
||||||
{
|
{
|
||||||
throw new Exception('Bad Request: Failed parsing iCal', 400);
|
throw new Exception('Bad Request: invalid-calendar-data: Failed parsing iCal', 400);
|
||||||
}
|
}
|
||||||
$version = $vcal->getAttribute('VERSION');
|
$version = $vcal->getAttribute('VERSION');
|
||||||
$handler = new calendar_ical();
|
$handler = new calendar_ical();
|
||||||
@ -200,7 +254,7 @@ class ischedule_server extends groupdav
|
|||||||
!($event = $handler->vevent2egw($vcal_comp, $version, $handler->supportedFields,
|
!($event = $handler->vevent2egw($vcal_comp, $version, $handler->supportedFields,
|
||||||
$principalURL='', $check_component='Horde_iCalendar_'.strtolower($component))))
|
$principalURL='', $check_component='Horde_iCalendar_'.strtolower($component))))
|
||||||
{
|
{
|
||||||
throw new Exception('Bad Request: Failed converting iCal', 400);
|
throw new Exception('Bad Request: invalid-calendar-data: Failed converting iCal', 400);
|
||||||
}
|
}
|
||||||
|
|
||||||
// validate originator matches organizer or attendee
|
// validate originator matches organizer or attendee
|
||||||
@ -248,7 +302,7 @@ class ischedule_server extends groupdav
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
throw new exception('Not yet implemented!');
|
throw new Exception ('Bad Request: invalid-calendar-data-type: not implemented', 400);
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml->endElement(); // schedule-response
|
$xml->endElement(); // schedule-response
|
||||||
@ -346,12 +400,8 @@ class ischedule_server extends groupdav
|
|||||||
/**
|
/**
|
||||||
* Validate DKIM signature
|
* Validate DKIM signature
|
||||||
*
|
*
|
||||||
* For multivalued Recipient header(s): as PHP engine agregates them ", " separated,
|
* For multivalued and multiple Recipient header(s): PHP engine agregates them ", " separated.
|
||||||
* we can not tell these apart from ", " separated recipients in one header!
|
* ischedule-relaxed canonisation takes care of that.
|
||||||
*
|
|
||||||
* Therefore we can only try to validate both situations.
|
|
||||||
*
|
|
||||||
* It will fail if multiple recipients in a single header are also ", " separated (just comma works fine).
|
|
||||||
*
|
*
|
||||||
* @param array $headers header-name in lowercase(!) as key
|
* @param array $headers header-name in lowercase(!) as key
|
||||||
* @param string $body
|
* @param string $body
|
||||||
@ -633,7 +683,7 @@ yXUKsIQVi3qPyPdB3QIDAQAB
|
|||||||
return array_combine($matches[1], $matches[2]);
|
return array_combine($matches[1], $matches[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
const SERIAL = '123';
|
const SERIAL = '124';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Serve an iSchedule GET request, currently only action=capabilities
|
* Serve an iSchedule GET request, currently only action=capabilities
|
||||||
@ -688,68 +738,74 @@ yXUKsIQVi3qPyPdB3QIDAQAB
|
|||||||
{
|
{
|
||||||
error_log(__METHOD__."() invalid iSchedule request using GET without action=capabilities!");
|
error_log(__METHOD__."() invalid iSchedule request using GET without action=capabilities!");
|
||||||
header("HTTP/1.1 400 Bad Request");
|
header("HTTP/1.1 400 Bad Request");
|
||||||
|
echo "<h1>Invalid iSchedule request using GET without action=capabilities!</h1>\n";
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// generate capabilities
|
// generate capabilities
|
||||||
/*$xml = new XMLWriter;
|
$xml = new XMLWriter;
|
||||||
$xml->openMemory();
|
$xml->openMemory();
|
||||||
$xml->setIndent(true);
|
$xml->setIndent(true);
|
||||||
$xml->startDocument('1.0', 'UTF-8');
|
$xml->startDocument('1.0', 'UTF-8');
|
||||||
$xml->startElementNs(null, 'query-result', self::ISCHEDULE);
|
$xml->startElementNs(null, 'query-result', self::ISCHEDULE);
|
||||||
$xml->startElement('capability-set');
|
$xml->startElement('capabilities');
|
||||||
|
|
||||||
foreach(array(
|
$xml->writeElement('serial-number', self::SERIAL);
|
||||||
'versions' => array('version' => array('1.0')),
|
|
||||||
'scheduling-messages' => array(
|
$xml->startElement('versions');
|
||||||
'component' => array('.name' => array(
|
foreach(self::$supported_versions as $version)
|
||||||
'VEVENT' => array('method' => array('REQUEST', 'ADD', 'REPLY', 'CANCEL')),
|
|
||||||
'VTODO' => '',
|
|
||||||
'VFREEBUSY' => '',
|
|
||||||
)),
|
|
||||||
)
|
|
||||||
) as $name => $data)
|
|
||||||
{
|
{
|
||||||
$xml->writeElement($name, $data);
|
$xml->writeElement('version', $version);
|
||||||
|
}
|
||||||
|
$xml->endElement(); // versions
|
||||||
|
|
||||||
|
$xml->startElement('scheduling-messages');
|
||||||
|
foreach(self::$supported_components as $component => $methods)
|
||||||
|
{
|
||||||
|
$xml->startElement('component');
|
||||||
|
$xml->writeAttribute('name', $component);
|
||||||
|
foreach($methods as $method)
|
||||||
|
{
|
||||||
|
$xml->startElement('method');
|
||||||
|
$xml->writeAttribute('name', $method);
|
||||||
|
$xml->endElement(); // method
|
||||||
|
}
|
||||||
|
$xml->endElement(); // component
|
||||||
|
}
|
||||||
|
$xml->endElement(); // scheduling-messages
|
||||||
|
|
||||||
|
$xml->startElement('calendar-data-types');
|
||||||
|
foreach(self::$supported_calendar_data_types as $data)
|
||||||
|
{
|
||||||
|
$xml->startElement('calendar-data-type');
|
||||||
|
foreach($data as $name => $value)
|
||||||
|
{
|
||||||
|
$xml->writeAttribute($name, $value);
|
||||||
|
}
|
||||||
|
$xml->endElement(); // calendar-data-type
|
||||||
|
}
|
||||||
|
$xml->endElement(); // calendar-data-types
|
||||||
|
|
||||||
|
$xml->startElement('attachments');
|
||||||
|
foreach(self::$supported_attachments as $type)
|
||||||
|
{
|
||||||
|
$xml->writeElement($type, '');
|
||||||
|
}
|
||||||
|
$xml->endElement(); // attachments
|
||||||
|
|
||||||
|
if (!empty($GLOBALS['egw_info']['server']['admin_mails']))
|
||||||
|
{
|
||||||
|
self::$capablities['administrator'] = 'mailto:'.$GLOBALS['egw_info']['server']['admin_mails'];
|
||||||
|
}
|
||||||
|
foreach(self::$capablities as $name => $value)
|
||||||
|
{
|
||||||
|
$xml->writeElement($name, $value);
|
||||||
}
|
}
|
||||||
|
|
||||||
$xml->endElement(); // capability-set
|
$xml->endElement(); // capabilities
|
||||||
$xml->endElement(); // query-result
|
$xml->endElement(); // query-result
|
||||||
$xml->endDocument();
|
$xml->endDocument();
|
||||||
$capabilities = $xml->outputMemory();*/
|
$capabilities = $xml->outputMemory();
|
||||||
|
|
||||||
$capabilities = '<?xml version="1.0" encoding="utf-8" ?>
|
|
||||||
<query-result xmlns="urn:ietf:params:xml:ns:ischedule">
|
|
||||||
<capabilities>
|
|
||||||
<serial-number>'.self::SERIAL.'</serial-number>
|
|
||||||
<versions>
|
|
||||||
<version>1.0</version>
|
|
||||||
</versions>
|
|
||||||
<scheduling-messages>
|
|
||||||
<component name="VEVENT">
|
|
||||||
<method name="REQUEST"/>
|
|
||||||
<method name="ADD"/>
|
|
||||||
<method name="REPLY"/>
|
|
||||||
<method name="CANCEL"/>
|
|
||||||
</component>
|
|
||||||
<component name="VTODO"/>
|
|
||||||
<component name="VFREEBUSY"/>
|
|
||||||
</scheduling-messages>
|
|
||||||
<calendar-data-types>
|
|
||||||
<calendar-data-type content-type="text/calendar" version="2.0"/>
|
|
||||||
</calendar-data-types>
|
|
||||||
<attachments>
|
|
||||||
<inline/>
|
|
||||||
<external/>
|
|
||||||
</attachments>
|
|
||||||
<max-content-length>102400</max-content-length>
|
|
||||||
<min-date-time>19910101T000000Z</min-date-time>
|
|
||||||
<max-date-time>20381231T000000Z</max-date-time>
|
|
||||||
<max-instances>150</max-instances>
|
|
||||||
<max-recipients>250</max-recipients>
|
|
||||||
<administrator>mailto:ischedule-admin@example.com</administrator>
|
|
||||||
</capabilities>
|
|
||||||
</query-result>';
|
|
||||||
|
|
||||||
// returning capabilities
|
// returning capabilities
|
||||||
header('Content-Type: application/xml; charset=utf-8');
|
header('Content-Type: application/xml; charset=utf-8');
|
||||||
|
@ -17,6 +17,8 @@
|
|||||||
* @link https://tools.ietf.org/html/draft-desruisseaux-ischedule-03 iSchedule draft from 2013-01-22
|
* @link https://tools.ietf.org/html/draft-desruisseaux-ischedule-03 iSchedule draft from 2013-01-22
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
ini_set('zlib.output_compression',0);
|
||||||
|
|
||||||
$GLOBALS['egw_info'] = array(
|
$GLOBALS['egw_info'] = array(
|
||||||
'flags' => array(
|
'flags' => array(
|
||||||
'noheader' => True,
|
'noheader' => True,
|
||||||
|
Loading…
Reference in New Issue
Block a user