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.elan.internal;
10 import java.util.ArrayList;
11 import java.util.List;
12 import java.util.concurrent.Callable;
14 import org.opendaylight.genius.interfacemanager.globals.InterfaceInfo;
15 import org.opendaylight.yang.gen.v1.urn.opendaylight.netvirt.elan.rev150602.elan.instances.ElanInstance;
16 import org.slf4j.Logger;
17 import org.slf4j.LoggerFactory;
19 import com.google.common.util.concurrent.ListenableFuture;
21 public class InterfaceRemoveWorkerOnElan implements Callable<List<ListenableFuture<Void>>> {
23 private ElanInstance elanInfo;
24 private String interfaceName;
25 private InterfaceInfo interfaceInfo;
26 private boolean isInterfaceStateRemoved;
27 private ElanInterfaceManager dataChangeListener;
28 private static final Logger logger = LoggerFactory.getLogger(InterfaceRemoveWorkerOnElan.class);
30 public InterfaceRemoveWorkerOnElan(String key, ElanInstance elanInfo, String interfaceName,
31 InterfaceInfo interfaceInfo, boolean isInterfaceStateRemoved, ElanInterfaceManager dataChangeListener) {
34 this.elanInfo = elanInfo;
35 this.interfaceName = interfaceName;
36 this.interfaceInfo = interfaceInfo;
37 this.isInterfaceStateRemoved = isInterfaceStateRemoved;
38 this.dataChangeListener = dataChangeListener;
42 public String toString() {
43 return "InterfaceRemoveWorkerOnElan [key=" + key + ", elanInfo=" + elanInfo +
44 ", interfaceName=" + interfaceName
45 + ", interfaceInfo=" + interfaceInfo + "]";
49 public List<ListenableFuture<Void>> call() throws Exception {
50 List<ListenableFuture<Void>> futures = new ArrayList<>();
52 dataChangeListener.removeElanInterface(elanInfo, interfaceName, interfaceInfo, isInterfaceStateRemoved);
53 } catch (Exception e) {
54 logger.error("Error while processing {} for {}, error {}", key, interfaceName, e);