mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-20 18:03:50 +03:00
Add <title> and <description> for Network Objects
This patch adds new elements <title> and <description> to the Network XML. - The <title> attribute holds a short title defined by the user and cannot contain newlines. - The <description> attribute holds any documentation that the user wants to store. - Schema definitions of <title> and <description> have been moved from domaincommon.rng to basictypes.rng for use by network and future objects. - Added Network XML parser logic for the above. Signed-off-by: K Shiva Kiran <shiva_kr@riseup.net> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
ab26247f46
commit
742c87d453
@ -30,6 +30,8 @@ The first elements provide basic metadata about the virtual network.
|
|||||||
<network ipv6='yes' trustGuestRxFilters='no'>
|
<network ipv6='yes' trustGuestRxFilters='no'>
|
||||||
<name>default</name>
|
<name>default</name>
|
||||||
<uuid>3e3fce45-4f53-4fa7-bb32-11f34168b82b</uuid>
|
<uuid>3e3fce45-4f53-4fa7-bb32-11f34168b82b</uuid>
|
||||||
|
<title>A short description - title - of the network</title>
|
||||||
|
<description>Some human readable description</description>
|
||||||
<metadata>
|
<metadata>
|
||||||
<app1:foo xmlns:app1="http://app1.org/app1/">..</app1:foo>
|
<app1:foo xmlns:app1="http://app1.org/app1/">..</app1:foo>
|
||||||
<app2:bar xmlns:app2="http://app1.org/app2/">..</app2:bar>
|
<app2:bar xmlns:app2="http://app1.org/app2/">..</app2:bar>
|
||||||
@ -47,6 +49,7 @@ The first elements provide basic metadata about the virtual network.
|
|||||||
the virtual network. The format must be RFC 4122 compliant, eg
|
the virtual network. The format must be RFC 4122 compliant, eg
|
||||||
``3e3fce45-4f53-4fa7-bb32-11f34168b82b``. If omitted when defining/creating a
|
``3e3fce45-4f53-4fa7-bb32-11f34168b82b``. If omitted when defining/creating a
|
||||||
new network, a random UUID is generated. :since:`Since 0.3.0`
|
new network, a random UUID is generated. :since:`Since 0.3.0`
|
||||||
|
``metadata``
|
||||||
The ``metadata`` node can be used by applications to store custom metadata in
|
The ``metadata`` node can be used by applications to store custom metadata in
|
||||||
the form of XML nodes/trees. Applications must use custom namespaces on their
|
the form of XML nodes/trees. Applications must use custom namespaces on their
|
||||||
XML nodes/trees, with only one top-level element per namespace (if the
|
XML nodes/trees, with only one top-level element per namespace (if the
|
||||||
@ -65,6 +68,14 @@ The first elements provide basic metadata about the virtual network.
|
|||||||
documentation for more details. Note that an explicit setting of this
|
documentation for more details. Note that an explicit setting of this
|
||||||
attribute in a portgroup or the individual domain interface will override the
|
attribute in a portgroup or the individual domain interface will override the
|
||||||
setting in the network.
|
setting in the network.
|
||||||
|
``title``
|
||||||
|
The optional element ``title`` provides space for a short description of the
|
||||||
|
network. The title should not contain any newlines. :since:`Since 9.7.0` .
|
||||||
|
``description``
|
||||||
|
The content of the ``description`` element provides a human readable
|
||||||
|
description of the network. This data is not used by libvirt in any
|
||||||
|
way, it can contain any information the user wants. :since:`Since 9.7.0`
|
||||||
|
|
||||||
|
|
||||||
Connectivity
|
Connectivity
|
||||||
~~~~~~~~~~~~
|
~~~~~~~~~~~~
|
||||||
|
@ -281,6 +281,8 @@ virNetworkDefFree(virNetworkDef *def)
|
|||||||
virNetDevBandwidthFree(def->bandwidth);
|
virNetDevBandwidthFree(def->bandwidth);
|
||||||
virNetDevVlanClear(&def->vlan);
|
virNetDevVlanClear(&def->vlan);
|
||||||
|
|
||||||
|
g_free(def->title);
|
||||||
|
g_free(def->description);
|
||||||
xmlFreeNode(def->metadata);
|
xmlFreeNode(def->metadata);
|
||||||
|
|
||||||
if (def->namespaceData && def->ns.free)
|
if (def->namespaceData && def->ns.free)
|
||||||
@ -1599,6 +1601,17 @@ virNetworkDefParseXML(xmlXPathContextPtr ctxt,
|
|||||||
def->uuid_specified = true;
|
def->uuid_specified = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Extract short description of network (title) */
|
||||||
|
def->title = virXPathString("string(./title[1])", ctxt);
|
||||||
|
if (def->title && strchr(def->title, '\n')) {
|
||||||
|
virReportError(VIR_ERR_XML_ERROR, "%s",
|
||||||
|
_("Network title can't contain newlines"));
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Extract documentation if present */
|
||||||
|
def->description = virXPathString("string(./description[1])", ctxt);
|
||||||
|
|
||||||
/* check if definitions with no IPv6 gateway addresses is to
|
/* check if definitions with no IPv6 gateway addresses is to
|
||||||
* allow guest-to-guest communications.
|
* allow guest-to-guest communications.
|
||||||
*/
|
*/
|
||||||
@ -2311,6 +2324,11 @@ virNetworkDefFormatBuf(virBuffer *buf,
|
|||||||
virUUIDFormat(uuid, uuidstr);
|
virUUIDFormat(uuid, uuidstr);
|
||||||
virBufferAsprintf(buf, "<uuid>%s</uuid>\n", uuidstr);
|
virBufferAsprintf(buf, "<uuid>%s</uuid>\n", uuidstr);
|
||||||
|
|
||||||
|
virBufferEscapeString(buf, "<title>%s</title>\n", def->title);
|
||||||
|
|
||||||
|
virBufferEscapeString(buf, "<description>%s</description>\n",
|
||||||
|
def->description);
|
||||||
|
|
||||||
if (virXMLFormatMetadata(buf, def->metadata) < 0)
|
if (virXMLFormatMetadata(buf, def->metadata) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
@ -249,6 +249,8 @@ struct _virNetworkDef {
|
|||||||
unsigned char uuid[VIR_UUID_BUFLEN];
|
unsigned char uuid[VIR_UUID_BUFLEN];
|
||||||
bool uuid_specified;
|
bool uuid_specified;
|
||||||
char *name;
|
char *name;
|
||||||
|
char *title;
|
||||||
|
char *description;
|
||||||
int connections; /* # of guest interfaces connected to this network */
|
int connections; /* # of guest interfaces connected to this network */
|
||||||
|
|
||||||
char *bridge; /* Name of bridge device */
|
char *bridge; /* Name of bridge device */
|
||||||
|
@ -610,6 +610,21 @@
|
|||||||
</choice>
|
</choice>
|
||||||
</define>
|
</define>
|
||||||
|
|
||||||
|
<!--
|
||||||
|
title and description element, may be placed anywhere under the root
|
||||||
|
-->
|
||||||
|
<define name="title">
|
||||||
|
<element name="title">
|
||||||
|
<ref name="objectNameWithSlash"/>
|
||||||
|
</element>
|
||||||
|
</define>
|
||||||
|
|
||||||
|
<define name="description">
|
||||||
|
<element name="description">
|
||||||
|
<text/>
|
||||||
|
</element>
|
||||||
|
</define>
|
||||||
|
|
||||||
<define name="metadata">
|
<define name="metadata">
|
||||||
<element name="metadata">
|
<element name="metadata">
|
||||||
<zeroOrMore>
|
<zeroOrMore>
|
||||||
|
@ -8,21 +8,6 @@
|
|||||||
<include href="nwfilter_params.rng"/>
|
<include href="nwfilter_params.rng"/>
|
||||||
<include href="privatedata.rng"/>
|
<include href="privatedata.rng"/>
|
||||||
|
|
||||||
<!--
|
|
||||||
description and title element, may be placed anywhere under the root
|
|
||||||
-->
|
|
||||||
<define name="description">
|
|
||||||
<element name="description">
|
|
||||||
<text/>
|
|
||||||
</element>
|
|
||||||
</define>
|
|
||||||
|
|
||||||
<define name="title">
|
|
||||||
<element name="title">
|
|
||||||
<ref name="objectNameWithSlash"/>
|
|
||||||
</element>
|
|
||||||
</define>
|
|
||||||
|
|
||||||
<define name="createMode">
|
<define name="createMode">
|
||||||
<data type="unsignedInt">
|
<data type="unsignedInt">
|
||||||
<param name="pattern">0[0-7]{3}|[0-7]{1,3}</param>
|
<param name="pattern">0[0-7]{3}|[0-7]{1,3}</param>
|
||||||
|
@ -37,6 +37,16 @@
|
|||||||
<text/>
|
<text/>
|
||||||
</element>
|
</element>
|
||||||
|
|
||||||
|
<!-- <title> element -->
|
||||||
|
<optional>
|
||||||
|
<ref name="title"/>
|
||||||
|
</optional>
|
||||||
|
|
||||||
|
<!-- <description> element -->
|
||||||
|
<optional>
|
||||||
|
<ref name="description"/>
|
||||||
|
</optional>
|
||||||
|
|
||||||
<!-- <metadata> element -->
|
<!-- <metadata> element -->
|
||||||
<optional>
|
<optional>
|
||||||
<ref name="metadata"/>
|
<ref name="metadata"/>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user