/* * Copyright (c) 2021 PANTHEON.tech, s.r.o. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.controller.cluster.datastore.admin.command; import com.google.common.util.concurrent.ListenableFuture; import java.util.List; import org.apache.karaf.shell.api.action.Argument; import org.apache.karaf.shell.api.action.Command; import org.apache.karaf.shell.api.action.lifecycle.Reference; import org.apache.karaf.shell.api.action.lifecycle.Service; import org.opendaylight.mdsal.binding.api.RpcConsumerRegistry; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.cluster.admin.rev151013.ChangeMemberVotingStatesForAllShardsInputBuilder; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.cluster.admin.rev151013.ClusterAdminService; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.cluster.admin.rev151013.member.voting.states.input.MemberVotingState; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.controller.md.sal.cluster.admin.rev151013.member.voting.states.input.MemberVotingStateBuilder; import org.opendaylight.yangtools.yang.common.RpcResult; @Service @Command(scope = "cluster-admin", name = "change-member-voting-states-for-all-shards", description = "Run a change-member-voting-states-for-all-shards test") public class ChangeMemberVotingStatesForAllShardsCommand extends AbstractRpcAction { @Reference private RpcConsumerRegistry rpcConsumerRegistry; @Argument(index = 0, name = "member-name", required = true) private String memberName; @Argument(index = 1, name = "voting", required = true) private boolean voting; @Override protected ListenableFuture> invokeRpc() { final MemberVotingState memberVotingState = new MemberVotingStateBuilder() .setMemberName(memberName) .setVoting(voting) .build(); return rpcConsumerRegistry.getRpcService(ClusterAdminService.class) .changeMemberVotingStatesForAllShards(new ChangeMemberVotingStatesForAllShardsInputBuilder() .setMemberVotingState(List.of(memberVotingState)) .build()); } }