From 50569114acdc64e7c7cae1498635d3f821517c30 Mon Sep 17 00:00:00 2001 From: Daniel Lange Date: Mon, 7 Mar 2016 15:53:16 +0100 Subject: Initial commit of the Faster IT roundcube_calendar plugin distribution This includes: * Kolab plugins 3.2.9 (calendar and libcalendaring) * CalDAV driver 3.2.8 * .htaccess files for at least some security * SabreDAV updated to 1.8.12 (Jan 2015 release) * Support for CURLOPT_SSL_* settings to allow self-signed certificates * Small fixes & improved documentation --- .../lib/OldSabre/VObject/Splitter/VCard.php | 76 ++++++++++++++++++++++ 1 file changed, 76 insertions(+) create mode 100644 libcalendaring/lib/OldSabre/VObject/Splitter/VCard.php (limited to 'libcalendaring/lib/OldSabre/VObject/Splitter/VCard.php') diff --git a/libcalendaring/lib/OldSabre/VObject/Splitter/VCard.php b/libcalendaring/lib/OldSabre/VObject/Splitter/VCard.php new file mode 100644 index 0000000..90a5e69 --- /dev/null +++ b/libcalendaring/lib/OldSabre/VObject/Splitter/VCard.php @@ -0,0 +1,76 @@ +input = $input; + + } + + /** + * Every time getNext() is called, a new object will be parsed, until we + * hit the end of the stream. + * + * When the end is reached, null will be returned. + * + * @return OldSabre\VObject\Component|null + */ + public function getNext() { + + $vcard = ''; + + do { + + if (feof($this->input)) { + return false; + } + + $line = fgets($this->input); + $vcard .= $line; + + } while(strtoupper(substr($line,0,4))!=="END:"); + + $object = VObject\Reader::read($vcard); + + if($object->name !== 'VCARD') { + throw new \InvalidArgumentException("Thats no vCard!", 1); + } + + return $object; + + } + +} -- cgit v1.2.3