Home | News | Projects | Releases
Bugs | RFE | Repositories | Help
Label servers that can cause data loss as dangerous
[xestiaab/.git] / source / frmNewAccount.cpp
index 1681134..9d0873e 100644 (file)
+// frmNewAccount.cpp - New Account form.
+//
+// (c) 2012-2015 Xestia Software Development.
+//
+// This file is part of Xestia Address Book.
+//
+// Xestia Address Book is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by the
+// Free Software Foundation, version 3 of the license.
+//
+// Xestia Address Book is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with Xestia Address Book. If not, see <http://www.gnu.org/licenses/>
+
 #include "frmNewAccount.h"
 #include <thread>
 #include <cstdlib>
 #include <wx/filefn.h>
 #include <wx/fileconf.h>
 
-#include "carddav/carddav.h"
+#if defined(__WIN32__)
+#include <cryptuiapi.h>
+#include "common/win32ssl.h"
+#endif
+
 #include "common/dirs.h"
+#include "common/svrdlist.h"
+#include "frmInvalidSSLCertificate.h"
+
+DEFINE_EVENT_TYPE(UPDATERESULTS);
+DEFINE_EVENT_TYPE(RUNCARDDAV2TEST);
+
+BEGIN_EVENT_TABLE(frmNewAccount, wxDialog)
+EVT_COMMAND(wxID_ANY, UPDATERESULTS, frmNewAccount::UpdateResults)
+EVT_COMMAND(wxID_ANY, RUNCARDDAV2TEST, frmNewAccount::RunCardDAV2Test)
+END_EVENT_TABLE()
 
 frmNewAccount::frmNewAccount( wxWindow* parent )
 :
 frmNewAccountADT( parent )
 {
-    btnPrevious->Disable();
+
+       // Disable the previous button upon form creation.
+
+       btnPrevious->Disable();
+       
 }
 
 void frmNewAccount::CheckAccountName( wxCommandEvent& event )
 {
     
-    wxString CheckAccName = txtAccountName->GetValue();
+       // Check that the account name is valid.
+    
+       wxString CheckAccName = txtAccountName->GetValue();
     
-    if ((txtAccountName->IsEmpty() && PageSeek == 2) || CheckAccName.Len() < 4){
+       if ((txtAccountName->IsEmpty() && PageSeek == 2) || CheckAccName.Len() < 4){
         
-        btnNext->Disable();
+               btnNext->Disable();
         
-    } else {
+       } else {
         
-        btnNext->Enable();
+               btnNext->Enable();
         
-    }
+       }
     
 }
 
 void frmNewAccount::ProcessPrevious( wxCommandEvent& event )
 {
-    PageSeek--;
+
+       // Go to the previous page.
+
+       PageSeek--;
     
-    if (PageSeek == 0){
+       if (PageSeek == 0){
         
-        // Currently at the Connection test screen.
+               // Currently at the Connection test screen.
         
-        //tbkAccount->ChangeSelection(0);
-        tabConn->Hide();
-        tabFinish->Hide();
-        tabType->Show();
-        szrNewAccount->RecalcSizes();
+               tabConn->Hide();
+               tabFinish->Hide();
+               tabType->Show();
+               szrNewAccount->RecalcSizes();
         
-        btnPrevious->Disable();
-        btnNext->Enable();
+               btnPrevious->Disable();
+               btnNext->Enable();
         
-    } else if (PageSeek == 1){
+       } else if (PageSeek == 1){
         
-        if (cmbServerType->GetCurrentSelection() == 0){
+               if (cmbServerType->GetCurrentSelection() == 0){
             
-            tabConn->Hide();
-            tabFinish->Hide();
-            tabType->Show();
-            PageSeek = 0;
-            btnPrevious->Disable();
-            btnNext->Enable();
-            btnNext->SetLabel(_("Next >"));
-            return;
+                       tabConn->Hide();
+                       tabFinish->Hide();
+                       tabType->Show();
+                       PageSeek = 0;
+                       btnPrevious->Disable();
+                       btnNext->Enable();
+                       btnNext->SetLabel(_("Next >"));
+                       return;
             
-        }
-        
-        // Currently at the Finish screen.
+               }
+               
+               // Currently at the Finish screen.
         
-        tabType->Hide();
-        tabConn->Show();
-        tabFinish->Hide();
-        szrNewAccount->RecalcSizes();
+               tabType->Hide();
+               tabConn->Show();
+               tabFinish->Hide();
+               szrNewAccount->RecalcSizes();
         
-        btnNext->SetLabel(_("Next >"));
-        btnNext->Enable();
+               btnNext->SetLabel(_("Next >"));
+               btnNext->Enable();
         
-    }
+       }
     
 }
 
 void frmNewAccount::ProcessNext( wxCommandEvent& event )
 {
-    PageSeek++;
+
+       // Go to the next page or setup the new account.
+
+       PageSeek++;
     
-    if (PageSeek == 1){
-        
-        if (cmbServerType->GetCurrentSelection() == 0){
-            
-            tabType->Hide();
-            tabConn->Hide();
-            tabFinish->Show();
-            PageSeek = 2;
-            btnPrevious->Enable();
-            szrNewAccount->RecalcSizes();
-            btnNext->Disable();
-            btnNext->SetLabel(_("Finish"));
-            return;
-            
-        }
-        
-        btnNext->Disable();
-        
-        bool ServerResult = FALSE;
-        bool ServerAction = FALSE;
-        bool UseSSL = TRUE;
-        wxString ServerMessage;
-        
-        // Connection test screen.
-        
-        tabType->Hide();
-        tabConn->Show();
-        tabFinish->Hide();
-        szrNewAccount->RecalcSizes();
-        btnPrevious->Enable();
-        
-        // Reset screen.
-        
-        lblServerConnResult->SetLabel(wxT(""));
-        lblServerResponse->SetLabel(wxT(""));
-        lblServerSSLResult->SetLabel(wxT(""));
-        lblServerSSLValid->SetLabel(wxT(""));
-        lblAbleToLoginResult->SetLabel(wxT(""));
-        lblCardDAVSupportResult->SetLabel(wxT(""));
-        
-        // Spawn a thread and check if server supports CardDAV.
-        
-        CardDAV CardDAVConn;
-        
-        lblServerConnResult->SetLabel(_("Testing..."));
-        
-        UseSSL = chkUseSSL->GetValue();
-        
-        CardDAVConn.SetupConnection(txtServerAddress->GetValue(),
-                                    wxAtoi(txtServerPort->GetValue()),
-                                    txtUsername->GetValue(),
-                                    txtPassword->GetValue(),
-                                    UseSSL);
-        CardDAVConn.SetupResultBools(&ServerResult, &ServerAction);
-        
-        std::thread ConnTest(&CardDAV::Connect, &CardDAVConn);
-        
-        ConnTest.join();
-        
-        if (ServerResult == FALSE){
-            
-            lblServerConnResult->SetLabel(_("Failed"));
-            wxMessageBox(CardDAVConn.GetErrorMessage());
-            return;
-            
-        } else {
-            
-            lblServerConnResult->SetLabel(_("Connected"));
-            
-        }
-        
-        if (CardDAVConn.HasValidResponse() == TRUE){
-            
-            lblServerResponse->SetLabel(_("Yes"));
-            
-        } else {
-            
-            lblServerResponse->SetLabel(_("No"));
-            
-        }
-        
-        if (CardDAVConn.CanDoSSL() == TRUE){
-            
-            lblCardDAVSupportResult->SetLabel(_("Used"));
-            
-        } else {
-            
-            lblServerSSLResult->SetLabel(_("Not Used"));
-            lblServerSSLValid->SetLabel(_("Not Applicable"));
-            
-        }
-        
-        if (CardDAVConn.SSLVerify() == TRUE && CardDAVConn.CanDoSSL() == TRUE){
-            
-            lblCardDAVSupportResult->SetLabel(_("Verified"));
-            
-        } else if (CardDAVConn.SSLVerify() == FALSE && CardDAVConn.CanDoSSL() == TRUE) {
-            
-            lblServerSSLResult->SetLabel(_("Unable to verify"));
-            
-        }
-        
-        if (CardDAVConn.CanDoCardDAV() == TRUE){
-            
-            lblCardDAVSupportResult->SetLabel(_("Supported"));
-            
-        } else {
-            
-            lblCardDAVSupportResult->SetLabel(_("Unsupported"));
-            
-        }
-        
-        if (CardDAVConn.AbleToLogin() == TRUE){
-            
-            lblAbleToLoginResult->SetLabel(_("Yes"));
-            
-        } else {
-            
-            lblAbleToLoginResult->SetLabel(_("No"));
-            
-        }
-        
-        // Get the address to process CardDAV requests.
-        
-        ServerPrefix = CardDAVConn.GetDefaultAddressBookURL();
-        
-        wxMessageBox(ServerPrefix);
-        
-        if (ServerResult == TRUE && CardDAVConn.HasValidResponse() == TRUE &&
-            //CardDAVConn.CanDoSSL() == TRUE && CardDAVConn.SSLVerify() == TRUE &&
-            CardDAVConn.CanDoCardDAV() == TRUE && CardDAVConn.AbleToLogin() == TRUE){
-            
-            btnNext->Enable();
-            
-            lblConnectionResultText->SetLabel(_("Click on Next to set the account name."));
-            
-        } else {
-            
-            lblConnectionResultText->SetLabel(_("A problem has occured whilst connecting to the CardDAV server.\nPlease review the above information and change the server details if needed.\nIf there are still problems, please speak to your system administrator(s)."));
-            
-        }
-        
-    } else if (PageSeek == 2){
-        
-        // Finish screen.
-        
-        tabType->Hide();
-        tabConn->Hide();
-        tabFinish->Show();
-        szrNewAccount->RecalcSizes();
-        
-        btnNext->Disable();
-        btnNext->SetLabel(_("Finish"));
-        if (txtAccountName->IsEmpty() && PageSeek == 2){
-            btnNext->Disable();
-        } else {
-            btnNext->Enable();
-        }
-        
-    } else if (PageSeek == 3){
-        
-        // Finished.
-        
-        wxString XestiaABPrefDirectory;
-        wxString AccountSettingsFile;
-        //wxFile ASFile;
-        wxString RandomNumberSuffix = wxString::Format(wxT("%i"), rand() % 32767);
-        bool DirectoryCreated = FALSE;
+       if (PageSeek == 1){
+        
+               if (cmbServerType->GetCurrentSelection() == 0){
+            
+                       tabType->Hide();
+                       tabConn->Hide();
+                       tabFinish->Show();
+                       PageSeek = 2;
+                       btnPrevious->Enable();
+                       szrNewAccount->RecalcSizes();
+                       btnNext->Disable();
+                       btnNext->SetLabel(_("Finish"));
+                       return;
+            
+               }
+        
+               // Check if server address matches against the dangerous list.
+               // Bring up warning message if it does.
+               
+               if (CheckDangerousList(txtServerAddress->GetValue())){
+               
+                       int MessageBoxResult = wxMessageBox(_("The server with the address given does not support the CardDAV protocol properly and shouldn't be used.\n\nData loss is very likely.\n\nDo you still want to continue using this server?"), _("Server warning"), wxYES_NO, this);
+               
+                       if (MessageBoxResult == wxNO){
+                               PageSeek--;
+                               return;
+                       }
+                       
+               }
+               
+               btnNext->Disable();
+        
+               bool ServerResult = FALSE;
+               bool ServerAction = FALSE;
+               bool UseSSL = TRUE;
+               wxString ServerMessage;
+        
+               // Connection test screen.
+        
+               tabType->Hide();
+               tabConn->Show();
+               tabFinish->Hide();
+               szrNewAccount->RecalcSizes();
+               btnPrevious->Disable();
+        
+               // Reset screen.
+        
+               lblServerConnResult->SetLabel(wxT(""));
+               lblServerResponse->SetLabel(wxT(""));
+               lblServerSSLResult->SetLabel(wxT(""));
+               lblServerSSLValid->SetLabel(wxT(""));
+               lblAbleToLoginResult->SetLabel(wxT(""));
+               lblCardDAVSupportResult->SetLabel(wxT(""));
+       
+               // Depending on account type, run the test.
+        
+               if (cmbServerType->GetCurrentSelection() == 1){
+                       wxCommandEvent RunTest(RUNCARDDAV2TEST);
+                       wxPostEvent(this, RunTest);
+               }
+        
+       } else if (PageSeek == 2){
+        
+               // Finish screen.
+        
+               tabType->Hide();
+               tabConn->Hide();
+               tabFinish->Show();
+               szrNewAccount->RecalcSizes();
+        
+               btnNext->Disable();
+               btnNext->SetLabel(_("Finish"));
+       
+               if (txtAccountName->IsEmpty() && PageSeek == 2){
+       
+                       btnNext->Disable();
+           
+               } else {
+       
+                       btnNext->Enable();
+           
+               }
+        
+       } else if (PageSeek == 3){
+        
+               // Finished.
+        
+               wxString XestiaABPrefDirectory;
+               wxString XestiaABDirectory;
+               wxString AccountSettingsFile;
+               //wxFile ASFile;
+               
+               srand(time(0));
+               int RandomNumber = rand() % 32767;
+               wxString RandomNumberSuffix = wxString::Format(wxT("%i"), RandomNumber);
+               bool DirectoryCreated = FALSE;
         
 #if defined(__HAIKU__)
         
-        //preffilename = wxT("noo");
+               //preffilename = wxT("noo");
         
 #elif defined(__WIN32__)
         
-        XestiaABPrefDirectory = GetUserDir();
+               XestiaABPrefDirectory = GetUserPrefDir();
+               XestiaABDirectory = GetUserDir();
+       
+               AccountSettingsFile = XestiaABPrefDirectory + wxT("accounts");
         
-        AccountSettingsFile = XestiaABPrefDirectory + wxT("accounts");
+               // Open the file for writing.
         
-        // Open the file for writing.
+               wxFileConfig *cfgfile = new wxFileConfig("", "", AccountSettingsFile);
         
-        wxFileConfig *cfgfile = new wxFileConfig("", "", AccountSettingsFile);
+               // Check if account name already exists and return an error message
+               // if this is the case.
         
-        // Check if account name already exists and return an error message
-        // if this is the case.
+               wxString AccountName;
+               long itemindex = 0;
+               bool ContinueAcc;
+               ContinueAcc = cfgfile->GetFirstGroup(AccountName, itemindex);
         
-        wxString AccountName;
-        long itemindex = 0;
-        bool ContinueAcc;
-        ContinueAcc = cfgfile->GetFirstGroup(AccountName, itemindex);
-        
-        while (ContinueAcc){
+               while (ContinueAcc){
             
-            if (txtAccountName->GetValue() == AccountName){
+                       if (txtAccountName->GetValue() == AccountName){
                 
-                wxMessageBox(_("The selected account name is already used, please use another account name."), _("Account name already used"), wxICON_ERROR);
-                return;
+                               wxMessageBox(_("The selected account name is already used, please use another account name."), _("Account name already used"), wxICON_ERROR);
+                               return;
                 
-            }
+                       }
             
-            cfgfile->SetPath(wxT("/"));
-            ContinueAcc = cfgfile->GetNextGroup(AccountName, itemindex);
+                       cfgfile->SetPath(wxT("/"));
+                       ContinueAcc = cfgfile->GetNextGroup(AccountName, itemindex);
             
-        }
+               }
         
-        if (cmbServerType->GetCurrentSelection() == 1){
+               if (cmbServerType->GetCurrentSelection() == 1){
             
-            // Create the account directory.
+                       // Create the account directory.
             
-            wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
+                       wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
             
-            if (wxMkdir(XestiaABPrefDirectory + wxT("/accounts/") + DirectoryName + wxT(".carddav"), 0740) == TRUE){
+                       if (wxMkdir(XestiaABDirectory + wxT("\\accounts\\") + DirectoryName + wxT(".carddav"), 0740) == TRUE){
                 
-                DirectoryCreated = TRUE;
+                               DirectoryCreated = TRUE;
                 
-            }
+                       }
             
-            if (DirectoryCreated == TRUE){
+                       if (DirectoryCreated == TRUE){
                 
-                WriteAccountDetails(cfgfile, wxT("CardDAV"), DirectoryName);
+                               WriteAccountDetails(cfgfile, wxT("CardDAV"), DirectoryName);
                 
-            } else {
+                       } else {
                 
-                wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
-                return;
+                               wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
+                               return;
                 
-            }
+                       }
             
-        } else if (cmbServerType->GetCurrentSelection() == 0){
+               } else if (cmbServerType->GetCurrentSelection() == 0){
             
-            // Create the account directory.
+                       // Create the account directory.
             
-            wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
+                       wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
             
-            if (wxMkdir(XestiaABPrefDirectory + wxT("/accounts/") + DirectoryName + wxT(".local"), 0740) == TRUE){
+                       if (wxMkdir(XestiaABDirectory + wxT("\\accounts\\") + DirectoryName + wxT(".local"), 0740) == TRUE){
                 
-                DirectoryCreated = TRUE;
+                               DirectoryCreated = TRUE;
                 
-            }
+                       }
             
-            if (DirectoryCreated == TRUE){
+                       if (DirectoryCreated == TRUE){
                 
-                WriteAccountDetails(cfgfile, wxT("Local"), DirectoryName);
+                               WriteAccountDetails(cfgfile, wxT("Local"), DirectoryName);
                 
-            } else {
+                       } else {
                 
-                wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
-                return;
+                               wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
+                               return;
                 
-            }
+                       }
             
-        }
+               }
         
-        delete cfgfile;
-        cfgfile = NULL;
+               delete cfgfile;
+               cfgfile = NULL;
         
-        ReloadAccountConfig = TRUE;
+               *ReloadAccountConfig = TRUE;
         
 #else
         
-        XestiaABPrefDirectory = GetUserDir();
+               XestiaABPrefDirectory = GetUserPrefDir();
+               XestiaABDirectory = GetUserDir();
         
-        AccountSettingsFile = GetUserPrefDir() + wxT("accounts");
+               AccountSettingsFile = XestiaABPrefDirectory + wxT("accounts");
         
-        // Open the file for writing.
+               // Open the file for writing.
         
-        wxFileConfig *cfgfile = new wxFileConfig("", "", AccountSettingsFile);
+               wxFileConfig *cfgfile = new wxFileConfig("", "", AccountSettingsFile);
         
-        // Check if account name already exists and return an error message
-        // if this is the case.
+               // Check if account name already exists and return an error message
+               // if this is the case.
         
-        wxString AccountName;
-        long itemindex = 0;
-        bool ContinueAcc;
-        ContinueAcc = cfgfile->GetFirstGroup(AccountName, itemindex);
+               wxString AccountName;
+               long itemindex = 0;
+               bool ContinueAcc;
+               ContinueAcc = cfgfile->GetFirstGroup(AccountName, itemindex);
         
-        while (ContinueAcc){
+               while (ContinueAcc){
             
-            if (txtAccountName->GetValue() == AccountName){
+                       if (txtAccountName->GetValue() == AccountName){
                 
-                wxMessageBox(_("The selected account name is already used, please use another account name."), _("Account name already used"), wxICON_ERROR);
-                return;
+                               wxMessageBox(_("The selected account name is already used, please use another account name."), _("Account name already used"), wxICON_ERROR);
+                               return;
                 
-            }
+                       }
             
-            cfgfile->SetPath(wxT("/"));
-            ContinueAcc = cfgfile->GetNextGroup(AccountName, itemindex);
+                       cfgfile->SetPath(wxT("/"));
+                       ContinueAcc = cfgfile->GetNextGroup(AccountName, itemindex);
             
-        }
+               }
         
-        if (cmbServerType->GetCurrentSelection() == 1){
+               if (cmbServerType->GetCurrentSelection() == 1){
             
-            // Create the account directory.
+                       // Create the account directory.
             
-            wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
+                       wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
             
-            if (wxMkdir(XestiaABPrefDirectory + wxT("/accounts/") + DirectoryName + wxT(".carddav"), 0740) == TRUE){
+                       if (wxMkdir(XestiaABDirectory + wxT("/accounts/") + DirectoryName + wxT(".carddav"), 0740) == TRUE){
                 
-                DirectoryCreated = TRUE;
+                               DirectoryCreated = TRUE;
                 
-            }
+                       }
             
-            if (DirectoryCreated == TRUE){
+                       if (DirectoryCreated == TRUE){
                 
-                WriteAccountDetails(cfgfile, wxT("CardDAV"), DirectoryName);
+                               WriteAccountDetails(cfgfile, wxT("CardDAV"), DirectoryName);
                 
-            } else {
+                       } else {
                 
-                wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
-                return;
+                               wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
+                               return;
                 
-            }
+                       }
             
-        } else if (cmbServerType->GetCurrentSelection() == 0){
+               } else if (cmbServerType->GetCurrentSelection() == 0){
             
-            // Create the account directory.
+                       // Create the account directory.
             
-            wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
+                       wxString DirectoryName = txtAccountName->GetValue().Mid(0, 30) + RandomNumberSuffix;
             
-            if (wxMkdir(XestiaABPrefDirectory + wxT("/accounts/") + DirectoryName + wxT(".local"), 0740) == TRUE){
+                       if (wxMkdir(XestiaABDirectory + wxT("/accounts/") + DirectoryName + wxT(".local"), 0740) == TRUE){
                 
-                DirectoryCreated = TRUE;
+                               DirectoryCreated = TRUE;
                 
-            }
+                       }
             
-            if (DirectoryCreated == TRUE){
+                       if (DirectoryCreated == TRUE){
                 
-                WriteAccountDetails(cfgfile, wxT("Local"), DirectoryName);
+                               WriteAccountDetails(cfgfile, wxT("Local"), DirectoryName);
                 
-            } else {
+                       } else {
                 
-                wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
-                return;
+                               wxMessageBox(_("An error occured whilst creating the account directory."), _("Cannot create account directory"));
+                               return;
                 
-            }
+                       }
             
-        }
+               }
         
-        delete cfgfile;
-        cfgfile = NULL;
+               delete cfgfile;
+               cfgfile = NULL;
         
-        ReloadAccountConfig = TRUE;
+               *ReloadAccountConfig = TRUE;
         
 #endif
         
-        this->Close();
+               this->Close();
         
-    }
+       }
     
 }
 
 void frmNewAccount::WriteAccountDetails(wxFileConfig *cfgfilein, wxString AccountType, wxString DirectoryName){
     
-    cfgfilein->SetPath(txtAccountName->GetValue());
-    cfgfilein->Write(wxT("address"), txtServerAddress->GetValue());
-    cfgfilein->Write(wxT("port"), txtServerPort->GetValue());
-    cfgfilein->Write(wxT("username"), txtUsername->GetValue());
-    cfgfilein->Write(wxT("password"), txtPassword->GetValue());
-    cfgfilein->Write(wxT("prefix"), ServerPrefix);
-    cfgfilein->Write(wxT("accountdir"), DirectoryName);
+       // Write the new account details.
+    
+       cfgfilein->SetPath(txtAccountName->GetValue());
+       cfgfilein->Write(wxT("address"), txtServerAddress->GetValue());
+       cfgfilein->Write(wxT("port"), txtServerPort->GetValue());
+       cfgfilein->Write(wxT("username"), txtUsername->GetValue());
+       cfgfilein->Write(wxT("password"), txtPassword->GetValue());
+       cfgfilein->Write(wxT("prefix"), ServerPrefix);
+       cfgfilein->Write(wxT("accountdir"), DirectoryName);
     
-    if (chkUseSSL->GetValue() == TRUE){
+       if (chkUseSSL->GetValue() == TRUE){
         
-        cfgfilein->Write(wxT("ssl"), wxT("true"));
+               cfgfilein->Write(wxT("ssl"), wxT("true"));
         
-    } else {
+       } else {
         
-        cfgfilein->Write(wxT("ssl"), wxT("false"));
+               cfgfilein->Write(wxT("ssl"), wxT("false"));
         
-    }
+       }
     
-    cfgfilein->Write(wxT("refresh"), wxT("1800"));
-    cfgfilein->Write(wxT("type"), AccountType);
+       cfgfilein->Write(wxT("refresh"), wxT("1800"));
+       cfgfilein->Write(wxT("type"), AccountType);
     
 }
 
 void frmNewAccount::CloseWindow( wxCommandEvent& event )
 {
-    ReloadAccountConfig = FALSE;
-    this->Close();
+
+       // Close the window.
+
+       *ReloadAccountConfig = FALSE;
+       this->Close();
+       
 }
 
 void frmNewAccount::UpdateRequirements( wxCommandEvent& event )
 {
     
-    // Update the options.
+       // Update the options.
     
-    if (cmbServerType->GetCurrentSelection() == 1){
+       if (cmbServerType->GetCurrentSelection() == 1){
         
-        txtServerAddress->Enable();
-        txtServerPort->Enable();
-        txtUsername->Enable();
-        txtPassword->Enable();
-        chkUseSSL->Enable();
+               txtServerAddress->Enable();
+               txtServerPort->Enable();
+               txtUsername->Enable();
+               txtPassword->Enable();
+               chkUseSSL->Enable();
         
-    } else if (cmbServerType->GetCurrentSelection() == 0){
+       } else if (cmbServerType->GetCurrentSelection() == 0){
         
-        txtServerAddress->Disable();
-        txtServerPort->Disable();
-        txtUsername->Disable();
-        txtPassword->Disable();
-        chkUseSSL->Disable();
+               txtServerAddress->Disable();
+               txtServerPort->Disable();
+               txtUsername->Disable();
+               txtPassword->Disable();
+               chkUseSSL->Disable();
         
-    }
+       }
     
 }
 
