summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'Swiften/Base/LogSerializers.cpp')
-rw-r--r--Swiften/Base/LogSerializers.cpp130
1 files changed, 130 insertions, 0 deletions
diff --git a/Swiften/Base/LogSerializers.cpp b/Swiften/Base/LogSerializers.cpp
new file mode 100644
index 0000000..3f8e9ce
--- /dev/null
+++ b/Swiften/Base/LogSerializers.cpp
@@ -0,0 +1,130 @@
+/*
+ * Copyright (c) 2016-2017 Isode Limited.
+ * All rights reserved.
+ * See the COPYING file for more information.
+ */
+
+#include <Swiften/Base/LogSerializers.h>
+
+#include <Swiften/Elements/Presence.h>
+#include <Swiften/Network/BOSHConnection.h>
+
+namespace Swift {
+
+std::ostream& operator<<(std::ostream& stream, const Presence& presence) {
+ std::string typeString;
+ switch (presence.getType()) {
+ case Presence::Available:
+ typeString = "Available";
+ break;
+ case Presence::Error:
+ typeString = "Error";
+ break;
+ case Presence::Probe:
+ typeString = "Probe";
+ break;
+ case Presence::Subscribe:
+ typeString = "Subscribe";
+ break;
+ case Presence::Subscribed:
+ typeString = "Subscribed";
+ break;
+ case Presence::Unavailable:
+ typeString = "Unavailable";
+ break;
+ case Presence::Unsubscribe:
+ typeString = "Unsubscribe";
+ break;
+ case Presence::Unsubscribed:
+ typeString = "Unsubscribed";
+ break;
+ }
+
+ std::string showTypeString;
+ switch (presence.getShow()) {
+ case StatusShow::Online:
+ showTypeString = "Online";
+ break;
+ case StatusShow::Away:
+ showTypeString = "Away";
+ break;
+ case StatusShow::FFC:
+ showTypeString = "FFC";
+ break;
+ case StatusShow::DND:
+ showTypeString = "DND";
+ break;
+ case StatusShow::XA:
+ showTypeString = "XA";
+ break;
+ case StatusShow::None:
+ showTypeString = "None";
+ break;
+ }
+
+ stream << "Presence(" << "from: " << presence.getFrom() << ", to: " << presence.getTo() << ", type: " << typeString << ", status: " << showTypeString << ", priority: " << presence.getPriority() << ", '" << presence.getStatus() << "'" << " )";
+ return stream;
+}
+
+std::ostream& operator<<(std::ostream& stream, const BOSHError& boshError) {
+ std::string errorString;
+ switch (boshError.getType()) {
+ case BOSHError::BadRequest:
+ errorString = "BadRequest";
+ break;
+ case BOSHError::HostGone:
+ errorString = "HostGone";
+ break;
+ case BOSHError::HostUnknown:
+ errorString = "HostUnknown";
+ break;
+ case BOSHError::ImproperAddressing:
+ errorString = "ImproperAddressing";
+ break;
+ case BOSHError::InternalServerError:
+ errorString = "InternalServerError";
+ break;
+ case BOSHError::ItemNotFound:
+ errorString = "ItemNotFound";
+ break;
+ case BOSHError::OtherRequest:
+ errorString = "OtherRequest";
+ break;
+ case BOSHError::PolicyViolation:
+ errorString = "PolicyViolation";
+ break;
+ case BOSHError::RemoteConnectionFailed:
+ errorString = "RemoteConnectionFailed";
+ break;
+ case BOSHError::RemoteStreamError:
+ errorString = "RemoteStreamError";
+ break;
+ case BOSHError::SeeOtherURI:
+ errorString = "SeeOtherURI";
+ break;
+ case BOSHError::SystemShutdown:
+ errorString = "SystemShutdown";
+ break;
+ case BOSHError::UndefinedCondition:
+ errorString = "UndefinedCondition";
+ break;
+ case BOSHError::NoError:
+ errorString = "NoError";
+ break;
+ }
+
+ stream << "BOSHError( " << errorString << " )";
+ return stream;
+}
+
+};
+
+::std::ostream& operator<<(::std::ostream& os, const boost::optional<std::string>& optStr) {
+ if (optStr.is_initialized()) {
+ return os << "boost::optional<std::string>(\"" << optStr.get() << "\")";
+ }
+ else {
+ return os << "boost::optional<std::string>()";
+ }
+}
+