mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-09 01:18:00 +03:00
Move virNetwork related APIs out of libvirt.h.in
Create a new libvirt-network.h file to hold the public API definitions for the virNetwork type. This header file is not self-contained, so applications will not directly include it. They will continue to #include <libvirt/libvirt.h>
This commit is contained in:
parent
84783d9d1c
commit
5c9789d2d1
@ -23,6 +23,7 @@ debugsym=None
|
||||
included_files = {
|
||||
"libvirt.h": "header with general libvirt API definitions",
|
||||
"libvirt-domain-snapshot.h": "header with general libvirt API definitions",
|
||||
"libvirt-network.h": "header with general libvirt API definitions",
|
||||
"virterror.h": "header with error specific API definitions",
|
||||
"libvirt.c": "Main interfaces for the libvirt library",
|
||||
"libvirt-domain.c": "Domain interfaces for the libvirt library",
|
||||
|
@ -20,6 +20,7 @@ virincdir = $(includedir)/libvirt
|
||||
|
||||
virinc_HEADERS = libvirt.h \
|
||||
libvirt-domain-snapshot.h \
|
||||
libvirt-network.h \
|
||||
libvirt-lxc.h \
|
||||
libvirt-qemu.h \
|
||||
virterror.h
|
||||
|
337
include/libvirt/libvirt-network.h
Normal file
337
include/libvirt/libvirt-network.h
Normal file
@ -0,0 +1,337 @@
|
||||
/*
|
||||
* libvirt-network.h
|
||||
* Summary: APIs for management of networks
|
||||
* Description: Provides APIs for the management of networks
|
||||
* Author: Daniel Veillard <veillard@redhat.com>
|
||||
*
|
||||
* Copyright (C) 2006-2014 Red Hat, Inc.
|
||||
*
|
||||
* This library is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU Lesser General Public
|
||||
* License as published by the Free Software Foundation; either
|
||||
* version 2.1 of the License, or (at your option) any later version.
|
||||
*
|
||||
* This library is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this library. If not, see
|
||||
* <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef __VIR_LIBVIRT_NETWORK_H__
|
||||
# define __VIR_LIBVIRT_NETWORK_H__
|
||||
|
||||
# ifndef __VIR_LIBVIRT_H_INCLUDES__
|
||||
# error "Don't include this file directly, only use libvirt/libvirt.h"
|
||||
# endif
|
||||
|
||||
typedef enum {
|
||||
VIR_NETWORK_XML_INACTIVE = (1 << 0), /* dump inactive network information */
|
||||
} virNetworkXMLFlags;
|
||||
|
||||
/**
|
||||
* virNetwork:
|
||||
*
|
||||
* a virNetwork is a private structure representing a virtual network.
|
||||
*/
|
||||
typedef struct _virNetwork virNetwork;
|
||||
|
||||
/**
|
||||
* virNetworkPtr:
|
||||
*
|
||||
* a virNetworkPtr is pointer to a virNetwork private structure, this is the
|
||||
* type used to reference a virtual network in the API.
|
||||
*/
|
||||
typedef virNetwork *virNetworkPtr;
|
||||
|
||||
/*
|
||||
* Get connection from network.
|
||||
*/
|
||||
virConnectPtr virNetworkGetConnect (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* List active networks
|
||||
*/
|
||||
int virConnectNumOfNetworks (virConnectPtr conn);
|
||||
int virConnectListNetworks (virConnectPtr conn,
|
||||
char **const names,
|
||||
int maxnames);
|
||||
|
||||
/*
|
||||
* List inactive networks
|
||||
*/
|
||||
int virConnectNumOfDefinedNetworks (virConnectPtr conn);
|
||||
int virConnectListDefinedNetworks (virConnectPtr conn,
|
||||
char **const names,
|
||||
int maxnames);
|
||||
/*
|
||||
* virConnectListAllNetworks:
|
||||
*
|
||||
* Flags used to filter the returned networks. Flags in each group
|
||||
* are exclusive attributes of a network.
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_CONNECT_LIST_NETWORKS_INACTIVE = 1 << 0,
|
||||
VIR_CONNECT_LIST_NETWORKS_ACTIVE = 1 << 1,
|
||||
|
||||
VIR_CONNECT_LIST_NETWORKS_PERSISTENT = 1 << 2,
|
||||
VIR_CONNECT_LIST_NETWORKS_TRANSIENT = 1 << 3,
|
||||
|
||||
VIR_CONNECT_LIST_NETWORKS_AUTOSTART = 1 << 4,
|
||||
VIR_CONNECT_LIST_NETWORKS_NO_AUTOSTART = 1 << 5,
|
||||
} virConnectListAllNetworksFlags;
|
||||
|
||||
int virConnectListAllNetworks (virConnectPtr conn,
|
||||
virNetworkPtr **nets,
|
||||
unsigned int flags);
|
||||
|
||||
/*
|
||||
* Lookup network by name or uuid
|
||||
*/
|
||||
virNetworkPtr virNetworkLookupByName (virConnectPtr conn,
|
||||
const char *name);
|
||||
virNetworkPtr virNetworkLookupByUUID (virConnectPtr conn,
|
||||
const unsigned char *uuid);
|
||||
virNetworkPtr virNetworkLookupByUUIDString (virConnectPtr conn,
|
||||
const char *uuid);
|
||||
|
||||
/*
|
||||
* Create active transient network
|
||||
*/
|
||||
virNetworkPtr virNetworkCreateXML (virConnectPtr conn,
|
||||
const char *xmlDesc);
|
||||
|
||||
/*
|
||||
* Define inactive persistent network
|
||||
*/
|
||||
virNetworkPtr virNetworkDefineXML (virConnectPtr conn,
|
||||
const char *xmlDesc);
|
||||
|
||||
/*
|
||||
* Delete persistent network
|
||||
*/
|
||||
int virNetworkUndefine (virNetworkPtr network);
|
||||
|
||||
/**
|
||||
* virNetworkUpdateCommand:
|
||||
*
|
||||
* describes which type of update to perform on a <network>
|
||||
* definition.
|
||||
*
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_UPDATE_COMMAND_NONE = 0, /* (invalid) */
|
||||
VIR_NETWORK_UPDATE_COMMAND_MODIFY = 1, /* modify an existing element */
|
||||
VIR_NETWORK_UPDATE_COMMAND_DELETE = 2, /* delete an existing element */
|
||||
VIR_NETWORK_UPDATE_COMMAND_ADD_LAST = 3, /* add an element at end of list */
|
||||
VIR_NETWORK_UPDATE_COMMAND_ADD_FIRST = 4, /* add an element at start of list */
|
||||
# ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_UPDATE_COMMAND_LAST
|
||||
# endif
|
||||
} virNetworkUpdateCommand;
|
||||
|
||||
/**
|
||||
* virNetworkUpdateSection:
|
||||
*
|
||||
* describes which section of a <network> definition the provided
|
||||
* xml should be applied to.
|
||||
*
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_SECTION_NONE = 0, /* (invalid) */
|
||||
VIR_NETWORK_SECTION_BRIDGE = 1, /* <bridge> */
|
||||
VIR_NETWORK_SECTION_DOMAIN = 2, /* <domain> */
|
||||
VIR_NETWORK_SECTION_IP = 3, /* <ip> */
|
||||
VIR_NETWORK_SECTION_IP_DHCP_HOST = 4, /* <ip>/<dhcp>/<host> */
|
||||
VIR_NETWORK_SECTION_IP_DHCP_RANGE = 5, /* <ip>/<dhcp>/<range> */
|
||||
VIR_NETWORK_SECTION_FORWARD = 6, /* <forward> */
|
||||
VIR_NETWORK_SECTION_FORWARD_INTERFACE = 7, /* <forward>/<interface> */
|
||||
VIR_NETWORK_SECTION_FORWARD_PF = 8, /* <forward>/<pf> */
|
||||
VIR_NETWORK_SECTION_PORTGROUP = 9, /* <portgroup> */
|
||||
VIR_NETWORK_SECTION_DNS_HOST = 10, /* <dns>/<host> */
|
||||
VIR_NETWORK_SECTION_DNS_TXT = 11, /* <dns>/<txt> */
|
||||
VIR_NETWORK_SECTION_DNS_SRV = 12, /* <dns>/<srv> */
|
||||
# ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_SECTION_LAST
|
||||
# endif
|
||||
} virNetworkUpdateSection;
|
||||
|
||||
/**
|
||||
* virNetworkUpdateFlags:
|
||||
*
|
||||
* Flags to control options for virNetworkUpdate()
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_UPDATE_AFFECT_CURRENT = 0, /* affect live if network is active,
|
||||
config if it's not active */
|
||||
VIR_NETWORK_UPDATE_AFFECT_LIVE = 1 << 0, /* affect live state of network only */
|
||||
VIR_NETWORK_UPDATE_AFFECT_CONFIG = 1 << 1, /* affect persistent config only */
|
||||
} virNetworkUpdateFlags;
|
||||
|
||||
/*
|
||||
* Update an existing network definition
|
||||
*/
|
||||
int virNetworkUpdate(virNetworkPtr network,
|
||||
unsigned int command, /* virNetworkUpdateCommand */
|
||||
unsigned int section, /* virNetworkUpdateSection */
|
||||
int parentIndex,
|
||||
const char *xml,
|
||||
unsigned int flags);
|
||||
|
||||
/*
|
||||
* Activate persistent network
|
||||
*/
|
||||
int virNetworkCreate (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* Network destroy/free
|
||||
*/
|
||||
int virNetworkDestroy (virNetworkPtr network);
|
||||
int virNetworkRef (virNetworkPtr network);
|
||||
int virNetworkFree (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* Network information
|
||||
*/
|
||||
const char* virNetworkGetName (virNetworkPtr network);
|
||||
int virNetworkGetUUID (virNetworkPtr network,
|
||||
unsigned char *uuid);
|
||||
int virNetworkGetUUIDString (virNetworkPtr network,
|
||||
char *buf);
|
||||
char * virNetworkGetXMLDesc (virNetworkPtr network,
|
||||
unsigned int flags);
|
||||
char * virNetworkGetBridgeName (virNetworkPtr network);
|
||||
|
||||
int virNetworkGetAutostart (virNetworkPtr network,
|
||||
int *autostart);
|
||||
int virNetworkSetAutostart (virNetworkPtr network,
|
||||
int autostart);
|
||||
|
||||
int virNetworkIsActive(virNetworkPtr net);
|
||||
int virNetworkIsPersistent(virNetworkPtr net);
|
||||
|
||||
/**
|
||||
* virNetworkEventLifecycleType:
|
||||
*
|
||||
* a virNetworkEventLifecycleType is emitted during network lifecycle events
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_EVENT_DEFINED = 0,
|
||||
VIR_NETWORK_EVENT_UNDEFINED = 1,
|
||||
VIR_NETWORK_EVENT_STARTED = 2,
|
||||
VIR_NETWORK_EVENT_STOPPED = 3,
|
||||
|
||||
# ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_EVENT_LAST
|
||||
# endif
|
||||
} virNetworkEventLifecycleType;
|
||||
|
||||
/**
|
||||
* virConnectNetworkEventLifecycleCallback:
|
||||
* @conn: connection object
|
||||
* @net: network on which the event occurred
|
||||
* @event: The specific virNetworkEventLifeCycleType which occurred
|
||||
* @detail: contains some details on the reason of the event.
|
||||
* It will be 0 for the while.
|
||||
* @opaque: application specified data
|
||||
*
|
||||
* This callback occurs when the network is started or stopped.
|
||||
*
|
||||
* The callback signature to use when registering for an event of type
|
||||
* VIR_NETWORK_EVENT_ID_LIFECYCLE with virConnectNetworkEventRegisterAny()
|
||||
*/
|
||||
typedef void (*virConnectNetworkEventLifecycleCallback)(virConnectPtr conn,
|
||||
virNetworkPtr net,
|
||||
int event,
|
||||
int detail,
|
||||
void *opaque);
|
||||
|
||||
/**
|
||||
* VIR_NETWORK_EVENT_CALLBACK:
|
||||
*
|
||||
* Used to cast the event specific callback into the generic one
|
||||
* for use for virConnectNetworkEventRegisterAny()
|
||||
*/
|
||||
# define VIR_NETWORK_EVENT_CALLBACK(cb) ((virConnectNetworkEventGenericCallback)(cb))
|
||||
|
||||
/**
|
||||
* virNetworkEventID:
|
||||
*
|
||||
* An enumeration of supported eventId parameters for
|
||||
* virConnectNetworkEventRegisterAny(). Each event id determines which
|
||||
* signature of callback function will be used.
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_EVENT_ID_LIFECYCLE = 0, /* virConnectNetworkEventLifecycleCallback */
|
||||
|
||||
# ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_EVENT_ID_LAST
|
||||
/*
|
||||
* NB: this enum value will increase over time as new events are
|
||||
* added to the libvirt API. It reflects the last event ID supported
|
||||
* by this version of the libvirt API.
|
||||
*/
|
||||
# endif
|
||||
} virNetworkEventID;
|
||||
|
||||
typedef enum {
|
||||
VIR_IP_ADDR_TYPE_IPV4,
|
||||
VIR_IP_ADDR_TYPE_IPV6,
|
||||
|
||||
# ifdef VIR_ENUM_SENTINELS
|
||||
VIR_IP_ADDR_TYPE_LAST
|
||||
# endif
|
||||
} virIPAddrType;
|
||||
|
||||
typedef struct _virNetworkDHCPLease virNetworkDHCPLease;
|
||||
typedef virNetworkDHCPLease *virNetworkDHCPLeasePtr;
|
||||
struct _virNetworkDHCPLease {
|
||||
char *iface; /* Network interface name */
|
||||
long long expirytime; /* Seconds since epoch */
|
||||
int type; /* virIPAddrType */
|
||||
char *mac; /* MAC address */
|
||||
char *iaid; /* IAID */
|
||||
char *ipaddr; /* IP address */
|
||||
unsigned int prefix; /* IP address prefix */
|
||||
char *hostname; /* Hostname */
|
||||
char *clientid; /* Client ID or DUID */
|
||||
};
|
||||
|
||||
void virNetworkDHCPLeaseFree(virNetworkDHCPLeasePtr lease);
|
||||
|
||||
int virNetworkGetDHCPLeases(virNetworkPtr network,
|
||||
const char *mac,
|
||||
virNetworkDHCPLeasePtr **leases,
|
||||
unsigned int flags);
|
||||
|
||||
/**
|
||||
* virConnectNetworkEventGenericCallback:
|
||||
* @conn: the connection pointer
|
||||
* @net: the network pointer
|
||||
* @opaque: application specified data
|
||||
*
|
||||
* A generic network event callback handler, for use with
|
||||
* virConnectNetworkEventRegisterAny(). Specific events usually
|
||||
* have a customization with extra parameters, often with @opaque being
|
||||
* passed in a different parameter position; use VIR_NETWORK_EVENT_CALLBACK()
|
||||
* when registering an appropriate handler.
|
||||
*/
|
||||
typedef void (*virConnectNetworkEventGenericCallback)(virConnectPtr conn,
|
||||
virNetworkPtr net,
|
||||
void *opaque);
|
||||
|
||||
/* Use VIR_NETWORK_EVENT_CALLBACK() to cast the 'cb' parameter */
|
||||
int virConnectNetworkEventRegisterAny(virConnectPtr conn,
|
||||
virNetworkPtr net, /* Optional, to filter */
|
||||
int eventID,
|
||||
virConnectNetworkEventGenericCallback cb,
|
||||
void *opaque,
|
||||
virFreeCallback freecb);
|
||||
|
||||
int virConnectNetworkEventDeregisterAny(virConnectPtr conn,
|
||||
int callbackID);
|
||||
|
||||
#endif /* __VIR_LIBVIRT_NETWORK_H__ */
|
@ -2855,191 +2855,6 @@ int virNodeGetCellsFreeMemory(virConnectPtr conn,
|
||||
int startCell,
|
||||
int maxCells);
|
||||
|
||||
/*
|
||||
* Virtual Networks API
|
||||
*/
|
||||
|
||||
typedef enum {
|
||||
VIR_NETWORK_XML_INACTIVE = (1 << 0), /* dump inactive network information */
|
||||
} virNetworkXMLFlags;
|
||||
|
||||
/**
|
||||
* virNetwork:
|
||||
*
|
||||
* a virNetwork is a private structure representing a virtual network.
|
||||
*/
|
||||
typedef struct _virNetwork virNetwork;
|
||||
|
||||
/**
|
||||
* virNetworkPtr:
|
||||
*
|
||||
* a virNetworkPtr is pointer to a virNetwork private structure, this is the
|
||||
* type used to reference a virtual network in the API.
|
||||
*/
|
||||
typedef virNetwork *virNetworkPtr;
|
||||
|
||||
/*
|
||||
* Get connection from network.
|
||||
*/
|
||||
virConnectPtr virNetworkGetConnect (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* List active networks
|
||||
*/
|
||||
int virConnectNumOfNetworks (virConnectPtr conn);
|
||||
int virConnectListNetworks (virConnectPtr conn,
|
||||
char **const names,
|
||||
int maxnames);
|
||||
|
||||
/*
|
||||
* List inactive networks
|
||||
*/
|
||||
int virConnectNumOfDefinedNetworks (virConnectPtr conn);
|
||||
int virConnectListDefinedNetworks (virConnectPtr conn,
|
||||
char **const names,
|
||||
int maxnames);
|
||||
/*
|
||||
* virConnectListAllNetworks:
|
||||
*
|
||||
* Flags used to filter the returned networks. Flags in each group
|
||||
* are exclusive attributes of a network.
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_CONNECT_LIST_NETWORKS_INACTIVE = 1 << 0,
|
||||
VIR_CONNECT_LIST_NETWORKS_ACTIVE = 1 << 1,
|
||||
|
||||
VIR_CONNECT_LIST_NETWORKS_PERSISTENT = 1 << 2,
|
||||
VIR_CONNECT_LIST_NETWORKS_TRANSIENT = 1 << 3,
|
||||
|
||||
VIR_CONNECT_LIST_NETWORKS_AUTOSTART = 1 << 4,
|
||||
VIR_CONNECT_LIST_NETWORKS_NO_AUTOSTART = 1 << 5,
|
||||
} virConnectListAllNetworksFlags;
|
||||
|
||||
int virConnectListAllNetworks (virConnectPtr conn,
|
||||
virNetworkPtr **nets,
|
||||
unsigned int flags);
|
||||
|
||||
/*
|
||||
* Lookup network by name or uuid
|
||||
*/
|
||||
virNetworkPtr virNetworkLookupByName (virConnectPtr conn,
|
||||
const char *name);
|
||||
virNetworkPtr virNetworkLookupByUUID (virConnectPtr conn,
|
||||
const unsigned char *uuid);
|
||||
virNetworkPtr virNetworkLookupByUUIDString (virConnectPtr conn,
|
||||
const char *uuid);
|
||||
|
||||
/*
|
||||
* Create active transient network
|
||||
*/
|
||||
virNetworkPtr virNetworkCreateXML (virConnectPtr conn,
|
||||
const char *xmlDesc);
|
||||
|
||||
/*
|
||||
* Define inactive persistent network
|
||||
*/
|
||||
virNetworkPtr virNetworkDefineXML (virConnectPtr conn,
|
||||
const char *xmlDesc);
|
||||
|
||||
/*
|
||||
* Delete persistent network
|
||||
*/
|
||||
int virNetworkUndefine (virNetworkPtr network);
|
||||
|
||||
/**
|
||||
* virNetworkUpdateCommand:
|
||||
*
|
||||
* describes which type of update to perform on a <network>
|
||||
* definition.
|
||||
*
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_UPDATE_COMMAND_NONE = 0, /* (invalid) */
|
||||
VIR_NETWORK_UPDATE_COMMAND_MODIFY = 1, /* modify an existing element */
|
||||
VIR_NETWORK_UPDATE_COMMAND_DELETE = 2, /* delete an existing element */
|
||||
VIR_NETWORK_UPDATE_COMMAND_ADD_LAST = 3, /* add an element at end of list */
|
||||
VIR_NETWORK_UPDATE_COMMAND_ADD_FIRST = 4, /* add an element at start of list */
|
||||
#ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_UPDATE_COMMAND_LAST
|
||||
#endif
|
||||
} virNetworkUpdateCommand;
|
||||
|
||||
/**
|
||||
* virNetworkUpdateSection:
|
||||
*
|
||||
* describes which section of a <network> definition the provided
|
||||
* xml should be applied to.
|
||||
*
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_SECTION_NONE = 0, /* (invalid) */
|
||||
VIR_NETWORK_SECTION_BRIDGE = 1, /* <bridge> */
|
||||
VIR_NETWORK_SECTION_DOMAIN = 2, /* <domain> */
|
||||
VIR_NETWORK_SECTION_IP = 3, /* <ip> */
|
||||
VIR_NETWORK_SECTION_IP_DHCP_HOST = 4, /* <ip>/<dhcp>/<host> */
|
||||
VIR_NETWORK_SECTION_IP_DHCP_RANGE = 5, /* <ip>/<dhcp>/<range> */
|
||||
VIR_NETWORK_SECTION_FORWARD = 6, /* <forward> */
|
||||
VIR_NETWORK_SECTION_FORWARD_INTERFACE = 7, /* <forward>/<interface> */
|
||||
VIR_NETWORK_SECTION_FORWARD_PF = 8, /* <forward>/<pf> */
|
||||
VIR_NETWORK_SECTION_PORTGROUP = 9, /* <portgroup> */
|
||||
VIR_NETWORK_SECTION_DNS_HOST = 10, /* <dns>/<host> */
|
||||
VIR_NETWORK_SECTION_DNS_TXT = 11, /* <dns>/<txt> */
|
||||
VIR_NETWORK_SECTION_DNS_SRV = 12, /* <dns>/<srv> */
|
||||
#ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_SECTION_LAST
|
||||
#endif
|
||||
} virNetworkUpdateSection;
|
||||
|
||||
/**
|
||||
* virNetworkUpdateFlags:
|
||||
*
|
||||
* Flags to control options for virNetworkUpdate()
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_UPDATE_AFFECT_CURRENT = 0, /* affect live if network is active,
|
||||
config if it's not active */
|
||||
VIR_NETWORK_UPDATE_AFFECT_LIVE = 1 << 0, /* affect live state of network only */
|
||||
VIR_NETWORK_UPDATE_AFFECT_CONFIG = 1 << 1, /* affect persistent config only */
|
||||
} virNetworkUpdateFlags;
|
||||
|
||||
/*
|
||||
* Update an existing network definition
|
||||
*/
|
||||
int virNetworkUpdate(virNetworkPtr network,
|
||||
unsigned int command, /* virNetworkUpdateCommand */
|
||||
unsigned int section, /* virNetworkUpdateSection */
|
||||
int parentIndex,
|
||||
const char *xml,
|
||||
unsigned int flags);
|
||||
|
||||
/*
|
||||
* Activate persistent network
|
||||
*/
|
||||
int virNetworkCreate (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* Network destroy/free
|
||||
*/
|
||||
int virNetworkDestroy (virNetworkPtr network);
|
||||
int virNetworkRef (virNetworkPtr network);
|
||||
int virNetworkFree (virNetworkPtr network);
|
||||
|
||||
/*
|
||||
* Network information
|
||||
*/
|
||||
const char* virNetworkGetName (virNetworkPtr network);
|
||||
int virNetworkGetUUID (virNetworkPtr network,
|
||||
unsigned char *uuid);
|
||||
int virNetworkGetUUIDString (virNetworkPtr network,
|
||||
char *buf);
|
||||
char * virNetworkGetXMLDesc (virNetworkPtr network,
|
||||
unsigned int flags);
|
||||
char * virNetworkGetBridgeName (virNetworkPtr network);
|
||||
|
||||
int virNetworkGetAutostart (virNetworkPtr network,
|
||||
int *autostart);
|
||||
int virNetworkSetAutostart (virNetworkPtr network,
|
||||
int autostart);
|
||||
|
||||
/*
|
||||
* Physical host interface configuration API
|
||||
@ -4241,9 +4056,6 @@ int virDomainIsActive(virDomainPtr dom);
|
||||
int virDomainIsPersistent(virDomainPtr dom);
|
||||
int virDomainIsUpdated(virDomainPtr dom);
|
||||
|
||||
int virNetworkIsActive(virNetworkPtr net);
|
||||
int virNetworkIsPersistent(virNetworkPtr net);
|
||||
|
||||
int virStoragePoolIsActive(virStoragePoolPtr pool);
|
||||
int virStoragePoolIsPersistent(virStoragePoolPtr pool);
|
||||
|
||||
@ -5228,126 +5040,6 @@ int virConnectDomainEventRegisterAny(virConnectPtr conn,
|
||||
int virConnectDomainEventDeregisterAny(virConnectPtr conn,
|
||||
int callbackID);
|
||||
|
||||
/**
|
||||
* virNetworkEventLifecycleType:
|
||||
*
|
||||
* a virNetworkEventLifecycleType is emitted during network lifecycle events
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_EVENT_DEFINED = 0,
|
||||
VIR_NETWORK_EVENT_UNDEFINED = 1,
|
||||
VIR_NETWORK_EVENT_STARTED = 2,
|
||||
VIR_NETWORK_EVENT_STOPPED = 3,
|
||||
|
||||
#ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_EVENT_LAST
|
||||
#endif
|
||||
} virNetworkEventLifecycleType;
|
||||
|
||||
/**
|
||||
* virConnectNetworkEventLifecycleCallback:
|
||||
* @conn: connection object
|
||||
* @net: network on which the event occurred
|
||||
* @event: The specific virNetworkEventLifeCycleType which occurred
|
||||
* @detail: contains some details on the reason of the event.
|
||||
* It will be 0 for the while.
|
||||
* @opaque: application specified data
|
||||
*
|
||||
* This callback occurs when the network is started or stopped.
|
||||
*
|
||||
* The callback signature to use when registering for an event of type
|
||||
* VIR_NETWORK_EVENT_ID_LIFECYCLE with virConnectNetworkEventRegisterAny()
|
||||
*/
|
||||
typedef void (*virConnectNetworkEventLifecycleCallback)(virConnectPtr conn,
|
||||
virNetworkPtr net,
|
||||
int event,
|
||||
int detail,
|
||||
void *opaque);
|
||||
|
||||
/**
|
||||
* VIR_NETWORK_EVENT_CALLBACK:
|
||||
*
|
||||
* Used to cast the event specific callback into the generic one
|
||||
* for use for virConnectNetworkEventRegisterAny()
|
||||
*/
|
||||
#define VIR_NETWORK_EVENT_CALLBACK(cb) ((virConnectNetworkEventGenericCallback)(cb))
|
||||
|
||||
/**
|
||||
* virNetworkEventID:
|
||||
*
|
||||
* An enumeration of supported eventId parameters for
|
||||
* virConnectNetworkEventRegisterAny(). Each event id determines which
|
||||
* signature of callback function will be used.
|
||||
*/
|
||||
typedef enum {
|
||||
VIR_NETWORK_EVENT_ID_LIFECYCLE = 0, /* virConnectNetworkEventLifecycleCallback */
|
||||
|
||||
#ifdef VIR_ENUM_SENTINELS
|
||||
VIR_NETWORK_EVENT_ID_LAST
|
||||
/*
|
||||
* NB: this enum value will increase over time as new events are
|
||||
* added to the libvirt API. It reflects the last event ID supported
|
||||
* by this version of the libvirt API.
|
||||
*/
|
||||
#endif
|
||||
} virNetworkEventID;
|
||||
|
||||
typedef enum {
|
||||
VIR_IP_ADDR_TYPE_IPV4,
|
||||
VIR_IP_ADDR_TYPE_IPV6,
|
||||
|
||||
#ifdef VIR_ENUM_SENTINELS
|
||||
VIR_IP_ADDR_TYPE_LAST
|
||||
#endif
|
||||
} virIPAddrType;
|
||||
|
||||
typedef struct _virNetworkDHCPLease virNetworkDHCPLease;
|
||||
typedef virNetworkDHCPLease *virNetworkDHCPLeasePtr;
|
||||
struct _virNetworkDHCPLease {
|
||||
char *iface; /* Network interface name */
|
||||
long long expirytime; /* Seconds since epoch */
|
||||
int type; /* virIPAddrType */
|
||||
char *mac; /* MAC address */
|
||||
char *iaid; /* IAID */
|
||||
char *ipaddr; /* IP address */
|
||||
unsigned int prefix; /* IP address prefix */
|
||||
char *hostname; /* Hostname */
|
||||
char *clientid; /* Client ID or DUID */
|
||||
};
|
||||
|
||||
void virNetworkDHCPLeaseFree(virNetworkDHCPLeasePtr lease);
|
||||
|
||||
int virNetworkGetDHCPLeases(virNetworkPtr network,
|
||||
const char *mac,
|
||||
virNetworkDHCPLeasePtr **leases,
|
||||
unsigned int flags);
|
||||
|
||||
/**
|
||||
* virConnectNetworkEventGenericCallback:
|
||||
* @conn: the connection pointer
|
||||
* @net: the network pointer
|
||||
* @opaque: application specified data
|
||||
*
|
||||
* A generic network event callback handler, for use with
|
||||
* virConnectNetworkEventRegisterAny(). Specific events usually
|
||||
* have a customization with extra parameters, often with @opaque being
|
||||
* passed in a different parameter position; use VIR_NETWORK_EVENT_CALLBACK()
|
||||
* when registering an appropriate handler.
|
||||
*/
|
||||
typedef void (*virConnectNetworkEventGenericCallback)(virConnectPtr conn,
|
||||
virNetworkPtr net,
|
||||
void *opaque);
|
||||
|
||||
/* Use VIR_NETWORK_EVENT_CALLBACK() to cast the 'cb' parameter */
|
||||
int virConnectNetworkEventRegisterAny(virConnectPtr conn,
|
||||
virNetworkPtr net, /* Optional, to filter */
|
||||
int eventID,
|
||||
virConnectNetworkEventGenericCallback cb,
|
||||
void *opaque,
|
||||
virFreeCallback freecb);
|
||||
|
||||
int virConnectNetworkEventDeregisterAny(virConnectPtr conn,
|
||||
int callbackID);
|
||||
|
||||
/**
|
||||
* virNWFilter:
|
||||
@ -5651,6 +5343,7 @@ typedef virMemoryParameter *virMemoryParameterPtr;
|
||||
|
||||
#define __VIR_LIBVIRT_H_INCLUDES__
|
||||
#include <libvirt/libvirt-domain-snapshot.h>
|
||||
#include <libvirt/libvirt-network.h>
|
||||
#undef __VIR_LIBVIRT_H_INCLUDES__
|
||||
|
||||
#ifdef __cplusplus
|
||||
|
@ -2252,6 +2252,7 @@ exit 0
|
||||
%{_includedir}/libvirt/virterror.h
|
||||
%{_includedir}/libvirt/libvirt.h
|
||||
%{_includedir}/libvirt/libvirt-domain-snapshot.h
|
||||
%{_includedir}/libvirt/libvirt-network.h
|
||||
%{_includedir}/libvirt/libvirt-qemu.h
|
||||
%{_includedir}/libvirt/libvirt-lxc.h
|
||||
%{_libdir}/pkgconfig/libvirt.pc
|
||||
|
@ -230,6 +230,7 @@ rm -rf $RPM_BUILD_ROOT%{mingw64_libexecdir}/libvirt-guests.sh
|
||||
%dir %{mingw32_includedir}/libvirt
|
||||
%{mingw32_includedir}/libvirt/libvirt.h
|
||||
%{mingw32_includedir}/libvirt/libvirt-domain-snapshot.h
|
||||
%{mingw32_includedir}/libvirt/libvirt-network.h
|
||||
%{mingw32_includedir}/libvirt/virterror.h
|
||||
%{mingw32_includedir}/libvirt/libvirt-lxc.h
|
||||
%{mingw32_includedir}/libvirt/libvirt-qemu.h
|
||||
@ -294,6 +295,7 @@ rm -rf $RPM_BUILD_ROOT%{mingw64_libexecdir}/libvirt-guests.sh
|
||||
%dir %{mingw64_includedir}/libvirt
|
||||
%{mingw64_includedir}/libvirt/libvirt.h
|
||||
%{mingw64_includedir}/libvirt/libvirt-domain-snapshot.h
|
||||
%{mingw64_includedir}/libvirt/libvirt-network.h
|
||||
%{mingw64_includedir}/libvirt/virterror.h
|
||||
%{mingw64_includedir}/libvirt/libvirt-lxc.h
|
||||
%{mingw64_includedir}/libvirt/libvirt-qemu.h
|
||||
|
Loading…
Reference in New Issue
Block a user