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
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c["SockaddrIn"]
  9b35b335_ca26_7c5b_0fea_e9067181d1c8["SockaddrIn.java"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|defined in| 9b35b335_ca26_7c5b_0fea_e9067181d1c8
  cb092578_de51_3581_0b29_3848fa63f361["SockaddrIn()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| cb092578_de51_3581_0b29_3848fa63f361
  505efae1_6ca9_d888_e0bd_f38ddda740d0["set()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| 505efae1_6ca9_d888_e0bd_f38ddda740d0
  49e528c6_f32d_db4a_bdde_2756711da5e2["setIPv4()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| 49e528c6_f32d_db4a_bdde_2756711da5e2
  df536e25_4700_d8d0_415f_750f8d5a622e["setIPv6()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| df536e25_4700_d8d0_415f_750f8d5a622e
  d173ce41_1d60_6e81_983c_35c81eb31f0a["setUds()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| d173ce41_1d60_6e81_983c_35c81eb31f0a
  82ed4807_5503_6e69_ae80_fade3cf2ff9d["InetSocketAddress()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| 82ed4807_5503_6e69_ae80_fade3cf2ff9d
  aa091fab_0a24_b7a9_661e_e5eeee98cedd["hasPortIpv4()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| aa091fab_0a24_b7a9_661e_e5eeee98cedd
  1ac3f38d_95cb_3e47_b3b3_282384ec73f4["hasPortIpv6()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| 1ac3f38d_95cb_3e47_b3b3_282384ec73f4
  66acc2f9_19b1_a6f4_38ea_a96b0fbdd651["handleNetworkOrder()"]
  0a4fbaf2_1e5c_bc5c_2cfb_5db23e53ba6c -->|method| 66acc2f9_19b1_a6f4_38ea_a96b0fbdd651

Relationship Graph

Source Code

transport-classes-io_uring/src/main/java/io/netty/channel/uring/SockaddrIn.java lines 30–240

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[Native.SIZEOF_SOCKADDR_IN6];
    static final byte[] SOCKADDR_IN_EMPTY_ARRAY = new byte[Native.SIZEOF_SOCKADDR_IN];

    private SockaddrIn() { }

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

    /**
     * <pre>{@code
     * 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
     * };
     * }</pre>
     */
    static int setIPv4(ByteBuffer memory, InetAddress address, int port) {
        int position = memory.position();
        memory.mark();
        try {
            // memset
            memory.put(SOCKADDR_IN_EMPTY_ARRAY);

            memory.putShort(position + Native.SOCKADDR_IN_OFFSETOF_SIN_FAMILY, Native.AF_INET);
            memory.putShort(position + Native.SOCKADDR_IN_OFFSETOF_SIN_PORT, handleNetworkOrder(memory.order(),
                    (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 + Native.SOCKADDR_IN_OFFSETOF_SIN_ADDR + Native.IN_ADDRESS_OFFSETOF_S_ADDR);
            memory.put(bytes, offset, IPV4_ADDRESS_LENGTH);
            return Native.SIZEOF_SOCKADDR_IN;
        } finally {
            // Restore position as we did change it via memory.put(byte[]...).
            memory.reset();
        }
    }

    /**
     * <pre>{@code
     * 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
     * };
     * }</pre>
     */
    static int setIPv6(ByteBuffer memory, InetAddress address, int port) {
        int position = memory.position();
        memory.mark();
        try {
            // memset
            memory.put(SOCKADDR_IN6_EMPTY_ARRAY);
            memory.putShort(position + Native.SOCKADDR_IN6_OFFSETOF_SIN6_FAMILY, Native.AF_INET6);
            memory.putShort(position + Native.SOCKADDR_IN6_OFFSETOF_SIN6_PORT,

Frequently Asked Questions

What is the SockaddrIn class?
SockaddrIn is a class in the netty codebase, defined in transport-classes-io_uring/src/main/java/io/netty/channel/uring/SockaddrIn.java.
Where is SockaddrIn defined?
SockaddrIn is defined in transport-classes-io_uring/src/main/java/io/netty/channel/uring/SockaddrIn.java at line 30.

Analyze Your Own Codebase

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

Try Supermodel Free