ONOS-3658 - Adding CLI commands to display and manage Device Keys.
Change-Id: I98d7d3b7bc9a61f106a6b79b38d7ddaebbfb3288
diff --git a/cli/src/main/java/org/onosproject/cli/net/DeviceKeyAddCommand.java b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyAddCommand.java
new file mode 100644
index 0000000..2c636ca
--- /dev/null
+++ b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyAddCommand.java
@@ -0,0 +1,81 @@
+/*
+ * Copyright 2016 Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onosproject.cli.net;
+
+import org.apache.karaf.shell.commands.Argument;
+import org.apache.karaf.shell.commands.Command;
+import org.apache.karaf.shell.commands.Option;
+import org.onosproject.cli.AbstractShellCommand;
+import org.onosproject.incubator.net.key.DeviceKey;
+import org.onosproject.incubator.net.key.DeviceKeyAdminService;
+import org.onosproject.incubator.net.key.DeviceKeyId;
+
+/**
+ * Adds a device key.
+ */
+@Command(scope = "onos", name = "device-key-add",
+ description = "Adds a device key. Adding a new device key with " +
+ "the same id will replace the existing device key.")
+
+public class DeviceKeyAddCommand extends AbstractShellCommand {
+
+ private static final String COMMUNITY_NAME = "CommunityName";
+ private static final String USERNAME = "UsernamePassword";
+
+ @Argument(index = 0, name = "id", description = "Device Key ID",
+ required = true, multiValued = false)
+ String id = null;
+
+ @Argument(index = 1, name = "type", description = "Device Key Type, " +
+ "it includes CommunityName, UsernamePassword.",
+ required = true, multiValued = false)
+ String type = null;
+
+ @Option(name = "-c", aliases = "--communityName", description = "Device Key Community Name",
+ required = false, multiValued = false)
+ String communityName = null;
+
+ @Option(name = "-l", aliases = "--label", description = "Device Key Label",
+ required = false, multiValued = false)
+ String label = null;
+
+ @Option(name = "-u", aliases = "--username", description = "Device Key Username",
+ required = false, multiValued = false)
+ String username = null;
+
+ @Option(name = "-p", aliases = "--password", description = "Device Key Password",
+ required = false, multiValued = false)
+ String password = null;
+
+ @Override
+ protected void execute() {
+ DeviceKeyAdminService service = get(DeviceKeyAdminService.class);
+ DeviceKey deviceKey = null;
+ if (type.equalsIgnoreCase(COMMUNITY_NAME)) {
+ deviceKey = DeviceKey.createDeviceKeyUsingCommunityName(DeviceKeyId.deviceKeyId(id),
+ label, communityName);
+ } else if (type.equalsIgnoreCase(USERNAME)) {
+ deviceKey = DeviceKey.createDeviceKeyUsingUsernamePassword(DeviceKeyId.deviceKeyId(id),
+ label, username, password);
+ } else {
+ print("Invalid Device key type: ", type);
+ return;
+ }
+ service.addKey(deviceKey);
+ print("Device Key successfully added.");
+ }
+}
diff --git a/cli/src/main/java/org/onosproject/cli/net/DeviceKeyListCommand.java b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyListCommand.java
new file mode 100644
index 0000000..5d84f59
--- /dev/null
+++ b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyListCommand.java
@@ -0,0 +1,79 @@
+/*
+ * Copyright 2016 Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onosproject.cli.net;
+
+import org.apache.karaf.shell.commands.Command;
+import org.onosproject.cli.AbstractShellCommand;
+import org.onosproject.cli.Comparators;
+import org.onosproject.incubator.net.key.DeviceKey;
+import org.onosproject.incubator.net.key.DeviceKeyService;
+
+import java.util.Collections;
+import java.util.List;
+
+import static com.google.common.collect.Lists.newArrayList;
+
+/**
+ * Lists all device keys.
+ */
+@Command(scope = "onos", name = "device-keys",
+ description = "Lists all device keys")
+
+public class DeviceKeyListCommand extends AbstractShellCommand {
+ private static final String FMT_COMMUNITY_NAME =
+ "identifier=%s, type=%s, community name=%s";
+ private static final String FMT_USERNAME_PASSWORD =
+ "identifier=%s, type=%s, username=%s, password=%s";
+
+ @Override
+ protected void execute() {
+ DeviceKeyService service = get(DeviceKeyService.class);
+ for (DeviceKey deviceKey : getSortedDeviceKeys(service)) {
+ printDeviceKey(deviceKey);
+ }
+ }
+
+ /**
+ * Returns the list of devices keys sorted using the device key identifier.
+ *
+ * @param service device key service
+ * @return sorted device key list
+ */
+ protected List<DeviceKey> getSortedDeviceKeys(DeviceKeyService service) {
+ List<DeviceKey> deviceKeys = newArrayList(service.getDeviceKeys());
+ Collections.sort(deviceKeys, Comparators.DEVICE_KEY_COMPARATOR);
+ return deviceKeys;
+ }
+
+ /**
+ * Prints out each device key.
+ *
+ * @param deviceKey the device key to be printed
+ */
+ private void printDeviceKey(DeviceKey deviceKey) {
+ if (DeviceKey.Type.COMMUNITY_NAME.equals(deviceKey.type())) {
+ print(FMT_COMMUNITY_NAME, deviceKey.deviceKeyId().id(), deviceKey.type(),
+ deviceKey.asCommunityName().name());
+ } else if (DeviceKey.Type.USERNAME_PASSWORD.equals(deviceKey.type())) {
+ print(FMT_USERNAME_PASSWORD, deviceKey.deviceKeyId().id(), deviceKey.type(),
+ deviceKey.asUsernamePassword().username(), deviceKey.asUsernamePassword().password());
+ } else {
+ log.error("Unsupported device key type: " + deviceKey.type());
+ }
+ }
+
+}
diff --git a/cli/src/main/java/org/onosproject/cli/net/DeviceKeyRemoveCommand.java b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyRemoveCommand.java
new file mode 100644
index 0000000..329c9af
--- /dev/null
+++ b/cli/src/main/java/org/onosproject/cli/net/DeviceKeyRemoveCommand.java
@@ -0,0 +1,42 @@
+/*
+ * Copyright 2016 Open Networking Laboratory
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.onosproject.cli.net;
+
+import org.apache.karaf.shell.commands.Argument;
+import org.apache.karaf.shell.commands.Command;
+import org.onosproject.cli.AbstractShellCommand;
+import org.onosproject.incubator.net.key.DeviceKeyAdminService;
+import org.onosproject.incubator.net.key.DeviceKeyId;
+
+/**
+ * Removes a device key.
+ */
+@Command(scope = "onos", name = "device-key-remove",
+ description = "Removes a device key")
+
+public class DeviceKeyRemoveCommand extends AbstractShellCommand {
+
+ @Argument(index = 0, name = "id", description = "Device Key ID",
+ required = true, multiValued = false)
+ String id = null;
+
+ @Override
+ protected void execute() {
+ DeviceKeyAdminService service = get(DeviceKeyAdminService.class);
+ service.removeKey(DeviceKeyId.deviceKeyId(id));
+ }
+}