lib: add virDomainGetGuestInfo()

This API is intended to aggregate several guest agent information
queries and is ispired by stats API virDomainListGetStats(). It is
anticipated that this information will be provided by a guest agent
running within the domain.

Signed-off-by: Jonathon Jongsma <jjongsma@redhat.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
Tested-by: Daniel Henrique Barboza <danielhb413@gmail.com>
This commit is contained in:
Jonathon Jongsma 2019-08-23 11:31:15 -05:00 committed by Michal Privoznik
parent 9d6737764f
commit 96880b87d0
4 changed files with 144 additions and 0 deletions

View File

@ -4902,4 +4902,18 @@ int virDomainGetLaunchSecurityInfo(virDomainPtr domain,
int *nparams, int *nparams,
unsigned int flags); unsigned int flags);
typedef enum {
VIR_DOMAIN_GUEST_INFO_USERS = (1 << 0), /* return active users */
VIR_DOMAIN_GUEST_INFO_OS = (1 << 1), /* return OS information */
VIR_DOMAIN_GUEST_INFO_TIMEZONE = (1 << 2), /* return timezone information */
VIR_DOMAIN_GUEST_INFO_HOSTNAME = (1 << 3), /* return hostname information */
VIR_DOMAIN_GUEST_INFO_FILESYSTEM = (1 << 4), /* return filesystem information */
} virDomainGuestInfoTypes;
int virDomainGetGuestInfo(virDomainPtr domain,
unsigned int types,
virTypedParameterPtr *params,
int *nparams,
unsigned int flags);
#endif /* LIBVIRT_DOMAIN_H */ #endif /* LIBVIRT_DOMAIN_H */

View File

@ -1359,6 +1359,13 @@ typedef int
(*virDrvDomainCheckpointDelete)(virDomainCheckpointPtr checkpoint, (*virDrvDomainCheckpointDelete)(virDomainCheckpointPtr checkpoint,
unsigned int flags); unsigned int flags);
typedef int
(*virDrvDomainGetGuestInfo)(virDomainPtr domain,
unsigned int types,
virTypedParameterPtr *params,
int *nparams,
unsigned int flags);
typedef struct _virHypervisorDriver virHypervisorDriver; typedef struct _virHypervisorDriver virHypervisorDriver;
typedef virHypervisorDriver *virHypervisorDriverPtr; typedef virHypervisorDriver *virHypervisorDriverPtr;
@ -1617,4 +1624,5 @@ struct _virHypervisorDriver {
virDrvDomainCheckpointLookupByName domainCheckpointLookupByName; virDrvDomainCheckpointLookupByName domainCheckpointLookupByName;
virDrvDomainCheckpointGetParent domainCheckpointGetParent; virDrvDomainCheckpointGetParent domainCheckpointGetParent;
virDrvDomainCheckpointDelete domainCheckpointDelete; virDrvDomainCheckpointDelete domainCheckpointDelete;
virDrvDomainGetGuestInfo domainGetGuestInfo;
}; };

View File

