diff options
| author | Jeremy Lainé <jeremy.laine@m4x.org> | 2012-09-05 15:28:18 +0200 |
|---|---|---|
| committer | Jeremy Lainé <jeremy.laine@m4x.org> | 2012-09-05 15:28:18 +0200 |
| commit | 9168d631d5c266ee79c3112840423d4fca0c96dd (patch) | |
| tree | d5e9d67627ca46cb04eb63e06a50ffa7dc38aa7d /src/base | |
| parent | 49d30871e8a605bea9679353afd9a6fb6a877664 (diff) | |
| download | qxmpp-9168d631d5c266ee79c3112840423d4fca0c96dd.tar.gz | |
Add support for X-OAUTH2 authentication for Google Talk.
Diffstat (limited to 'src/base')
| -rw-r--r-- | src/base/QXmppSasl.cpp | 29 | ||||
| -rw-r--r-- | src/base/QXmppSasl_p.h | 11 |
2 files changed, 39 insertions, 1 deletions
diff --git a/src/base/QXmppSasl.cpp b/src/base/QXmppSasl.cpp index 54683032..bf50eaa6 100644 --- a/src/base/QXmppSasl.cpp +++ b/src/base/QXmppSasl.cpp @@ -230,7 +230,7 @@ QXmppSaslClient::~QXmppSaslClient() QStringList QXmppSaslClient::availableMechanisms() { - return QStringList() << "PLAIN" << "DIGEST-MD5" << "ANONYMOUS" << "X-FACEBOOK-PLATFORM" << "X-MESSENGER-OAUTH2"; + return QStringList() << "PLAIN" << "DIGEST-MD5" << "ANONYMOUS" << "X-FACEBOOK-PLATFORM" << "X-MESSENGER-OAUTH2" << "X-OAUTH2"; } /// Creates an SASL client for the given mechanism. @@ -247,6 +247,8 @@ QXmppSaslClient* QXmppSaslClient::create(const QString &mechanism, QObject *pare return new QXmppSaslClientFacebook(parent); } else if (mechanism == "X-MESSENGER-OAUTH2") { return new QXmppSaslClientWindowsLive(parent); + } else if (mechanism == "X-OAUTH2") { + return new QXmppSaslClientGoogle(parent); } else { return 0; } @@ -456,6 +458,31 @@ bool QXmppSaslClientFacebook::respond(const QByteArray &challenge, QByteArray &r } } +QXmppSaslClientGoogle::QXmppSaslClientGoogle(QObject *parent) + : QXmppSaslClient(parent) + , m_step(0) +{ +} + +QString QXmppSaslClientGoogle::mechanism() const +{ + return "X-OAUTH2"; +} + +bool QXmppSaslClientGoogle::respond(const QByteArray &challenge, QByteArray &response) +{ + Q_UNUSED(challenge); + if (m_step == 0) { + // send initial response + response = QString('\0' + username() + '\0' + password()).toUtf8(); + m_step++; + return true; + } else { + warning("QXmppSaslClientGoogle : Invalid step"); + return false; + } +} + QXmppSaslClientPlain::QXmppSaslClientPlain(QObject *parent) : QXmppSaslClient(parent) , m_step(0) diff --git a/src/base/QXmppSasl_p.h b/src/base/QXmppSasl_p.h index 153c4544..8e596ffe 100644 --- a/src/base/QXmppSasl_p.h +++ b/src/base/QXmppSasl_p.h @@ -240,6 +240,17 @@ private: int m_step; }; +class QXmppSaslClientGoogle : public QXmppSaslClient +{ +public: + QXmppSaslClientGoogle(QObject *parent = 0); + QString mechanism() const; + bool respond(const QByteArray &challenge, QByteArray &response); + +private: + int m_step; +}; + class QXmppSaslClientPlain : public QXmppSaslClient { public: |
