summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYamato Sugawara <yamato.sugawara@linecorp.com>2021-10-26 12:21:20 +0000
committerYamato Sugawara <yamato.sugawara@linecorp.com>2021-11-28 23:53:41 +0000
commit559f4b2f2a46823be670cb46f1cd17f56f5f3675 (patch)
tree94796e9cef1c06bd971ca5c840c13176404185a8
parentc786485164de9e75675c32ad1c1f406169637b0f (diff)
zebra: Add support for json output in srv6 locator detail command
Signed-off-by: Yamato Sugawara <yamato.sugawara@linecorp.com>
-rw-r--r--lib/srv6.c88
-rw-r--r--lib/srv6.h3
-rw-r--r--zebra/zebra_srv6_vty.c10
3 files changed, 99 insertions, 2 deletions
diff --git a/lib/srv6.c b/lib/srv6.c
index aacd30a7af..6a658444c6 100644
--- a/lib/srv6.c
+++ b/lib/srv6.c
@@ -171,6 +171,47 @@ json_object *srv6_locator_chunk_json(const struct srv6_locator_chunk *chunk)
return jo_root;
}
+json_object *
+srv6_locator_chunk_detailed_json(const struct srv6_locator_chunk *chunk)
+{
+ json_object *jo_root = NULL;
+
+ jo_root = json_object_new_object();
+
+ /* set prefix */
+ json_object_string_addf(jo_root, "prefix", "%pFX", &chunk->prefix);
+
+ /* set block_bits_length */
+ json_object_int_add(jo_root, "blockBitsLength",
+ chunk->block_bits_length);
+
+ /* set node_bits_length */
+ json_object_int_add(jo_root, "nodeBitsLength", chunk->node_bits_length);
+
+ /* set function_bits_length */
+ json_object_int_add(jo_root, "functionBitsLength",
+ chunk->function_bits_length);
+
+ /* set argument_bits_length */
+ json_object_int_add(jo_root, "argumentBitsLength",
+ chunk->argument_bits_length);
+
+ /* set keep */
+ json_object_int_add(jo_root, "keep", chunk->keep);
+
+ /* set proto */
+ json_object_string_add(jo_root, "proto",
+ zebra_route_string(chunk->proto));
+
+ /* set instance */
+ json_object_int_add(jo_root, "instance", chunk->instance);
+
+ /* set session_id */
+ json_object_int_add(jo_root, "sessionId", chunk->session_id);
+
+ return jo_root;
+}
+
json_object *srv6_locator_json(const struct srv6_locator *loc)
{
struct listnode *node;
@@ -205,3 +246,50 @@ json_object *srv6_locator_json(const struct srv6_locator *loc)
return jo_root;
}
+
+json_object *srv6_locator_detailed_json(const struct srv6_locator *loc)
+{
+ struct listnode *node;
+ struct srv6_locator_chunk *chunk;
+ json_object *jo_root = NULL;
+ json_object *jo_chunk = NULL;
+ json_object *jo_chunks = NULL;
+
+ jo_root = json_object_new_object();
+
+ /* set name */
+ json_object_string_add(jo_root, "name", loc->name);
+
+ /* set prefix */
+ json_object_string_addf(jo_root, "prefix", "%pFX", &loc->prefix);
+
+ /* set block_bits_length */
+ json_object_int_add(jo_root, "blockBitsLength", loc->block_bits_length);
+
+ /* set node_bits_length */
+ json_object_int_add(jo_root, "nodeBitsLength", loc->node_bits_length);
+
+ /* set function_bits_length */
+ json_object_int_add(jo_root, "functionBitsLength",
+ loc->function_bits_length);
+
+ /* set argument_bits_length */
+ json_object_int_add(jo_root, "argumentBitsLength",
+ loc->argument_bits_length);
+
+ /* set algonum */
+ json_object_int_add(jo_root, "algoNum", loc->algonum);
+
+ /* set status_up */
+ json_object_boolean_add(jo_root, "statusUp", loc->status_up);
+
+ /* set chunks */
+ jo_chunks = json_object_new_array();
+ json_object_object_add(jo_root, "chunks", jo_chunks);
+ for (ALL_LIST_ELEMENTS_RO((struct list *)loc->chunks, node, chunk)) {
+ jo_chunk = srv6_locator_chunk_detailed_json(chunk);
+ json_object_array_add(jo_chunks, jo_chunk);
+ }
+
+ return jo_root;
+}
diff --git a/lib/srv6.h b/lib/srv6.h
index 715fc3723b..e0db30cd13 100644
--- a/lib/srv6.h
+++ b/lib/srv6.h
@@ -189,6 +189,9 @@ extern void srv6_locator_free(struct srv6_locator *locator);
extern void srv6_locator_chunk_free(struct srv6_locator_chunk *chunk);
json_object *srv6_locator_chunk_json(const struct srv6_locator_chunk *chunk);
json_object *srv6_locator_json(const struct srv6_locator *loc);
+json_object *srv6_locator_detailed_json(const struct srv6_locator *loc);
+json_object *
+srv6_locator_chunk_detailed_json(const struct srv6_locator_chunk *chunk);
#ifdef __cplusplus
}
diff --git a/zebra/zebra_srv6_vty.c b/zebra/zebra_srv6_vty.c
index cb1e6c4228..bf87696204 100644
--- a/zebra/zebra_srv6_vty.c
+++ b/zebra/zebra_srv6_vty.c
@@ -147,10 +147,16 @@ DEFUN (show_srv6_locator_detail,
struct listnode *node;
char str[256];
const char *locator_name = argv[4]->arg;
+ json_object *json_locator = NULL;
if (uj) {
- vty_out(vty, "JSON format isn't supported\n");
- return CMD_WARNING;
+ locator = zebra_srv6_locator_lookup(locator_name);
+ if (!locator)
+ return CMD_WARNING;
+
+ json_locator = srv6_locator_detailed_json(locator);
+ vty_json(vty, json_locator);
+ return CMD_SUCCESS;
}
for (ALL_LIST_ELEMENTS_RO(srv6->locators, node, locator)) {