mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-10 05:41:59 +01:00
137 lines
3.1 KiB
PHP
137 lines
3.1 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Sabre\VObject\ITip;
|
||
|
|
||
|
/**
|
||
|
* This class represents an iTip message.
|
||
|
*
|
||
|
* A message holds all the information relevant to the message, including the
|
||
|
* object itself.
|
||
|
*
|
||
|
* It should for the most part be treated as immutable.
|
||
|
*
|
||
|
* @copyright Copyright (C) fruux GmbH (https://fruux.com/)
|
||
|
* @author Evert Pot (http://evertpot.com/)
|
||
|
* @license http://sabre.io/license/ Modified BSD License
|
||
|
*/
|
||
|
class Message
|
||
|
{
|
||
|
/**
|
||
|
* The object's UID.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $uid;
|
||
|
|
||
|
/**
|
||
|
* The component type, such as VEVENT.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $component;
|
||
|
|
||
|
/**
|
||
|
* Contains the ITip method, which is something like REQUEST, REPLY or
|
||
|
* CANCEL.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $method;
|
||
|
|
||
|
/**
|
||
|
* The current sequence number for the event.
|
||
|
*
|
||
|
* @var int
|
||
|
*/
|
||
|
public $sequence;
|
||
|
|
||
|
/**
|
||
|
* The senders' email address.
|
||
|
*
|
||
|
* Note that this does not imply that this has to be used in a From: field
|
||
|
* if the message is sent by email. It may also be populated in Reply-To:
|
||
|
* or not at all.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $sender;
|
||
|
|
||
|
/**
|
||
|
* The name of the sender. This is often populated from a CN parameter from
|
||
|
* either the ORGANIZER or ATTENDEE, depending on the message.
|
||
|
*
|
||
|
* @var string|null
|
||
|
*/
|
||
|
public $senderName;
|
||
|
|
||
|
/**
|
||
|
* The recipient's email address.
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $recipient;
|
||
|
|
||
|
/**
|
||
|
* The name of the recipient. This is usually populated with the CN
|
||
|
* parameter from the ATTENDEE or ORGANIZER property, if it's available.
|
||
|
*
|
||
|
* @var string|null
|
||
|
*/
|
||
|
public $recipientName;
|
||
|
|
||
|
/**
|
||
|
* After the message has been delivered, this should contain a string such
|
||
|
* as : 1.1;Sent or 1.2;Delivered.
|
||
|
*
|
||
|
* In case of a failure, this will hold the error status code.
|
||
|
*
|
||
|
* See:
|
||
|
* http://tools.ietf.org/html/rfc6638#section-7.3
|
||
|
*
|
||
|
* @var string
|
||
|
*/
|
||
|
public $scheduleStatus;
|
||
|
|
||
|
/**
|
||
|
* The iCalendar / iTip body.
|
||
|
*
|
||
|
* @var \Sabre\VObject\Component\VCalendar
|
||
|
*/
|
||
|
public $message;
|
||
|
|
||
|
/**
|
||
|
* This will be set to true, if the iTip broker considers the change
|
||
|
* 'significant'.
|
||
|
*
|
||
|
* In practice, this means that we'll only mark it true, if for instance
|
||
|
* DTSTART changed. This allows systems to only send iTip messages when
|
||
|
* significant changes happened. This is especially useful for iMip, as
|
||
|
* normally a ton of messages may be generated for normal calendar use.
|
||
|
*
|
||
|
* To see the list of properties that are considered 'significant', check
|
||
|
* out Sabre\VObject\ITip\Broker::$significantChangeProperties.
|
||
|
*
|
||
|
* @var bool
|
||
|
*/
|
||
|
public $significantChange = true;
|
||
|
|
||
|
/**
|
||
|
* Returns the schedule status as a string.
|
||
|
*
|
||
|
* For example:
|
||
|
* 1.2
|
||
|
*
|
||
|
* @return mixed bool|string
|
||
|
*/
|
||
|
public function getScheduleStatus()
|
||
|
{
|
||
|
if (!$this->scheduleStatus) {
|
||
|
return false;
|
||
|
} else {
|
||
|
list($scheduleStatus) = explode(';', $this->scheduleStatus);
|
||
|
|
||
|
return $scheduleStatus;
|
||
|
}
|
||
|
}
|
||
|
}
|