+void frmNewAccount::UpdateResults( wxCommandEvent& event )
+{
+
+       NewAccountResult *ResultDataPointer = static_cast<NewAccountResult*>(event.GetClientData());
+       NewAccountResult ResultData = (*ResultDataPointer);
+       
+       delete(ResultDataPointer);
+       ResultDataPointer = nullptr;
+       bool ServerResult = true;
+       
+       // Process the result if the server connected.
+
+       if (ResultData.Connected == false){
+               lblServerConnResult->SetLabel(_("Failed"));
+               ServerResult = false;
+       } else {
+               lblServerConnResult->SetLabel(_("Success"));            
+       }
+       
+       // Check the result if the server gave a valid response.
+       
+       if (ResultData.ValidResponse == false){
+               lblServerResponse->SetLabel(_("No"));
+               ServerResult = false;
+       } else {
+               lblServerResponse->SetLabel(_("Yes"));
+       }
+       
+       // Check the result if the server uses SSL.     
+       
+       if (ResultData.SSLStatus == false){
+               lblServerSSLResult->SetLabel(_("No"));
+       } else {
+               lblServerSSLResult->SetLabel(_("Yes"));
+       }
+       
+       // Check the server has a valid SSL certificate.
+       
+       switch(ResultData.SSLVerified){
+               case COSSL_VERIFIED:
+                       lblServerSSLValid->SetLabel(_("Verified"));
+                       break;
+               case COSSL_VERIFIED_USER:
+                       lblServerSSLValid->SetLabel(_("Verified (User)"));
+                       break;
+               case COSSL_UNABLETOVERIFY:
+                       lblServerSSLValid->SetLabel(_("Unable to verify"));
+                       ServerResult = false;
+                       break;
+               case COSSL_NOTAPPLICABLE:
+                       lblServerSSLValid->SetLabel(_("Not applicable"));
+                       break;
+       }
+       
+       // Check if able to log into the server.
+       
+       if (ResultData.AuthPassed == false){
+               lblAbleToLoginResult->SetLabel(_("No"));
+               ServerResult = false;
+       } else {
+               lblAbleToLoginResult->SetLabel(_("Yes"));               
+       }
+       
+       // Check if server has CardDAV support.
+       
+       if (ResultData.CanProcess == false){
+               lblCardDAVSupportResult->SetLabel(_("No"));
+               ServerResult = false;
+       } else {
+               lblCardDAVSupportResult->SetLabel(_("Yes"));
+       }
+       
+       if (ServerResult == false){
+               lblConnectionResultText->SetLabel(wxString::Format(_("An error occured whilst connecting: %s"), ResultData.ErrorMessage));
+       } else {
+               btnNext->Enable();
+               lblConnectionResultText->SetLabel(_("Click on Next to set the account name."));
+       }
+       
+       btnPrevious->Enable();
+       
+}
+
 void frmNewAccount::SetupPointers(bool *ReloadAccountInc){
+
+       // Setup the pointers for the new account window.
+   
+       ReloadAccountConfig = ReloadAccountInc;
     
-    ReloadAccountConfig = ReloadAccountInc;
-    
+}
+
+void frmNewAccount::SetErrorMessageLabel(){
+       
+       lblConnectionResultText->SetLabel(_("A problem has occured whilst connecting to the CardDAV server.\nPlease review the above information and change the server details if needed.\nIf there are still problems, please speak to your system administrator(s)."));
+       
 }
\ No newline at end of file
Xestia Software Development
Yn Maystri
© 2006 - 2019 Xestia Software Development
Software

Xestia Address Book
Xestia Calendar
Development

Xestia Gelforn
Everything else

About
News
Privacy Policy