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