blob: 027a047c40a30246d3965822d3580a954940772b [file] [log] [blame]
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -07003 *
4 * 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
7 *
8 * 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.
15 */
16package org.onosproject.netconf.cli.impl;
17
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070018import static com.google.common.base.Preconditions.checkNotNull;
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080019import java.util.concurrent.ExecutionException;
20import java.util.concurrent.TimeUnit;
21import java.util.concurrent.TimeoutException;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070022
Ray Milkey86ad7bb2018-09-27 12:32:28 -070023import org.apache.karaf.shell.api.action.Argument;
24import org.apache.karaf.shell.api.action.Command;
25import org.apache.karaf.shell.api.action.Option;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070026import org.onosproject.cli.AbstractShellCommand;
27import org.onosproject.net.DeviceId;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070028import org.onosproject.netconf.NetconfController;
29import org.onosproject.netconf.NetconfDevice;
Yuta HIGUCHI234eaf32017-09-06 13:45:05 -070030import org.onosproject.netconf.NetconfException;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070031import org.onosproject.netconf.NetconfSession;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070032
33/**
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080034 * Command that retrieves running configuration and device state.
35 * If configuration cannot be retrieved it prints an error string.
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070036 */
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080037@Command(scope = "onos", name = "netconf-get",
38 description = "Retrieve running configuration and "
39 + "device state information from specified device.")
40public class NetconfGetCommand extends AbstractShellCommand {
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070041
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080042 @Argument(index = 0, name = "deviceId", description = "Device ID",
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070043 required = true, multiValued = false)
44 String uri = null;
45
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080046 @Option(name = "--timeout",
47 description = "Timeout in seconds",
48 required = false)
49 long timeoutSec = 30;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070050
51 @Override
Ray Milkeyd84f89b2018-08-17 14:54:17 -070052 protected void doExecute() {
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080053 DeviceId deviceId = DeviceId.deviceId(uri);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070054
55 NetconfController controller = get(NetconfController.class);
56 checkNotNull(controller, "Netconf controller is null");
57
58 NetconfDevice device = controller.getDevicesMap().get(deviceId);
59 if (device == null) {
60 print("Netconf device object not found for %s", deviceId);
61 return;
62 }
63
64 NetconfSession session = device.getSession();
65 if (session == null) {
66 print("Netconf session not found for %s", deviceId);
67 return;
68 }
69
70 try {
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080071 CharSequence res = session.asyncGet()
72 .get(timeoutSec, TimeUnit.SECONDS);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070073 print("%s", res);
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080074 } catch (NetconfException | InterruptedException | ExecutionException | TimeoutException e) {
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070075 log.error("Configuration could not be retrieved", e);
Frank Wangd8ab0962017-08-11 11:09:30 +080076 print("Error occurred retrieving configuration");
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070077 }
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070078 }
79
80}