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.vpnservice.itm.cli;
10 import com.google.common.base.Optional;
12 import org.apache.karaf.shell.commands.Command;
13 import org.apache.karaf.shell.console.OsgiCommandSupport;
14 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
15 import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
16 import org.opendaylight.vpnservice.itm.api.IITMProvider;
17 import org.opendaylight.vpnservice.itm.impl.ItmUtils;
18 //import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.itm.op.rev150701.TunnelsState;
19 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
21 import java.util.ArrayList;
22 import java.util.List;
24 @Command(scope = "tep", name = "show-state", description="Monitors tunnel state")
26 public class TepShowState extends OsgiCommandSupport {
28 private IITMProvider itmProvider;
30 public void setItmProvider(IITMProvider itmProvider) {
31 this.itmProvider = itmProvider;
35 protected Object doExecute() throws Exception {
37 DataBroker broker = itmProvider.getDataBroker();
38 List<String> result = new ArrayList<String>();
39 InstanceIdentifier<TunnelsState> path = InstanceIdentifier.builder(TunnelsState.class).build();
40 Optional<TunnelsState> tunnels = ItmUtils.read(LogicalDatastoreType.OPERATIONAL, path, broker);
41 if (tunnels.isPresent()) {
42 itmProvider.showState(tunnels.get());
45 System.out.println("No Logical Tunnels Exist");
47 System.out.println( "Logical Tunnels state is not currently supported");