2013-02-19 02:21:29 +01:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* ownCloud - CardDAV plugin
|
|
|
|
*
|
|
|
|
* The CardDAV plugin adds CardDAV functionality to the WebDAV server
|
|
|
|
*
|
|
|
|
* @author Thomas Tanghus
|
2014-01-26 00:40:22 +01:00
|
|
|
* @copyright 2013-2014 Thomas Tanghus (thomas@tanghus.net)
|
2013-02-19 02:21:29 +01:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 3 of the License, or any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU AFFERO GENERAL PUBLIC LICENSE for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2013-03-05 11:08:04 +01:00
|
|
|
namespace OCA\Contacts\CardDAV;
|
2013-02-19 02:21:29 +01:00
|
|
|
|
|
|
|
use Sabre\VObject;
|
2013-03-10 12:36:08 +01:00
|
|
|
use OCA\Contacts\VObject\VCard;
|
2013-02-19 02:21:29 +01:00
|
|
|
|
|
|
|
/**
|
2014-05-26 22:09:12 +02:00
|
|
|
* This class overrides \Sabre\CardDAV\Plugin::validateVCard() to be able
|
2013-02-19 02:21:29 +01:00
|
|
|
* to import partially invalid vCards by ignoring invalid lines and to
|
2013-03-05 11:36:35 +01:00
|
|
|
* validate and upgrade using \OCA\Contacts\VCard.
|
2013-02-19 02:21:29 +01:00
|
|
|
*/
|
2014-05-26 22:09:12 +02:00
|
|
|
class Plugin extends \Sabre\CardDAV\Plugin {
|
2013-02-19 02:21:29 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Checks if the submitted vCard data is in fact, valid.
|
|
|
|
*
|
|
|
|
* An exception is thrown if it's not.
|
|
|
|
*
|
|
|
|
* @param resource|string $data
|
2015-02-16 18:42:41 +01:00
|
|
|
* @param boolean $modified whether the data was modified
|
2013-02-19 02:21:29 +01:00
|
|
|
* @return void
|
|
|
|
*/
|
2015-02-16 18:42:41 +01:00
|
|
|
protected function validateVCard(&$data, &$modified) {
|
2013-02-19 02:21:29 +01:00
|
|
|
|
|
|
|
// If it's a stream, we convert it to a string first.
|
|
|
|
if (is_resource($data)) {
|
|
|
|
$data = stream_get_contents($data);
|
2014-03-17 23:48:16 +01:00
|
|
|
} elseif (!is_string($data)) {
|
|
|
|
throw new \Exception(__METHOD__ . ' argument 1 only supports string or stream resource.');
|
2013-02-19 02:21:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2013-03-10 12:36:08 +01:00
|
|
|
$vobj = VObject\Reader::read($data, VObject\Reader::OPTION_IGNORE_INVALID_LINES);
|
2013-02-19 02:21:29 +01:00
|
|
|
} catch (VObject\ParseException $e) {
|
2014-05-26 22:09:12 +02:00
|
|
|
throw new \Sabre\DAV\Exception\UnsupportedMediaType('This resource only supports valid vcard data. Parse error: ' . $e->getMessage());
|
2013-02-19 02:21:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($vobj->name !== 'VCARD') {
|
2014-05-26 22:09:12 +02:00
|
|
|
throw new \Sabre\DAV\Exception\UnsupportedMediaType('This collection can only support vcard objects.');
|
2013-02-19 02:21:29 +01:00
|
|
|
}
|
|
|
|
|
2015-02-16 18:42:41 +01:00
|
|
|
$modified = true; // FIXME: set to false if neither repair nor upgrade was done
|
2013-03-05 11:36:35 +01:00
|
|
|
$vobj->validate(VCard::REPAIR|VCard::UPGRADE);
|
2013-02-19 02:21:29 +01:00
|
|
|
$data = $vobj->serialize();
|
|
|
|
}
|
2014-05-26 22:09:12 +02:00
|
|
|
}
|