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
8 package org.opendaylight.netvirt.cloudservicechain.jobs;
10 import com.google.common.util.concurrent.ListenableFuture;
11 import java.util.ArrayList;
12 import java.util.List;
13 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
14 import org.opendaylight.controller.md.sal.binding.api.WriteTransaction;
15 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
16 import org.opendaylight.genius.mdsalutil.MDSALUtil;
17 import org.opendaylight.netvirt.cloudservicechain.utils.VpnServiceChainUtils;
18 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.cloud.servicechain.state.rev170511.vpn.to.pseudo.port.list.VpnToPseudoPortData;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.cloud.servicechain.state.rev170511.vpn.to.pseudo.port.list.VpnToPseudoPortDataBuilder;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.cloud.servicechain.state.rev170511.vpn.to.pseudo.port.list.VpnToPseudoPortDataKey;
21 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
22 import org.slf4j.Logger;
23 import org.slf4j.LoggerFactory;
25 public class AddVpnPseudoPortDataJob extends VpnPseudoPortDataBaseJob {
27 private static final Logger LOG = LoggerFactory.getLogger(AddVpnPseudoPortDataJob.class);
29 protected final long vpnPseudoLportTag;
30 private final short scfTableIdToGo;
31 private final int scfTag;
33 public AddVpnPseudoPortDataJob(DataBroker dataBroker, String vpnRd, long vpnPseudoLportTag, short scfTableToGo,
35 super(dataBroker, vpnRd);
37 this.vpnPseudoLportTag = vpnPseudoLportTag;
39 this.scfTableIdToGo = scfTableToGo;
43 public List<ListenableFuture<Void>> call() throws Exception {
44 LOG.debug("Adding VpnToPseudoPortMap: vpnRd={} vpnPseudoLportTag={} scfTag={} scfTable={}",
45 super.vpnRd, vpnPseudoLportTag, scfTag, scfTableIdToGo);
46 List<ListenableFuture<Void>> result = new ArrayList<>();
48 WriteTransaction writeTxn = super.dataBroker.newWriteOnlyTransaction();
49 if ( writeTxn == null ) {
50 throw new Exception("Could not create a proper WriteTransaction");
52 VpnToPseudoPortData newValue =
53 new VpnToPseudoPortDataBuilder().setKey(new VpnToPseudoPortDataKey(super.vpnRd)).setVrfId(super.vpnRd)
54 .setScfTableId(scfTableIdToGo).setScfTag(scfTag)
55 .setVpnLportTag(vpnPseudoLportTag).build();
56 LOG.trace("Adding lportTag={} to VpnToLportTag map for VPN with rd={}", vpnPseudoLportTag, vpnRd);
57 InstanceIdentifier<VpnToPseudoPortData> path = VpnServiceChainUtils.getVpnToPseudoPortTagIid(vpnRd);
58 writeTxn.merge(LogicalDatastoreType.CONFIGURATION, path, newValue, true);
59 MDSALUtil.syncWrite(dataBroker, LogicalDatastoreType.CONFIGURATION, path, newValue);
61 result.add(writeTxn.submit());