2 * Copyright (c) 2016 Ericsson India Global Services Pvt Ltd. and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.netvirt.vpnmanager.intervpnlink;
11 import javax.annotation.PreDestroy;
12 import javax.inject.Inject;
13 import javax.inject.Singleton;
14 import org.opendaylight.infrautils.utils.concurrent.Executors;
15 import org.opendaylight.mdsal.binding.api.DataBroker;
16 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
17 import org.opendaylight.netvirt.vpnmanager.api.intervpnlink.InterVpnLinkCache;
18 import org.opendaylight.serviceutils.tools.listener.AbstractClusteredAsyncDataTreeChangeListener;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.netvirt.inter.vpn.link.rev160311.InterVpnLinkStates;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.netvirt.inter.vpn.link.rev160311.inter.vpn.link.states.InterVpnLinkState;
21 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
22 import org.slf4j.Logger;
23 import org.slf4j.LoggerFactory;
26 * Clustered listener whose only purpose is to keep global (well, per cluster)
27 * caches updated. Same as InterVpnLinkCacheFeeder but this listens on
28 * InterVpnLinkState changes.
31 public class InterVpnLinkStateCacheFeeder extends AbstractClusteredAsyncDataTreeChangeListener<InterVpnLinkState> {
33 private static final Logger LOG = LoggerFactory.getLogger(InterVpnLinkStateCacheFeeder.class);
35 private final InterVpnLinkCache interVpnLinkCache;
36 private final DataBroker dataBroker;
39 public InterVpnLinkStateCacheFeeder(final DataBroker dataBroker, final InterVpnLinkCache interVpnLinkCache) {
40 super(dataBroker, LogicalDatastoreType.CONFIGURATION, InstanceIdentifier.create(InterVpnLinkStates.class)
41 .child(InterVpnLinkState.class),
42 Executors.newListeningSingleThreadExecutor("InterVpnLinkStateCacheFeeder", LOG));
43 this.dataBroker = dataBroker;
44 this.interVpnLinkCache = interVpnLinkCache;
48 LOG.info("{} start", getClass().getSimpleName());
55 Executors.shutdownAndAwaitTermination(getExecutorService());
59 public void remove(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState del) {
60 LOG.debug("InterVpnLinkState {} has been removed", del.getInterVpnLinkName());
61 interVpnLinkCache.removeInterVpnLinkStateFromCache(del);
65 public void update(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState original,
66 InterVpnLinkState update) {
67 LOG.debug("InterVpnLinkState {} has been updated", update.getInterVpnLinkName());
68 interVpnLinkCache.addInterVpnLinkStateToCaches(update);
72 public void add(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState add) {
73 LOG.debug("InterVpnLinkState {} has been added", add.getInterVpnLinkName());
74 interVpnLinkCache.addInterVpnLinkStateToCaches(add);