3 use Friendica\Core\L10n;
4 use Friendica\Util\DateTimeFormat;
10 function wdcal_jsonp_encode($obj)
12 $str = json_encode($obj);
13 if (isset($_REQUEST["callback"])) {
14 $str = $_REQUEST["callback"] . "(" . $str . ")";
22 * @param int $weekstartday
23 * @param int $num_days
27 function wdcal_get_list_range_params($day, $weekstartday, $num_days, $type)
29 $phpTime = IntVal($day);
32 $st = mktime(0, 0, 0, date("m", $phpTime), 1, date("Y", $phpTime));
33 $et = mktime(0, 0, -1, date("m", $phpTime) + 1, 1, date("Y", $phpTime));
36 //suppose first day of a week is monday
37 $monday = date("d", $phpTime) - date('N', $phpTime) + 1;
38 //echo date('N', $phpTime);
39 $st = mktime(0, 0, 0, date("m", $phpTime), $monday, date("Y", $phpTime));
40 $et = mktime(0, 0, -1, date("m", $phpTime), $monday + 7, date("Y", $phpTime));
43 //suppose first day of a week is monday
44 $monday = date("d", $phpTime) - date('N', $phpTime) + $weekstartday;
45 //echo date('N', $phpTime);
46 $st = mktime(0, 0, 0, date("m", $phpTime), $monday, date("Y", $phpTime));
47 $et = mktime(0, 0, -1, date("m", $phpTime), $monday + $num_days, date("Y", $phpTime));
50 $st = mktime(0, 0, 0, date("m", $phpTime), date("d", $phpTime), date("Y", $phpTime));
51 $et = mktime(0, 0, -1, date("m", $phpTime), date("d", $phpTime) + 1, date("Y", $phpTime));
56 return array($st, $et);
61 * @param Sabre_DAV_Server $server
62 * @param string $right
63 * @return null|Sabre_CalDAV_Calendar
65 function wdcal_print_feed_getCal(&$server, $right)
67 $cals = dav_get_current_user_calendars($server, $right);
69 for ($i = 0; $i < count($cals) && $calfound === null; $i++) {
70 $prop = $cals[$i]->getProperties(array("id"));
71 if (isset($prop["id"]) && (!isset($_REQUEST["cal"]) || in_array($prop["id"], $_REQUEST["cal"]))) $calfound = $cals[$i];
80 function wdcal_print_feed($base_path = "")
82 $server = dav_create_server(true, true, false);
86 $method = $_GET["method"];
89 $cs = wdcal_print_feed_getCal($server, DAV_ACL_WRITE);
91 echo wdcal_jsonp_encode(array('IsSuccess' => false,
92 'Msg' => L10n::t('No access')));
96 $item = dav_create_empty_vevent();
97 $component = dav_get_eventComponent($item);
98 $component->add("SUMMARY", icalendar_sanitize_string(dav_compat_parse_text_serverside("CalendarTitle")));
100 if (isset($_REQUEST["allday"])) $type = Sabre\VObject\Property\DateTime::DATE;
101 else $type = Sabre\VObject\Property\DateTime::LOCALTZ;
103 $datetime_start = new Sabre\VObject\Property\DateTime("DTSTART");
104 $datetime_start->setDateTime(new DateTime(date(DateTimeFormat::MYSQL, IntVal($_REQUEST["CalendarStartTime"]))), $type);
105 $datetime_end = new Sabre\VObject\Property\DateTime("DTEND");
106 $datetime_end->setDateTime(new DateTime(date(DateTimeFormat::MYSQL, IntVal($_REQUEST["CalendarEndTime"]))), $type);
108 $component->add($datetime_start);
109 $component->add($datetime_end);
111 $uid = $component->__get("UID");
112 $data = $item->serialize();
114 $cs->createFile($uid . ".ics", $data);
118 'Msg' => 'add success',
119 'Data' => $uid . ".ics",
122 } catch (Exception $e) {
124 'IsSuccess' => false,
125 'Msg' => $e->__toString(),
130 $weekstartday = (isset($_REQUEST["weekstartday"]) ? IntVal($_REQUEST["weekstartday"]) : 1); // 1 = Monday
131 $num_days = (isset($_REQUEST["num_days"]) ? IntVal($_REQUEST["num_days"]) : 7);
134 $date = wdcal_get_list_range_params($_REQUEST["showdate"], $weekstartday, $num_days, $_REQUEST["viewtype"]);
136 $ret['events'] = array();
137 $ret["issort"] = true;
138 $ret["start"] = $date[0];
139 $ret["end"] = $date[1];
140 $ret['error'] = null;
142 $cals = dav_get_current_user_calendars($server, DAV_ACL_READ);
143 foreach ($cals as $cal) {
144 $prop = $cal->getProperties(array("id"));
145 if (isset($prop["id"]) && (!isset($_REQUEST["cal"]) || in_array($prop["id"], $_REQUEST["cal"]))) {
146 $backend = wdcal_calendar_factory_by_id($prop["id"]);
147 $events = $backend->listItemsByRange($prop["id"], $date[0], $date[1], $base_path);
148 $ret["events"] = array_merge($ret["events"], $events);
153 foreach ($ret["events"] as $e) {
154 if (!isset($tmpev[$e["start"]])) $tmpev[$e["start"]] = array();
155 $tmpev[$e["start"]][] = $e;
158 $ret["events"] = array();
159 foreach ($tmpev as $e) foreach ($e as $f) $ret["events"][] = $f;
163 $r = q("SELECT `calendarobject_id`, `calendar_id` FROM %s%sjqcalendar WHERE `id`=%d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["jq_id"]));
164 if (count($r) != 1) {
165 echo wdcal_jsonp_encode(array('IsSuccess' => false,
166 'Msg' => L10n::t('No access')));
170 $cs = dav_get_current_user_calendar_by_id($server, $r[0]["calendar_id"], DAV_ACL_READ);
171 $obj_uri = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($r[0]["calendarobject_id"]);
173 $vObject = dav_get_current_user_calendarobject($server, $cs, $obj_uri["uri"], DAV_ACL_WRITE);
174 $component = dav_get_eventComponent($vObject);
177 echo wdcal_jsonp_encode(array('IsSuccess' => false,
178 'Msg' => L10n::t('No access')));
182 if (isset($_REQUEST["allday"])) $type = Sabre\VObject\Property\DateTime::DATE;
183 else $type = Sabre\VObject\Property\DateTime::LOCALTZ;
185 $datetime_start = new Sabre\VObject\Property\DateTime("DTSTART");
186 $datetime_start->setDateTime(new DateTime(date(DateTimeFormat::MYSQL, IntVal($_REQUEST["CalendarStartTime"]))), $type);
187 $datetime_end = new Sabre\VObject\Property\DateTime("DTEND");
188 $datetime_end->setDateTime(new DateTime(date(DateTimeFormat::MYSQL, IntVal($_REQUEST["CalendarEndTime"]))), $type);
190 $component->__unset("DTSTART");
191 $component->__unset("DTEND");
192 $component->add($datetime_start);
193 $component->add($datetime_end);
195 $data = $vObject->serialize();
196 /** @var Sabre_CalDAV_CalendarObject $child */
197 $child = $cs->getChild($obj_uri["uri"]);
202 'Msg' => 'Succefully',
204 } catch (Exception $e) {
205 echo wdcal_jsonp_encode(array('IsSuccess' => false,
206 'Msg' => L10n::t('No access')));
211 $r = q("SELECT `calendarobject_id`, `calendar_id` FROM %s%sjqcalendar WHERE `id`=%d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["jq_id"]));
212 if (count($r) != 1) {
213 echo wdcal_jsonp_encode(array('IsSuccess' => false,
214 'Msg' => L10n::t('No access')));
218 $cs = dav_get_current_user_calendar_by_id($server, $r[0]["calendar_id"], DAV_ACL_WRITE);
219 $obj_uri = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($r[0]["calendarobject_id"]);
220 $child = $cs->getChild($obj_uri["uri"]);
225 'Msg' => 'Succefully',
227 } catch (Exception $e) {
228 echo wdcal_jsonp_encode(array('IsSuccess' => false,
229 'Msg' => L10n::t('No access')));
235 echo wdcal_jsonp_encode($ret);