@ -12212,6 +12212,123 @@ virDomainSetVcpu(virDomainPtr domain,
return -1; return -1;
} }
/**
* virDomainGetGuestInfo:
* @domain: pointer to domain object
* @types: types of information to return, binary-OR of virDomainGuestInfoTypes
* @params: location to store the guest info parameters
* @nparams: number of items in @params
* @flags: currently unused, set to 0
*
* Queries the guest agent for the various information about the guest system.
* The reported data depends on the guest agent implementation. The information
* is returned as an array of typed parameters containing the individual
* parameters. The parameter name for each information field consists of a
* dot-separated strign containing the name of the requested group followed by
* a group-specific description of the statistic value.
*
* The information groups are enabled using the @types parameter which is a
* binary-OR of enum virDomainGuestInfoTypes. The following groups are available
* (although not necessarily implemented for each hypervisor):
*
* VIR_DOMAIN_GUEST_INFO_USERS:
* returns information about users that are currently logged in within the
* guest domain. The typed parameter keys are in this format:
*
* "user.count" - the number of active users on this domain as an
* unsigned int
* "user.<num>.name - username of the user as a string
* "user.<num>.domain - domain of the user as a string (may only be
* present on certain guest types)
* "user.<num>.login-time - the login time of a user in milliseconds
* since the epoch as unsigned long long
*
* VIR_DOMAIN_GUEST_INFO_OS:
* Return information about the operating system running within the guest. The
* typed parameter keys are in this format:
*
* "os.id" - a string identifying the operating system
* "os.name" - the name of the operating system, suitable for presentation
* to a user, as a string
* "os.pretty-name" - a pretty name for the operating system, suitable for
* presentation to a user, as a string
* "os.version" - the version of the operating system suitable for
* presentation to a user, as a string
* "os.version-id" - the version id of the operating system suitable for
* processing by scripts, as a string
* "os.kernel-release" - the release of the operating system kernel, as a
* string
* "os.kernel-version" - the version of the operating system kernel, as a
* string
* "os.machine" - the machine hardware name as a string
* "os.variant" - a specific variant or edition of the operating system
* suitable for presentation to a user, as a string
* "os.variant-id" - the id for a specific variant or edition of the
* operating system, as a string
*
* VIR_DOMAIN_GUEST_INFO_TIMEZONE:
* Returns information about the timezone within the domain. The typed
* parameter keys are in this format:
*
* "timezone.name" - the name of the timezone as a string
* "timezone.offset" - the offset to UTC in seconds as an int
*
* VIR_DOMAIN_GUEST_INFO_FILESYSTEM:
* Returns inforamtion about the filesystems within the domain. The typed
* parameter keys are in this format:
* "fs.count" - the number of filesystems defined on this domain
* as an unsigned int
* "fs.<num>.mountpoint" - the path to the mount point for the filesystem
* "fs.<num>.name" - device name in the guest (e.g. "sda1")
* "fs.<num>.fstype" - the type of filesystem
* "fs.<num>.total-bytes" - the total size of the filesystem
* "fs.<num>.used-bytes" - the number of bytes used in the filesystem
* "fs.<num>.disk.count" - the number of disks targeted by this filesystem
* "fs.<num>.disk.<num>.alias" - the device alias of the disk (e.g. sda)
* "fs.<num>.disk.<num>.serial" - the serial number of the disk
* "fs.<num>.disk.<num>.device" - the device node of the disk
*
* Using 0 for @types returns all information groups supported by the given
* hypervisor.
*
* This API requires the VM to run. The caller is responsible for calling
* virTypedParamsFree to free memory returned in @params.
*
* Returns 0 on success, -1 on error.
*/
int virDomainGetGuestInfo(virDomainPtr domain,
unsigned int types,
virTypedParameterPtr *params,
int *nparams,
unsigned int flags)
{
VIR_DOMAIN_DEBUG(domain, "types=0x%x, params=%p, nparams=%p, flags=0x%x",
types, params, nparams, flags);
virResetLastError();
virCheckDomainReturn(domain, -1);
virCheckReadOnlyGoto(domain->conn->flags, error);
virCheckNonNullArgGoto(params, error);
virCheckNonNullArgGoto(nparams, error);
if (domain->conn->driver->domainGetGuestInfo) {
int ret;
ret = domain->conn->driver->domainGetGuestInfo(domain, types,
params, nparams, flags);
if (ret < 0)
goto error;
return ret;
}
virReportUnsupportedError();
error:
virDispatchError(domain->conn);
return -1;
}
/** /**
* virDomainSetBlockThreshold: * virDomainSetBlockThreshold:

View File

@ -852,4 +852,9 @@ LIBVIRT_5.6.0 {
virDomainListAllCheckpoints; virDomainListAllCheckpoints;
} LIBVIRT_5.5.0; } LIBVIRT_5.5.0;
LIBVIRT_5.7.0 {
global:
virDomainGetGuestInfo;
} LIBVIRT_5.6.0;
# .... define new API here using predicted next version number .... # .... define new API here using predicted next version number ....