/* * Copyright (c) 2015 Isode Limited. * All rights reserved. * See the COPYING file for more information. */ #include <Swiften/Base/Debug.h> #include <iostream> #include <boost/shared_ptr.hpp> #include <Swiften/Client/ClientError.h> #include <Swiften/Serializer/PayloadSerializer.h> #include <Swiften/Serializer/PayloadSerializers/FullPayloadSerializerCollection.h> #include <Swiften/Serializer/XMPPSerializer.h> std::ostream& operator<<(std::ostream& os, const Swift::ClientError& error) { os << "ClientError("; switch(error.getType()) { case Swift::ClientError::UnknownError: os << "UnknownError"; break; case Swift::ClientError::DomainNameResolveError: os << "DomainNameResolveError"; break; case Swift::ClientError::ConnectionError: os << "ConnectionError"; break; case Swift::ClientError::ConnectionReadError: os << "ConnectionReadError"; break; case Swift::ClientError::ConnectionWriteError: os << "ConnectionWriteError"; break; case Swift::ClientError::XMLError: os << "XMLError"; break; case Swift::ClientError::AuthenticationFailedError: os << "AuthenticationFailedError"; break; case Swift::ClientError::CompressionFailedError: os << "CompressionFailedError"; break; case Swift::ClientError::ServerVerificationFailedError: os << "ServerVerificationFailedError"; break; case Swift::ClientError::NoSupportedAuthMechanismsError: os << "NoSupportedAuthMechanismsError"; break; case Swift::ClientError::UnexpectedElementError: os << "UnexpectedElementError"; break; case Swift::ClientError::ResourceBindError: os << "ResourceBindError"; break; case Swift::ClientError::SessionStartError: os << "SessionStartError"; break; case Swift::ClientError::StreamError: os << "StreamError"; break; case Swift::ClientError::TLSError: os << "TLSError"; break; case Swift::ClientError::ClientCertificateLoadError: os << "ClientCertificateLoadError"; break; case Swift::ClientError::ClientCertificateError: os << "ClientCertificateError"; break; case Swift::ClientError::CertificateCardRemoved: os << "CertificateCardRemoved"; break; case Swift::ClientError::UnknownCertificateError: os << "UnknownCertificateError"; break; case Swift::ClientError::CertificateExpiredError: os << "CertificateExpiredError"; break; case Swift::ClientError::CertificateNotYetValidError: os << "CertificateNotYetValidError"; break; case Swift::ClientError::CertificateSelfSignedError: os << "CertificateSelfSignedError"; break; case Swift::ClientError::CertificateRejectedError: os << "CertificateRejectedError"; break; case Swift::ClientError::CertificateUntrustedError: os << "CertificateUntrustedError"; break; case Swift::ClientError::InvalidCertificatePurposeError: os << "InvalidCertificatePurposeError"; break; case Swift::ClientError::CertificatePathLengthExceededError: os << "CertificatePathLengthExceededError"; break; case Swift::ClientError::InvalidCertificateSignatureError: os << "InvalidCertificateSignatureError"; break; case Swift::ClientError::InvalidCAError: os << "InvalidCAError"; break; case Swift::ClientError::InvalidServerIdentityError: os << "InvalidServerIdentityError"; break; case Swift::ClientError::RevokedError: os << "RevokedError"; break; case Swift::ClientError::RevocationCheckFailedError: os << "RevocationCheckFailedError"; break; } os << ")"; return os; } std::ostream& operator<<(std::ostream& os, Swift::Element* ele) { using namespace Swift; boost::shared_ptr<Element> element = boost::shared_ptr<Element>(ele); boost::shared_ptr<Payload> payload = boost::dynamic_pointer_cast<Payload>(element); if (payload) { FullPayloadSerializerCollection payloadSerializerCollection; PayloadSerializer *serializer = payloadSerializerCollection.getPayloadSerializer(payload); os << "Payload(" << serializer->serialize(payload) << ")"; return os; } boost::shared_ptr<ToplevelElement> topLevelElement = boost::dynamic_pointer_cast<ToplevelElement>(element); if (topLevelElement) { FullPayloadSerializerCollection payloadSerializerCollection; XMPPSerializer xmppSerializer(&payloadSerializerCollection, ClientStreamType, false); SafeByteArray serialized = xmppSerializer.serializeElement(topLevelElement); os << "TopLevelElement(" << safeByteArrayToString(serialized) << ")"; return os; } os << "Element(Unknown)"; return os; }