Page Menu
Home
Phabricator
Search
Configure Global Search
Log In
Files
F1812355
SharedCalendar.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Size
4 KB
Subscribers
None
SharedCalendar.php
View Options
<?php
namespace
Sabre\CalDAV
;
/**
* This object represents a CalDAV calendar that is shared by a different user.
*
* @copyright Copyright (C) 2007-2015 fruux GmbH (https://fruux.com/).
* @author Evert Pot (http://evertpot.com/)
* @license http://sabre.io/license/ Modified BSD License
*/
class
SharedCalendar
extends
Calendar
implements
ISharedCalendar
{
/**
* Constructor
*
* @param Backend\BackendInterface $caldavBackend
* @param array $calendarInfo
*/
function
__construct
(
Backend\BackendInterface
$caldavBackend
,
$calendarInfo
)
{
$required
=
[
'{http://calendarserver.org/ns/}shared-url'
,
'{http://sabredav.org/ns}owner-principal'
,
'{http://sabredav.org/ns}read-only'
,
];
foreach
(
$required
as
$r
)
{
if
(!
isset
(
$calendarInfo
[
$r
]))
{
throw
new
\InvalidArgumentException
(
'The '
.
$r
.
' property must be specified for SharedCalendar(s)'
);
}
}
parent
::
__construct
(
$caldavBackend
,
$calendarInfo
);
}
/**
* This method should return the url of the owners' copy of the shared
* calendar.
*
* @return string
*/
function
getSharedUrl
()
{
return
$this
->
calendarInfo
[
'{http://calendarserver.org/ns/}shared-url'
];
}
/**
* Returns the owner principal
*
* This must be a url to a principal, or null if there's no owner
*
* @return string|null
*/
function
getOwner
()
{
return
$this
->
calendarInfo
[
'{http://sabredav.org/ns}owner-principal'
];
}
/**
* Returns a list of ACE's for this node.
*
* Each ACE has the following properties:
* * 'privilege', a string such as {DAV:}read or {DAV:}write. These are
* currently the only supported privileges
* * 'principal', a url to the principal who owns the node
* * 'protected' (optional), indicating that this ACE is not allowed to
* be updated.
*
* @return array
*/
function
getACL
()
{
// The top-level ACL only contains access information for the true
// owner of the calendar, so we need to add the information for the
// sharee.
$acl
=
parent
::
getACL
();
$acl
[]
=
[
'privilege'
=>
'{DAV:}read'
,
'principal'
=>
$this
->
calendarInfo
[
'principaluri'
],
'protected'
=>
true
,
];
if
(
$this
->
calendarInfo
[
'{http://sabredav.org/ns}read-only'
])
{
$acl
[]
=
[
'privilege'
=>
'{DAV:}write-properties'
,
'principal'
=>
$this
->
calendarInfo
[
'principaluri'
],
'protected'
=>
true
,
];
}
else
{
$acl
[]
=
[
'privilege'
=>
'{DAV:}write'
,
'principal'
=>
$this
->
calendarInfo
[
'principaluri'
],
'protected'
=>
true
,
];
}
return
$acl
;
}
/**
* This method returns the ACL's for calendar objects in this calendar.
* The result of this method automatically gets passed to the
* calendar-object nodes in the calendar.
*
* @return array
*/
function
getChildACL
()
{
$acl
=
parent
::
getChildACL
();
$acl
[]
=
[
'privilege'
=>
'{DAV:}read'
,
'principal'
=>
$this
->
calendarInfo
[
'principaluri'
],
'protected'
=>
true
,
];
if
(!
$this
->
calendarInfo
[
'{http://sabredav.org/ns}read-only'
])
{
$acl
[]
=
[
'privilege'
=>
'{DAV:}write'
,
'principal'
=>
$this
->
calendarInfo
[
'principaluri'
],
'protected'
=>
true
,
];
}
return
$acl
;
}
/**
* Returns the list of people whom this calendar is shared with.
*
* Every element in this array should have the following properties:
* * href - Often a mailto: address
* * commonName - Optional, for example a first + last name
* * status - See the Sabre\CalDAV\SharingPlugin::STATUS_ constants.
* * readOnly - boolean
* * summary - Optional, a description for the share
*
* @return array
*/
function
getShares
()
{
return
$this
->
caldavBackend
->
getShares
(
$this
->
calendarInfo
[
'id'
]);
}
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Dec 20 2024, 5:52 AM (4 w, 5 d ago)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
914274
Default Alt Text
SharedCalendar.php (4 KB)
Attached To
rDAVCAL DokuWiki DAVCal PlugIn
Event Timeline
Log In to Comment