1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #ifndef NET_BASE_PORT_UTIL_H_ 6*6777b538SAndroid Build Coastguard Worker #define NET_BASE_PORT_UTIL_H_ 7*6777b538SAndroid Build Coastguard Worker 8*6777b538SAndroid Build Coastguard Worker #include <stddef.h> 9*6777b538SAndroid Build Coastguard Worker #include <stdint.h> 10*6777b538SAndroid Build Coastguard Worker 11*6777b538SAndroid Build Coastguard Worker #include <string_view> 12*6777b538SAndroid Build Coastguard Worker 13*6777b538SAndroid Build Coastguard Worker #include "base/containers/span.h" 14*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h" 15*6777b538SAndroid Build Coastguard Worker 16*6777b538SAndroid Build Coastguard Worker namespace net { 17*6777b538SAndroid Build Coastguard Worker 18*6777b538SAndroid Build Coastguard Worker // Checks if |port| is in the valid range (0 to 65535, though 0 is technically 19*6777b538SAndroid Build Coastguard Worker // reserved). Should be used before casting a port to a uint16_t. 20*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool IsPortValid(int port); 21*6777b538SAndroid Build Coastguard Worker 22*6777b538SAndroid Build Coastguard Worker // Returns true if the port is in the range [0, 1023]. These ports are 23*6777b538SAndroid Build Coastguard Worker // registered by IANA and typically need root access to listen on. 24*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool IsWellKnownPort(int port); 25*6777b538SAndroid Build Coastguard Worker 26*6777b538SAndroid Build Coastguard Worker // Checks if the port is allowed for the specified scheme. Ports set as allowed 27*6777b538SAndroid Build Coastguard Worker // with SetExplicitlyAllowedPorts() or by using ScopedPortException() will be 28*6777b538SAndroid Build Coastguard Worker // considered allowed for any scheme. 29*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool IsPortAllowedForScheme(int port, std::string_view url_scheme); 30*6777b538SAndroid Build Coastguard Worker 31*6777b538SAndroid Build Coastguard Worker // Returns the number of explicitly allowed ports; for testing. 32*6777b538SAndroid Build Coastguard Worker NET_EXPORT_PRIVATE size_t GetCountOfExplicitlyAllowedPorts(); 33*6777b538SAndroid Build Coastguard Worker 34*6777b538SAndroid Build Coastguard Worker // Set the list of ports to be allowed that otherwise would not be. This 35*6777b538SAndroid Build Coastguard Worker // replaces the list of allowed ports with the list passed to this function. An 36*6777b538SAndroid Build Coastguard Worker // empty list will remove all ports. This will reset any ScopedPortExceptions 37*6777b538SAndroid Build Coastguard Worker // currently active, so it's best to avoid calling this when any of those are 38*6777b538SAndroid Build Coastguard Worker // active. 39*6777b538SAndroid Build Coastguard Worker NET_EXPORT void SetExplicitlyAllowedPorts( 40*6777b538SAndroid Build Coastguard Worker base::span<const uint16_t> allowed_ports); 41*6777b538SAndroid Build Coastguard Worker 42*6777b538SAndroid Build Coastguard Worker // Returns true for ports which are permitted to be passed to 43*6777b538SAndroid Build Coastguard Worker // SetExplicitlyAllowedPorts(). This is not currently enforced by 44*6777b538SAndroid Build Coastguard Worker // SetExplicitlyAllowedPorts() itself, as there are still callers that pass 45*6777b538SAndroid Build Coastguard Worker // other ports. 46*6777b538SAndroid Build Coastguard Worker NET_EXPORT bool IsAllowablePort(int port); 47*6777b538SAndroid Build Coastguard Worker 48*6777b538SAndroid Build Coastguard Worker class NET_EXPORT ScopedPortException { 49*6777b538SAndroid Build Coastguard Worker public: 50*6777b538SAndroid Build Coastguard Worker explicit ScopedPortException(int port); 51*6777b538SAndroid Build Coastguard Worker ScopedPortException(const ScopedPortException&) = delete; 52*6777b538SAndroid Build Coastguard Worker ScopedPortException& operator=(const ScopedPortException&) = delete; 53*6777b538SAndroid Build Coastguard Worker ~ScopedPortException(); 54*6777b538SAndroid Build Coastguard Worker 55*6777b538SAndroid Build Coastguard Worker private: 56*6777b538SAndroid Build Coastguard Worker int port_; 57*6777b538SAndroid Build Coastguard Worker }; 58*6777b538SAndroid Build Coastguard Worker 59*6777b538SAndroid Build Coastguard Worker // Adds a port to the set permitted by GetAllowablePorts(). Cannot be nested. 60*6777b538SAndroid Build Coastguard Worker class NET_EXPORT ScopedAllowablePortForTesting { 61*6777b538SAndroid Build Coastguard Worker public: 62*6777b538SAndroid Build Coastguard Worker explicit ScopedAllowablePortForTesting(int port); 63*6777b538SAndroid Build Coastguard Worker ScopedAllowablePortForTesting(const ScopedAllowablePortForTesting&) = delete; 64*6777b538SAndroid Build Coastguard Worker ScopedAllowablePortForTesting& operator=( 65*6777b538SAndroid Build Coastguard Worker const ScopedAllowablePortForTesting&) = delete; 66*6777b538SAndroid Build Coastguard Worker ~ScopedAllowablePortForTesting(); 67*6777b538SAndroid Build Coastguard Worker }; 68*6777b538SAndroid Build Coastguard Worker 69*6777b538SAndroid Build Coastguard Worker } // namespace net 70*6777b538SAndroid Build Coastguard Worker 71*6777b538SAndroid Build Coastguard Worker #endif // NET_BASE_PORT_UTIL_H_ 72