value = $value[0]; } else { throw new \InvalidArgumentException('The argument must either be a string or an array with only one child'); } } else { $this->value = $value; } } /** * Sets a raw value coming from a mimedir (iCalendar/vCard) file. * * This has been 'unfolded', so only 1 line will be passed. Unescaping is * not yet done, but parameters are not included. * * @param string $val * * @return void */ function setRawMimeDirValue($val) { $this->value = base64_decode($val); } /** * Returns a raw mime-dir representation of the value. * * @return string */ function getRawMimeDirValue() { return base64_encode($this->value); } /** * Returns the type of value. * * This corresponds to the VALUE= parameter. Every property also has a * 'default' valueType. * * @return string */ function getValueType() { return 'BINARY'; } /** * Returns the value, in the format it should be encoded for json. * * This method must always return an array. * * @return array */ function getJsonValue() { return [base64_encode($this->getValue())]; } /** * Sets the json value, as it would appear in a jCard or jCal object. * * The value must always be an array. * * @param array $value * * @return void */ function setJsonValue(array $value) { $value = array_map('base64_decode', $value); parent::setJsonValue($value); } }