Chromium Code Reviews| Index: remoting/jingle_glue/network_settings.h |
| diff --git a/remoting/jingle_glue/network_settings.h b/remoting/jingle_glue/network_settings.h |
| index a37b0bcb0facb4e57fff30802d23b0998ed0c715..1ff83eb2a92ba67f38e791dc325a12a92afd4674 100644 |
| --- a/remoting/jingle_glue/network_settings.h |
| +++ b/remoting/jingle_glue/network_settings.h |
| @@ -5,6 +5,11 @@ |
| #ifndef REMOTING_JINGLE_GLUE_NETWORK_SETTINGS_H_ |
| #define REMOTING_JINGLE_GLUE_NETWORK_SETTINGS_H_ |
| +#include <string> |
| + |
| +#include "base/basictypes.h" |
| +#include "base/logging.h" |
| + |
| namespace remoting { |
| struct NetworkSettings { |
| @@ -15,33 +20,48 @@ struct NetworkSettings { |
| static const int kDefaultMinPort = 12400; |
| static const int kDefaultMaxPort = 12409; |
| - enum NatTraversalMode { |
| - // Active NAT traversal using STUN and relay servers. |
| - NAT_TRAVERSAL_ENABLED, |
| - |
| + enum Flags { |
| // Don't use STUN or relay servers. Accept incoming P2P connection |
| // attempts, but don't initiate any. This ensures that the peer is |
| // on the same network. Note that connection will always fail if |
| // both ends use this mode. |
| - NAT_TRAVERSAL_DISABLED, |
| + NAT_TRAVERSAL_DISABLED = 0x0, |
| + |
| + // Allow outgoing connections, even when STUN and RELAY are not enabled. |
| + NAT_TRAVERSAL_OUTGOING = 0x1, |
| - // Don't use STUN or relay servers but make outgoing connections. |
| - NAT_TRAVERSAL_OUTGOING, |
| + // Active NAT traversal using STUN. |
| + NAT_TRAVERSAL_STUN = 0x2, |
| + |
| + // Allow the use of relay servers when a direct connection is not available. |
| + NAT_TRAVERSAL_RELAY = 0x4, |
| + |
| + // Active NAT traversal using STUN and relay servers. |
| + NAT_TRAVERSAL_FULL = NAT_TRAVERSAL_STUN | NAT_TRAVERSAL_RELAY | |
| + NAT_TRAVERSAL_OUTGOING |
| }; |
| NetworkSettings() |
| - : nat_traversal_mode(NAT_TRAVERSAL_DISABLED), |
| + : flags(NAT_TRAVERSAL_DISABLED), |
| min_port(0), |
| max_port(0) { |
| + DCHECK(!(flags & (NAT_TRAVERSAL_STUN | NAT_TRAVERSAL_RELAY)) || |
|
Sergey Ulanov
2014/03/27 23:43:06
nit: maybe comment why this is needed.
|
| + (flags & NAT_TRAVERSAL_OUTGOING)); |
| } |
| - explicit NetworkSettings(NatTraversalMode nat_traversal_mode) |
| - : nat_traversal_mode(nat_traversal_mode), |
| + explicit NetworkSettings(uint32 flags) |
| + : flags(flags), |
| min_port(0), |
| max_port(0) { |
| } |
| - NatTraversalMode nat_traversal_mode; |
| + // Parse string in the form "<min_port>-<max_port>". E.g. "12400-12409". |
| + // Returns true if string was parsed successfuly. |
| + static bool ParsePortRange(const std::string& port_range, |
| + int* out_min_port, |
| + int* out_max_port); |
| + |
| + uint32 flags; |
| // |min_port| and |max_port| specify range (inclusive) of ports used by |
| // P2P sessions. Any port can be used when both values are set to 0. |