/**
  * @param int $calendarId
  * @param string $sd
  * @param string $ed
  * @param string $base_path
  * @return array
  */
 public function listItemsByRange($calendarId, $sd, $ed, $base_path)
 {
     $calendar = Sabre_CalDAV_Backend_Common::loadCalendarById($calendarId);
     $von = wdcal_php2MySqlTime($sd);
     $bis = wdcal_php2MySqlTime($ed);
     $timezoneOffset = date("P");
     // @TODO Events, die früher angefangen haben, aber noch andauern
     $evs = q("SELECT *, CONVERT_TZ(`StartTime`, @@session.time_zone, '{$timezoneOffset}') StartTime, CONVERT_TZ(`EndTime`, @@session.time_zone, '{$timezoneOffset}') EndTime\n\t\t\tFROM %s%sjqcalendar WHERE `calendar_id` = %d AND `StartTime` between '%s' and '%s'", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($calendarId), dbesc($von), dbesc($bis));
     $events = array();
     foreach ($evs as $row) {
         $events[] = $this->jqcal2wdcal($row, $calendar, $base_path . $row["calendar_id"] . "/");
     }
     return $events;
 }
/**
 * @param string $uri
 * @param int $uid
 * @param string $timezone
 * @param string $goaway_url
 * @return array
 */
function wdcal_postEditPage($uri, $uid = 0, $timezone = "", $goaway_url = "")
{
    $uid = IntVal($uid);
    $localization = wdcal_local::getInstanceByUser($uid);
    $server = dav_create_server(true, true, false);
    if ($uri > 0) {
        $calendar = dav_get_current_user_calendar_by_id($server, $_REQUEST["calendar"], DAV_ACL_READ);
        $obj_uri = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($uri);
        $obj_uri = $obj_uri["uri"];
        $vObject = dav_get_current_user_calendarobject($server, $calendar, $obj_uri, DAV_ACL_WRITE);
        $component = dav_get_eventComponent($vObject);
        if ($component == null) {
            return array("ok" => false, "msg" => t('Could not open component for editing'));
        }
    } else {
        $calendar = dav_get_current_user_calendar_by_id($server, $_REQUEST["calendar"], DAV_ACL_WRITE);
        $vObject = dav_create_empty_vevent();
        $component = dav_get_eventComponent($vObject);
        $obj_uri = $component->__get("UID");
    }
    $ts_start = wdcal_set_component_date($component, $localization);
    wdcal_set_component_recurrence($component, $localization);
    wdcal_set_component_alerts($component, $localization, icalendar_sanitize_string(dav_compat_parse_text_serverside("summary")), $ts_start);
    $component->__unset("LOCATION");
    $component->__unset("SUMMARY");
    $component->__unset("DESCRIPTION");
    $component->__unset("X-ANIMEXX-COLOR");
    $component->add("SUMMARY", icalendar_sanitize_string(dav_compat_parse_text_serverside("summary")));
    $component->add("LOCATION", icalendar_sanitize_string(dav_compat_parse_text_serverside("location")));
    $component->add("DESCRIPTION", icalendar_sanitize_string(dav_compat_parse_text_serverside("wdcal_desc")));
    if (isset($_REQUEST["color_override"])) {
        $component->add("X-ANIMEXX-COLOR", $_REQUEST["color"]);
    }
    $data = $vObject->serialize();
    if ($uri == 0) {
        $calendar->createFile($obj_uri . ".ics", $data);
    } else {
        $obj = $calendar->getChild($obj_uri);
        $obj->put($data);
    }
    return array("ok" => false, "msg" => t("Saved"));
}
/**
 *
 */
