xref: /plugin/davcal/vendor/sabre/vobject/lib/Property/Binary.php (revision a1a3b6794e0e143a4a8b51d3185ce2d339be61ab)
1*a1a3b679SAndreas Boehler<?php
2*a1a3b679SAndreas Boehler
3*a1a3b679SAndreas Boehlernamespace Sabre\VObject\Property;
4*a1a3b679SAndreas Boehler
5*a1a3b679SAndreas Boehleruse
6*a1a3b679SAndreas Boehler    LogicException,
7*a1a3b679SAndreas Boehler    Sabre\VObject\Property;
8*a1a3b679SAndreas Boehler
9*a1a3b679SAndreas Boehler/**
10*a1a3b679SAndreas Boehler * BINARY property
11*a1a3b679SAndreas Boehler *
12*a1a3b679SAndreas Boehler * This object represents BINARY values.
13*a1a3b679SAndreas Boehler *
14*a1a3b679SAndreas Boehler * Binary values are most commonly used by the iCalendar ATTACH property, and
15*a1a3b679SAndreas Boehler * the vCard PHOTO property.
16*a1a3b679SAndreas Boehler *
17*a1a3b679SAndreas Boehler * This property will transparently encode and decode to base64.
18*a1a3b679SAndreas Boehler *
19*a1a3b679SAndreas Boehler * @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/).
20*a1a3b679SAndreas Boehler * @author Evert Pot (http://evertpot.com/)
21*a1a3b679SAndreas Boehler * @license http://sabre.io/license/ Modified BSD License
22*a1a3b679SAndreas Boehler */
23*a1a3b679SAndreas Boehlerclass Binary extends Property {
24*a1a3b679SAndreas Boehler
25*a1a3b679SAndreas Boehler    /**
26*a1a3b679SAndreas Boehler     * In case this is a multi-value property. This string will be used as a
27*a1a3b679SAndreas Boehler     * delimiter.
28*a1a3b679SAndreas Boehler     *
29*a1a3b679SAndreas Boehler     * @var string|null
30*a1a3b679SAndreas Boehler     */
31*a1a3b679SAndreas Boehler    public $delimiter = null;
32*a1a3b679SAndreas Boehler
33*a1a3b679SAndreas Boehler    /**
34*a1a3b679SAndreas Boehler     * Updates the current value.
35*a1a3b679SAndreas Boehler     *
36*a1a3b679SAndreas Boehler     * This may be either a single, or multiple strings in an array.
37*a1a3b679SAndreas Boehler     *
38*a1a3b679SAndreas Boehler     * @param string|array $value
39*a1a3b679SAndreas Boehler     * @return void
40*a1a3b679SAndreas Boehler     */
41*a1a3b679SAndreas Boehler    public function setValue($value) {
42*a1a3b679SAndreas Boehler
43*a1a3b679SAndreas Boehler        if(is_array($value)) {
44*a1a3b679SAndreas Boehler
45*a1a3b679SAndreas Boehler            if(count($value) === 1) {
46*a1a3b679SAndreas Boehler                $this->value = $value[0];
47*a1a3b679SAndreas Boehler            } else {
48*a1a3b679SAndreas Boehler                throw new \InvalidArgumentException('The argument must either be a string or an array with only one child');
49*a1a3b679SAndreas Boehler            }
50*a1a3b679SAndreas Boehler
51*a1a3b679SAndreas Boehler        } else {
52*a1a3b679SAndreas Boehler
53*a1a3b679SAndreas Boehler            $this->value = $value;
54*a1a3b679SAndreas Boehler
55*a1a3b679SAndreas Boehler        }
56*a1a3b679SAndreas Boehler
57*a1a3b679SAndreas Boehler    }
58*a1a3b679SAndreas Boehler
59*a1a3b679SAndreas Boehler    /**
60*a1a3b679SAndreas Boehler     * Sets a raw value coming from a mimedir (iCalendar/vCard) file.
61*a1a3b679SAndreas Boehler     *
62*a1a3b679SAndreas Boehler     * This has been 'unfolded', so only 1 line will be passed. Unescaping is
63*a1a3b679SAndreas Boehler     * not yet done, but parameters are not included.
64*a1a3b679SAndreas Boehler     *
65*a1a3b679SAndreas Boehler     * @param string $val
66*a1a3b679SAndreas Boehler     * @return void
67*a1a3b679SAndreas Boehler     */
68*a1a3b679SAndreas Boehler    public function setRawMimeDirValue($val) {
69*a1a3b679SAndreas Boehler
70*a1a3b679SAndreas Boehler        $this->value = base64_decode($val);
71*a1a3b679SAndreas Boehler
72*a1a3b679SAndreas Boehler    }
73*a1a3b679SAndreas Boehler
74*a1a3b679SAndreas Boehler    /**
75*a1a3b679SAndreas Boehler     * Returns a raw mime-dir representation of the value.
76*a1a3b679SAndreas Boehler     *
77*a1a3b679SAndreas Boehler     * @return string
78*a1a3b679SAndreas Boehler     */
79*a1a3b679SAndreas Boehler    public function getRawMimeDirValue() {
80*a1a3b679SAndreas Boehler
81*a1a3b679SAndreas Boehler        return base64_encode($this->value);
82*a1a3b679SAndreas Boehler
83*a1a3b679SAndreas Boehler    }
84*a1a3b679SAndreas Boehler
85*a1a3b679SAndreas Boehler    /**
86*a1a3b679SAndreas Boehler     * Returns the type of value.
87*a1a3b679SAndreas Boehler     *
88*a1a3b679SAndreas Boehler     * This corresponds to the VALUE= parameter. Every property also has a
89*a1a3b679SAndreas Boehler     * 'default' valueType.
90*a1a3b679SAndreas Boehler     *
91*a1a3b679SAndreas Boehler     * @return string
92*a1a3b679SAndreas Boehler     */
93*a1a3b679SAndreas Boehler    public function getValueType() {
94*a1a3b679SAndreas Boehler
95*a1a3b679SAndreas Boehler        return 'BINARY';
96*a1a3b679SAndreas Boehler
97*a1a3b679SAndreas Boehler    }
98*a1a3b679SAndreas Boehler
99*a1a3b679SAndreas Boehler    /**
100*a1a3b679SAndreas Boehler     * Returns the value, in the format it should be encoded for json.
101*a1a3b679SAndreas Boehler     *
102*a1a3b679SAndreas Boehler     * This method must always return an array.
103*a1a3b679SAndreas Boehler     *
104*a1a3b679SAndreas Boehler     * @return array
105*a1a3b679SAndreas Boehler     */
106*a1a3b679SAndreas Boehler    public function getJsonValue() {
107*a1a3b679SAndreas Boehler
108*a1a3b679SAndreas Boehler        return array(base64_encode($this->getValue()));
109*a1a3b679SAndreas Boehler
110*a1a3b679SAndreas Boehler    }
111*a1a3b679SAndreas Boehler
112*a1a3b679SAndreas Boehler    /**
113*a1a3b679SAndreas Boehler     * Sets the json value, as it would appear in a jCard or jCal object.
114*a1a3b679SAndreas Boehler     *
115*a1a3b679SAndreas Boehler     * The value must always be an array.
116*a1a3b679SAndreas Boehler     *
117*a1a3b679SAndreas Boehler     * @param array $value
118*a1a3b679SAndreas Boehler     * @return void
119*a1a3b679SAndreas Boehler     */
120*a1a3b679SAndreas Boehler    public function setJsonValue(array $value) {
121*a1a3b679SAndreas Boehler
122*a1a3b679SAndreas Boehler        $value = array_map('base64_decode', $value);
123*a1a3b679SAndreas Boehler        parent::setJsonValue($value);
124*a1a3b679SAndreas Boehler
125*a1a3b679SAndreas Boehler    }
126*a1a3b679SAndreas Boehler
127*a1a3b679SAndreas Boehler}
128