diff options
Diffstat (limited to 'Swiften/Serializer/AuthRequestSerializer.cpp')
| -rw-r--r-- | Swiften/Serializer/AuthRequestSerializer.cpp | 20 | 
1 files changed, 11 insertions, 9 deletions
diff --git a/Swiften/Serializer/AuthRequestSerializer.cpp b/Swiften/Serializer/AuthRequestSerializer.cpp index 0bee302..7f25c93 100644 --- a/Swiften/Serializer/AuthRequestSerializer.cpp +++ b/Swiften/Serializer/AuthRequestSerializer.cpp @@ -4,29 +4,31 @@   * See Documentation/Licenses/GPLv3.txt for more information.   */ -#include "Swiften/Serializer/AuthRequestSerializer.h" +#include <Swiften/Serializer/AuthRequestSerializer.h> -#include "Swiften/Elements/AuthRequest.h" -#include "Swiften/StringCodecs/Base64.h" +#include <Swiften/Elements/AuthRequest.h> +#include <Swiften/StringCodecs/Base64.h> +#include <Swiften/Base/SafeByteArray.h> +#include <Swiften/Base/Concat.h>  namespace Swift {  AuthRequestSerializer::AuthRequestSerializer() {  } -std::string AuthRequestSerializer::serialize(boost::shared_ptr<Element> element)  const { +SafeByteArray AuthRequestSerializer::serialize(boost::shared_ptr<Element> element)  const {  	boost::shared_ptr<AuthRequest> authRequest(boost::dynamic_pointer_cast<AuthRequest>(element)); -	std::string value; -	boost::optional<ByteArray> message = authRequest->getMessage(); +	SafeByteArray value; +	boost::optional<SafeByteArray> message = authRequest->getMessage();  	if (message) { -		if ((*message).isEmpty()) { -			value = "="; +		if ((*message).empty()) { +			value = createSafeByteArray("=");  		}  		else {  			value = Base64::encode(*message);  		}  	} -	return "<auth xmlns=\"urn:ietf:params:xml:ns:xmpp-sasl\" mechanism=\"" + authRequest->getMechanism() + "\">" + value + "</auth>"; +	return concat(createSafeByteArray("<auth xmlns=\"urn:ietf:params:xml:ns:xmpp-sasl\" mechanism=\"" + authRequest->getMechanism() + "\">"), value, createSafeByteArray("</auth>"));  }  }  | 
 Swift