blob: 58057ab92a9bccb64f02b10e4d2870dfbb6d9114 [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 HIGUCHI89111d92017-05-04 11:29:17 -070019import static org.onosproject.netconf.DatastoreId.datastore;
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070020
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080021import java.util.concurrent.ExecutionException;
22import java.util.concurrent.TimeUnit;
23import java.util.concurrent.TimeoutException;
24
Ray Milkey86ad7bb2018-09-27 12:32:28 -070025import org.apache.karaf.shell.api.action.Argument;
26import org.apache.karaf.shell.api.action.Command;
27import org.apache.karaf.shell.api.action.Option;
Ray Milkey7a2dee52018-09-28 10:58:28 -070028import org.apache.karaf.shell.api.action.lifecycle.Service;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070029import org.onosproject.cli.AbstractShellCommand;
30import 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/**
37 * Command that gets the configuration of the specified type from the specified
38 * device. 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 HIGUCHI57ba1e12017-04-26 15:51:47 -070041@Command(scope = "onos", name = "netconf-get-config",
42 description = "Gets the configuration of the specified type from the" +
43 "specified device.")
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080044public class NetconfGetConfigCommand 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)
48 String uri = null;
49
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080050 @Argument(index = 1, name = "datastore",
Yuta HIGUCHI89111d92017-05-04 11:29:17 -070051 description = "Configuration datastore name (running, etc.)",
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080052 required = false, multiValued = false)
53 String datastore = "running";
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070054
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080055 @Option(name = "--timeout",
56 description = "Timeout in seconds",
57 required = false)
58 long timeoutSec = 30;
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070059
60 private DeviceId deviceId;
61
62 @Override
Ray Milkeyd84f89b2018-08-17 14:54:17 -070063 protected void doExecute() {
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070064 deviceId = DeviceId.deviceId(uri);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070065
66 NetconfController controller = get(NetconfController.class);
67 checkNotNull(controller, "Netconf controller is null");
68
69 NetconfDevice device = controller.getDevicesMap().get(deviceId);
70 if (device == null) {
71 print("Netconf device object not found for %s", deviceId);
72 return;
73 }
74
75 NetconfSession session = device.getSession();
76 if (session == null) {
77 print("Netconf session not found for %s", deviceId);
78 return;
79 }
80
81 try {
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080082 CharSequence res = session.asyncGetConfig(datastore(datastore.toLowerCase()))
83 .get(timeoutSec, TimeUnit.SECONDS);
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070084 print("%s", res);
Yuta HIGUCHI5ac34432018-02-13 16:29:15 -080085 } catch (NetconfException | InterruptedException | ExecutionException | TimeoutException e) {
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070086 log.error("Configuration could not be retrieved", e);
Frank Wangd8ab0962017-08-11 11:09:30 +080087 print("Error occurred retrieving configuration");
Yuta HIGUCHId31bc6e2017-05-03 17:23:34 -070088 }
Yuta HIGUCHI57ba1e12017-04-26 15:51:47 -070089 }
90
91}