Home / Class/ SockaddrIn Class — netty Architecture

SockaddrIn Class — netty Architecture

Architecture documentation for the SockaddrIn class in SockaddrIn.java from the netty codebase.

Entity Profile

Dependency Diagram

graph TD
  25164b27_46c0_d628_1986_f46b53ee8d7c["SockaddrIn"]
  e208dbf1_1e96_c13a_b789_2541320c363a["SockaddrIn.java"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|defined in| e208dbf1_1e96_c13a_b789_2541320c363a
  522674bb_4e24_6ad2_9ee9_2d0c526a9f4f["SockaddrIn()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| 522674bb_4e24_6ad2_9ee9_2d0c526a9f4f
  29d6e569_b6b2_25d7_814d_ffe07d284fc6["cmp()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| 29d6e569_b6b2_25d7_814d_ffe07d284fc6
  2004ada0_a0c9_e64f_394d_cfe69d9ed1e3["setAddress()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| 2004ada0_a0c9_e64f_394d_cfe69d9ed1e3
  d1133751_664a_282a_9376_88a6578418dc["setIPv4()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| d1133751_664a_282a_9376_88a6578418dc
  ebc3d1cf_f4f9_d2a3_70a0_2464309e683e["setIPv6()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| ebc3d1cf_f4f9_d2a3_70a0_2464309e683e
  4325cce6_d34d_5934_1d22_b4b043e9dfde["InetSocketAddress()"]
  25164b27_46c0_d628_1986_f46b53ee8d7c -->|method| 4325cce6_d34d_5934_1d22_b4b043e9dfde

Relationship Graph

Source Code

codec-classes-quic/src/main/java/io/netty/handler/codec/quic/SockaddrIn.java lines 28–190

final class SockaddrIn {
    static final byte[] IPV4_MAPPED_IPV6_PREFIX = {
            0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, (byte) 0xff, (byte) 0xff };
    static final int IPV4_ADDRESS_LENGTH = 4;
    static final int IPV6_ADDRESS_LENGTH = 16;
    static final byte[] SOCKADDR_IN6_EMPTY_ARRAY = new byte[Quiche.SIZEOF_SOCKADDR_IN6];
    static final byte[] SOCKADDR_IN_EMPTY_ARRAY = new byte[Quiche.SIZEOF_SOCKADDR_IN];

    private SockaddrIn() { }

    static int cmp(long memory, long memory2) {
        return Quiche.sockaddr_cmp(memory, memory2);
    }

    static int setAddress(ByteBuffer memory, InetSocketAddress address) {
        InetAddress addr = address.getAddress();
        return setAddress(addr instanceof Inet6Address, memory, address);
    }

    static int setAddress(boolean ipv6, ByteBuffer memory, InetSocketAddress address) {
        if (ipv6) {
            return SockaddrIn.setIPv6(memory, address.getAddress(), address.getPort());
        } else {
            return SockaddrIn.setIPv4(memory, address.getAddress(), address.getPort());
        }
    }

    /**
     *
     * struct sockaddr_in {
     *      sa_family_t    sin_family; // address family: AF_INET
     *      in_port_t      sin_port;   // port in network byte order
     *      struct in_addr sin_addr;   // internet address
     * };
     *
     * // Internet address.
     * struct in_addr {
     *     uint32_t       s_addr;     // address in network byte order
     * };
     *
     */
    static int setIPv4(ByteBuffer memory, InetAddress address, int port) {
        int position = memory.position();
        try {
            // memset
            memory.put(SOCKADDR_IN_EMPTY_ARRAY);

            memory.putShort(position + Quiche.SOCKADDR_IN_OFFSETOF_SIN_FAMILY, Quiche.AF_INET);
            memory.putShort(position + Quiche.SOCKADDR_IN_OFFSETOF_SIN_PORT, (short) port);

            byte[] bytes = address.getAddress();
            int offset = 0;
            if (bytes.length == IPV6_ADDRESS_LENGTH) {
                // IPV6 mapped IPV4 address, we only need the last 4 bytes.
                offset = IPV4_MAPPED_IPV6_PREFIX.length;
            }
            assert bytes.length == offset + IPV4_ADDRESS_LENGTH;
            memory.position(position + Quiche.SOCKADDR_IN_OFFSETOF_SIN_ADDR + Quiche.IN_ADDRESS_OFFSETOF_S_ADDR);
            memory.put(bytes, offset, IPV4_ADDRESS_LENGTH);
            return Quiche.SIZEOF_SOCKADDR_IN;
        } finally {
            memory.position(position);
        }
    }

    /**
     * struct sockaddr_in6 {
     *     sa_family_t     sin6_family;   // AF_INET6
     *     in_port_t       sin6_port;     // port number
     *     uint32_t        sin6_flowinfo; // IPv6 flow information
     *     struct in6_addr sin6_addr;     // IPv6 address
     *     uint32_t        sin6_scope_id; /* Scope ID (new in 2.4)
     * };
     *
     * struct in6_addr {
     *     unsigned char s6_addr[16];   // IPv6 address
     * };
     */
    static int setIPv6(ByteBuffer memory, InetAddress address, int port) {
        int position = memory.position();
        try {

Frequently Asked Questions

What is the SockaddrIn class?
SockaddrIn is a class in the netty codebase, defined in codec-classes-quic/src/main/java/io/netty/handler/codec/quic/SockaddrIn.java.
Where is SockaddrIn defined?
SockaddrIn is defined in codec-classes-quic/src/main/java/io/netty/handler/codec/quic/SockaddrIn.java at line 28.

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free