| // Copyright (c) 2016 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 QUICHE_QUIC_PLATFORM_API_QUIC_IP_ADDRESS_H_ | 
 | #define QUICHE_QUIC_PLATFORM_API_QUIC_IP_ADDRESS_H_ | 
 |  | 
 | #if defined(_WIN32) | 
 | #include <winsock2.h> | 
 | #include <ws2tcpip.h> | 
 | #else | 
 | #include <arpa/inet.h> | 
 | #include <netinet/in.h> | 
 | #include <sys/socket.h> | 
 | #include <sys/types.h> | 
 | #endif | 
 |  | 
 | #include <ostream> | 
 | #include <string> | 
 |  | 
 | #include "net/third_party/quiche/src/quic/platform/api/quic_export.h" | 
 | #include "net/third_party/quiche/src/quic/platform/api/quic_ip_address_family.h" | 
 |  | 
 | namespace quic { | 
 |  | 
 | // Represents an IP address. | 
 | class QUIC_EXPORT_PRIVATE QuicIpAddress { | 
 |  public: | 
 |   // Sizes of IP addresses of different types, in bytes. | 
 |   enum : size_t { | 
 |     kIPv4AddressSize = 32 / 8, | 
 |     kIPv6AddressSize = 128 / 8, | 
 |     kMaxAddressSize = kIPv6AddressSize, | 
 |   }; | 
 |  | 
 |   // TODO(fayang): Remove Loopback*() and use TestLoopback*() in tests. | 
 |   static QuicIpAddress Loopback4(); | 
 |   static QuicIpAddress Loopback6(); | 
 |   static QuicIpAddress Any4(); | 
 |   static QuicIpAddress Any6(); | 
 |  | 
 |   QuicIpAddress(); | 
 |   QuicIpAddress(const QuicIpAddress& other) = default; | 
 |   explicit QuicIpAddress(const in_addr& ipv4_address); | 
 |   explicit QuicIpAddress(const in6_addr& ipv6_address); | 
 |   QuicIpAddress& operator=(const QuicIpAddress& other) = default; | 
 |   QuicIpAddress& operator=(QuicIpAddress&& other) = default; | 
 |   QUIC_EXPORT_PRIVATE friend bool operator==(QuicIpAddress lhs, | 
 |                                              QuicIpAddress rhs); | 
 |   QUIC_EXPORT_PRIVATE friend bool operator!=(QuicIpAddress lhs, | 
 |                                              QuicIpAddress rhs); | 
 |  | 
 |   bool IsInitialized() const; | 
 |   IpAddressFamily address_family() const; | 
 |   int AddressFamilyToInt() const; | 
 |   // Returns the address as a sequence of bytes in network-byte-order. IPv4 will | 
 |   // be 4 bytes. IPv6 will be 16 bytes. | 
 |   std::string ToPackedString() const; | 
 |   // Returns string representation of the address. | 
 |   std::string ToString() const; | 
 |   // Normalizes the address representation with respect to IPv4 addresses, i.e, | 
 |   // mapped IPv4 addresses ("::ffff:X.Y.Z.Q") are converted to pure IPv4 | 
 |   // addresses.  All other IPv4, IPv6, and empty values are left unchanged. | 
 |   QuicIpAddress Normalized() const; | 
 |   // Returns an address suitable for use in IPv6-aware contexts.  This is the | 
 |   // opposite of NormalizeIPAddress() above.  IPv4 addresses are converted into | 
 |   // their IPv4-mapped address equivalents (e.g. 192.0.2.1 becomes | 
 |   // ::ffff:192.0.2.1).  IPv6 addresses are a noop (they are returned | 
 |   // unchanged). | 
 |   QuicIpAddress DualStacked() const; | 
 |   bool FromPackedString(const char* data, size_t length); | 
 |   bool FromString(std::string str); | 
 |   bool IsIPv4() const; | 
 |   bool IsIPv6() const; | 
 |   bool InSameSubnet(const QuicIpAddress& other, int subnet_length); | 
 |  | 
 |   in_addr GetIPv4() const; | 
 |   in6_addr GetIPv6() const; | 
 |  | 
 |  private: | 
 |   union { | 
 |     in_addr v4; | 
 |     in6_addr v6; | 
 |     uint8_t bytes[kMaxAddressSize]; | 
 |     char chars[kMaxAddressSize]; | 
 |   } address_; | 
 |   IpAddressFamily family_; | 
 | }; | 
 |  | 
 | inline std::ostream& operator<<(std::ostream& os, const QuicIpAddress address) { | 
 |   os << address.ToString(); | 
 |   return os; | 
 | } | 
 |  | 
 | }  // namespace quic | 
 |  | 
 | #endif  // QUICHE_QUIC_PLATFORM_API_QUIC_IP_ADDRESS_H_ |