| Index: third_party/xmpp/saslplainmechanism.h
|
| diff --git a/third_party/xmpp/saslplainmechanism.h b/third_party/xmpp/saslplainmechanism.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..cf312ae4265db30170f24613a3f99485c783c8b4
|
| --- /dev/null
|
| +++ b/third_party/xmpp/saslplainmechanism.h
|
| @@ -0,0 +1,42 @@
|
| +// Copyright 2004 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef WEBRTC_LIBJINGLE_XMPP_SASLPLAINMECHANISM_H_
|
| +#define WEBRTC_LIBJINGLE_XMPP_SASLPLAINMECHANISM_H_
|
| +
|
| +#include "third_party/xmpp/saslmechanism.h"
|
| +#include "webrtc/base/cryptstring.h"
|
| +
|
| +namespace buzz {
|
| +
|
| +class SaslPlainMechanism : public SaslMechanism {
|
| +
|
| +public:
|
| + SaslPlainMechanism(const buzz::Jid user_jid, const rtc::CryptString & password) :
|
| + user_jid_(user_jid), password_(password) {}
|
| +
|
| + virtual std::string GetMechanismName() { return "PLAIN"; }
|
| +
|
| + virtual XmlElement * StartSaslAuth() {
|
| + // send initial request
|
| + XmlElement * el = new XmlElement(QN_SASL_AUTH, true);
|
| + el->AddAttr(QN_MECHANISM, "PLAIN");
|
| +
|
| + rtc::FormatCryptString credential;
|
| + credential.Append("\0", 1);
|
| + credential.Append(user_jid_.node());
|
| + credential.Append("\0", 1);
|
| + credential.Append(&password_);
|
| + el->AddText(Base64EncodeFromArray(credential.GetData(), credential.GetLength()));
|
| + return el;
|
| + }
|
| +
|
| +private:
|
| + Jid user_jid_;
|
| + rtc::CryptString password_;
|
| +};
|
| +
|
| +}
|
| +
|
| +#endif // WEBRTC_LIBJINGLE_XMPP_SASLPLAINMECHANISM_H_
|
|
|