[libvirt] [PATCHv4 5/7] interface: expose network config transaction API to virsh
Daniel P. Berrange
berrange at redhat.com
Fri May 27 13:12:41 UTC 2011
On Thu, May 26, 2011 at 12:17:43PM -0400, Laine Stump wrote:
> From: Michal Privoznik <mprivozn at redhat.com>
>
> This implements the commands iface-begin, iface-commit, and iface-rollback,
> which simply call the corresponding functions in the libvirt API.
>
> change from previous version: follow the same pattern as other virsh commands.
> ---
> tools/virsh.c | 91 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
> 1 files changed, 91 insertions(+), 0 deletions(-)
>
> diff --git a/tools/virsh.c b/tools/virsh.c
> index de49489..e3bb81b 100644
> --- a/tools/virsh.c
> +++ b/tools/virsh.c
> @@ -5118,6 +5118,91 @@ cmdInterfaceDestroy(vshControl *ctl, const vshCmd *cmd)
> return ret;
> }
>
> +/*
> + * "iface-begin" command
> + */
> +static const vshCmdInfo info_interface_begin[] = {
> + {"help", N_("create a snapshot of current interfaces settings, "
> + "which can be later commited (iface-commit) or "
> + "restored (iface-rollback)")},
> + {"desc", N_("Create a restore point for interfaces settings")},
> + {NULL, NULL}
> +};
> +
> +static const vshCmdOptDef opts_interface_begin[] = {
> + {NULL, 0, 0, NULL}
> +};
> +
> +static bool
> +cmdInterfaceBegin(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
> +{
> + if (!vshConnectionUsability(ctl, ctl->conn))
> + return false;
> +
> + if (virInterfaceChangeBegin(ctl->conn, 0) < 0) {
> + vshError(ctl, "%s", _("Failed to begin network config change transaction"));
> + return false;
> + }
> +
> + vshPrint(ctl, "%s", _("Network config change transaction started\n"));
> + return true;
> +}
> +
> +/*
> + * "iface-commit" command
> + */
> +static const vshCmdInfo info_interface_commit[] = {
> + {"help", N_("commit changes made since iface-begin and free restore point")},
> + {"desc", N_("commit changes and free restore point")},
> + {NULL, NULL}
> +};
> +
> +static const vshCmdOptDef opts_interface_commit[] = {
> + {NULL, 0, 0, NULL}
> +};
> +
> +static bool
> +cmdInterfaceCommit(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
> +{
> + if (!vshConnectionUsability(ctl, ctl->conn))
> + return false;
> +
> + if (virInterfaceChangeCommit(ctl->conn, 0) < 0) {
> + vshError(ctl, "%s", _("Failed to commit network config change transaction"));
> + return false;
> + }
> +
> + vshPrint(ctl, "%s", _("Network config change transaction committed\n"));
> + return true;
> +}
> +
> +/*
> + * "iface-rollback" command
> + */
> +static const vshCmdInfo info_interface_rollback[] = {
> + {"help", N_("rollback to previous saved configuration created via iface-begin")},
> + {"desc", N_("rollback to previous restore point")},
> + {NULL, NULL}
> +};
> +
> +static const vshCmdOptDef opts_interface_rollback[] = {
> + {NULL, 0, 0, NULL}
> +};
> +
> +static bool
> +cmdInterfaceRollback(vshControl *ctl, const vshCmd *cmd ATTRIBUTE_UNUSED)
> +{
> + if (!vshConnectionUsability(ctl, ctl->conn))
> + return false;
> +
> + if (virInterfaceChangeRollback(ctl->conn, 0) < 0) {
> + vshError(ctl, "%s", _("Failed to rollback network config change transaction"));
> + return false;
> + }
> +
> + vshPrint(ctl, "%s", _("Network config change transaction rolled back\n"));
> + return true;
> +}
>
> /*
> * "nwfilter-define" command
> @@ -10933,6 +11018,12 @@ static const vshCmdDef ifaceCmds[] = {
> info_interface_start, 0},
> {"iface-undefine", cmdInterfaceUndefine, opts_interface_undefine,
> info_interface_undefine, 0},
> + {"iface-begin", cmdInterfaceBegin, opts_interface_begin,
> + info_interface_begin, 0},
> + {"iface-commit", cmdInterfaceCommit, opts_interface_commit,
> + info_interface_commit, 0},
> + {"iface-rollback", cmdInterfaceRollback, opts_interface_rollback,
> + info_interface_rollback, 0},
> {NULL, NULL, NULL, NULL, 0}
> };
ACK,
Though we will be wanting a followup patch for virsh.pod to add docs
for this
Daniel
--
|: http://berrange.com -o- http://www.flickr.com/photos/dberrange/ :|
|: http://libvirt.org -o- http://virt-manager.org :|
|: http://autobuild.org -o- http://search.cpan.org/~danberr/ :|
|: http://entangle-photo.org -o- http://live.gnome.org/gtk-vnc :|
More information about the libvir-list
mailing list