net: merge virNetworkGetDHCPLeases and virNetworkGetDHCPLeasesForMAC

Instead of maintaining two very similar APIs, add the "@mac" parameter
to virNetworkGetDHCPLeases and kill virNetworkGetDHCPLeasesForMAC. Both
of those functions would return data the same way, so making @mac an
optional filter simplifies a lot of stuff.
This commit is contained in:
Peter Krempa 2014-06-26 16:08:34 +02:00
parent 96f6275513
commit 02bffd47bd
10 changed files with 37 additions and 301 deletions

View File

@ -6292,6 +6292,7 @@ remoteDispatchNetworkGetDHCPLeases(virNetServerPtr server ATTRIBUTE_UNUSED,
goto cleanup; goto cleanup;
if ((nleases = virNetworkGetDHCPLeases(net, if ((nleases = virNetworkGetDHCPLeases(net,
args->mac ? *args->mac : NULL,
args->need_results ? &leases : NULL, args->need_results ? &leases : NULL,
args->flags)) < 0) args->flags)) < 0)
goto cleanup; goto cleanup;
@ -6336,74 +6337,6 @@ remoteDispatchNetworkGetDHCPLeases(virNetServerPtr server ATTRIBUTE_UNUSED,
} }
static int
remoteDispatchNetworkGetDHCPLeasesForMAC(virNetServerPtr server ATTRIBUTE_UNUSED,
virNetServerClientPtr client,
virNetMessagePtr msg ATTRIBUTE_UNUSED,
virNetMessageErrorPtr rerr,
remote_network_get_dhcp_leases_for_mac_args *args,
remote_network_get_dhcp_leases_for_mac_ret *ret)
{
int rv = -1;
size_t i;
struct daemonClientPrivate *priv = virNetServerClientGetPrivateData(client);
virNetworkDHCPLeasePtr *leases = NULL;
virNetworkPtr net = NULL;
int nleases = 0;
if (!priv->conn) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s", _("connection not open"));
goto cleanup;
}
if (!(net = get_nonnull_network(priv->conn, args->net)))
goto cleanup;
if ((nleases = virNetworkGetDHCPLeasesForMAC(net, args->mac,
args->need_results ? &leases : NULL,
args->flags)) < 0)
goto cleanup;
if (nleases > REMOTE_NETWORK_DHCP_LEASES_MAX) {
virReportError(VIR_ERR_INTERNAL_ERROR,
_("Number of leases is %d, which exceeds max limit: %d"),
nleases, REMOTE_NETWORK_DHCP_LEASES_MAX);
return -1;
}
if (leases && nleases) {
if (VIR_ALLOC_N(ret->leases.leases_val, nleases) < 0)
goto cleanup;
ret->leases.leases_len = nleases;
for (i = 0; i < nleases; i++) {
if (remoteSerializeDHCPLease(ret->leases.leases_val + i, leases[i]) < 0)
goto cleanup;
}
} else {
ret->leases.leases_len = 0;
ret->leases.leases_val = NULL;
}
ret->ret = nleases;
rv = 0;
cleanup:
if (rv < 0)
virNetMessageSaveError(rerr);
if (leases) {
for (i = 0; i < nleases; i++)
virNetworkDHCPLeaseFree(leases[i]);
VIR_FREE(leases);
}
virNetworkFree(net);
return rv;
}
/*----- Helpers. -----*/ /*----- Helpers. -----*/
/* get_nonnull_domain and get_nonnull_network turn an on-wire /* get_nonnull_domain and get_nonnull_network turn an on-wire

View File

@ -5169,14 +5169,10 @@ struct _virNetworkDHCPLease {
void virNetworkDHCPLeaseFree(virNetworkDHCPLeasePtr lease); void virNetworkDHCPLeaseFree(virNetworkDHCPLeasePtr lease);
int virNetworkGetDHCPLeases(virNetworkPtr network, int virNetworkGetDHCPLeases(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases, virNetworkDHCPLeasePtr **leases,
unsigned int flags); unsigned int flags);
int virNetworkGetDHCPLeasesForMAC(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases,
unsigned int flags);
/** /**
* virConnectNetworkEventGenericCallback: * virConnectNetworkEventGenericCallback:
* @conn: the connection pointer * @conn: the connection pointer

View File

@ -1184,15 +1184,10 @@ typedef int
typedef int typedef int
(*virDrvNetworkGetDHCPLeases)(virNetworkPtr network, (*virDrvNetworkGetDHCPLeases)(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases, virNetworkDHCPLeasePtr **leases,
unsigned int flags); unsigned int flags);
typedef int
(*virDrvNetworkGetDHCPLeasesForMAC)(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases,
unsigned int flags);
typedef struct _virDriver virDriver; typedef struct _virDriver virDriver;
typedef virDriver *virDriverPtr; typedef virDriver *virDriverPtr;
@ -1546,7 +1541,6 @@ struct _virNetworkDriver {
virDrvNetworkIsActive networkIsActive; virDrvNetworkIsActive networkIsActive;
virDrvNetworkIsPersistent networkIsPersistent; virDrvNetworkIsPersistent networkIsPersistent;
virDrvNetworkGetDHCPLeases networkGetDHCPLeases; virDrvNetworkGetDHCPLeases networkGetDHCPLeases;
virDrvNetworkGetDHCPLeasesForMAC networkGetDHCPLeasesForMAC;
}; };

View File

@ -21014,6 +21014,7 @@ virNodeGetFreePages(virConnectPtr conn,
/** /**
* virNetworkGetDHCPLeases: * virNetworkGetDHCPLeases:
* @network: Pointer to network object * @network: Pointer to network object
* @mac: Optional ASCII formatted MAC address of an interface
* @leases: Pointer to a variable to store the array containing details on * @leases: Pointer to a variable to store the array containing details on
* obtained leases, or NULL if the list is not required (just returns * obtained leases, or NULL if the list is not required (just returns
* number of leases). * number of leases).
@ -21040,6 +21041,11 @@ virNodeGetFreePages(virConnectPtr conn,
* Note: @mac, @iaid, @ipaddr, @clientid are in ASCII form, not raw bytes. * Note: @mac, @iaid, @ipaddr, @clientid are in ASCII form, not raw bytes.
* Note: @expirytime can 0, in case the lease is for infinite time. * Note: @expirytime can 0, in case the lease is for infinite time.
* *
* The API fetches leases info of guests in the specified network. If the
* optional parameter @mac is specified, the returned list will contain only
* lease info about a specific guest interface with @mac. There can be
* multiple leases for a single @mac because this API supports DHCPv6 too.
*
* Returns the number of leases found or -1 and sets @leases to NULL in * Returns the number of leases found or -1 and sets @leases to NULL in
* case of error. On success, the array stored into @leases is guaranteed to * case of error. On success, the array stored into @leases is guaranteed to
* have an extra allocated element set to NULL but not included in the return * have an extra allocated element set to NULL but not included in the return
@ -21057,7 +21063,7 @@ virNodeGetFreePages(virConnectPtr conn,
* int nleases; * int nleases;
* unsigned int flags = 0; * unsigned int flags = 0;
* *
* nleases = virNetworkGetDHCPLeases(network, &leases, flags); * nleases = virNetworkGetDHCPLeases(network, NULL, &leases, flags);
* if (nleases < 0) * if (nleases < 0)
* error(); * error();
* *
@ -21079,12 +21085,13 @@ virNodeGetFreePages(virConnectPtr conn,
*/ */
int int
virNetworkGetDHCPLeases(virNetworkPtr network, virNetworkGetDHCPLeases(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases, virNetworkDHCPLeasePtr **leases,
unsigned int flags) unsigned int flags)
{ {
virConnectPtr conn; virConnectPtr conn;
VIR_DEBUG("network=%p, leases=%p, flags=%x", VIR_DEBUG("network=%p, mac='%s' leases=%p, flags=%x",
network, leases, flags); network, NULLSTR(mac), leases, flags);
virResetLastError(); virResetLastError();
@ -21097,7 +21104,7 @@ virNetworkGetDHCPLeases(virNetworkPtr network,
if (conn->networkDriver && conn->networkDriver->networkGetDHCPLeases) { if (conn->networkDriver && conn->networkDriver->networkGetDHCPLeases) {
int ret; int ret;
ret = conn->networkDriver->networkGetDHCPLeases(network, leases, flags); ret = conn->networkDriver->networkGetDHCPLeases(network, mac, leases, flags);
if (ret < 0) if (ret < 0)
goto error; goto error;
return ret; return ret;
@ -21110,65 +21117,6 @@ virNetworkGetDHCPLeases(virNetworkPtr network,
return -1; return -1;
} }
/**
* virNetworkGetDHCPLeasesForMAC:
* @network: Pointer to network object
* @mac: ASCII formatted MAC address of an interface
* @leases: Pointer to a variable to store the array containing details on
* obtained leases, or NULL if the list is not required (just returns
* number of leases).
* @flags: extra flags, not used yet, so callers should always pass 0
*
* The API fetches leases info of the interface which matches with the
* given @mac. There can be multiple leases for a single @mac because this
* API supports DHCPv6 too.
*
* Returns the number of leases found or -1 and sets @leases to NULL in case of
* error. On success, the array stored into @leases is guaranteed to have an
* extra allocated element set to NULL but not included in the return count,
* to make iteration easier. The caller is responsible for calling
* virNetworkDHCPLeaseFree() on each array element, then calling free() on @leases.
*
* See virNetworkGetDHCPLeases() for more details on list contents.
*/
int
virNetworkGetDHCPLeasesForMAC(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases,
unsigned int flags)
{
virConnectPtr conn;
VIR_DEBUG("network=%p, mac=%s, leases=%p, flags=%x",
network, mac, leases, flags);
virResetLastError();
if (leases)
*leases = NULL;
virCheckNonNullArgGoto(mac, error);
virCheckNetworkReturn(network, -1);
conn = network->conn;
if (conn->networkDriver &&
conn->networkDriver->networkGetDHCPLeasesForMAC) {
int ret;
ret = conn->networkDriver->networkGetDHCPLeasesForMAC(network, mac,
leases, flags);
if (ret < 0)
goto error;
return ret;
}
virReportUnsupportedError();
error:
virDispatchError(network->conn);
return -1;
}
/** /**
* virNetworkDHCPLeaseFree: * virNetworkDHCPLeaseFree:

View File

@ -663,7 +663,6 @@ LIBVIRT_1.2.6 {
virNodeGetFreePages; virNodeGetFreePages;
virNetworkDHCPLeaseFree; virNetworkDHCPLeaseFree;
virNetworkGetDHCPLeases; virNetworkGetDHCPLeases;
virNetworkGetDHCPLeasesForMAC;
} LIBVIRT_1.2.5; } LIBVIRT_1.2.5;
# .... define new API here using predicted next version number .... # .... define new API here using predicted next version number ....

View File

@ -3369,9 +3369,10 @@ static int networkSetAutostart(virNetworkPtr net,
} }
static int static int
networkGetDHCPLeasesHelper(virNetworkObjPtr obj, networkGetDHCPLeases(virNetworkPtr network,
const char *mac, const char *mac,
virNetworkDHCPLeasePtr **leases) virNetworkDHCPLeasePtr **leases,
unsigned int flags)
{ {
size_t i, j; size_t i, j;
size_t nleases = 0; size_t nleases = 0;
@ -3391,6 +3392,15 @@ networkGetDHCPLeasesHelper(virNetworkObjPtr obj,
virNetworkIpDefPtr ipdef_tmp = NULL; virNetworkIpDefPtr ipdef_tmp = NULL;
virNetworkDHCPLeasePtr lease = NULL; virNetworkDHCPLeasePtr lease = NULL;
virNetworkDHCPLeasePtr *leases_ret = NULL; virNetworkDHCPLeasePtr *leases_ret = NULL;
virNetworkObjPtr obj;
virCheckFlags(0, -1);
if (!(obj = networkObjFromNetwork(network)))
return -1;
if (virNetworkGetDHCPLeasesEnsureACL(network->conn, obj->def) < 0)
goto cleanup;
/* Retrieve custom leases file location */ /* Retrieve custom leases file location */
custom_lease_file = networkDnsmasqLeaseFileNameCustom(obj->def->bridge); custom_lease_file = networkDnsmasqLeaseFileNameCustom(obj->def->bridge);
@ -3530,6 +3540,10 @@ networkGetDHCPLeasesHelper(virNetworkObjPtr obj,
VIR_FREE(lease_entries); VIR_FREE(lease_entries);
VIR_FREE(custom_lease_file); VIR_FREE(custom_lease_file);
virJSONValueFree(leases_array); virJSONValueFree(leases_array);
if (obj)
virNetworkObjUnlock(obj);
return rv; return rv;
error: error:
@ -3541,54 +3555,6 @@ networkGetDHCPLeasesHelper(virNetworkObjPtr obj,
goto cleanup; goto cleanup;
} }
static int
networkGetDHCPLeases(virNetworkPtr network,
virNetworkDHCPLeasePtr **leases,
unsigned int flags)
{
int rv = -1;
virNetworkObjPtr obj;
virCheckFlags(0, -1);
if (!(obj = networkObjFromNetwork(network)))
return rv;
if (virNetworkGetDHCPLeasesEnsureACL(network->conn, obj->def) < 0)
goto cleanup;
rv = networkGetDHCPLeasesHelper(obj, NULL, leases);
cleanup:
if (obj)
virNetworkObjUnlock(obj);
return rv;
}
static int
networkGetDHCPLeasesForMAC(virNetworkPtr network,
const char *mac,
virNetworkDHCPLeasePtr **leases,
unsigned int flags)
{
int rv = -1;
virNetworkObjPtr obj;
virCheckFlags(0, -1);
if (!(obj = networkObjFromNetwork(network)))
return rv;
if (virNetworkGetDHCPLeasesForMACEnsureACL(network->conn, obj->def) < 0)
goto cleanup;
rv = networkGetDHCPLeasesHelper(obj, mac, leases);
cleanup:
if (obj)
virNetworkObjUnlock(obj);
return rv;
}
static virNetworkDriver networkDriver = { static virNetworkDriver networkDriver = {
"Network", "Network",
@ -3616,7 +3582,6 @@ static virNetworkDriver networkDriver = {
.networkIsActive = networkIsActive, /* 0.7.3 */ .networkIsActive = networkIsActive, /* 0.7.3 */
.networkIsPersistent = networkIsPersistent, /* 0.7.3 */ .networkIsPersistent = networkIsPersistent, /* 0.7.3 */
.networkGetDHCPLeases = networkGetDHCPLeases, /* 1.2.6 */ .networkGetDHCPLeases = networkGetDHCPLeases, /* 1.2.6 */
.networkGetDHCPLeasesForMAC = networkGetDHCPLeasesForMAC, /* 1.2.6 */
}; };
static virStateDriver networkStateDriver = { static virStateDriver networkStateDriver = {

View File

@ -7601,6 +7601,7 @@ remoteSerializeDHCPLease(virNetworkDHCPLeasePtr lease_dst, remote_network_dhcp_l
static int static int
remoteNetworkGetDHCPLeases(virNetworkPtr net, remoteNetworkGetDHCPLeases(virNetworkPtr net,
const char *mac,
virNetworkDHCPLeasePtr **leases, virNetworkDHCPLeasePtr **leases,
unsigned int flags) unsigned int flags)
{ {
@ -7614,6 +7615,7 @@ remoteNetworkGetDHCPLeases(virNetworkPtr net,
remoteDriverLock(priv); remoteDriverLock(priv);
make_nonnull_network(&args.net, net); make_nonnull_network(&args.net, net);
args.mac = mac ? (char **) &mac : NULL;
args.flags = flags; args.flags = flags;
args.need_results = !!leases; args.need_results = !!leases;
@ -7665,74 +7667,6 @@ remoteNetworkGetDHCPLeases(virNetworkPtr net,
} }
static int
remoteNetworkGetDHCPLeasesForMAC(virNetworkPtr net,
const char *mac,
virNetworkDHCPLeasePtr **leases,
unsigned int flags)
{
int rv = -1;
size_t i;
struct private_data *priv = net->conn->networkPrivateData;
remote_network_get_dhcp_leases_for_mac_args args;
remote_network_get_dhcp_leases_for_mac_ret ret;
virNetworkDHCPLeasePtr *leases_ret = NULL;
remoteDriverLock(priv);
make_nonnull_network(&args.net, net);
args.mac = (char *) mac;
args.flags = flags;
args.need_results = !!leases;
memset(&ret, 0, sizeof(ret));
if (call(net->conn, priv, 0, REMOTE_PROC_NETWORK_GET_DHCP_LEASES_FOR_MAC,
(xdrproc_t)xdr_remote_network_get_dhcp_leases_for_mac_args, (char *)&args,
(xdrproc_t)xdr_remote_network_get_dhcp_leases_for_mac_ret, (char *)&ret) == -1)
goto done;
if (ret.leases.leases_len > REMOTE_NETWORK_DHCP_LEASES_MAX) {
virReportError(VIR_ERR_INTERNAL_ERROR,
_("Number of leases is %d, which exceeds max limit: %d"),
ret.leases.leases_len, REMOTE_NETWORK_DHCP_LEASES_MAX);
goto cleanup;
}
if (leases) {
if (ret.leases.leases_len &&
VIR_ALLOC_N(leases_ret, ret.leases.leases_len + 1) < 0)
goto cleanup;
for (i = 0; i < ret.leases.leases_len; i++) {
if (VIR_ALLOC(leases_ret[i]) < 0)
goto cleanup;
if (remoteSerializeDHCPLease(leases_ret[i], &ret.leases.leases_val[i]) < 0)
goto cleanup;
}
*leases = leases_ret;
leases_ret = NULL;
}
rv = ret.ret;
cleanup:
if (leases_ret) {
for (i = 0; i < ret.leases.leases_len; i++)
virNetworkDHCPLeaseFree(leases_ret[i]);
VIR_FREE(leases_ret);
}
xdr_free((xdrproc_t)xdr_remote_network_get_dhcp_leases_for_mac_ret,
(char *) &ret);
done:
remoteDriverUnlock(priv);
return rv;
}
/* get_nonnull_domain and get_nonnull_network turn an on-wire /* get_nonnull_domain and get_nonnull_network turn an on-wire
* (name, uuid) pair into virDomainPtr or virNetworkPtr object. * (name, uuid) pair into virDomainPtr or virNetworkPtr object.
* These can return NULL if underlying memory allocations fail, * These can return NULL if underlying memory allocations fail,
@ -8098,7 +8032,6 @@ static virNetworkDriver network_driver = {
.networkIsActive = remoteNetworkIsActive, /* 0.7.3 */ .networkIsActive = remoteNetworkIsActive, /* 0.7.3 */
.networkIsPersistent = remoteNetworkIsPersistent, /* 0.7.3 */ .networkIsPersistent = remoteNetworkIsPersistent, /* 0.7.3 */
.networkGetDHCPLeases = remoteNetworkGetDHCPLeases, /* 1.2.6 */ .networkGetDHCPLeases = remoteNetworkGetDHCPLeases, /* 1.2.6 */
.networkGetDHCPLeasesForMAC = remoteNetworkGetDHCPLeasesForMAC, /* 1.2.6 */
}; };
static virInterfaceDriver interface_driver = { static virInterfaceDriver interface_driver = {

View File

@ -3035,6 +3035,7 @@ struct remote_network_dhcp_lease {
struct remote_network_get_dhcp_leases_args { struct remote_network_get_dhcp_leases_args {
remote_nonnull_network net; remote_nonnull_network net;
remote_string mac;
int need_results; int need_results;
unsigned int flags; unsigned int flags;
}; };
@ -3044,18 +3045,6 @@ struct remote_network_get_dhcp_leases_ret {
unsigned int ret; unsigned int ret;
}; };
struct remote_network_get_dhcp_leases_for_mac_args {
remote_nonnull_network net;
remote_nonnull_string mac;
int need_results;
unsigned int flags;
};
struct remote_network_get_dhcp_leases_for_mac_ret {
remote_network_dhcp_lease leases<REMOTE_NETWORK_DHCP_LEASES_MAX>;
unsigned int ret;
};
/*----- Protocol. -----*/ /*----- Protocol. -----*/
/* Define the program number, protocol version and procedure numbers here. */ /* Define the program number, protocol version and procedure numbers here. */
@ -5413,11 +5402,6 @@ enum remote_procedure {
* @generate: none * @generate: none
* @acl: network:read * @acl: network:read
*/ */
REMOTE_PROC_NETWORK_GET_DHCP_LEASES = 341, REMOTE_PROC_NETWORK_GET_DHCP_LEASES = 341
/**
* @generate: none
* @acl: network:read
*/
REMOTE_PROC_NETWORK_GET_DHCP_LEASES_FOR_MAC = 342
}; };

View File

@ -2498,6 +2498,7 @@ struct remote_network_dhcp_lease {
}; };
struct remote_network_get_dhcp_leases_args { struct remote_network_get_dhcp_leases_args {
remote_nonnull_network net; remote_nonnull_network net;
remote_string mac;
int need_results; int need_results;
u_int flags; u_int flags;
}; };
@ -2508,19 +2509,6 @@ struct remote_network_get_dhcp_leases_ret {
} leases; } leases;
u_int ret; u_int ret;
}; };
struct remote_network_get_dhcp_leases_for_mac_args {
remote_nonnull_network net;
remote_nonnull_string mac;
int need_results;
u_int flags;
};
struct remote_network_get_dhcp_leases_for_mac_ret {
struct {
u_int leases_len;
remote_network_dhcp_lease * leases_val;
} leases;
u_int ret;
};
enum remote_procedure { enum remote_procedure {
REMOTE_PROC_CONNECT_OPEN = 1, REMOTE_PROC_CONNECT_OPEN = 1,
REMOTE_PROC_CONNECT_CLOSE = 2, REMOTE_PROC_CONNECT_CLOSE = 2,
@ -2863,5 +2851,4 @@ enum remote_procedure {
REMOTE_PROC_DOMAIN_EVENT_BLOCK_JOB_2 = 339, REMOTE_PROC_DOMAIN_EVENT_BLOCK_JOB_2 = 339,
REMOTE_PROC_NODE_GET_FREE_PAGES = 340, REMOTE_PROC_NODE_GET_FREE_PAGES = 340,
REMOTE_PROC_NETWORK_GET_DHCP_LEASES = 341, REMOTE_PROC_NETWORK_GET_DHCP_LEASES = 341,
REMOTE_PROC_NETWORK_GET_DHCP_LEASES_FOR_MAC = 342,
}; };

View File

@ -1348,10 +1348,7 @@ cmdNetworkDHCPLeases(vshControl *ctl, const vshCmd *cmd)
if (!(network = vshCommandOptNetwork(ctl, cmd, &name))) if (!(network = vshCommandOptNetwork(ctl, cmd, &name)))
return false; return false;
nleases = mac ? virNetworkGetDHCPLeasesForMAC(network, mac, &leases, flags) if ((nleases = virNetworkGetDHCPLeases(network, mac, &leases, flags)) < 0) {
: virNetworkGetDHCPLeases(network, &leases, flags);
if (nleases < 0) {
vshError(ctl, _("Failed to get leases info for %s"), name); vshError(ctl, _("Failed to get leases info for %s"), name);
goto cleanup; goto cleanup;
} }