Index: third_party/libjingle_xmpp/xmpp/plainsaslhandler.h |
diff --git a/third_party/libjingle_xmpp/xmpp/plainsaslhandler.h b/third_party/libjingle_xmpp/xmpp/plainsaslhandler.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..894570e9c77254b02a4d12b8f093d330aa85eb53 |
--- /dev/null |
+++ b/third_party/libjingle_xmpp/xmpp/plainsaslhandler.h |
@@ -0,0 +1,64 @@ |
+/* |
+ * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
+ * |
+ * Use of this source code is governed by a BSD-style license |
+ * that can be found in the LICENSE file in the root of the source |
+ * tree. An additional intellectual property rights grant can be found |
+ * in the file PATENTS. All contributing project authors may |
+ * be found in the AUTHORS file in the root of the source tree. |
+ */ |
+ |
+#ifndef WEBRTC_LIBJINGLE_XMPP_PLAINSASLHANDLER_H_ |
+#define WEBRTC_LIBJINGLE_XMPP_PLAINSASLHANDLER_H_ |
+ |
+#include <algorithm> |
+#include "third_party/libjingle_xmpp/xmpp/saslhandler.h" |
+#include "third_party/libjingle_xmpp/xmpp/saslplainmechanism.h" |
+#include "third_party/webrtc/base/cryptstring.h" |
+ |
+namespace buzz { |
+ |
+class PlainSaslHandler : public SaslHandler { |
+public: |
+ PlainSaslHandler(const Jid & jid, const rtc::CryptString & password, |
+ bool allow_plain) : jid_(jid), password_(password), |
+ allow_plain_(allow_plain) {} |
+ |
+ virtual ~PlainSaslHandler() {} |
+ |
+ // Should pick the best method according to this handler |
+ // returns the empty string if none are suitable |
+ virtual std::string ChooseBestSaslMechanism(const std::vector<std::string> & mechanisms, bool encrypted) { |
+ |
+ if (!encrypted && !allow_plain_) { |
+ return ""; |
+ } |
+ |
+ std::vector<std::string>::const_iterator it = std::find(mechanisms.begin(), mechanisms.end(), "PLAIN"); |
+ if (it == mechanisms.end()) { |
+ return ""; |
+ } |
+ else { |
+ return "PLAIN"; |
+ } |
+ } |
+ |
+ // Creates a SaslMechanism for the given mechanism name (you own it |
+ // once you get it). If not handled, return NULL. |
+ virtual SaslMechanism * CreateSaslMechanism(const std::string & mechanism) { |
+ if (mechanism == "PLAIN") { |
+ return new SaslPlainMechanism(jid_, password_); |
+ } |
+ return NULL; |
+ } |
+ |
+private: |
+ Jid jid_; |
+ rtc::CryptString password_; |
+ bool allow_plain_; |
+}; |
+ |
+ |
+} |
+ |
+#endif // WEBRTC_LIBJINGLE_XMPP_PLAINSASLHANDLER_H_ |