xref: /plugin/davcal/vendor/sabre/vobject/lib/Splitter/VCard.php (revision a1a3b6794e0e143a4a8b51d3185ce2d339be61ab)
1*a1a3b679SAndreas Boehler<?php
2*a1a3b679SAndreas Boehler
3*a1a3b679SAndreas Boehlernamespace Sabre\VObject\Splitter;
4*a1a3b679SAndreas Boehler
5*a1a3b679SAndreas Boehleruse
6*a1a3b679SAndreas Boehler    Sabre\VObject,
7*a1a3b679SAndreas Boehler    Sabre\VObject\Parser\MimeDir;
8*a1a3b679SAndreas Boehler
9*a1a3b679SAndreas Boehler/**
10*a1a3b679SAndreas Boehler * Splitter
11*a1a3b679SAndreas Boehler *
12*a1a3b679SAndreas Boehler * This class is responsible for splitting up VCard objects.
13*a1a3b679SAndreas Boehler *
14*a1a3b679SAndreas Boehler * It is assumed that the input stream contains 1 or more VCARD objects. This
15*a1a3b679SAndreas Boehler * class checks for BEGIN:VCARD and END:VCARD and parses each encountered
16*a1a3b679SAndreas Boehler * component individually.
17*a1a3b679SAndreas Boehler *
18*a1a3b679SAndreas Boehler * @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/).
19*a1a3b679SAndreas Boehler * @author Dominik Tobschall
20*a1a3b679SAndreas Boehler * @author Armin Hackmann
21*a1a3b679SAndreas Boehler * @license http://sabre.io/license/ Modified BSD License
22*a1a3b679SAndreas Boehler */
23*a1a3b679SAndreas Boehlerclass VCard implements SplitterInterface {
24*a1a3b679SAndreas Boehler
25*a1a3b679SAndreas Boehler    /**
26*a1a3b679SAndreas Boehler     * File handle
27*a1a3b679SAndreas Boehler     *
28*a1a3b679SAndreas Boehler     * @var resource
29*a1a3b679SAndreas Boehler     */
30*a1a3b679SAndreas Boehler    protected $input;
31*a1a3b679SAndreas Boehler
32*a1a3b679SAndreas Boehler    /**
33*a1a3b679SAndreas Boehler     * Persistent parser
34*a1a3b679SAndreas Boehler     *
35*a1a3b679SAndreas Boehler     * @var MimeDir
36*a1a3b679SAndreas Boehler     */
37*a1a3b679SAndreas Boehler    protected $parser;
38*a1a3b679SAndreas Boehler
39*a1a3b679SAndreas Boehler    /**
40*a1a3b679SAndreas Boehler     * Constructor
41*a1a3b679SAndreas Boehler     *
42*a1a3b679SAndreas Boehler     * The splitter should receive an readable file stream as it's input.
43*a1a3b679SAndreas Boehler     *
44*a1a3b679SAndreas Boehler     * @param resource $input
45*a1a3b679SAndreas Boehler     * @param int $options Parser options, see the OPTIONS constants.
46*a1a3b679SAndreas Boehler     */
47*a1a3b679SAndreas Boehler    public function __construct($input, $options = 0) {
48*a1a3b679SAndreas Boehler
49*a1a3b679SAndreas Boehler        $this->input = $input;
50*a1a3b679SAndreas Boehler        $this->parser = new MimeDir($input, $options);
51*a1a3b679SAndreas Boehler
52*a1a3b679SAndreas Boehler    }
53*a1a3b679SAndreas Boehler
54*a1a3b679SAndreas Boehler    /**
55*a1a3b679SAndreas Boehler     * Every time getNext() is called, a new object will be parsed, until we
56*a1a3b679SAndreas Boehler     * hit the end of the stream.
57*a1a3b679SAndreas Boehler     *
58*a1a3b679SAndreas Boehler     * When the end is reached, null will be returned.
59*a1a3b679SAndreas Boehler     *
60*a1a3b679SAndreas Boehler     * @return Sabre\VObject\Component|null
61*a1a3b679SAndreas Boehler     */
62*a1a3b679SAndreas Boehler    public function getNext() {
63*a1a3b679SAndreas Boehler
64*a1a3b679SAndreas Boehler        try {
65*a1a3b679SAndreas Boehler            $object = $this->parser->parse();
66*a1a3b679SAndreas Boehler
67*a1a3b679SAndreas Boehler            if (!$object instanceof VObject\Component\VCard) {
68*a1a3b679SAndreas Boehler                throw new VObject\ParseException('The supplied input contained non-VCARD data.');
69*a1a3b679SAndreas Boehler            }
70*a1a3b679SAndreas Boehler
71*a1a3b679SAndreas Boehler        } catch (VObject\EofException $e) {
72*a1a3b679SAndreas Boehler            return null;
73*a1a3b679SAndreas Boehler        }
74*a1a3b679SAndreas Boehler
75*a1a3b679SAndreas Boehler        return $object;
76*a1a3b679SAndreas Boehler
77*a1a3b679SAndreas Boehler    }
78*a1a3b679SAndreas Boehler
79*a1a3b679SAndreas Boehler}
80