10e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org/* 20e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * libjingle 30e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * Copyright 2004--2005, Google Inc. 40e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 50e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * Redistribution and use in source and binary forms, with or without 60e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * modification, are permitted provided that the following conditions are met: 70e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 80e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 1. Redistributions of source code must retain the above copyright notice, 90e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * this list of conditions and the following disclaimer. 100e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 2. Redistributions in binary form must reproduce the above copyright notice, 110e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * this list of conditions and the following disclaimer in the documentation 120e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * and/or other materials provided with the distribution. 130e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 3. The name of the author may not be used to endorse or promote products 140e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * derived from this software without specific prior written permission. 150e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * 160e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 170e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 180e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO 190e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 200e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 210e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 220e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 230e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR 240e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF 250e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 260e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org */ 270e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 280e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#ifndef TALK_XMPP_XMPPAUTH_H_ 290e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#define TALK_XMPP_XMPPAUTH_H_ 300e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 310e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#include <vector> 320e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 330e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#include "talk/xmpp/jid.h" 340e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#include "talk/xmpp/prexmppauth.h" 35cf81adffe15fa8ea0f333432e41f6d504148f18abuildbot@webrtc.org#include "talk/xmpp/saslhandler.h" 36cf81adffe15fa8ea0f333432e41f6d504148f18abuildbot@webrtc.org#include "webrtc/base/cryptstring.h" 37cf81adffe15fa8ea0f333432e41f6d504148f18abuildbot@webrtc.org#include "webrtc/base/sigslot.h" 380e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 390e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgclass XmppAuth: public buzz::PreXmppAuth { 400e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgpublic: 410e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org XmppAuth(); 420e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual ~XmppAuth(); 430e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 440e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org // TODO: Just have one "secret" that is either pass or 450e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org // token? 460e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual void StartPreXmppAuth(const buzz::Jid& jid, 472a86ce22ccc387dfa6f8a98ce3eba5c1e6f9e538buildbot@webrtc.org const rtc::SocketAddress& server, 482a86ce22ccc387dfa6f8a98ce3eba5c1e6f9e538buildbot@webrtc.org const rtc::CryptString& pass, 490e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org const std::string& auth_mechanism, 500e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org const std::string& auth_token); 510e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 520e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual bool IsAuthDone() const { return done_; } 530e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual bool IsAuthorized() const { return true; } 540e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual bool HadError() const { return false; } 550e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual int GetError() const { return 0; } 560e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual buzz::CaptchaChallenge GetCaptchaChallenge() const { 570e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org return buzz::CaptchaChallenge(); 580e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org } 590e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual std::string GetAuthMechanism() const { return auth_mechanism_; } 600e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual std::string GetAuthToken() const { return auth_token_; } 610e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 620e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual std::string ChooseBestSaslMechanism( 630e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org const std::vector<std::string>& mechanisms, 640e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org bool encrypted); 650e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 660e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org virtual buzz::SaslMechanism * CreateSaslMechanism( 670e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org const std::string& mechanism); 680e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 690e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgprivate: 700e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org buzz::Jid jid_; 712a86ce22ccc387dfa6f8a98ce3eba5c1e6f9e538buildbot@webrtc.org rtc::CryptString passwd_; 720e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org std::string auth_mechanism_; 730e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org std::string auth_token_; 740e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org bool done_; 750e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org}; 760e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 770e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#endif // TALK_XMPP_XMPPAUTH_H_ 780e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org 79