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_SASLCOOKIEMECHANISM_H_
290e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#define TALK_XMPP_SASLCOOKIEMECHANISM_H_
300e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
3113b2d035e2e7f2f18e3a4d3377bc1a09f43a4ff9buildbot@webrtc.org#include "webrtc/libjingle/xmllite/qname.h"
3213b2d035e2e7f2f18e3a4d3377bc1a09f43a4ff9buildbot@webrtc.org#include "webrtc/libjingle/xmllite/xmlelement.h"
330e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#include "talk/xmpp/constants.h"
34cf81adffe15fa8ea0f333432e41f6d504148f18abuildbot@webrtc.org#include "talk/xmpp/saslmechanism.h"
350e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
360e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgnamespace buzz {
370e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
380e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgclass SaslCookieMechanism : public SaslMechanism {
390e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
400e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgpublic:
410e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  SaslCookieMechanism(const std::string & mechanism,
420e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org                      const std::string & username,
430e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org                      const std::string & cookie,
440e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org                      const std::string & token_service)
450e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    : mechanism_(mechanism),
460e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      username_(username),
470e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      cookie_(cookie),
480e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      token_service_(token_service) {}
490e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
500e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  SaslCookieMechanism(const std::string & mechanism,
510e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org                      const std::string & username,
520e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org                      const std::string & cookie)
530e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    : mechanism_(mechanism),
540e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      username_(username),
550e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      cookie_(cookie),
560e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      token_service_("") {}
570e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
580e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  virtual std::string GetMechanismName() { return mechanism_; }
590e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
600e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  virtual XmlElement * StartSaslAuth() {
610e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    // send initial request
620e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    XmlElement * el = new XmlElement(QN_SASL_AUTH, true);
630e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    el->AddAttr(QN_MECHANISM, mechanism_);
640e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    if (!token_service_.empty()) {
650e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org      el->AddAttr(QN_GOOGLE_AUTH_SERVICE, token_service_);
660e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    }
670e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
680e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    std::string credential;
690e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    credential.append("\0", 1);
700e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    credential.append(username_);
710e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    credential.append("\0", 1);
720e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    credential.append(cookie_);
730e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    el->AddText(Base64Encode(credential));
740e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org    return el;
750e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  }
760e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
770e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.orgprivate:
780e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  std::string mechanism_;
790e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  std::string username_;
800e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  std::string cookie_;
810e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org  std::string token_service_;
820e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org};
830e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
840e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org}
850e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org
860e118e7129884fbea117e78d6f2068139a414dbhenrike@webrtc.org#endif  // TALK_XMPP_SASLCOOKIEMECHANISM_H_
87