blob: 6933b17b8cec1df6e7948020ad2a3ab17249849e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
// 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.
#ifndef REMOTING_JINGLE_GLUE_IQ_REQUEST_H_
#define REMOTING_JINGLE_GLUE_IQ_REQUEST_H_
#include <string>
#include "base/callback.h"
#include "base/gtest_prod_util.h"
#include "third_party/libjingle/source/talk/xmpp/xmppengine.h"
namespace remoting {
class JingleClient;
// IqRequest class can be used to send an IQ stanza and then receive reply
// stanza for that request. It sends outgoing stanza when SendIq() is called,
// after that it forwards incoming reply stanza to the callback set with
// set_callback(). If multiple IQ stanzas are send with SendIq() then only reply
// to the last one will be received.
// The class must be used on the jingle thread only.
class IqRequest : private buzz::XmppIqHandler {
public:
typedef Callback1<const buzz::XmlElement*>::Type ReplyCallback;
explicit IqRequest(JingleClient* jingle_client);
virtual ~IqRequest();
// Sends stanza of type |type| to |addressee|. |iq_body| contains body of
// the stanza. Ownership of |iq_body| is transfered to IqRequest. Must
// be called on the jingle thread.
virtual void SendIq(const std::string& type, const std::string& addressee,
buzz::XmlElement* iq_body);
// Sets callback that is called when reply stanza is received. Callback
// is called on the jingle thread.
void set_callback(ReplyCallback* callback) {
callback_.reset(callback);
}
private:
FRIEND_TEST_ALL_PREFIXES(IqRequestTest, MakeIqStanza);
// XmppIqHandler interface.
virtual void IqResponse(buzz::XmppIqCookie cookie,
const buzz::XmlElement* stanza);
static buzz::XmlElement* MakeIqStanza(const std::string& type,
const std::string& addressee,
buzz::XmlElement* iq_body,
const std::string& id);
void Unregister();
scoped_refptr<JingleClient> jingle_client_;
buzz::XmppIqCookie cookie_;
scoped_ptr<ReplyCallback> callback_;
};
} // namespace remoting
#endif // REMOTING_JINGLE_GLUE_IQ_REQUEST_H_
|