summaryrefslogtreecommitdiff
path: root/lib/srv6.c
diff options
context:
space:
mode:
authorDonatas Abraitis <donatas@opensourcerouting.org>2024-08-08 22:39:34 +0300
committerGitHub <noreply@github.com>2024-08-08 22:39:34 +0300
commit536d478049b4ae7c3d60676a75a56115491d9b6f (patch)
tree9f043e62b3f9c8678349377e08a28398b6f3b8c9 /lib/srv6.c
parent7b8ca3e2ed6e7f98a63633c7dc91a9f0d12c576a (diff)
parent5d027fc79194870d26d14373d5c15f2ea4d58bd5 (diff)
Merge pull request #16535 from pguibert6WIND/srv6_nexthop_context
lib: add seg6localContext json attribute in nexthop information
Diffstat (limited to 'lib/srv6.c')
-rw-r--r--lib/srv6.c38
1 files changed, 38 insertions, 0 deletions
diff --git a/lib/srv6.c b/lib/srv6.c
index 883d429b62..e6fc375fbb 100644
--- a/lib/srv6.c
+++ b/lib/srv6.c
@@ -71,6 +71,44 @@ int snprintf_seg6_segs(char *str,
return strlen(str);
}
+void seg6local_context2json(const struct seg6local_context *ctx,
+ uint32_t action, json_object *json)
+{
+ switch (action) {
+ case ZEBRA_SEG6_LOCAL_ACTION_END:
+ json_object_boolean_add(json, "USP", true);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_X:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DX6:
+ json_object_string_addf(json, "nh6", "%pI6", &ctx->nh6);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DX4:
+ json_object_string_addf(json, "nh4", "%pI4", &ctx->nh4);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_T:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DT6:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DT4:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DT46:
+ json_object_int_add(json, "table", ctx->table);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_DX2:
+ json_object_boolean_add(json, "none", true);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_B6:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_B6_ENCAP:
+ json_object_string_addf(json, "nh6", "%pI6", &ctx->nh6);
+ return;
+ case ZEBRA_SEG6_LOCAL_ACTION_END_BM:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_S:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_AS:
+ case ZEBRA_SEG6_LOCAL_ACTION_END_AM:
+ case ZEBRA_SEG6_LOCAL_ACTION_UNSPEC:
+ default:
+ json_object_boolean_add(json, "unknown", true);
+ return;
+ }
+}
+
const char *seg6local_context2str(char *str, size_t size,
const struct seg6local_context *ctx,
uint32_t action)