uk.co.real_logic.aeron.driver.SubscriptionLink Maven / Gradle / Ivy
/*
* Copyright 2014 - 2015 Real Logic Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package uk.co.real_logic.aeron.driver;
import uk.co.real_logic.aeron.driver.media.ReceiveChannelEndpoint;
import uk.co.real_logic.agrona.concurrent.status.ReadablePosition;
import java.util.IdentityHashMap;
import java.util.Map;
import static uk.co.real_logic.aeron.driver.Configuration.CLIENT_LIVENESS_TIMEOUT_NS;
/**
* Subscription registration from a client used for liveness tracking
*/
public class SubscriptionLink implements DriverManagedResource
{
private final long registrationId;
private final int streamId;
private final ReceiveChannelEndpoint channelEndpoint;
private final AeronClient aeronClient;
private final Map positionByImageMap = new IdentityHashMap<>();
private final DirectPublication directPublication;
private final ReadablePosition directPublicationSubscriberPosition;
private boolean reachedEndOfLife = false;
public SubscriptionLink(
final long registrationId,
final ReceiveChannelEndpoint channelEndpoint,
final int streamId,
final AeronClient aeronClient)
{
this.registrationId = registrationId;
this.channelEndpoint = channelEndpoint;
this.streamId = streamId;
this.aeronClient = aeronClient;
this.directPublication = null;
this.directPublicationSubscriberPosition = null;
}
public SubscriptionLink(
final long registrationId,
final int streamId,
final DirectPublication directPublication,
final ReadablePosition subscriberPosition,
final AeronClient aeronClient)
{
this.registrationId = registrationId;
this.channelEndpoint = null; // will prevent matches between PublicationImages and DirectPublications
this.streamId = streamId;
this.aeronClient = aeronClient;
this.directPublication = directPublication;
directPublication.incRef();
this.directPublicationSubscriberPosition = subscriberPosition;
}
public long registrationId()
{
return registrationId;
}
public ReceiveChannelEndpoint channelEndpoint()
{
return channelEndpoint;
}
public int streamId()
{
return streamId;
}
public boolean matches(final ReceiveChannelEndpoint channelEndpoint, final int streamId)
{
return channelEndpoint == this.channelEndpoint && streamId == this.streamId;
}
public void addImage(final PublicationImage image, final ReadablePosition position)
{
positionByImageMap.put(image, position);
}
public void removeImage(final PublicationImage image)
{
positionByImageMap.remove(image);
}
public void close()
{
positionByImageMap.forEach(PublicationImage::removeSubscriber);
if (null != directPublication)
{
directPublication.removeSubscription(directPublicationSubscriberPosition);
directPublication.decRef();
}
}
public void onTimeEvent(final long time, final DriverConductor conductor)
{
if (time > (aeronClient.timeOfLastKeepalive() + CLIENT_LIVENESS_TIMEOUT_NS))
{
reachedEndOfLife = true;
conductor.cleanupSubscriptionLink(SubscriptionLink.this);
}
}
public boolean hasReachedEndOfLife()
{
return reachedEndOfLife;
}
public void timeOfLastStateChange(final long time)
{
// not set this way
}
public long timeOfLastStateChange()
{
return aeronClient.timeOfLastKeepalive();
}
public void delete()
{
close();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy