1 // frmNewAccount.cpp - New Account form (CardDAV2 account section).
3 // (c) 2012-2015 Xestia Software Development.
5 // This file is part of Xestia Address Book.
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 Address Book. If not, see <http://www.gnu.org/licenses/>
19 #include "frmNewAccount.h"
22 void frmNewAccount::RunCardDAV2Test( wxCommandEvent& event ){
24 NewAccountResult *ResultData = new NewAccountResult;
26 lblServerConnResult->SetLabel(_("Testing..."));
27 lblCardDAVSupportResult->SetLabel(_(""));
28 lblServerResponse->SetLabel(_(""));
29 lblServerSSLResult->SetLabel(_(""));
30 lblServerSSLValid->SetLabel(_(""));
31 lblAbleToLoginResult->SetLabel(_(""));
32 bool UsingSSLBypass = false;
34 // Setup a CardDAV2 connection object for testing.
36 CardDAV2 TestConnection(txtServerAddress->GetValue().ToStdString(),
37 wxAtoi(txtServerPort->GetValue()),
38 txtUsername->GetValue().ToStdString(),
39 txtPassword->GetValue().ToStdString(),
40 chkUseSSL->GetValue());
42 // Test the connection.
44 TestConnection.SetupConnectionObject();
45 COConnectResult TestConnectionResult = TestConnection.Connect(false);
47 // If server is using SSL, verify that the SSL connection is valid.
49 if (TestConnection.SSLVerify() == COSSL_UNABLETOVERIFY){
50 #if defined(__APPLE__)
51 #elif defined(__WIN32__)
54 // Connect again and fetch SSL certificate information.
56 TestConnection.BypassSSLVerification(true);
58 COConnectResult TestConnectionResult = TestConnection.Connect(false);
60 TestConnection.BypassSSLVerification(false);
62 SSLCertCollectionString CertData = TestConnection.BuildSSLCollection();
63 frmInvalidSSLCertificate *frmICPtr = new frmInvalidSSLCertificate(this);
65 frmICPtr->LoadDataNew(CertData, txtServerAddress->GetValue().ToStdString());
66 frmICPtr->ShowModal();
68 int SSLResult = frmICPtr->GetResult();
70 // Clean up before processing response.
75 // Process the response from the user.
79 // Accept the Certificate.
81 UsingSSLBypass = true;
82 TestConnection.BypassSSLVerification(true);
84 COConnectResult TestConnectionResult = TestConnection.Connect(true);
86 TestConnection.BypassSSLVerification(false);
88 } else if (SSLResult == 2){
90 // Reject the certificate, abort the task and mark as failed.
92 // TODO: Integrate into the code.
94 //lblConnectionResultText->SetLabel(_("An error occured whilst connnecting: ") + CardDAVConn.GetErrorMessage() + wxString::Format(wxT(" (%i)\n%s"), sslcode, CardDAVConn.GetErrorBuffer().mb_str()));
101 // Get the server prefix if the connection was successful.
103 if (TestConnectionResult == COCONNECT_OK){
105 if (UsingSSLBypass == true){
106 TestConnection.BypassSSLVerification(true);
109 std::string ReceivedServerPrefix;
110 COServerResponse PrefixRequestResult = TestConnection.GetDefaultPrefix(&ReceivedServerPrefix);
111 ServerPrefix = ReceivedServerPrefix;
113 if (UsingSSLBypass == true){
114 TestConnection.BypassSSLVerification(true);
119 TestConnectionResult == COCONNECT_OK ? ResultData->Connected = true : ResultData->Connected = false;
121 ResultData->SSLStatus = TestConnection.CanDoSSL();
122 ResultData->SSLVerified = TestConnection.SSLVerify();
123 ResultData->ValidResponse = TestConnection.HasValidResponse();
124 ResultData->AuthPassed = TestConnection.AbleToLogin();
125 ResultData->CanProcess = TestConnection.CanDoProcessing();
126 ResultData->ErrorMessage = TestConnection.GetErrorMessage();
128 // Post event back confirming the tests.
130 wxCommandEvent ResultsEvent(UPDATERESULTS);
131 ResultsEvent.SetClientData(ResultData);
132 wxPostEvent(this, ResultsEvent);