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

Unified Diff: webrtc/p2p/stunprober/stunprober.h

Issue 1422593002: Separate StunProber::Start into Prepare and Run so we could create multiple of them and send out ST… (Closed) Base URL: https://chromium.googlesource.com/external/webrtc@master
Patch Set: Created 5 years, 2 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 | « no previous file | webrtc/p2p/stunprober/stunprober.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webrtc/p2p/stunprober/stunprober.h
diff --git a/webrtc/p2p/stunprober/stunprober.h b/webrtc/p2p/stunprober/stunprober.h
index b71d52374f8588520ba85787b20cbaa92b9a0e83..9c5b3a36ba851c355f1004254aa5c5cb98f6c804 100644
--- a/webrtc/p2p/stunprober/stunprober.h
+++ b/webrtc/p2p/stunprober/stunprober.h
@@ -32,6 +32,7 @@ class AsyncPacketSocket;
class PacketSocketFactory;
class Thread;
class NetworkManager;
+class AsyncResolverInterface;
} // namespace rtc
namespace stunprober {
@@ -60,6 +61,13 @@ class StunProber : public sigslot::has_slots<> {
READ_FAILED, // Reading the reply from the server failed.
};
+ class Observer {
+ public:
+ virtual ~Observer() = default;
+ virtual void OnPrepared(StunProber* prober, StunProber::Status status) = 0;
+ virtual void OnFinished(StunProber* prober, StunProber::Status status) = 0;
+ };
+
struct Stats {
Stats() {}
@@ -98,7 +106,8 @@ class StunProber : public sigslot::has_slots<> {
// many requests should be tried for each resolved IP address. In shared mode,
// (the number of sockets to be created) equals to |requests_per_ip|. In
// non-shared mode, (the number of sockets) equals to requests_per_ip * (the
- // number of resolved IP addresses).
+ // number of resolved IP addresses). TODO(guoweis): Remove this once
+ // everything moved to Prepare() and Run().
bool Start(const std::vector<rtc::SocketAddress>& servers,
bool shared_socket_mode,
int stun_ta_interval_ms,
@@ -106,16 +115,54 @@ class StunProber : public sigslot::has_slots<> {
int timeout_ms,
const AsyncCallback finish_callback);
+ // TODO(guoweis): The combination of Prepare() and Run() are equivalent to the
+ // Start() above. Remove Start() once everything is migrated.
+ bool Prepare(const std::vector<rtc::SocketAddress>& servers,
+ bool shared_socket_mode,
+ int stun_ta_interval_ms,
+ int requests_per_ip,
+ int timeout_ms,
+ StunProber::Observer* observer);
+
+ // Start to send out the STUN probes.
+ bool Run(StunProber::Observer* observer);
pthatcher1 2015/10/22 22:26:22 Run makes it sound synchronous. Shouldn't we ca
+
// Method to retrieve the Stats once |finish_callback| is invoked. Returning
// false when the result is inconclusive, for example, whether it's behind a
// NAT or not.
bool GetStats(Stats* stats) const;
+ // Return the estimated execution time, i.e. |requests_per_ip_| *
+ // |all_servers_addrs_|.size() * |interval_ms_|.
pthatcher1 2015/10/22 22:26:22 This comment is just a duplication of the method n
+ int estimated_execution_time() {
+ return requests_per_ip_ * all_servers_addrs_.size() * interval_ms_;
+ }
+
private:
// A requester tracks the requests and responses from a single socket to many
// STUN servers.
class Requester;
+ // TODO(guoweis): Remove this once all dependencies move away from
+ // AsyncCallback.
+ class ObserverAdapter : public Observer {
+ public:
+ void set_callback(AsyncCallback callback) { callback_ = callback; }
+ void OnPrepared(StunProber* stunprober, Status status) {
+ if (status == SUCCESS) {
+ stunprober->Run(this);
+ } else {
+ callback_(stunprober, status);
+ }
+ }
+ void OnFinished(StunProber* stunprober, Status status) {
+ callback_(stunprober, status);
+ }
+
+ private:
+ AsyncCallback callback_;
+ };
+
bool ResolveServerName(const rtc::SocketAddress& addr);
void OnServerResolved(rtc::AsyncResolverInterface* resolver);
@@ -131,15 +178,17 @@ class StunProber : public sigslot::has_slots<> {
requests_per_ip_;
}
+ bool should_send_next_request(uint32_t now);
+ int get_wake_up_interval_ms();
+
bool SendNextRequest();
// Will be invoked in 1ms intervals and schedule the next request from the
// |current_requester_| if the time has passed for another request.
void MaybeScheduleStunRequests();
- // End the probe with the given |status|. Invokes |fininsh_callback|, which
- // may destroy the class.
- void End(StunProber::Status status);
+ void ReportOnPrepared(StunProber::Status status);
+ void ReportOnFinished(StunProber::Status status);
Requester* CreateRequester();
@@ -172,10 +221,6 @@ class StunProber : public sigslot::has_slots<> {
// Accumulate all resolved addresses.
std::vector<rtc::SocketAddress> all_servers_addrs_;
- // Caller-supplied callback executed when testing is completed, called by
- // End().
- AsyncCallback finished_callback_;
-
// The set of STUN probe sockets and their state.
std::vector<Requester*> requesters_;
@@ -188,6 +233,11 @@ class StunProber : public sigslot::has_slots<> {
rtc::AsyncInvoker invoker_;
+ Observer* observer_ = nullptr;
+ // TODO(guoweis): Remove this once all dependencies move away from
+ // AsyncCallback.
+ ObserverAdapter observer_adapter_;
+
rtc::NetworkManager::NetworkList networks_;
RTC_DISALLOW_COPY_AND_ASSIGN(StunProber);
« no previous file with comments | « no previous file | webrtc/p2p/stunprober/stunprober.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698