Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(171)

Unified Diff: remoting/jingle_glue/iq_request.cc

Issue 2690003: Copy the (early prototype of) remoting in Chrome into the public tree.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « remoting/jingle_glue/iq_request.h ('k') | remoting/jingle_glue/iq_request_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: remoting/jingle_glue/iq_request.cc
===================================================================
--- remoting/jingle_glue/iq_request.cc (revision 0)
+++ remoting/jingle_glue/iq_request.cc (revision 0)
@@ -0,0 +1,79 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "remoting/jingle_glue/iq_request.h"
+
+#include "base/logging.h"
+#include "base/message_loop.h"
+#include "base/scoped_ptr.h"
+#include "remoting/jingle_glue/jingle_client.h"
+#include "talk/xmpp/constants.h"
+#include "talk/xmpp/xmppengine.h"
+
+namespace remoting {
+
+IqRequest::IqRequest(JingleClient* jingle_client)
+ : jingle_client_(jingle_client),
+ cookie_(NULL) {
+ DCHECK(jingle_client_ != NULL);
+ DCHECK(MessageLoop::current() == jingle_client_->message_loop());
+}
+
+IqRequest::~IqRequest() {
+ DCHECK(MessageLoop::current() == jingle_client_->message_loop());
+ Unregister();
+}
+
+void IqRequest::SendIq(const std::string& type,
+ const std::string& addressee,
+ buzz::XmlElement* iq_body) {
+ DCHECK(MessageLoop::current() == jingle_client_->message_loop());
+
+ // Unregister the handler if it is already registered.
+ Unregister();
+
+ DCHECK(type.length() > 0);
+ DCHECK(addressee.length() > 0);
+
+ buzz::XmppClient* xmpp_client = jingle_client_->xmpp_client();
+ DCHECK(xmpp_client); // Expect that connection is active.
+
+ scoped_ptr<buzz::XmlElement> stanza(MakeIqStanza(type, addressee, iq_body,
+ xmpp_client->NextId()));
+
+ xmpp_client->engine()->SendIq(stanza.get(), this, &cookie_);
+}
+
+// static
+buzz::XmlElement* IqRequest::MakeIqStanza(const std::string& type,
+ const std::string& addressee,
+ buzz::XmlElement* iq_body,
+ const std::string& id) {
+ buzz::XmlElement* stanza = new buzz::XmlElement(buzz::QN_IQ);
+ stanza->AddAttr(buzz::QN_TYPE, type);
+ stanza->AddAttr(buzz::QN_TO, addressee);
+ stanza->AddAttr(buzz::QN_ID, id);
+ stanza->AddElement(iq_body);
+ return stanza;
+}
+
+void IqRequest::Unregister() {
+ if (cookie_) {
+ buzz::XmppClient* xmpp_client = jingle_client_->xmpp_client();
+ // No need to unregister the handler if the client has been destroyed.
+ if (xmpp_client) {
+ xmpp_client->engine()->RemoveIqHandler(cookie_, NULL);
+ }
+ cookie_ = NULL;
+ }
+}
+
+void IqRequest::IqResponse(buzz::XmppIqCookie cookie,
+ const buzz::XmlElement* stanza) {
+ if (callback_.get() != NULL) {
+ callback_->Run(stanza);
+ }
+}
+
+} // namespace remoting
Property changes on: remoting/jingle_glue/iq_request.cc
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « remoting/jingle_glue/iq_request.h ('k') | remoting/jingle_glue/iq_request_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698