/* Copyright (c) 2012 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. */ /* From private/ppb_net_address_private.idl, * modified Wed Mar 21 11:10:47 2012. */ #ifndef PPAPI_C_PRIVATE_PPB_NET_ADDRESS_PRIVATE_H_ #define PPAPI_C_PRIVATE_PPB_NET_ADDRESS_PRIVATE_H_ #include "ppapi/c/pp_bool.h" #include "ppapi/c/pp_macros.h" #include "ppapi/c/pp_module.h" #include "ppapi/c/pp_stdint.h" #include "ppapi/c/pp_var.h" #define PPB_NETADDRESS_PRIVATE_INTERFACE_0_1 "PPB_NetAddress_Private;0.1" #define PPB_NETADDRESS_PRIVATE_INTERFACE_1_0 "PPB_NetAddress_Private;1.0" #define PPB_NETADDRESS_PRIVATE_INTERFACE_1_1 "PPB_NetAddress_Private;1.1" #define PPB_NETADDRESS_PRIVATE_INTERFACE PPB_NETADDRESS_PRIVATE_INTERFACE_1_1 /** * @file * This file defines the PPB_NetAddress_Private interface. */ /** * @addtogroup Enums * @{ */ typedef enum { /** * The address family is unspecified. */ PP_NETADDRESSFAMILY_UNSPECIFIED = 0, /** * The Internet Protocol version 4 (IPv4) address family. */ PP_NETADDRESSFAMILY_IPV4 = 1, /** * The Internet Protocol version 6 (IPv6) address family. */ PP_NETADDRESSFAMILY_IPV6 = 2 } PP_NetAddressFamily_Private; PP_COMPILE_ASSERT_SIZE_IN_BYTES(PP_NetAddressFamily_Private, 4); /** * @} */ /** * @addtogroup Structs * @{ */ /** * This is an opaque type holding a network address. Plugins must * never access members of this struct directly. */ struct PP_NetAddress_Private { uint32_t size; char data[128]; }; PP_COMPILE_ASSERT_STRUCT_SIZE_IN_BYTES(PP_NetAddress_Private, 132); /** * @} */ /** * @addtogroup Interfaces * @{ */ /** * The PPB_NetAddress_Private interface provides operations on * network addresses. */ struct PPB_NetAddress_Private_1_1 { /** * Returns PP_TRUE if the two addresses are equal (host and port). */ PP_Bool (*AreEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); /** * Returns PP_TRUE if the two addresses refer to the same host. */ PP_Bool (*AreHostsEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); /** * Returns a human-readable description of the network address, optionally * including the port (e.g., "192.168.0.1", "192.168.0.1:99", or "[::1]:80"), * or an undefined var on failure. */ struct PP_Var (*Describe)(PP_Module module, const struct PP_NetAddress_Private* addr, PP_Bool include_port); /** * Replaces the port in the given source address. Returns PP_TRUE on success. */ PP_Bool (*ReplacePort)(const struct PP_NetAddress_Private* src_addr, uint16_t port, struct PP_NetAddress_Private* addr_out); /** * Gets the "any" address (for IPv4 or IPv6); for use with UDP Bind. */ void (*GetAnyAddress)(PP_Bool is_ipv6, struct PP_NetAddress_Private* addr); /** * Gets the address family. */ PP_NetAddressFamily_Private (*GetFamily)( const struct PP_NetAddress_Private* addr); /** * Gets the port. The port is returned in host byte order. */ uint16_t (*GetPort)(const struct PP_NetAddress_Private* addr); /** * Gets the address. The output, address, must be large enough for the * current socket family. The output will be the binary representation of an * address for the current socket family. For IPv4 and IPv6 the address is in * network byte order. PP_TRUE is returned if the address was successfully * retrieved. */ PP_Bool (*GetAddress)(const struct PP_NetAddress_Private* addr, void* address, uint16_t address_size); /** * Returns ScopeID for IPv6 addresses or 0 for IPv4. */ uint32_t (*GetScopeID)(const struct PP_NetAddress_Private* addr); /** * Creates NetAddress with the specified IPv4 address and port * number. */ void (*CreateFromIPv4Address)(const uint8_t ip[4], uint16_t port, struct PP_NetAddress_Private* addr_out); /** * Creates NetAddress with the specified IPv6 address, scope_id and * port number. */ void (*CreateFromIPv6Address)(const uint8_t ip[16], uint32_t scope_id, uint16_t port, struct PP_NetAddress_Private* addr_out); }; typedef struct PPB_NetAddress_Private_1_1 PPB_NetAddress_Private; struct PPB_NetAddress_Private_0_1 { PP_Bool (*AreEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); PP_Bool (*AreHostsEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); struct PP_Var (*Describe)(PP_Module module, const struct PP_NetAddress_Private* addr, PP_Bool include_port); PP_Bool (*ReplacePort)(const struct PP_NetAddress_Private* src_addr, uint16_t port, struct PP_NetAddress_Private* addr_out); void (*GetAnyAddress)(PP_Bool is_ipv6, struct PP_NetAddress_Private* addr); }; struct PPB_NetAddress_Private_1_0 { PP_Bool (*AreEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); PP_Bool (*AreHostsEqual)(const struct PP_NetAddress_Private* addr1, const struct PP_NetAddress_Private* addr2); struct PP_Var (*Describe)(PP_Module module, const struct PP_NetAddress_Private* addr, PP_Bool include_port); PP_Bool (*ReplacePort)(const struct PP_NetAddress_Private* src_addr, uint16_t port, struct PP_NetAddress_Private* addr_out); void (*GetAnyAddress)(PP_Bool is_ipv6, struct PP_NetAddress_Private* addr); PP_NetAddressFamily_Private (*GetFamily)( const struct PP_NetAddress_Private* addr); uint16_t (*GetPort)(const struct PP_NetAddress_Private* addr); PP_Bool (*GetAddress)(const struct PP_NetAddress_Private* addr, void* address, uint16_t address_size); }; /** * @} */ #endif /* PPAPI_C_PRIVATE_PPB_NET_ADDRESS_PRIVATE_H_ */