Home / Class/ DynamicAddressConnectHandler Class — netty Architecture

DynamicAddressConnectHandler Class — netty Architecture

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

Entity Profile

Dependency Diagram

graph TD
  33481830_4009_3b9e_d4c5_d0070d36ff1a["DynamicAddressConnectHandler"]
  9267c17a_8a06_ed3c_6f62_d04d6cfdb864["DynamicAddressConnectHandler.java"]
  33481830_4009_3b9e_d4c5_d0070d36ff1a -->|defined in| 9267c17a_8a06_ed3c_6f62_d04d6cfdb864
  7e80158a_cf94_6da4_b231_e5219a9c7477["connect()"]
  33481830_4009_3b9e_d4c5_d0070d36ff1a -->|method| 7e80158a_cf94_6da4_b231_e5219a9c7477
  2bbe6a9a_b146_de63_c5e3_8f9763639fc0["SocketAddress()"]
  33481830_4009_3b9e_d4c5_d0070d36ff1a -->|method| 2bbe6a9a_b146_de63_c5e3_8f9763639fc0

Relationship Graph

Source Code

handler/src/main/java/io/netty/handler/address/DynamicAddressConnectHandler.java lines 33–77

public abstract class DynamicAddressConnectHandler extends ChannelOutboundHandlerAdapter {

    @Override
    public final void connect(ChannelHandlerContext ctx, SocketAddress remoteAddress,
                              SocketAddress localAddress, ChannelPromise promise) {
        final SocketAddress remote;
        final SocketAddress local;
        try {
            remote = remoteAddress(remoteAddress, localAddress);
            local = localAddress(remoteAddress, localAddress);
        } catch (Exception e) {
            promise.setFailure(e);
            return;
        }
        ctx.connect(remote, local, promise).addListener(future -> {
            if (future.isSuccess()) {
                // We only remove this handler from the pipeline once the connect was successful as otherwise
                // the user may try to connect again.
                ctx.pipeline().remove(DynamicAddressConnectHandler.this);
            }
        });
    }

    /**
     * Returns the local {@link SocketAddress} to use for
     * {@link ChannelHandlerContext#connect(SocketAddress, SocketAddress)} based on the original {@code remoteAddress}
     * and {@code localAddress}.
     * By default, this method returns the given {@code localAddress}.
     */
    protected SocketAddress localAddress(
            @SuppressWarnings("unused") SocketAddress remoteAddress, SocketAddress localAddress) throws Exception {
        return localAddress;
    }

    /**
     * Returns the remote {@link SocketAddress} to use for
     * {@link ChannelHandlerContext#connect(SocketAddress, SocketAddress)} based on the original {@code remoteAddress}
     * and {@code localAddress}.
     * By default, this method returns the given {@code remoteAddress}.
     */
    protected SocketAddress remoteAddress(
            SocketAddress remoteAddress, @SuppressWarnings("unused") SocketAddress localAddress) throws Exception {
        return remoteAddress;
    }
}

Frequently Asked Questions

What is the DynamicAddressConnectHandler class?
DynamicAddressConnectHandler is a class in the netty codebase, defined in handler/src/main/java/io/netty/handler/address/DynamicAddressConnectHandler.java.
Where is DynamicAddressConnectHandler defined?
DynamicAddressConnectHandler is defined in handler/src/main/java/io/netty/handler/address/DynamicAddressConnectHandler.java at line 33.

Analyze Your Own Codebase

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

Try Supermodel Free