+
+ // Check if server address matches against the blacklist.
+ // Bring up warning message if it does.
+
+ if (CheckBlacklist(txtAddress->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){
+ return;
+ }
+
+ }
+
+ // Update the settings for the account.
+
+ long itemIndex = 0;
+ bool continueAcc = TRUE;
+ wxString accountName;
+
+ // Look for the account
+
+ while (continueAcc){
+
+ if (accountName == accName){
+
+ // Update the settings for the account.
+
+ cfgFile->RenameGroup(accountName, txtAccountName->GetValue());
+
+ cfgFile->SetPath(txtAccountName->GetValue());
+ //txtAccountName->SetValue(AccountName);
+
+ cfgFile->DeleteEntry(wxT("address"), FALSE);
+ cfgFile->Write(wxT("address"), txtAddress->GetValue());
+
+ cfgFile->DeleteEntry(wxT("port"), FALSE);
+ cfgFile->Write(wxT("port"), txtPort->GetValue());
+
+ cfgFile->DeleteEntry(wxT("username"), FALSE);
+ cfgFile->Write(wxT("username"), txtUsername->GetValue());
+
+ cfgFile->DeleteEntry(wxT("password"), FALSE);
+ cfgFile->Write(wxT("password"), txtPassword->GetValue());
+
+ cfgFile->DeleteEntry(wxT("prefix"), FALSE);
+ cfgFile->Write(wxT("prefix"), txtPrefix->GetValue());
+
+ cfgFile->DeleteEntry(wxT("ssl"), FALSE);
+
+ if (chkSSL->GetValue() == TRUE){
+
+ cfgFile->Write(wxT("ssl"), wxT("true"));
+
+ } else {
+
+ cfgFile->Write(wxT("ssl"), wxT("false"));
+
+ }
+
+ cfgFile->DeleteEntry(wxT("refresh"), FALSE);
+ cfgFile->Write(wxT("refresh"), txtRefresh->GetValue());
+
+ break;
+
+ }
+
+ cfgFile->SetPath(wxT("/"));
+ continueAcc = cfgFile->GetNextGroup(accountName, itemIndex);
+
+ }
+
+ // Set the dialog result to true and close the window.
+
+ dialogResult = true;
+ this->Close();
+
+}
+
+void frmEditAccount::LoadSettings( wxString accNameIn ){
+
+ // Get the data from the accounts settings file and
+ // fill in the account fields.
+
+ accName = accNameIn;
+ long itemIndex = 0;
+ bool continueAcc = TRUE;
+ wxString accountName;
+ wxString accountData;
+
+ continueAcc = cfgFile->GetFirstGroup(accountName, itemIndex);
+
+ while (continueAcc){
+
+ if (accountName == accName){
+
+ cfgFile->SetPath(accountName);
+ txtAccountName->SetValue(accountName);
+
+ cfgFile->Read("address", &accountData);
+ txtAddress->SetValue(accountData);
+
+ cfgFile->Read("port", &accountData);
+ txtPort->SetValue(accountData);
+
+ cfgFile->Read("username", &accountData);
+ txtUsername->SetValue(accountData);
+
+ cfgFile->Read("password", &accountData);
+ txtPassword->SetValue(accountData);
+
+ cfgFile->Read("prefix", &accountData);
+ txtPrefix->SetValue(accountData);
+
+ cfgFile->Read("ssl", &accountData);
+ if (accountData == wxT("true")){
+
+ chkSSL->SetValue(TRUE);
+
+ }
+
+ cfgFile->Read("refresh", &accountData);
+ txtRefresh->SetValue(accountData);
+
+ break;
+
+ }
+
+ cfgFile->SetPath(wxT("/"));
+ continueAcc = cfgFile->GetNextGroup(accountName, itemIndex);
+
+ }
+