ifparse: add --yaml flag

This commit is contained in:
Ariadne Conill 2020-11-11 02:50:29 -07:00
parent cfb43e9573
commit 2ec3a39c89

View file

@ -19,6 +19,12 @@
#include <string.h> #include <string.h>
#include <getopt.h> #include <getopt.h>
#include "libifupdown/libifupdown.h" #include "libifupdown/libifupdown.h"
#ifdef CONFIG_YAML
# include "libifupdown/yaml-base.h"
# include "libifupdown/yaml-writer.h"
#endif
#include "cmd/multicall.h" #include "cmd/multicall.h"
#include "cmd/pretty-print-iface.h" #include "cmd/pretty-print-iface.h"
@ -41,9 +47,24 @@ set_allow_undefined(const char *arg)
allow_undefined = true; allow_undefined = true;
} }
#ifdef CONFIG_YAML
static bool use_yaml = false;
static void
set_yaml(const char *arg)
{
(void) arg;
use_yaml = true;
}
#endif
static struct if_option local_options[] = { static struct if_option local_options[] = {
{'A', "all", NULL, "show all interfaces", false, set_show_all}, {'A', "all", NULL, "show all interfaces", false, set_show_all},
{'U', "allow-undefined", NULL, "allow querying undefined (virtual) interfaces", false, set_allow_undefined}, {'U', "allow-undefined", NULL, "allow querying undefined (virtual) interfaces", false, set_allow_undefined},
#ifdef CONFIG_YAML
{'Y', "yaml", NULL, "render output as YAML", false, set_yaml},
#endif
}; };
static struct if_option_group local_option_group = { static struct if_option_group local_option_group = {
@ -52,6 +73,43 @@ static struct if_option_group local_option_group = {
.group = local_options .group = local_options
}; };
#ifdef CONFIG_YAML
static void
prettyprint_interface_yaml(struct lif_interface *iface)
{
struct lif_yaml_node doc = {};
lif_yaml_document_init(&doc, "interfaces");
struct lif_yaml_node *iface_node = lif_yaml_node_new_list(iface->ifname);
lif_yaml_node_append_child(&doc, iface_node);
struct lif_node *iter;
LIF_DICT_FOREACH(iter, &iface->vars)
{
struct lif_dict_entry *entry = iter->data;
const char *value = entry->data;
char addr_buf[512];
if (!strcmp(entry->key, "address"))
{
struct lif_address *addr = entry->data;
if (!lif_address_unparse(addr, addr_buf, sizeof addr_buf, true))
continue;
value = addr_buf;
}
struct lif_yaml_node *iface_entry_node = lif_yaml_node_new_string(entry->key, value);
lif_yaml_node_append_child(iface_node, iface_entry_node);
}
lif_yaml_write(iface_node, stdout);
lif_yaml_node_free(&doc);
}
#endif
int int
ifparse_main(int argc, char *argv[]) ifparse_main(int argc, char *argv[])
{ {
@ -95,6 +153,11 @@ ifparse_main(int argc, char *argv[])
{ {
struct lif_dict_entry *entry = n->data; struct lif_dict_entry *entry = n->data;
#ifdef CONFIG_YAML
if (use_yaml)
prettyprint_interface_yaml(entry->data);
else
#endif
prettyprint_interface_eni(entry->data); prettyprint_interface_eni(entry->data);
} }
@ -122,6 +185,11 @@ ifparse_main(int argc, char *argv[])
return EXIT_FAILURE; return EXIT_FAILURE;
} }
#ifdef CONFIG_YAML
if (use_yaml)
prettyprint_interface_yaml(entry->data);
else
#endif
prettyprint_interface_eni(iface); prettyprint_interface_eni(iface);
} }