mirror of
https://github.com/libvirt/libvirt.git
synced 2025-02-25 18:55:26 -06:00
Tue Feb 14 15:03:22 EST 2007 Mark McLoughlin <markmc@redhat.com>
* src/virsh.c: Re-name some of the VSH_DOMBYFOO stuff to VSH_BYFOO in order to re-use it for the network stuff.
This commit is contained in:
parent
4e6c38e10f
commit
c3373b92a0
107
ChangeLog
107
ChangeLog
@ -1,108 +1,21 @@
|
|||||||
Tue Feb 14 16:02:23 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 15:03:22 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* configure.in: add --disable-bridge-params, check
|
|
||||||
for libsysfs and various kernel headers
|
|
||||||
|
|
||||||
* bridge.[ch]: add code for managing bridges
|
|
||||||
|
|
||||||
* qemud/Makefile.am: add bridge.[ch] and link against
|
|
||||||
libsysfs if enabled.
|
|
||||||
|
|
||||||
* qemud/conf.c: add support for bridge config.
|
|
||||||
|
|
||||||
* qemud/internal.h: add various bridging bits
|
|
||||||
|
|
||||||
* qemud/qemud.c: implement qemudStartNetworkDaemon()
|
|
||||||
and qemudShutdownNetworkDaemon().
|
|
||||||
|
|
||||||
Tue Feb 14 15:55:02 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* qemud/conf.[ch]: implement parsing and saving network
|
|
||||||
configs.
|
|
||||||
|
|
||||||
* qemud/driver.c: flesh out the stubs
|
|
||||||
|
|
||||||
* qemud/internal.h: add networks list etc. to
|
|
||||||
struct qemud_server
|
|
||||||
|
|
||||||
* qemud/qemud.c: add qemudStartNetworkDaemon() and
|
|
||||||
qemudShutdownNetworkDaemon() stubs.
|
|
||||||
|
|
||||||
Tue Feb 14 15:52:34 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* qemud/protocol.h: add the protocol for virtual networks
|
|
||||||
|
|
||||||
* qemud/dispatch.c: implement the protocol
|
|
||||||
|
|
||||||
* qemud/driver.[ch]: add stubs for the driver
|
|
||||||
|
|
||||||
* qemud/internal.h: add struct qemud_network
|
|
||||||
|
|
||||||
* src/qemu_internal.c: add a virtual networks driver
|
|
||||||
|
|
||||||
Tue Feb 14 15:43:28 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* src/virsh.c: add the net-* commands.
|
|
||||||
|
|
||||||
Tue Feb 14 15:37:17 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
Note: potential ABI break here, but people should
|
|
||||||
only really be using virError structs returned from
|
|
||||||
libvirt itself.
|
|
||||||
|
|
||||||
* include/libvirt/virterror.h: add virNetwork
|
|
||||||
to virError
|
|
||||||
|
|
||||||
* src/internal.h, src/virterror.c: add network param
|
|
||||||
to __virRaiseError()
|
|
||||||
|
|
||||||
* src/conf.c, src/hash.c, src/libvirt.c, src/proxy_internal.c,
|
|
||||||
src/qemu_internal.c, src/sexpr.c, src/test.c, src/xen_internal.c,
|
|
||||||
src/xend_internal.c, src/xm_internal.c, src/xml.c, src/xmlrpc.c,
|
|
||||||
src/xs_internal.c: update.
|
|
||||||
|
|
||||||
Tue Feb 14 15:33:05 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* include/libvirt/libvirt.h.in: add the networks APIs
|
|
||||||
|
|
||||||
* include/libvirt/virterror.h: add some error codes
|
|
||||||
|
|
||||||
* src/driver.h: add network driver vtable
|
|
||||||
|
|
||||||
* src/hash.c: add networks hash
|
|
||||||
|
|
||||||
* src/internal.h: add virNetwork
|
|
||||||
|
|
||||||
* src/libvirt.c: hook up the APIs to the network
|
|
||||||
driver
|
|
||||||
|
|
||||||
* src/libvirt_sym.version: add the new APIs
|
|
||||||
|
|
||||||
* src/virterror.c: handle the new error codes
|
|
||||||
|
|
||||||
Tue Feb 14 15:07:26 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* src/conf.h: fix merge error - remove the argc argument
|
|
||||||
from qemudBuildCommandLine()
|
|
||||||
|
|
||||||
Tue Feb 14 15:03:22 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|
||||||
|
|
||||||
* src/virsh.c: Re-name some of the VSH_DOMBYFOO stuff
|
* src/virsh.c: Re-name some of the VSH_DOMBYFOO stuff
|
||||||
to VSH_BYFOO in order to re-use it for the network stuff.
|
to VSH_BYFOO in order to re-use it for the network stuff.
|
||||||
|
|
||||||
Tue Feb 14 14:58:35 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:58:35 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* src/hash.c, src/internal.h: Re-name virConnect->domains_mux
|
* src/hash.c, src/internal.h: Re-name virConnect->domains_mux
|
||||||
to virConnect->hashes_mux since it will also be used to
|
to virConnect->hashes_mux since it will also be used to
|
||||||
protect the networks hash.
|
protect the networks hash.
|
||||||
|
|
||||||
Tue Feb 14 14:57:52 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:57:52 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* qemud/conf.c: qemudSaveConfig() will always report a
|
* qemud/conf.c: qemudSaveConfig() will always report a
|
||||||
more specific error, so we should avoid overwriting
|
more specific error, so we should avoid overwriting
|
||||||
this error.
|
this error.
|
||||||
|
|
||||||
Tue Feb 14 14:54:25 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:54:25 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* qemud/qemud.c: Re-factor out qemudExec() so that it can
|
* qemud/qemud.c: Re-factor out qemudExec() so that it can
|
||||||
be used to launch dnsmasq.
|
be used to launch dnsmasq.
|
||||||
@ -110,7 +23,7 @@ Tue Feb 14 14:54:25 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|||||||
* qemud/conf.c: don't return argc from qemudBuildCommandLine()
|
* qemud/conf.c: don't return argc from qemudBuildCommandLine()
|
||||||
as exec() doesn't need it.
|
as exec() doesn't need it.
|
||||||
|
|
||||||
Tue Feb 14 14:52:12 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:52:12 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* qemud/conf.c: Re-factor bits of conf.c so that:
|
* qemud/conf.c: Re-factor bits of conf.c so that:
|
||||||
|
|
||||||
@ -120,25 +33,25 @@ Tue Feb 14 14:52:12 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|||||||
- split qemudScanConfigDir() out so that qemudScanConfigs()
|
- split qemudScanConfigDir() out so that qemudScanConfigs()
|
||||||
can scan multiple configDirs
|
can scan multiple configDirs
|
||||||
|
|
||||||
Tue Feb 14 14:50:22 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:50:22 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* qemud/conf.c: handle an unspecified MAC address,
|
* qemud/conf.c: handle an unspecified MAC address,
|
||||||
fix the argv freeing code in qemudBuildCommandLine()
|
fix the argv freeing code in qemudBuildCommandLine()
|
||||||
and fix copy and paste error in qemudGenerateXML()
|
and fix copy and paste error in qemudGenerateXML()
|
||||||
|
|
||||||
Tue Feb 14 14:42:38 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:42:38 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* src/internal.h: add virConnect->qemud_fd so that
|
* src/internal.h: add virConnect->qemud_fd so that
|
||||||
xen and qemu don't share the handle member.
|
xen and qemu don't share the handle member.
|
||||||
|
|
||||||
* src/hash.c, src/qemu_internal.c: update
|
* src/hash.c, src/qemu_internal.c: update
|
||||||
|
|
||||||
Tue Feb 14 14:40:52 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:40:52 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* qemud/conf.c, qemud/dispatch.c, qemud/driver.c,
|
* qemud/conf.c, qemud/dispatch.c, qemud/driver.c,
|
||||||
qemud/qemud.c: include autoconf's config.h
|
qemud/qemud.c: include autoconf's config.h
|
||||||
|
|
||||||
Tue Feb 14 14:39:18 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:39:18 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* conf.[ch]: rename from config.[ch] so we can use
|
* conf.[ch]: rename from config.[ch] so we can use
|
||||||
autoconf's config.h
|
autoconf's config.h
|
||||||
@ -147,7 +60,7 @@ Tue Feb 14 14:39:18 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
|||||||
|
|
||||||
* driver.c, qemud.c: upd.
|
* driver.c, qemud.c: upd.
|
||||||
|
|
||||||
Tue Feb 14 14:33:22 IST 2007 Mark McLoughlin <markmc@redhat.com>
|
Tue Feb 14 14:33:22 EST 2007 Mark McLoughlin <markmc@redhat.com>
|
||||||
|
|
||||||
* autogen.sh: run autoheader
|
* autogen.sh: run autoheader
|
||||||
|
|
||||||
|
507
src/virsh.c
507
src/virsh.c
@ -206,14 +206,6 @@ static virDomainPtr vshCommandOptDomainBy(vshControl * ctl, vshCmd * cmd,
|
|||||||
vshCommandOptDomainBy(_ctl, _cmd, _optname, _name, \
|
vshCommandOptDomainBy(_ctl, _cmd, _optname, _name, \
|
||||||
VSH_BYID|VSH_BYUUID|VSH_BYNAME)
|
VSH_BYID|VSH_BYUUID|VSH_BYNAME)
|
||||||
|
|
||||||
static virNetworkPtr vshCommandOptNetworkBy(vshControl * ctl, vshCmd * cmd,
|
|
||||||
const char *optname, char **name, int flag);
|
|
||||||
|
|
||||||
/* default is lookup by Name and UUID */
|
|
||||||
#define vshCommandOptNetwork(_ctl, _cmd, _optname, _name) \
|
|
||||||
vshCommandOptNetworkBy(_ctl, _cmd, _optname, _name, \
|
|
||||||
VSH_BYUUID|VSH_BYNAME)
|
|
||||||
|
|
||||||
static void vshPrintExtra(vshControl * ctl, const char *format, ...);
|
static void vshPrintExtra(vshControl * ctl, const char *format, ...);
|
||||||
static void vshDebug(vshControl * ctl, int level, const char *format, ...);
|
static void vshDebug(vshControl * ctl, int level, const char *format, ...);
|
||||||
|
|
||||||
@ -1633,459 +1625,6 @@ cmdDomuuid(vshControl * ctl, vshCmd * cmd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-create" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_create[] = {
|
|
||||||
{"syntax", "create a network from an XML <file>"},
|
|
||||||
{"help", gettext_noop("create a network from an XML file")},
|
|
||||||
{"desc", gettext_noop("Create a network.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_create[] = {
|
|
||||||
{"file", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("file containing an XML network description")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkCreate(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
char *from;
|
|
||||||
int found;
|
|
||||||
int ret = TRUE;
|
|
||||||
char buffer[BUFSIZ];
|
|
||||||
int fd, l;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
from = vshCommandOptString(cmd, "file", &found);
|
|
||||||
if (!found)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
fd = open(from, O_RDONLY);
|
|
||||||
if (fd < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to read description file %s"), from);
|
|
||||||
return(FALSE);
|
|
||||||
}
|
|
||||||
l = read(fd, &buffer[0], sizeof(buffer));
|
|
||||||
if ((l <= 0) || (l >= (int) sizeof(buffer))) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to read description file %s"), from);
|
|
||||||
close(fd);
|
|
||||||
return(FALSE);
|
|
||||||
}
|
|
||||||
buffer[l] = 0;
|
|
||||||
network = virNetworkCreateXML(ctl->conn, &buffer[0]);
|
|
||||||
if (network != NULL) {
|
|
||||||
vshPrint(ctl, _("Network %s created from %s\n"),
|
|
||||||
virNetworkGetName(network), from);
|
|
||||||
} else {
|
|
||||||
vshError(ctl, FALSE, _("Failed to create network from %s"), from);
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-define" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_define[] = {
|
|
||||||
{"syntax", "define a network from an XML <file>"},
|
|
||||||
{"help", gettext_noop("define (but don't start) a network from an XML file")},
|
|
||||||
{"desc", gettext_noop("Define a network.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_define[] = {
|
|
||||||
{"file", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("file conatining an XML network description")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkDefine(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
char *from;
|
|
||||||
int found;
|
|
||||||
int ret = TRUE;
|
|
||||||
char buffer[BUFSIZ];
|
|
||||||
int fd, l;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
from = vshCommandOptString(cmd, "file", &found);
|
|
||||||
if (!found)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
fd = open(from, O_RDONLY);
|
|
||||||
if (fd < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to read description file %s"), from);
|
|
||||||
return(FALSE);
|
|
||||||
}
|
|
||||||
l = read(fd, &buffer[0], sizeof(buffer));
|
|
||||||
if ((l <= 0) || (l >= (int) sizeof(buffer))) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to read description file %s"), from);
|
|
||||||
close(fd);
|
|
||||||
return(FALSE);
|
|
||||||
}
|
|
||||||
buffer[l] = 0;
|
|
||||||
network = virNetworkDefineXML(ctl->conn, &buffer[0]);
|
|
||||||
if (network != NULL) {
|
|
||||||
vshPrint(ctl, _("Network %s defined from %s\n"),
|
|
||||||
virNetworkGetName(network), from);
|
|
||||||
} else {
|
|
||||||
vshError(ctl, FALSE, _("Failed to define network from %s"), from);
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-destroy" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_destroy[] = {
|
|
||||||
{"syntax", "net-destroy <network>"},
|
|
||||||
{"help", gettext_noop("destroy a network")},
|
|
||||||
{"desc", gettext_noop("Destroy a given network.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_destroy[] = {
|
|
||||||
{"network", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("network name, id or uuid")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkDestroy(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
int ret = TRUE;
|
|
||||||
char *name;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (!(network = vshCommandOptNetwork(ctl, cmd, "network", &name)))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (virNetworkDestroy(network) == 0) {
|
|
||||||
vshPrint(ctl, _("Network %s destroyed\n"), name);
|
|
||||||
} else {
|
|
||||||
vshError(ctl, FALSE, _("Failed to destroy network %s"), name);
|
|
||||||
ret = FALSE;
|
|
||||||
virNetworkFree(network);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-dumpxml" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_dumpxml[] = {
|
|
||||||
{"syntax", "net-dumpxml <name>"},
|
|
||||||
{"help", gettext_noop("network information in XML")},
|
|
||||||
{"desc", gettext_noop("Ouput the network information as an XML dump to stdout.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_dumpxml[] = {
|
|
||||||
{"network", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("network name, id or uuid")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkDumpXML(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
int ret = TRUE;
|
|
||||||
char *dump;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (!(network = vshCommandOptNetwork(ctl, cmd, "network", NULL)))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
dump = virNetworkGetXMLDesc(network, 0);
|
|
||||||
if (dump != NULL) {
|
|
||||||
printf("%s", dump);
|
|
||||||
free(dump);
|
|
||||||
} else {
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
virNetworkFree(network);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-list" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_list[] = {
|
|
||||||
{"syntax", "net-list [ --inactive | --all ]"},
|
|
||||||
{"help", gettext_noop("list networks")},
|
|
||||||
{"desc", gettext_noop("Returns list of networks.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_list[] = {
|
|
||||||
{"inactive", VSH_OT_BOOL, 0, gettext_noop("list inactive networks")},
|
|
||||||
{"all", VSH_OT_BOOL, 0, gettext_noop("list inactive & active networks")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkList(vshControl * ctl, vshCmd * cmd ATTRIBUTE_UNUSED)
|
|
||||||
{
|
|
||||||
int inactive = vshCommandOptBool(cmd, "inactive");
|
|
||||||
int all = vshCommandOptBool(cmd, "all");
|
|
||||||
int active = !inactive || all ? 1 : 0;
|
|
||||||
int maxactive = 0, maxinactive = 0, i;
|
|
||||||
const char **activeNames = NULL, **inactiveNames = NULL;
|
|
||||||
inactive |= all;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (active) {
|
|
||||||
maxactive = virConnectNumOfNetworks(ctl->conn);
|
|
||||||
if (maxactive < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to list active networks"));
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
if (maxactive) {
|
|
||||||
activeNames = vshMalloc(ctl, sizeof(int) * maxactive);
|
|
||||||
|
|
||||||
if ((maxactive = virConnectListNetworks(ctl->conn, &activeNames[0], maxactive)) < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to list active networks"));
|
|
||||||
free(activeNames);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
qsort(&activeNames[0], maxactive, sizeof(int), namesorter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (inactive) {
|
|
||||||
maxinactive = virConnectNumOfDefinedNetworks(ctl->conn);
|
|
||||||
if (maxinactive < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to list inactive networks"));
|
|
||||||
if (activeNames)
|
|
||||||
free(activeNames);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
if (maxinactive) {
|
|
||||||
inactiveNames = vshMalloc(ctl, sizeof(char *) * maxinactive);
|
|
||||||
|
|
||||||
if ((maxinactive = virConnectListDefinedNetworks(ctl->conn, inactiveNames, maxinactive)) < 0) {
|
|
||||||
vshError(ctl, FALSE, _("Failed to list inactive networks"));
|
|
||||||
if (activeNames)
|
|
||||||
free(activeNames);
|
|
||||||
free(inactiveNames);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
qsort(&inactiveNames[0], maxinactive, sizeof(char*), namesorter);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
vshPrintExtra(ctl, "%-20s\n", _("Name"));
|
|
||||||
vshPrintExtra(ctl, "----------------------------------\n");
|
|
||||||
|
|
||||||
for (i = 0; i < maxactive; i++) {
|
|
||||||
virNetworkPtr network = virNetworkLookupByName(ctl->conn, activeNames[i]);
|
|
||||||
|
|
||||||
/* this kind of work with networks is not atomic operation */
|
|
||||||
if (!network) {
|
|
||||||
free(activeNames[i]);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
vshPrint(ctl, "%-20s\n",
|
|
||||||
virNetworkGetName(network));
|
|
||||||
virNetworkFree(network);
|
|
||||||
free(activeNames[i]);
|
|
||||||
}
|
|
||||||
for (i = 0; i < maxinactive; i++) {
|
|
||||||
virNetworkPtr network = virNetworkLookupByName(ctl->conn, inactiveNames[i]);
|
|
||||||
|
|
||||||
/* this kind of work with networks is not atomic operation */
|
|
||||||
if (!network) {
|
|
||||||
free(inactiveNames[i]);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
vshPrint(ctl, "%-20s\n",
|
|
||||||
inactiveNames[i]);
|
|
||||||
|
|
||||||
virNetworkFree(network);
|
|
||||||
free(inactiveNames[i]);
|
|
||||||
}
|
|
||||||
if (activeNames)
|
|
||||||
free(activeNames);
|
|
||||||
if (inactiveNames)
|
|
||||||
free(inactiveNames);
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-name" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_name[] = {
|
|
||||||
{"syntax", "net-name <network>"},
|
|
||||||
{"help", gettext_noop("convert a network UUID to network name")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_name[] = {
|
|
||||||
{"network", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("network uuid")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkName(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
if (!(network = vshCommandOptNetworkBy(ctl, cmd, "network", NULL,
|
|
||||||
VSH_BYUUID)))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
vshPrint(ctl, "%s\n", virNetworkGetName(network));
|
|
||||||
virNetworkFree(network);
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-start" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_start[] = {
|
|
||||||
{"syntax", "start <network>"},
|
|
||||||
{"help", gettext_noop("start a (previously defined) inactive network")},
|
|
||||||
{"desc", gettext_noop("Start a network.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_start[] = {
|
|
||||||
{"name", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("name of the inactive network")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkStart(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
char *name;
|
|
||||||
int found;
|
|
||||||
int ret = TRUE;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
name = vshCommandOptString(cmd, "name", &found);
|
|
||||||
if (!found)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
network = virNetworkLookupByName(ctl->conn, name);
|
|
||||||
if (!network)
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (virNetworkCreate(network) == 0) {
|
|
||||||
vshPrint(ctl, _("Network %s started\n"),
|
|
||||||
name);
|
|
||||||
} else {
|
|
||||||
vshError(ctl, FALSE, _("Failed to start network %s"), name);
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-undefine" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_undefine[] = {
|
|
||||||
{"syntax", "net-undefine <network>"},
|
|
||||||
{"help", gettext_noop("undefine an inactive network")},
|
|
||||||
{"desc", gettext_noop("Undefine the configuration for an inactive network.")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_undefine[] = {
|
|
||||||
{"network", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("network name or uuid")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkUndefine(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
int ret = TRUE;
|
|
||||||
char *name;
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (!(network = vshCommandOptNetwork(ctl, cmd, "network", &name)))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (virNetworkUndefine(network) == 0) {
|
|
||||||
vshPrint(ctl, _("Network %s has been undefined\n"), name);
|
|
||||||
} else {
|
|
||||||
vshError(ctl, FALSE, _("Failed to undefine network %s"), name);
|
|
||||||
ret = FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* "net-uuid" command
|
|
||||||
*/
|
|
||||||
static vshCmdInfo info_network_uuid[] = {
|
|
||||||
{"syntax", "net-uuid <network>"},
|
|
||||||
{"help", gettext_noop("convert a network name to network UUID")},
|
|
||||||
{NULL, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static vshCmdOptDef opts_network_uuid[] = {
|
|
||||||
{"network", VSH_OT_DATA, VSH_OFLAG_REQ, gettext_noop("network name")},
|
|
||||||
{NULL, 0, 0, NULL}
|
|
||||||
};
|
|
||||||
|
|
||||||
static int
|
|
||||||
cmdNetworkUuid(vshControl * ctl, vshCmd * cmd)
|
|
||||||
{
|
|
||||||
virNetworkPtr network;
|
|
||||||
char uuid[VIR_UUID_STRING_BUFLEN];
|
|
||||||
|
|
||||||
if (!vshConnectionUsability(ctl, ctl->conn, TRUE))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (!(network = vshCommandOptNetworkBy(ctl, cmd, "network", NULL,
|
|
||||||
VSH_BYNAME)))
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
if (virNetworkGetUUIDString(network, uuid) != -1)
|
|
||||||
vshPrint(ctl, "%s\n", uuid);
|
|
||||||
else
|
|
||||||
vshError(ctl, FALSE, _("failed to get network UUID"));
|
|
||||||
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* "version" command
|
* "version" command
|
||||||
*/
|
*/
|
||||||
@ -2282,15 +1821,6 @@ static vshCmdDef commands[] = {
|
|||||||
{"dumpxml", cmdDumpXML, opts_dumpxml, info_dumpxml},
|
{"dumpxml", cmdDumpXML, opts_dumpxml, info_dumpxml},
|
||||||
{"help", cmdHelp, opts_help, info_help},
|
{"help", cmdHelp, opts_help, info_help},
|
||||||
{"list", cmdList, opts_list, info_list},
|
{"list", cmdList, opts_list, info_list},
|
||||||
{"net-create", cmdNetworkCreate, opts_network_create, info_network_create},
|
|
||||||
{"net-define", cmdNetworkDefine, opts_network_define, info_network_define},
|
|
||||||
{"net-destroy", cmdNetworkDestroy, opts_network_destroy, info_network_destroy},
|
|
||||||
{"net-dumpxml", cmdNetworkDumpXML, opts_network_dumpxml, info_network_dumpxml},
|
|
||||||
{"net-list", cmdNetworkList, opts_network_list, info_network_list},
|
|
||||||
{"net-name", cmdNetworkName, opts_network_name, info_network_name},
|
|
||||||
{"net-start", cmdNetworkStart, opts_network_start, info_network_start},
|
|
||||||
{"net-undefine", cmdNetworkUndefine, opts_network_undefine, info_network_undefine},
|
|
||||||
{"net-uuid", cmdNetworkUuid, opts_network_uuid, info_network_uuid},
|
|
||||||
{"nodeinfo", cmdNodeinfo, NULL, info_nodeinfo},
|
{"nodeinfo", cmdNodeinfo, NULL, info_nodeinfo},
|
||||||
{"quit", cmdQuit, NULL, info_quit},
|
{"quit", cmdQuit, NULL, info_quit},
|
||||||
{"reboot", cmdReboot, opts_reboot, info_reboot},
|
{"reboot", cmdReboot, opts_reboot, info_reboot},
|
||||||
@ -2588,43 +2118,6 @@ vshCommandOptDomainBy(vshControl * ctl, vshCmd * cmd, const char *optname,
|
|||||||
return dom;
|
return dom;
|
||||||
}
|
}
|
||||||
|
|
||||||
static virNetworkPtr
|
|
||||||
vshCommandOptNetworkBy(vshControl * ctl, vshCmd * cmd, const char *optname,
|
|
||||||
char **name, int flag)
|
|
||||||
{
|
|
||||||
virNetworkPtr network = NULL;
|
|
||||||
char *n;
|
|
||||||
|
|
||||||
if (!(n = vshCommandOptString(cmd, optname, NULL))) {
|
|
||||||
vshError(ctl, FALSE, _("undefined network name"));
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
vshDebug(ctl, 5, "%s: found option <%s>: %s\n",
|
|
||||||
cmd->def->name, optname, n);
|
|
||||||
|
|
||||||
if (name)
|
|
||||||
*name = n;
|
|
||||||
|
|
||||||
/* try it by UUID */
|
|
||||||
if (network==NULL && (flag & VSH_BYUUID) && strlen(n)==VIR_UUID_STRING_BUFLEN-1) {
|
|
||||||
vshDebug(ctl, 5, "%s: <%s> tring as network UUID\n",
|
|
||||||
cmd->def->name, optname);
|
|
||||||
network = virNetworkLookupByUUIDString(ctl->conn, n);
|
|
||||||
}
|
|
||||||
/* try it by NAME */
|
|
||||||
if (network==NULL && (flag & VSH_BYNAME)) {
|
|
||||||
vshDebug(ctl, 5, "%s: <%s> tring as network NAME\n",
|
|
||||||
cmd->def->name, optname);
|
|
||||||
network = virNetworkLookupByName(ctl->conn, n);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!network)
|
|
||||||
vshError(ctl, FALSE, _("failed to get network '%s'"), n);
|
|
||||||
|
|
||||||
return network;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Executes command(s) and returns return code from last command
|
* Executes command(s) and returns return code from last command
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user