1 // CalDAV.h - CalDAV Connection Object header.
3 // (c) 2016 Xestia Software Development.
5 // This file is part of Xestia Calendar.
7 // Xestia Address Book is free software: you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License as published by the
9 // Free Software Foundation, version 3 of the license.
11 // Xestia Address Book is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with Xestia Calendar. If not, see <http://www.gnu.org/licenses/>
19 #ifndef __OBJECTS_CALDAV_CALDAV_H__
20 #define __OBJECTS_CALDAV_CALDAV_H__
22 #include <curl/curl.h>
23 #include <libxml/parser.h>
24 #include <libxml/tree.h>
30 #include "../../common/colour.h"
31 #include "../../common/text.h"
32 #include "../../common/uuid.h"
36 // CalDAVConnectionData: used for
37 // connecting to the server.
39 enum CalDAVQueryResult {
40 CALDAVQUERYRESULT_UNITTESTFAIL = -1,
42 CALDAVQUERYRESULT_NOTRUN,
43 CALDAVQUERYRESULT_SERVERERROR
46 struct CalDAVCalendarList {
51 map<int,string> Description;
52 map<int,Colour> CalColour;
57 struct CalDAVConnectionData{
69 // CalDAVStatusData: used for
70 // getting the current server
71 // settings for the CalDAV
85 // CalDAVServerSupport: used for
86 // getting what the server supports
87 // from the CalDAV specification.
89 struct CalDAVServerSupport{
91 // Variable name. Name in CalDAV header.
93 bool BasicSupport = false; // calendar-access
97 // CalDAVServerResult: used for
98 // getting the result of the
99 // request made via the CalDAV
102 struct CalDAVServerResult{
104 CalDAVQueryResult Result = CALDAVQUERYRESULT_NOTRUN;
105 CURLcode Code = CURLE_OK;
110 // CalDAVSendData: used for
111 // sending data to the CaLDAV
114 struct CalDAVSendData{
123 string ProcessXMLUserPrincipal();
124 string ProcessXMLCalendarHome();
125 CalDAVCalendarList ProcessXMLCalendarList();
126 bool MatchXMLNameTransverse(xmlNodePtr *NodePtr, string NodeName);
127 bool MatchXMLName(xmlNodePtr *NodePtrOriginal, string NodeName);
128 string FetchXMLData(xmlNodePtr *NodePtr);
129 CalDAVServerResult EditCalendarProcess(string *CalendarHREF,
130 string *CalendarName,
131 Colour *CalendarColour,
132 string *CalendarDescription,
135 CalDAVConnectionData ConnectionData;
136 CalDAVServerResult ConnectionServerResult;
137 CURL *ConnectionHandle = nullptr;
138 string ServerData = "";
139 string ServerHeader = "";
144 void SetupConnectionData(CalDAVConnectionData *ConnData);
145 CalDAVStatus GetConnectionData();
146 CalDAVServerResult Connect();
147 CalDAVServerResult GetServerResult();
148 CalDAVServerSupport GetServerSupport();
150 CalDAVCalendarList GetCalendars();
152 CalDAVServerResult AddCalendar(string CalendarName);
154 CalDAVServerResult EditCalendar(string *CalendarHREF,
155 string *CalendarName,
156 Colour *CalendarColour,
157 string *CalendarDescription,
159 CalDAVServerResult EditCalendar(string *CalendarHREF,
160 Colour *CalendarColour);
161 CalDAVServerResult EditCalendar(string *CalendarHREF,
162 string *CalendarName);
163 CalDAVServerResult EditCalendar(string *CalendarHREF,
165 CalDAVServerResult EditCalendarDescription(string *CalendarHREF,
166 string *CalendarDescription);
168 CalDAVServerResult DeleteCalendar(string *CalendarHREF);
170 CalDAVServerResult AddEntry(string *CalendarEntryHREF, string *EntryData);
172 string GetUserPrincipal();
173 string GetCalendarHome(string UserPrincipalURI);
177 // Subroutines that are used with the
178 // CalDAVConnectionData struct.
180 bool CalDAVObjectValidSettings(CalDAVConnectionData *ConnData);
181 string BuildServerAddress(CalDAVConnectionData *ConnData, string URIAddress);