void CardDAV::GetServerETagValueThread()
{
+
+ // Get the server etag value (threaded).
PageData.Clear();
PageHeader.Clear();
AbortConnection = FALSE;
bool FilenameIsDirectory = FALSE;
- CURL *conn;
- CURLcode conncode;
+ CURL *conn;
+ CURLcode conncode;
wxString ServerAddressURL;
wxString ServerAuth;
wxString ServerAddressSSL;
conn = curl_easy_init();
+#if defined(__APPLE__)
+
+ SetConnectionObject(conn);
+
+#endif
+
struct CardDAVCURLPasser {
CardDAV *Data;
wxString Data1;
wxString Data2;
- ServerAddressURL = ServerAddress + wxT(":") + wxString::Format(wxT("%i"), ServerPort) + wxT("/") + ServerPrefix + ServerFilenameLocation;
+ ServerAddressURL = ServerAddress + wxT(":") + wxString::Format(wxT("%i"), ServerPort) + ServerPrefix + ServerFilenameLocation;
ServerAddressSSL = wxT("https://") + ServerAddressURL;
ServerAddressNormal = wxT("http://") + ServerAddressURL;
ServerAuth = ServerUser + wxT(":") + ServerPass;
-
- // Workout if path is directory or filename.
-
- /*if (ServerAddress){
- FilenameIsDirectory = TRUE;
- } else {
- FilenameIsDirectory = FALSE;
- }*/
-
- // Try SSL first.
-
-
- /*
- char *ServerAdrSSLChar = new char[(ServerAddressSSL.Length() - 1)];
- //memset(ServerAdrSSLChar, 0, ServerAddressSSL.Length());
- strncpy(ServerAdrSSLChar, (const char*)ServerAddressSSL.mb_str(wxConvUTF8), (ServerAddressSSL.Length() - 1));
-
- char *ServerAdrNorChar = new char[(ServerAddressNormal.Length() - 1)];
- //memset(ServerAdrNorChar, 0, ServerAddressSSL.Length());
- strncpy(ServerAdrNorChar, (const char*)ServerAddressNormal.mb_str(wxConvUTF8), (ServerAddressNormal.Length() - 1));
-
- char *ServerAuthChar = new char[(ServerAuth.Length() - 1)];
- //memset(ServerAuthChar, 0, ServerAddressSSL.Length());
- strncpy(ServerAuthChar, (const char*)ServerAuth.mb_str(wxConvUTF8), (ServerAuth.Length() - 1));
-
- */
-
- //std::string WriteDataString = std::string(ServerUploadData.mb_str());
std::map<int,int>::iterator ActIter;
struct UploadDataStruc UploadData;
"<C:addressbook-query xmlns:D=\"DAV:\""
" xmlns:C=\"urn:ietf:params:xml:ns:carddav\">"
"<D:prop><D:getetag/>"
- //"<C:address-data>"
- //" <C:allprop/>"
- //"</C:address-data></D:prop>"
"</D:prop>"
"<C:filter/>"
"</C:addressbook-query>";
curl_easy_setopt(conn, CURLOPT_PROGRESSFUNCTION, ProgressFunc);
curl_easy_setopt(conn, CURLOPT_CUSTOMREQUEST, "REPORT");
curl_easy_setopt(conn, CURLOPT_NOSIGNAL, 1);
-
- //UploadData.readptr = &CardDAVDataQuery;
- //UploadData.sizeleft = CardDAVDataQuery.Len();
- //curl_easy_setopt(conn, CURLOPT_UPLOAD, 1);
- //curl_easy_setopt(conn, CURLOPT_READDATA, &UploadData);
- //curl_easy_setopt(conn, CURLOPT_READFUNCTION, UploadReadFunc);
-
- //curl_easy_setopt(conn, CURLOPT_WRITEFUNCTION, writefunc);
curl_easy_setopt(conn, CURLOPT_POSTFIELDS, query);
curl_easy_setopt(conn, CURLOPT_POSTFIELDSIZE, strlen(query));
+#if defined(__APPLE__) || defined(__WIN32__)
+
+#else
+
ServerCertFilename = GetAccountDir(ServerAccount, TRUE);
if (wxFile::Exists(ServerCertFilename) == TRUE){
}
+#endif
+
claconncode = (curl_easy_perform(conn));
// If CURLE_PEER_FAILED_VERIFICATION is returned, retry without
// Check if it fails with a CURLE_SSL_CACERT then compare
// the certificates as PEM files.
- if (claconncode == CURLE_SSL_CACERT && wxFile::Exists(ServerCertFilename) == TRUE){
+#if defined(__APPLE__)
- //curl_easy_cleanup(conn);
- //conn = curl_easy_init();
+#else
+
+ if (claconncode == CURLE_SSL_CACERT && wxFile::Exists(ServerCertFilename) == TRUE){
CURL *sslerrconn;
sslerrconn = curl_easy_init();
CURLcode sslerrconncode;
- //claconncode = (curl_easy_perform(conn));
-
wxString ServerAddressOnly = wxT("https://") + ServerAddress + wxT(":") + wxString::Format(wxT("%i"), ServerPort) + wxT("/");
PageData.clear();
curl_easy_cleanup(sslerrconn);
}
+
+#endif
// Sort out SSL error.
sslerrconncode = (curl_easy_perform(sslerrconn));
+#if defined(__APPLE__)
+
+ SetConnectionObject(sslerrconn);
+
+#endif
+
SSLCertCol = BuildSSLCollection(sslerrconn);
SSLCertCol.SuccessCode = 1;
} else if (claconncode == CURLE_HTTP_RETURNED_ERROR){
- fprintf(stderr, "curl_easy_perform() failed: %s\n",
+ fprintf(stderr, "GetServerETagValueThread(): curl_easy_perform() failed: %s\n",
curl_easy_strerror(claconncode));
int http_code = 0;
curl_easy_getinfo(conn, CURLINFO_RESPONSE_CODE, &http_code);
} else {
- fprintf(stderr, "curl_easy_perform() failed: %s\n",
+ fprintf(stderr, "GetServerETagValueThread(): curl_easy_perform() failed: %s\n",
curl_easy_strerror(claconncode));
int http_code = 0;
curl_easy_getinfo(conn, CURLINFO_RESPONSE_CODE, &http_code);
curl_easy_setopt(conn, CURLOPT_PROGRESSFUNCTION, ProgressFunc);
curl_easy_setopt(conn, CURLOPT_CUSTOMREQUEST, "REPORT");
curl_easy_setopt(conn, CURLOPT_NOSIGNAL, 1);
-
- //UploadData.readptr = &CardDAVDataQuery;
- //UploadData.sizeleft = CardDAVDataQuery.Len();
- //curl_easy_setopt(conn, CURLOPT_UPLOAD, 1);
- //curl_easy_setopt(conn, CURLOPT_READDATA, &UploadData);
- //curl_easy_setopt(conn, CURLOPT_READFUNCTION, UploadReadFunc);
-
- //curl_easy_setopt(conn, CURLOPT_WRITEFUNCTION, writefunc);
curl_easy_setopt(conn, CURLOPT_POSTFIELDS, query);
curl_easy_setopt(conn, CURLOPT_POSTFIELDSIZE, strlen(query));
void CardDAV::GetServerETagValue(){
+ // Get the server etag value.
+
std::thread ConnectThread(&CardDAV::GetServerETagValueThread, this);
ConnectThread.detach();