// 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/>
+#ifndef __CONNOBJECT_CONNECTIONOBJECT_H__
+#define __CONNOBJECT_CONNECTIONOBJECT_H__
+
#include <string>
#include <vector>
+#include <iostream>
enum COConnectResult {
COCONNECT_UNITTESTFAIL = -1,
COCONNECT_OK,
+ COCONNECT_SSLFAIL,
COCONNECT_INVALID,
COCONNECT_TIMEOUT,
COCONNECT_AUTHFAIL
COREQUEST_ERROR_SERVER
};
+enum COSSLVerified {
+ COSSL_UNITTESTFAIL = -1,
+ COSSL_VERIFIED,
+ COSSL_VERIFIED_USER,
+ COSSL_UNABLETOVERIFY,
+ COSSL_NOTAPPLICABLE,
+ COSSL_NORESULT
+};
+
struct COServerResponse {
CORequestResult RequestResult;
std::string EntityTag;
// Virtual functions to be setup by the inheriting classes.
- virtual void SetupConnectionObject() {};
- virtual ~ConnectionObject() {};
+ virtual void SetupConnectionObject() { };
+ //virtual ~ConnectionObject() {};
- virtual COConnectResult Connect() {};
+ virtual bool IsTaskCompleted() {};
+
+ virtual COConnectResult Connect(bool DoAuthentication) {};
virtual std::string GetDefaultPrefix() {};
virtual COServerResponse AddContact(std::string Location, std::string Data) {};
virtual bool CanDoProcessing() {};
virtual bool CanDoSSL() {};
- virtual bool SSLVerify() {};
+ virtual COSSLVerified SSLVerify() {};
virtual bool AbleToLogin() {};
virtual bool HasValidResponse() {};
+ virtual bool IsSelfSigned() {};
+ virtual std::string GetErrorMessage() {};
protected:
// Test Mode.
std::string ServerAccount = "";
bool ServerSSL = true;
std::string ErrorMessage = "";
- std::string ErrorBufferMessage = "";
// Connect results.
bool SSLStatus = false;
- bool SSLVerified = false;
+ COSSLVerified SSLVerified = COSSL_NORESULT;
bool ValidResponse = false;
bool AuthPassed = false;
bool CanProcess = false;
bool SSLSelfSigned = false;
+ bool TaskCompleted = false;
private:
-};
\ No newline at end of file
+};
+
+#endif
\ No newline at end of file