All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.as.clustering.jgroups.subsystem.LegacyFailureDetectionProtocolResourceDefinition Maven / Gradle / Ivy

The newest version!
/*
 * Copyright The WildFly Authors
 * SPDX-License-Identifier: Apache-2.0
 */

package org.jboss.as.clustering.jgroups.subsystem;

import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.UnaryOperator;

import org.jboss.as.clustering.controller.ResourceDescriptor;
import org.jboss.as.controller.OperationContext;
import org.jboss.as.controller.OperationFailedException;
import org.jboss.as.controller.RequirementServiceBuilder;
import org.jboss.as.network.ClientMapping;
import org.jboss.as.network.SocketBinding;
import org.jboss.dmr.ModelNode;
import org.jgroups.protocols.FD_SOCK;
import org.wildfly.clustering.jgroups.spi.ProtocolConfiguration;
import org.wildfly.clustering.jgroups.spi.ProtocolStackConfiguration;
import org.wildfly.subsystem.service.ResourceServiceConfigurator;
import org.wildfly.subsystem.service.ServiceDependency;

/**
 * @author Paul Ferraro
 */
public class LegacyFailureDetectionProtocolResourceDefinition extends SocketProtocolResourceDefinition {

    public LegacyFailureDetectionProtocolResourceDefinition(String name, UnaryOperator configurator, ResourceServiceConfigurator parentServiceConfigurator) {
        super(name, configurator, parentServiceConfigurator);
    }

    @Override
    public Map.Entry, ProtocolConfiguration>, Consumer>> resolve(OperationContext context, ModelNode model) throws OperationFailedException {
        String bindingName = Attribute.SOCKET_BINDING.resolveModelAttribute(context, model).asStringOrNull();
        String clientBindingName = Attribute.CLIENT_SOCKET_BINDING.resolveModelAttribute(context, model).asStringOrNull();

        ServiceDependency binding = (bindingName != null) ? ServiceDependency.on(SocketBinding.SERVICE_DESCRIPTOR, bindingName) : ServiceDependency.of(null);
        ServiceDependency clientBinding = (clientBindingName != null) ? ServiceDependency.on(SocketBinding.SERVICE_DESCRIPTOR, clientBindingName) : ServiceDependency.of(null);

        return Map.entry(new UnaryOperator<>() {
            @Override
            public ProtocolConfiguration apply(ProtocolConfiguration configuration) {
                return new ProtocolConfigurationDecorator<>(configuration) {
                    @Override
                    public FD_SOCK createProtocol(ProtocolStackConfiguration stackConfiguration) {
                        FD_SOCK protocol = super.createProtocol(stackConfiguration);
                        // If binding is undefined, protocol will use bind address of transport and a random ephemeral port
                        SocketBinding socketBinding = binding.get();
                        protocol.setStartPort((socketBinding != null) ? socketBinding.getAbsolutePort() : 0);

                        if (socketBinding != null) {
                            protocol.setBindAddress(socketBinding.getAddress());

                            List clientMappings = socketBinding.getClientMappings();
                            if (!clientMappings.isEmpty()) {
                                // JGroups cannot select a client mapping based on the source address, so just use the first one
                                ClientMapping mapping = clientMappings.get(0);
                                try {
                                    protocol.setExternalAddress(InetAddress.getByName(mapping.getDestinationAddress()));
                                    protocol.setExternalPort(mapping.getDestinationPort());
                                } catch (UnknownHostException e) {
                                    throw new IllegalArgumentException(e);
                                }
                            }
                        }
                        SocketBinding clientSocketBinding = clientBinding.get();
                        if (clientSocketBinding != null) {
                            protocol.setClientBindPort(clientSocketBinding.getSocketAddress().getPort());
                        }
                        return protocol;
                    }

                    @Override
                    public Map getSocketBindings() {
                        Map result = new TreeMap<>();
                        SocketBinding socketBinding = binding.get();
                        if (socketBinding != null) {
                            result.put("jgroups.fd_sock.srv_sock", socketBinding);
                        }
                        SocketBinding clientSocketBinding = clientBinding.get();
                        if (clientSocketBinding != null) {
                            result.put("jgroups.fd.ping_sock", clientSocketBinding);
                        }
                        return result;
                    }
                };
            }
        }, binding.andThen(clientBinding));
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy