import java.time.Duration;
import org.opendaylight.mdsal.dom.api.DOMDataBroker;
import org.opendaylight.mdsal.singleton.common.api.ClusterSingletonServiceProvider;
-import org.opendaylight.yangtools.concepts.AbstractRegistration;
import org.opendaylight.yangtools.concepts.Registration;
import org.osgi.service.component.annotations.Activate;
import org.osgi.service.component.annotations.Component;
+import org.osgi.service.component.annotations.Deactivate;
import org.osgi.service.component.annotations.Reference;
import org.osgi.service.metatype.annotations.AttributeDefinition;
import org.osgi.service.metatype.annotations.Designate;
@Reference
private ClusterSingletonServiceProvider singletonService;
- private static final class Disabled extends AbstractRegistration {
- @Override
- protected void removeRegistration() {
- // no-op
- }
- }
-
- private NettyReplicationSink() {
+ private Registration reg;
+ public NettyReplicationSink() {
+ // Visible for DI
}
@Activate
final Duration reconnectDelay = Duration.ofMillis(config.reconnectDelayMillis());
final Duration keepaliveInterval = Duration.ofSeconds(config.keepAliveIntervalSeconds());
- createSink(bootstrapSupport, dataBroker, singletonService, config.enabled(), sourceAddress,
+ reg = createSink(bootstrapSupport, dataBroker, singletonService, config.enabled(), sourceAddress,
config.sourcePort(), reconnectDelay, keepaliveInterval, config.maxMissedKeepalives());
}
+ @Deactivate
+ void deactivate() {
+ reg.close();
+ reg = null;
+ }
+
static Registration createSink(final BootstrapSupport bootstrap, final DOMDataBroker broker,
final ClusterSingletonServiceProvider singleton, final boolean enabled,
final InetAddress sourceAddress, final int sourcePort, final Duration reconnectDelay,
checkArgument(maxMissedKeepalives > 0, "max-missed-keepalives %s must be greater than 0", maxMissedKeepalives);
return enabled ? singleton.registerClusterSingletonService(new SinkSingletonService(bootstrap,
broker, new InetSocketAddress(sourceAddress, sourcePort), reconnectDelay, keepaliveInterval,
- maxMissedKeepalives)) : new Disabled();
+ maxMissedKeepalives)) : new NoOpRegistration();
}
}