function wdcal_print_feed($base_path = "")
{
    $server = dav_create_server(true, true, false);
    $ret = null;
    $method = $_GET["method"];
    switch ($method) {
        case "add":
            $cs = wdcal_print_feed_getCal($server, DAV_ACL_WRITE);
            if ($cs == null) {
                echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                killme();
            }
            try {
                $item = dav_create_empty_vevent();
                $component = dav_get_eventComponent($item);
                $component->add("SUMMARY", icalendar_sanitize_string(dav_compat_parse_text_serverside("CalendarTitle")));
                if (isset($_REQUEST["allday"])) {
                    $type = Sabre\VObject\Property\DateTime::DATE;
                } else {
                    $type = Sabre\VObject\Property\DateTime::LOCALTZ;
                }
                $datetime_start = new Sabre\VObject\Property\DateTime("DTSTART");
                $datetime_start->setDateTime(new DateTime(date("Y-m-d H:i:s", IntVal($_REQUEST["CalendarStartTime"]))), $type);
                $datetime_end = new Sabre\VObject\Property\DateTime("DTEND");
                $datetime_end->setDateTime(new DateTime(date("Y-m-d H:i:s", IntVal($_REQUEST["CalendarEndTime"]))), $type);
                $component->add($datetime_start);
                $component->add($datetime_end);
                $uid = $component->__get("UID");
                $data = $item->serialize();
                $cs->createFile($uid . ".ics", $data);
                $ret = array('IsSuccess' => true, 'Msg' => 'add success', 'Data' => $uid . ".ics");
            } catch (Exception $e) {
                $ret = array('IsSuccess' => false, 'Msg' => $e->__toString());
            }
            break;
        case "list":
            $weekstartday = isset($_REQUEST["weekstartday"]) ? IntVal($_REQUEST["weekstartday"]) : 1;
            // 1 = Monday
            $num_days = isset($_REQUEST["num_days"]) ? IntVal($_REQUEST["num_days"]) : 7;
            $ret = null;
            $date = wdcal_get_list_range_params($_REQUEST["showdate"], $weekstartday, $num_days, $_REQUEST["viewtype"]);
            $ret = array();
            $ret['events'] = array();
            $ret["issort"] = true;
            $ret["start"] = $date[0];
            $ret["end"] = $date[1];
            $ret['error'] = null;
            $cals = dav_get_current_user_calendars($server, DAV_ACL_READ);
            foreach ($cals as $cal) {
                $prop = $cal->getProperties(array("id"));
                if (isset($prop["id"]) && (!isset($_REQUEST["cal"]) || in_array($prop["id"], $_REQUEST["cal"]))) {
                    $backend = wdcal_calendar_factory_by_id($prop["id"]);
                    $events = $backend->listItemsByRange($prop["id"], $date[0], $date[1], $base_path);
                    $ret["events"] = array_merge($ret["events"], $events);
                }
            }
            $tmpev = array();
            foreach ($ret["events"] as $e) {
                if (!isset($tmpev[$e["start"]])) {
                    $tmpev[$e["start"]] = array();
                }
                $tmpev[$e["start"]][] = $e;
            }
            ksort($tmpev);
            $ret["events"] = array();
            foreach ($tmpev as $e) {
                foreach ($e as $f) {
                    $ret["events"][] = $f;
                }
            }
            break;
        case "update":
            $r = q("SELECT `calendarobject_id`, `calendar_id` FROM %s%sjqcalendar WHERE `id`=%d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["jq_id"]));
            if (count($r) != 1) {
                echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                killme();
            }
            try {
                $cs = dav_get_current_user_calendar_by_id($server, $r[0]["calendar_id"], DAV_ACL_READ);
                $obj_uri = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($r[0]["calendarobject_id"]);
                $vObject = dav_get_current_user_calendarobject($server, $cs, $obj_uri["uri"], DAV_ACL_WRITE);
                $component = dav_get_eventComponent($vObject);
                if (!$component) {
                    echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                    killme();
                }
                if (isset($_REQUEST["allday"])) {
                    $type = Sabre\VObject\Property\DateTime::DATE;
                } else {
                    $type = Sabre\VObject\Property\DateTime::LOCALTZ;
                }
                $datetime_start = new Sabre\VObject\Property\DateTime("DTSTART");
                $datetime_start->setDateTime(new DateTime(date("Y-m-d H:i:s", IntVal($_REQUEST["CalendarStartTime"]))), $type);
                $datetime_end = new Sabre\VObject\Property\DateTime("DTEND");
                $datetime_end->setDateTime(new DateTime(date("Y-m-d H:i:s", IntVal($_REQUEST["CalendarEndTime"]))), $type);
                $component->__unset("DTSTART");
                $component->__unset("DTEND");
                $component->add($datetime_start);
                $component->add($datetime_end);
                $data = $vObject->serialize();
                /** @var Sabre_CalDAV_CalendarObject $child  */
                $child = $cs->getChild($obj_uri["uri"]);
                $child->put($data);
                $ret = array('IsSuccess' => true, 'Msg' => 'Succefully');
            } catch (Exception $e) {
                echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                killme();
            }
            break;
        case "remove":
            $r = q("SELECT `calendarobject_id`, `calendar_id` FROM %s%sjqcalendar WHERE `id`=%d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["jq_id"]));
            if (count($r) != 1) {
                echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                killme();
            }
            try {
                $cs = dav_get_current_user_calendar_by_id($server, $r[0]["calendar_id"], DAV_ACL_WRITE);
                $obj_uri = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($r[0]["calendarobject_id"]);
                $child = $cs->getChild($obj_uri["uri"]);
                $child->delete();
                $ret = array('IsSuccess' => true, 'Msg' => 'Succefully');
            } catch (Exception $e) {
                echo wdcal_jsonp_encode(array('IsSuccess' => false, 'Msg' => t('No access')));
                killme();
            }
            break;
    }
    echo wdcal_jsonp_encode($ret);
    killme();
}
 /**
  * @param int $calendarId
  */
 protected function increaseCalendarCtag($calendarId)
 {
     q("UPDATE %s%scalendars SET `ctag` = `ctag` + 1 WHERE `id` = '%d'", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($calendarId));
     self::$calendarObjectCache = array();
 }
/**
 * @param int $calendar_id
 * @return Sabre_CalDAV_Backend_Common
 * @throws Exception
 */
function wdcal_calendar_factory_by_id($calendar_id)
{
    $calendar = Sabre_CalDAV_Backend_Common::loadCalendarById($calendar_id);
    return wdcal_calendar_factory($calendar["namespace"], $calendar["namespace_id"], $calendar["uri"], $calendar);
}
/**
 * @param int $calendar_id
 * @param int $calendarobject_id
 * @return string
 */
function wdcal_getDetailPage($calendar_id, $calendarobject_id)
{
    $a = get_app();
    try {
        $details = null;
        $server = dav_create_server(true, true, false);
        $cal = dav_get_current_user_calendar_by_id($server, $calendar_id, DAV_ACL_READ);
        $obj = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($calendarobject_id);
        dav_get_current_user_calendarobject($server, $cal, $obj["uri"], DAV_ACL_READ);
        // Check permissions
        $calbackend = wdcal_calendar_factory_by_id($calendar_id);
        $redirect = $calbackend->getItemDetailRedirect($calendar_id, $calendarobject_id);
        if ($redirect !== null) {
            goaway($a->get_baseurl() . $redirect);
        }
        $details = $obj;
    } catch (Exception $e) {
        info(t("Error") . ": " . $e);
        goaway($a->get_baseurl() . "/dav/wdcal/");
    }
    return print_r($details, true);
}
 /**
  * @param int $calendarId
  * @param string $date_from
  * @param string $date_to
  * @param string $base_path
  * @throws Sabre_DAV_Exception_NotFound
  * @return array
  */
 public function listItemsByRange($calendarId, $date_from, $date_to, $base_path)
 {
     $calendar = Sabre_CalDAV_Backend_Common::loadCalendarById($calendarId);
     if ($calendar["namespace"] != CALDAV_NAMESPACE_PRIVATE) {
         throw new Sabre_DAV_Exception_NotFound();
     }
     switch ($calendar["uri"]) {
         case CALDAV_FRIENDICA_MINE:
             $sql_where = " AND cid = 0";
             break;
         case CALDAV_FRIENDICA_CONTACTS:
             $sql_where = " AND cid > 0";
             break;
         default:
             throw new Sabre_DAV_Exception_NotFound();
     }
     if ($date_from != "") {
         if (is_numeric($date_from)) {
             $sql_where .= " AND `finish` >= '" . date("Y-m-d H:i:s", $date_from) . "'";
         } else {
             $sql_where .= " AND `finish` >= '" . dbesc($date_from) . "'";
         }
     }
     if ($date_to != "") {
         if (is_numeric($date_to)) {
             $sql_where .= " AND `start` <= '" . date("Y-m-d H:i:s", $date_to) . "'";
         } else {
             $sql_where .= " AND `start` <= '" . dbesc($date_to) . "'";
         }
     }
     $ret = array();
     $r = q("SELECT * FROM `event` WHERE `uid` = %d " . $sql_where . " ORDER BY `start`", IntVal($calendar["namespace_id"]));
     $a = get_app();
     foreach ($r as $row) {
         $r = $this->jqcal2wdcal($row, $calendar, $a->get_baseurl());
         $r["calendar_id"] = $calendar["id"];
         $ret[] = $r;
     }
     return $ret;
 }