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