A recent patch added "type" and "options" columns to the Logical_Port table in OVN_Northbound. This patch allows you to get and set those columns with ovn-nbctl.
ovn-nbctl should eventually get converted to use the common db-ctl code that was recently added. When that happens, these commands can just be removed. Signed-off-by: Russell Bryant <rbry...@redhat.com> --- ovn/ovn-nbctl.8.xml | 24 ++++++++++-- ovn/ovn-nbctl.c | 111 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 132 insertions(+), 3 deletions(-) diff --git a/ovn/ovn-nbctl.8.xml b/ovn/ovn-nbctl.8.xml index 39ffb35..ba3cc82 100644 --- a/ovn/ovn-nbctl.8.xml +++ b/ovn/ovn-nbctl.8.xml @@ -23,9 +23,7 @@ <h1>Logical Switch Commands</h1> <dl> - <dt><code>lswitch-add</code> [<var>lswitch</var>]</dt> - <dd> - Creates a new logical switch named <var>lswitch</var>. If + <dt><code>lswitch-add</code> [<var>lswitch</var>]</dt> <dd> Creates a new logical switch named <var>lswitch</var>. If <var>lswitch</var> is not provided, the switch will not have a name so other commands must refer to this switch by its UUID. Initially the switch will have no ports. @@ -192,6 +190,26 @@ or <code>disabled</code>. </dd> + <dt><code>lport-set-type</code> <var>lport</var> <var>type</var></dt> + <dd> + Set the type for the logical port. No special types have been implemented yet. + </dd> + + <dt><code>lport-get-type</code> <var>lport</var></dt> + <dd> + Get the type for the logical port. + </dd> + + <dt><code>lport-set-options</code> <var>lport</var> [<var>key=value</var>]...</dt> + <dd> + Set type-specific key-value options for the logical port. + </dd> + + <dt><code>lport-get-options</code> <var>lport</var></dt> + <dd> + Get the type-specific options for the logical port. + </dd> + </dl> <h1>Options</h1> diff --git a/ovn/ovn-nbctl.c b/ovn/ovn-nbctl.c index 8430122..0bdb3a3 100644 --- a/ovn/ovn-nbctl.c +++ b/ovn/ovn-nbctl.c @@ -86,6 +86,11 @@ Logical port commands:\n\ ('enabled' or 'disabled')\n\ lport-get-enabled LPORT get administrative state LPORT\n\ ('enabled' or 'disabled')\n\ + lport-set-type LPORT TYPE Set the type for LPORT\n\ + lport-get-type LPORT Get the type for LPORT\n\ + lport-set-options LPORT KEY=VALUE [KEY=VALUE]...\n\ + Set options related to the type of LPORT\n\ + lport-get-options LPORT Get the type specific options for LPORT\n\ \n\ Options:\n\ --db=DATABASE connect to DATABASE\n\ @@ -627,6 +632,84 @@ do_lport_get_enabled(struct ovs_cmdl_context *ctx) printf("%s\n", (!lport->enabled || *lport->enabled) ? "enabled" : "disabled"); } + +static void +do_lport_set_type(struct ovs_cmdl_context *ctx) +{ + struct nbctl_context *nb_ctx = ctx->pvt; + const char *id = ctx->argv[1]; + const char *type = ctx->argv[2]; + const struct nbrec_logical_port *lport; + + lport = lport_by_name_or_uuid(nb_ctx, id); + if (!lport) { + return; + } + + nbrec_logical_port_set_type(lport, type); +} + +static void +do_lport_get_type(struct ovs_cmdl_context *ctx) +{ + struct nbctl_context *nb_ctx = ctx->pvt; + const char *id = ctx->argv[1]; + const struct nbrec_logical_port *lport; + + lport = lport_by_name_or_uuid(nb_ctx, id); + if (!lport) { + return; + } + + printf("%s\n", lport->type); +} + +static void +do_lport_set_options(struct ovs_cmdl_context *ctx) +{ + struct nbctl_context *nb_ctx = ctx->pvt; + const char *id = ctx->argv[1]; + const struct nbrec_logical_port *lport; + size_t i; + struct smap options = SMAP_INITIALIZER(&options); + + lport = lport_by_name_or_uuid(nb_ctx, id); + if (!lport) { + return; + } + + for (i = 2; i < ctx->argc; i++) { + char *key, *value; + value = xstrdup(ctx->argv[i]); + key = strsep(&value, "="); + if (value) { + smap_add(&options, key, value); + } + free(key); + } + + nbrec_logical_port_set_options(lport, &options); + + smap_destroy(&options); +} + +static void +do_lport_get_options(struct ovs_cmdl_context *ctx) +{ + struct nbctl_context *nb_ctx = ctx->pvt; + const char *id = ctx->argv[1]; + const struct nbrec_logical_port *lport; + struct smap_node *node; + + lport = lport_by_name_or_uuid(nb_ctx, id); + if (!lport) { + return; + } + + SMAP_FOR_EACH(node, &lport->options) { + printf("%s=%s\n", node->key, node->value); + } +} static void parse_options(int argc, char *argv[]) @@ -828,6 +911,34 @@ static const struct ovs_cmdl_command all_commands[] = { .max_args = 1, .handler = do_lport_get_enabled, }, + { + .name = "lport-set-type", + .usage = "LPORT TYPE", + .min_args = 2, + .max_args = 2, + .handler = do_lport_set_type, + }, + { + .name = "lport-get-type", + .usage = "LPORT", + .min_args = 1, + .max_args = 1, + .handler = do_lport_get_type, + }, + { + .name = "lport-set-options", + .usage = "LPORT KEY=VALUE [KEY=VALUE]...", + .min_args = 1, + .max_args = INT_MAX, + .handler = do_lport_set_options + }, + { + .name = "lport-get-options", + .usage = "LPORT", + .min_args = 1, + .max_args = 1, + .handler = do_lport_get_options, + }, { /* sentinel */ -- 2.4.3 _______________________________________________ dev mailing list dev@openvswitch.org http://openvswitch.org/mailman/listinfo/dev