xref: /plugin/davcal/vendor/sabre/vobject/lib/Property/ICalendar/CalAddress.php (revision a1a3b6794e0e143a4a8b51d3185ce2d339be61ab)
1*a1a3b679SAndreas Boehler<?php
2*a1a3b679SAndreas Boehler
3*a1a3b679SAndreas Boehlernamespace Sabre\VObject\Property\ICalendar;
4*a1a3b679SAndreas Boehler
5*a1a3b679SAndreas Boehleruse
6*a1a3b679SAndreas Boehler    Sabre\VObject\Property\Text;
7*a1a3b679SAndreas Boehler
8*a1a3b679SAndreas Boehler/**
9*a1a3b679SAndreas Boehler * CalAddress property
10*a1a3b679SAndreas Boehler *
11*a1a3b679SAndreas Boehler * This object encodes CAL-ADDRESS values, as defined in rfc5545
12*a1a3b679SAndreas Boehler *
13*a1a3b679SAndreas Boehler * @copyright Copyright (C) 2011-2015 fruux GmbH (https://fruux.com/).
14*a1a3b679SAndreas Boehler * @author Evert Pot (http://evertpot.com/)
15*a1a3b679SAndreas Boehler * @license http://sabre.io/license/ Modified BSD License
16*a1a3b679SAndreas Boehler */
17*a1a3b679SAndreas Boehlerclass CalAddress extends Text {
18*a1a3b679SAndreas Boehler
19*a1a3b679SAndreas Boehler    /**
20*a1a3b679SAndreas Boehler     * In case this is a multi-value property. This string will be used as a
21*a1a3b679SAndreas Boehler     * delimiter.
22*a1a3b679SAndreas Boehler     *
23*a1a3b679SAndreas Boehler     * @var string|null
24*a1a3b679SAndreas Boehler     */
25*a1a3b679SAndreas Boehler    public $delimiter = null;
26*a1a3b679SAndreas Boehler
27*a1a3b679SAndreas Boehler    /**
28*a1a3b679SAndreas Boehler     * Returns the type of value.
29*a1a3b679SAndreas Boehler     *
30*a1a3b679SAndreas Boehler     * This corresponds to the VALUE= parameter. Every property also has a
31*a1a3b679SAndreas Boehler     * 'default' valueType.
32*a1a3b679SAndreas Boehler     *
33*a1a3b679SAndreas Boehler     * @return string
34*a1a3b679SAndreas Boehler     */
35*a1a3b679SAndreas Boehler    public function getValueType() {
36*a1a3b679SAndreas Boehler
37*a1a3b679SAndreas Boehler        return 'CAL-ADDRESS';
38*a1a3b679SAndreas Boehler
39*a1a3b679SAndreas Boehler    }
40*a1a3b679SAndreas Boehler
41*a1a3b679SAndreas Boehler    /**
42*a1a3b679SAndreas Boehler     * This returns a normalized form of the value.
43*a1a3b679SAndreas Boehler     *
44*a1a3b679SAndreas Boehler     * This is primarily used right now to turn mixed-cased schemes in user
45*a1a3b679SAndreas Boehler     * uris to lower-case.
46*a1a3b679SAndreas Boehler     *
47*a1a3b679SAndreas Boehler     * Evolution in particular tends to encode mailto: as MAILTO:.
48*a1a3b679SAndreas Boehler     *
49*a1a3b679SAndreas Boehler     * @return string
50*a1a3b679SAndreas Boehler     */
51*a1a3b679SAndreas Boehler    public function getNormalizedValue() {
52*a1a3b679SAndreas Boehler
53*a1a3b679SAndreas Boehler        $input = $this->getValue();
54*a1a3b679SAndreas Boehler        if (!strpos($input, ':')) {
55*a1a3b679SAndreas Boehler            return $input;
56*a1a3b679SAndreas Boehler        }
57*a1a3b679SAndreas Boehler        list($schema, $everythingElse) = explode(':', $input, 2);
58*a1a3b679SAndreas Boehler        return strtolower($schema) . ':' . $everythingElse;
59*a1a3b679SAndreas Boehler
60*a1a3b679SAndreas Boehler    }
61*a1a3b679SAndreas Boehler}
62