diff options
| author | Manjeet Dahiya <manjeetdahiya@gmail.com> | 2009-10-18 22:54:04 +0000 |
|---|---|---|
| committer | Manjeet Dahiya <manjeetdahiya@gmail.com> | 2009-10-18 22:54:04 +0000 |
| commit | 8054a813ea973b69fa655ce0cdfb516db58e4295 (patch) | |
| tree | adaaf6c64f467008130b2126fa121aff20a4d286 /source/QXmppNonSASLAuth.cpp | |
| parent | d7a8921864d1a622ee1125075139b6693a9011c2 (diff) | |
| download | qxmpp-8054a813ea973b69fa655ce0cdfb516db58e4295.tar.gz | |
XEP-0078: Non-SASL Authentication Implementation
Diffstat (limited to 'source/QXmppNonSASLAuth.cpp')
| -rw-r--r-- | source/QXmppNonSASLAuth.cpp | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/source/QXmppNonSASLAuth.cpp b/source/QXmppNonSASLAuth.cpp new file mode 100644 index 00000000..883bdc0d --- /dev/null +++ b/source/QXmppNonSASLAuth.cpp @@ -0,0 +1,71 @@ +#include "QXmppNonSASLAuth.h"
+#include "QXmppUtils.h"
+#include <QCryptographicHash>
+
+QXmppNonSASLAuthTypesRequestIq::QXmppNonSASLAuthTypesRequestIq() : QXmppIq(QXmppIq::Get)
+{
+
+}
+
+void QXmppNonSASLAuthTypesRequestIq::setUsername( const QString &username )
+{
+ m_username = username;
+}
+
+QByteArray QXmppNonSASLAuthTypesRequestIq::toXmlElementFromChild() const
+{
+ QByteArray resultingXml;
+ resultingXml += "<query xmlns=\"jabber:iq:auth\">";
+ resultingXml += "<username>" + escapeString(m_username).toUtf8() + "</username>";
+ resultingXml += "</query>";
+ return resultingXml;
+}
+
+QXmppNonSASLAuthIq::QXmppNonSASLAuthIq() : QXmppIq(QXmppIq::Set), m_useplaintext(false)
+{
+
+}
+
+QByteArray QXmppNonSASLAuthIq::toXmlElementFromChild() const
+{
+ QByteArray resultingXml;
+ resultingXml += "<query xmlns=\"jabber:iq:auth\">";
+ resultingXml += "<username>" + escapeString(m_username).toUtf8() + "</username>";
+ if ( m_useplaintext )
+ resultingXml += "<password>" + escapeString(m_password).toUtf8() + "</password>";
+ else
+ {//SHA1(concat(sid, password)).
+ QByteArray textSid = m_sid.toUtf8();
+ QByteArray encodedPassword = m_password.toUtf8();
+ QByteArray digest = QCryptographicHash::hash(textSid + encodedPassword, QCryptographicHash::Sha1 ).toHex();
+ resultingXml += "<digest>" + digest + "</digest>";
+ }
+ resultingXml += "<resource>" + escapeString(m_resource).toUtf8() + "</resource>";
+ resultingXml += "</query>";
+ return resultingXml;
+}
+
+void QXmppNonSASLAuthIq::setUsername( const QString &username )
+{
+ m_username = username;
+}
+
+void QXmppNonSASLAuthIq::setPassword( const QString &password )
+{
+ m_password = password;
+}
+
+void QXmppNonSASLAuthIq::setResource( const QString &resource )
+{
+ m_resource = resource;
+}
+
+void QXmppNonSASLAuthIq::setStreamId( const QString &sid )
+{
+ m_sid = sid;
+}
+
+void QXmppNonSASLAuthIq::setUsePlainText( bool use )
+{
+ m_useplaintext = use;
+}
|
