org.jboss.as.clustering.jgroups.subsystem.FailureDetectionProtocolResourceDefinition Maven / Gradle / Ivy
The newest version!
/*
* Copyright The WildFly Authors
* SPDX-License-Identifier: Apache-2.0
*/
package org.jboss.as.clustering.jgroups.subsystem;
import org.jboss.as.clustering.controller.ResourceDescriptor;
import java.net.InetAddress;
import java.net.InetSocketAddress;
import java.net.UnknownHostException;
import java.util.List;
import java.util.Map;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.UnaryOperator;
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_SOCK2;
import org.jgroups.protocols.TP;
import org.wildfly.clustering.jgroups.spi.ProtocolConfiguration;
import org.wildfly.clustering.jgroups.spi.ProtocolStackConfiguration;
import org.wildfly.clustering.jgroups.spi.TransportConfiguration;
import org.wildfly.subsystem.service.ResourceServiceConfigurator;
import org.wildfly.subsystem.service.ServiceDependency;
/**
* @author Paul Ferraro
*/
public class FailureDetectionProtocolResourceDefinition extends SocketProtocolResourceDefinition {
FailureDetectionProtocolResourceDefinition(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);
ServiceDependency> transport = ServiceDependency.on(TransportConfiguration.SERVICE_DESCRIPTOR, context.getCurrentAddress().getParent().getLastElement().getValue());
return Map.entry(new UnaryOperator<>() {
@Override
public ProtocolConfiguration apply(ProtocolConfiguration configuration) {
return new ProtocolConfigurationDecorator<>(configuration) {
@Override
public FD_SOCK2 createProtocol(ProtocolStackConfiguration stackConfiguration) {
FD_SOCK2 protocol = super.createProtocol(stackConfiguration);
SocketBinding protocolBinding = binding.get();
SocketBinding transportBinding = transport.get().getSocketBinding();
InetSocketAddress protocolBindAddress = (protocolBinding != null) ? protocolBinding.getSocketAddress() : null;
InetSocketAddress transportBindAddress = transportBinding.getSocketAddress();
protocol.setBindAddress(((protocolBindAddress != null) ? protocolBindAddress : transportBindAddress).getAddress());
if (protocolBinding != null) {
protocol.setOffset(protocolBindAddress.getPort() - transportBindAddress.getPort());
List clientMappings = protocolBinding.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(clientBinding.get().getSocketAddress().getPort());
}
return protocol;
}
@Override
public Map getSocketBindings() {
// Socket binding is optional
SocketBinding socketBinding = binding.get();
return (socketBinding != null) ? Map.of("jgroups.nio.server.fd_sock", socketBinding) : Map.of();
}
};
}
}, binding.andThen(clientBinding).andThen(transport));
}
}