blob: 5470c38df9edfd3e392f62660c9fbc8169426900 [file] [log] [blame]
Thomas Vachuska7d693f52014-10-21 19:17:57 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2014-present Open Networking Foundation
Thomas Vachuska7d693f52014-10-21 19:17:57 -07003 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07004 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
Thomas Vachuska7d693f52014-10-21 19:17:57 -07007 *
Thomas Vachuska4f1a60c2014-10-28 13:39:07 -07008 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
Thomas Vachuska7d693f52014-10-21 19:17:57 -070015 */
Brian O'Connorabafb502014-12-02 22:26:20 -080016package org.onosproject.cli;
tom9710fb42014-09-29 11:35:28 -070017
Ray Milkeyd84f89b2018-08-17 14:54:17 -070018import org.apache.karaf.shell.api.action.Argument;
19import org.apache.karaf.shell.api.action.Command;
20import org.apache.karaf.shell.api.action.lifecycle.Service;
Brian O'Connorabafb502014-12-02 22:26:20 -080021import org.onosproject.cluster.ClusterAdminService;
22import org.onosproject.cluster.NodeId;
tom9710fb42014-09-29 11:35:28 -070023
24/**
25 * Removes a controller cluster node.
26 */
Ray Milkeyd84f89b2018-08-17 14:54:17 -070027@Service
tom9710fb42014-09-29 11:35:28 -070028@Command(scope = "onos", name = "remove-node",
29 description = "Removes a new controller cluster node")
30public class NodeRemoveCommand extends AbstractShellCommand {
31
32 @Argument(index = 0, name = "nodeId", description = "Node ID",
33 required = true, multiValued = false)
34 String nodeId = null;
35
36 @Override
Ray Milkeyd84f89b2018-08-17 14:54:17 -070037 protected void doExecute() {
tom9710fb42014-09-29 11:35:28 -070038 ClusterAdminService service = get(ClusterAdminService.class);
39 service.removeNode(new NodeId(nodeId));
40 }
41
42}