1a75b5b9f16b5b4d528cf24cb69a39ccedc0fc21
[controller.git] / opendaylight / md-sal / samples / clustering-test-app / karaf-cli / src / main / java / org / opendaylight / clustering / it / karaf / cli / odl / mdsal / lowlevel / control / ShutdownShardReplicaCommand.java
1 /*
2  * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others.  All rights reserved.
3  *
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
7  */
8 package org.opendaylight.clustering.it.karaf.cli.odl.mdsal.lowlevel.control;
9
10 import com.google.common.util.concurrent.ListenableFuture;
11 import org.apache.karaf.shell.api.action.Argument;
12 import org.apache.karaf.shell.api.action.Command;
13 import org.apache.karaf.shell.api.action.lifecycle.Reference;
14 import org.apache.karaf.shell.api.action.lifecycle.Service;
15 import org.opendaylight.clustering.it.karaf.cli.AbstractRpcAction;
16 import org.opendaylight.mdsal.binding.api.RpcConsumerRegistry;
17 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.OdlMdsalLowlevelControlService;
18 import org.opendaylight.yang.gen.v1.tag.opendaylight.org._2017.controller.yang.lowlevel.control.rev170215.ShutdownShardReplicaInputBuilder;
19 import org.opendaylight.yangtools.yang.common.RpcResult;
20
21 @Service
22 @Command(scope = "test-app", name = "shutdown-shard-replica", description = " Run a shutdown-shard-replica test")
23 public class ShutdownShardReplicaCommand extends AbstractRpcAction {
24     @Reference
25     private RpcConsumerRegistry rpcService;
26     @Argument(index = 0, name = "shard-name", required = true)
27     String shardName;
28
29     @Override
30     protected ListenableFuture<? extends RpcResult<?>> invokeRpc() {
31         return rpcService.getRpcService(OdlMdsalLowlevelControlService.class)
32                 .shutdownShardReplica(new ShutdownShardReplicaInputBuilder()
33                         .setShardName(shardName)
34                         .build());
35     }
36 }