package org.jivesoftware.openfire.pubsub.cluster; import org.jivesoftware.openfire.pubsub.Node; import org.jivesoftware.openfire.pubsub.NodeSubscription; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public class CancelSubscriptionTask extends SubscriptionTask { private static final Logger log = LoggerFactory.getLogger(CancelSubscriptionTask.class); public CancelSubscriptionTask() { } public CancelSubscriptionTask(NodeSubscription subscription) { super(subscription); } @Override public void run() { log.debug("[TASK] Cancel Subscription : {}", toString()); Node node = getNode(); // This will only occur if a PEP service is not loaded. We can safely do nothing in this // case since any changes will get loaded from the db when it is loaded. if (node == null) return; // This method will make a db call, but it will simply do nothing since // the record will already be deleted. node.cancelSubscription(getSubscription(), false); } }