. * */ namespace OCA\Contacts\CardDAV; use Sabre\VObject; use OCA\Contacts\VObject\VCard; /** * This class overrides \Sabre\CardDAV\Plugin::validateVCard() to be able * to import partially invalid vCards by ignoring invalid lines and to * validate and upgrade using \OCA\Contacts\VCard. */ class Plugin extends \Sabre\CardDAV\Plugin { /** * Checks if the submitted vCard data is in fact, valid. * * An exception is thrown if it's not. * * @param resource|string $data * @param boolean $modified whether the data was modified * @return void */ protected function validateVCard(&$data, &$modified) { // If it's a stream, we convert it to a string first. if (is_resource($data)) { $data = stream_get_contents($data); } elseif (!is_string($data)) { throw new \Exception(__METHOD__ . ' argument 1 only supports string or stream resource.'); } try { $vobj = VObject\Reader::read($data, VObject\Reader::OPTION_IGNORE_INVALID_LINES); } catch (VObject\ParseException $e) { throw new \Sabre\DAV\Exception\UnsupportedMediaType('This resource only supports valid vcard data. Parse error: ' . $e->getMessage()); } if ($vobj->name !== 'VCARD') { throw new \Sabre\DAV\Exception\UnsupportedMediaType('This collection can only support vcard objects.'); } $modified = true; // FIXME: set to false if neither repair nor upgrade was done $vobj->validate(VCard::REPAIR|VCard::UPGRADE); $data = $vobj->serialize(); } }