summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'Swiften')
-rw-r--r--Swiften/TLS/SecurityError.cpp31
-rw-r--r--Swiften/TLS/SecurityError.h42
2 files changed, 73 insertions, 0 deletions
diff --git a/Swiften/TLS/SecurityError.cpp b/Swiften/TLS/SecurityError.cpp
new file mode 100644
index 0000000..03aadf0
--- /dev/null
+++ b/Swiften/TLS/SecurityError.cpp
@@ -0,0 +1,31 @@
+/*
+ * Copyright (c) 2010 Remko Tronçon
+ * Licensed under the GNU General Public License v3.
+ * See Documentation/Licenses/GPLv3.txt for more information.
+ */
+
+#include "Swiften/TLS/SecurityError.h"
+#include "Swiften/TLS/CertificateVerificationError.h"
+
+namespace Swift {
+
+SecurityError::SecurityError(Type type) : type(type) {
+}
+
+SecurityError::SecurityError(const CertificateVerificationError& verificationError) {
+ type = UnknownError;
+ switch(verificationError.getType()) {
+ case CertificateVerificationError::UnknownError: type = UnknownError;
+ case CertificateVerificationError::Expired: type = Expired;
+ case CertificateVerificationError::NotYetValid: type = NotYetValid;
+ case CertificateVerificationError::SelfSigned: type = SelfSigned;
+ case CertificateVerificationError::Rejected: type = Rejected;
+ case CertificateVerificationError::Untrusted: type = Untrusted;
+ case CertificateVerificationError::InvalidPurpose: type = InvalidPurpose;
+ case CertificateVerificationError::PathLengthExceeded: type = PathLengthExceeded;
+ case CertificateVerificationError::InvalidSignature: type = InvalidSignature;
+ case CertificateVerificationError::InvalidCA: type = InvalidCA;
+ }
+}
+
+}
diff --git a/Swiften/TLS/SecurityError.h b/Swiften/TLS/SecurityError.h
new file mode 100644
index 0000000..55ac7d5
--- /dev/null
+++ b/Swiften/TLS/SecurityError.h
@@ -0,0 +1,42 @@
+/*
+ * Copyright (c) 2010 Remko Tronçon
+ * Licensed under the GNU General Public License v3.
+ * See Documentation/Licenses/GPLv3.txt for more information.
+ */
+
+#pragma once
+
+namespace Swift {
+ class CertificateVerificationError;
+
+ class SecurityError {
+ public:
+ enum Type {
+ // From CertificateVerificationError
+ UnknownError,
+ Expired,
+ NotYetValid,
+ SelfSigned,
+ Rejected,
+ Untrusted,
+ InvalidPurpose,
+ PathLengthExceeded,
+ InvalidSignature,
+ InvalidCA,
+
+ // Identity verification
+ InvalidIdentity,
+ };
+
+ SecurityError(Type type);
+ SecurityError(const CertificateVerificationError& verificationError);
+
+
+ Type getType() const {
+ return type;
+ }
+
+ private:
+ Type type;
+ };
+}