blob: c99e11ee377aad891f5e2c3a1e4bc32024a623cb [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;
Ray Milkeyec20a292018-10-11 15:53:33 -070025import org.apache.karaf.shell.api.action.Completion;
Ray Milkey86ad7bb2018-09-27 12:32:28 -070026import org.apache.karaf.shell.api.action.Option;
Ray Milkey7a2dee52018-09-28 10:58:28 -070027import org.apache.karaf.shell.api.action.lifecycle.Service;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070028import org.onosproject.cli.AbstractShellCommand;
Ray Milkeyec20a292018-10-11 15:53:33 -070029import org.onosproject.cli.net.DeviceIdCompleter;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070030import org.onosproject.net.DeviceId;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070031import org.onosproject.netconf.NetconfController;
32import org.onosproject.netconf.NetconfDevice;
Yuta HIGUCHI234eaf32017-09-06 13:45:05 -070033import org.onosproject.netconf.NetconfException;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070034import org.onosproject.netconf.NetconfSession;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070035
36/**
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080037 * Command that retrieves running configuration and device state.
38 * If configuration cannot be retrieved it prints an error string.
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070039 */
Ray Milkey7a2dee52018-09-28 10:58:28 -070040@Service
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080041@Command(scope = "onos", name = "netconf-get",
42 description = "Retrieve running configuration and "
43 + "device state information from specified device.")
44public class NetconfGetCommand extends AbstractShellCommand {
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070045
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080046 @Argument(index = 0, name = "deviceId", description = "Device ID",
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070047 required = true, multiValued = false)
Ray Milkeyec20a292018-10-11 15:53:33 -070048 @Completion(DeviceIdCompleter.class)
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070049 String uri = null;
50
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080051 @Option(name = "--timeout",
52 description = "Timeout in seconds",
53 required = false)
54 long timeoutSec = 30;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070055
56 @Override
Ray Milkeyd84f89b2018-08-17 14:54:17 -070057 protected void doExecute() {
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080058 DeviceId deviceId = DeviceId.deviceId(uri);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070059
60 NetconfController controller = get(NetconfController.class);
61 checkNotNull(controller, "Netconf controller is null");
62
63 NetconfDevice device = controller.getDevicesMap().get(deviceId);
64 if (device == null) {
65 print("Netconf device object not found for %s", deviceId);
66 return;
67 }
68
69 NetconfSession session = device.getSession();
70 if (session == null) {
71 print("Netconf session not found for %s", deviceId);
72 return;
73 }
74
75 try {
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080076 CharSequence res = session.asyncGet()
77 .get(timeoutSec, TimeUnit.SECONDS);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070078 print("%s", res);
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080079 } catch (NetconfException | InterruptedException | ExecutionException | TimeoutException e) {
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070080 log.error("Configuration could not be retrieved", e);
Frank Wangd8ab0962017-08-11 11:09:30 +080081 print("Error occurred retrieving configuration");
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070082 }
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070083 }
84
85}