2010-12-16 16:10:54 +00:00
|
|
|
/*
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* domain_audit.c: Domain audit management
|
2010-12-16 16:10:54 +00:00
|
|
|
*
|
2012-03-02 13:27:39 -07:00
|
|
|
* Copyright (C) 2006-2012 Red Hat, Inc.
|
2010-12-16 16:10:54 +00:00
|
|
|
* Copyright (C) 2006 Daniel P. Berrange
|
|
|
|
*
|
|
|
|
* 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
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-21 18:06:23 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2010-12-16 16:10:54 +00:00
|
|
|
*
|
|
|
|
* Author: Daniel P. Berrange <berrange@redhat.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
|
|
|
|
2011-03-07 16:17:26 -07:00
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
#include "domain_audit.h"
|
2011-07-11 13:42:15 -06:00
|
|
|
#include "viraudit.h"
|
2010-12-16 16:10:54 +00:00
|
|
|
#include "uuid.h"
|
|
|
|
#include "logging.h"
|
|
|
|
#include "memory.h"
|
|
|
|
|
2011-03-07 16:17:26 -07:00
|
|
|
/* Return nn:mm in hex for block and character devices, and NULL
|
|
|
|
* for other file types, stat failure, or allocation failure. */
|
|
|
|
#if defined major && defined minor
|
|
|
|
static char *
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditGetRdev(const char *path)
|
2011-03-07 16:17:26 -07:00
|
|
|
{
|
|
|
|
char *ret = NULL;
|
|
|
|
struct stat sb;
|
|
|
|
|
|
|
|
if (stat(path, &sb) == 0 &&
|
|
|
|
(S_ISCHR(sb.st_mode) || S_ISBLK(sb.st_mode))) {
|
|
|
|
int maj = major(sb.st_rdev);
|
|
|
|
int min = minor(sb.st_rdev);
|
2011-08-02 14:26:17 -06:00
|
|
|
ignore_value(virAsprintf(&ret, "%02X:%02X", maj, min));
|
2011-03-07 16:17:26 -07:00
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
static char *
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditGetRdev(const char *path ATTRIBUTE_UNUSED)
|
2011-03-07 16:17:26 -07:00
|
|
|
{
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditDisk(virDomainObjPtr vm,
|
2011-08-22 13:49:10 -06:00
|
|
|
const char *oldDef, const char *newDef,
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
const char *reason, bool success)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
|
|
|
char *oldsrc = NULL;
|
|
|
|
char *newsrc = NULL;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2011-08-22 13:49:10 -06:00
|
|
|
if (!(oldsrc = virAuditEncode("old-disk", VIR_AUDIT_STR(oldDef)))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
goto cleanup;
|
|
|
|
}
|
2011-08-22 13:49:10 -06:00
|
|
|
if (!(newsrc = virAuditEncode("new-disk", VIR_AUDIT_STR(newDef)))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2011-07-04 12:21:21 +01:00
|
|
|
"virt=%s resrc=disk reason=%s %s uuid=%s %s %s",
|
|
|
|
virt, reason, vmname, uuidstr,
|
2010-12-16 16:10:54 +00:00
|
|
|
oldsrc, newsrc);
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
VIR_FREE(oldsrc);
|
|
|
|
VIR_FREE(newsrc);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-07-04 12:00:33 +01:00
|
|
|
void
|
|
|
|
virDomainAuditFS(virDomainObjPtr vm,
|
|
|
|
virDomainFSDefPtr oldDef, virDomainFSDefPtr newDef,
|
|
|
|
const char *reason, bool success)
|
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
|
|
|
char *oldsrc = NULL;
|
|
|
|
char *newsrc = NULL;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2011-07-04 12:00:33 +01:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:00:33 +01:00
|
|
|
if (!(oldsrc = virAuditEncode("old-fs",
|
|
|
|
oldDef && oldDef->src ?
|
|
|
|
oldDef->src : "?"))) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
if (!(newsrc = virAuditEncode("new-fs",
|
|
|
|
newDef && newDef->src ?
|
|
|
|
newDef->src : "?"))) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2011-07-04 12:21:21 +01:00
|
|
|
"virt=%s resrc=fs reason=%s %s uuid=%s %s %s",
|
|
|
|
virt, reason, vmname, uuidstr,
|
2011-07-04 12:00:33 +01:00
|
|
|
oldsrc, newsrc);
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
VIR_FREE(oldsrc);
|
|
|
|
VIR_FREE(newsrc);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditNet(virDomainObjPtr vm,
|
|
|
|
virDomainNetDefPtr oldDef, virDomainNetDefPtr newDef,
|
|
|
|
const char *reason, bool success)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char newMacstr[VIR_MAC_STRING_BUFLEN];
|
|
|
|
char oldMacstr[VIR_MAC_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (oldDef)
|
2012-07-17 08:07:59 -04:00
|
|
|
virMacAddrFormat(&oldDef->mac, oldMacstr);
|
2010-12-16 16:10:54 +00:00
|
|
|
if (newDef)
|
2012-07-17 08:07:59 -04:00
|
|
|
virMacAddrFormat(&newDef->mac, newMacstr);
|
2010-12-16 16:10:54 +00:00
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2010-12-16 16:10:54 +00:00
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2012-02-09 17:06:00 -02:00
|
|
|
"virt=%s resrc=net reason=%s %s uuid=%s old-net=%s new-net=%s",
|
2011-07-04 12:21:21 +01:00
|
|
|
virt, reason, vmname, uuidstr,
|
2010-12-16 16:10:54 +00:00
|
|
|
oldDef ? oldMacstr : "?",
|
|
|
|
newDef ? newMacstr : "?");
|
|
|
|
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
}
|
|
|
|
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditNetDevice:
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
* @vm: domain opening a network-related device
|
|
|
|
* @def: details of network device that fd will be tied to
|
|
|
|
* @device: device being opened (such as /dev/vhost-net,
|
|
|
|
* /dev/net/tun, /dev/tanN). Note that merely opening a device
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* does not mean that virDomain owns it; a followup virDomainAuditNet
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
* shows whether the fd was passed on.
|
|
|
|
* @success: true if the device was opened
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted network device open.
|
|
|
|
*/
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditNetDevice(virDomainDefPtr vmDef, virDomainNetDefPtr netDef,
|
|
|
|
const char *device, bool success)
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char macstr[VIR_MAC_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-09-16 14:05:58 +02:00
|
|
|
char *dev_name;
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
char *rdev;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
|
|
|
|
virUUIDFormat(vmDef->uuid, uuidstr);
|
2012-07-17 08:07:59 -04:00
|
|
|
virMacAddrFormat(&netDef->mac, macstr);
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
rdev = virDomainAuditGetRdev(device);
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
|
|
|
|
if (!(vmname = virAuditEncode("vm", vmDef->name)) ||
|
2011-09-16 14:05:58 +02:00
|
|
|
!(dev_name = virAuditEncode("path", device))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vmDef->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vmDef->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2012-02-09 17:06:00 -02:00
|
|
|
"virt=%s resrc=net reason=open %s uuid=%s net=%s %s rdev=%s",
|
2011-09-16 14:05:58 +02:00
|
|
|
virt, vmname, uuidstr, macstr, dev_name, VIR_AUDIT_STR(rdev));
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(vmname);
|
2011-09-16 14:05:58 +02:00
|
|
|
VIR_FREE(dev_name);
|
audit: audit use of /dev/net/tun, /dev/tapN, /dev/vhost-net
Opening raw network devices with the intent of passing those fds to
qemu is worth an audit point. This makes a multi-part audit: first,
we audit the device(s) that libvirt opens on behalf of the MAC address
of a to-be-created interface (which can independently succeed or
fail), then we audit whether qemu actually started the network device
with the same MAC (so searching backwards for successful audits with
the same MAC will show which fd(s) qemu is actually using). Note that
it is possible for the fd to be successfully opened but no attempt
made to pass the fd to qemu (for example, because intermediate
nwfilter operations failed) - no interface start audit will occur in
that case; so the audit for a successful opened fd does not imply
rights given to qemu unless there is a followup audit about the
attempt to start a new interface.
Likewise, when a network device is hot-unplugged, there is only one
audit message about the MAC being discontinued; again, searching back
to the earlier device open audits will show which fds that qemu quits
using (and yes, I checked via /proc/<qemu-pid>/fd that qemu _does_
close out the fds associated with an interface on hot-unplug). The
code would require much more refactoring to be able to definitively
state which device(s) were discontinued at that point, since we
currently don't record anywhere in the XML whether /dev/vhost-net was
opened for a given interface.
* src/qemu/qemu_audit.h (qemuAuditNetDevice): New prototype.
* src/qemu/qemu_audit.c (qemuAuditNetDevice): New function.
* src/qemu/qemu_command.h (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Adjust prototype.
* src/qemu/qemu_command.c (qemuNetworkIfaceConnect)
(qemuPhysIfaceConnect, qemuOpenVhostNet): Add audit points and
adjust parameters.
(qemuBuildCommandLine): Adjust caller.
* src/qemu/qemu_hotplug.c (qemuDomainAttachNetDevice): Likewise.
2011-03-08 11:00:59 -07:00
|
|
|
VIR_FREE(rdev);
|
|
|
|
}
|
2010-12-16 16:10:54 +00:00
|
|
|
|
2011-02-23 16:15:23 -07:00
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditHostdev:
|
2011-02-23 16:15:23 -07:00
|
|
|
* @vm: domain making a change in pass-through host device
|
|
|
|
* @hostdev: device being attached or removed
|
2011-03-07 16:17:26 -07:00
|
|
|
* @reason: one of "start", "attach", or "detach"
|
2011-02-23 16:15:23 -07:00
|
|
|
* @success: true if the device passthrough operation succeeded
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted device passthrough change.
|
|
|
|
*/
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditHostdev(virDomainObjPtr vm, virDomainHostdevDefPtr hostdev,
|
|
|
|
const char *reason, bool success)
|
2011-02-23 16:15:23 -07:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-09-14 22:02:30 +02:00
|
|
|
char *address = NULL;
|
|
|
|
char *device = NULL;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2011-02-23 16:15:23 -07:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-23 16:15:23 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2011-02-23 16:15:23 -07:00
|
|
|
switch (hostdev->source.subsys.type) {
|
|
|
|
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI:
|
|
|
|
if (virAsprintf(&address, "%.4x:%.2x:%.2x.%.1x",
|
|
|
|
hostdev->source.subsys.u.pci.domain,
|
|
|
|
hostdev->source.subsys.u.pci.bus,
|
|
|
|
hostdev->source.subsys.u.pci.slot,
|
|
|
|
hostdev->source.subsys.u.pci.function) < 0) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-23 16:15:23 -07:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_USB:
|
|
|
|
if (virAsprintf(&address, "%.3d.%.3d",
|
|
|
|
hostdev->source.subsys.u.usb.bus,
|
|
|
|
hostdev->source.subsys.u.usb.device) < 0) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-23 16:15:23 -07:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
VIR_WARN("Unexpected hostdev type while encoding audit message: %d",
|
|
|
|
hostdev->source.subsys.type);
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(device = virAuditEncode("device", VIR_AUDIT_STR(address)))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-23 16:15:23 -07:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2011-07-04 12:21:21 +01:00
|
|
|
"virt=%s resrc=dev reason=%s %s uuid=%s bus=%s %s",
|
|
|
|
virt, reason, vmname, uuidstr,
|
2011-02-23 16:15:23 -07:00
|
|
|
virDomainHostdevSubsysTypeToString(hostdev->source.subsys.type),
|
|
|
|
device);
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
VIR_FREE(device);
|
|
|
|
VIR_FREE(address);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-09-02 23:09:14 +08:00
|
|
|
/**
|
|
|
|
* virDomainAuditRedirdev:
|
|
|
|
* @vm: domain making a change in pass-through host device
|
|
|
|
* @redirdev: device being attached or removed
|
|
|
|
* @reason: one of "start", "attach", or "detach"
|
|
|
|
* @success: true if the device passthrough operation succeeded
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted device passthrough change.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
virDomainAuditRedirdev(virDomainObjPtr vm, virDomainRedirdevDefPtr redirdev,
|
|
|
|
const char *reason, bool success)
|
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-09-14 22:02:30 +02:00
|
|
|
char *address = NULL;
|
|
|
|
char *device = NULL;
|
2011-09-02 23:09:14 +08:00
|
|
|
const char *virt;
|
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (redirdev->bus) {
|
|
|
|
case VIR_DOMAIN_REDIRDEV_BUS_USB:
|
|
|
|
if (virAsprintf(&address, "USB redirdev") < 0) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
2011-09-14 22:02:30 +02:00
|
|
|
break;
|
2011-09-02 23:09:14 +08:00
|
|
|
default:
|
|
|
|
VIR_WARN("Unexpected redirdev bus while encoding audit message: %d",
|
|
|
|
redirdev->bus);
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!(device = virAuditEncode("device", VIR_AUDIT_STR(address)))) {
|
|
|
|
VIR_WARN("OOM while encoding audit message");
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
|
|
|
"virt=%s resrc=dev reason=%s %s uuid=%s bus=%s %s",
|
|
|
|
virt, reason, vmname, uuidstr,
|
|
|
|
virDomainRedirdevBusTypeToString(redirdev->bus),
|
|
|
|
device);
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
VIR_FREE(device);
|
|
|
|
VIR_FREE(address);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-02-15 19:35:43 -07:00
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditCgroup:
|
2011-02-15 19:35:43 -07:00
|
|
|
* @vm: domain making the cgroups ACL change
|
|
|
|
* @cgroup: cgroup that manages the devices
|
|
|
|
* @reason: either "allow" or "deny"
|
2011-03-07 16:17:26 -07:00
|
|
|
* @extra: additional details, in the form "all",
|
|
|
|
* "major category=xyz maj=nn", or "path path=xyz dev=nn:mm" (the
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* latter two are generated by virDomainAuditCgroupMajor and
|
|
|
|
* virDomainAuditCgroupPath).
|
2011-02-15 19:35:43 -07:00
|
|
|
* @success: true if the cgroup operation succeeded
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted cgroup device ACL change.
|
|
|
|
*/
|
2011-03-07 16:17:26 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditCgroup(virDomainObjPtr vm, virCgroupPtr cgroup,
|
|
|
|
const char *reason, const char *extra, bool success)
|
2011-02-15 19:35:43 -07:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-03-07 16:41:40 -07:00
|
|
|
char *controller = NULL;
|
|
|
|
char *detail;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2011-02-15 19:35:43 -07:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-15 19:35:43 -07:00
|
|
|
return;
|
|
|
|
}
|
2011-03-07 16:17:26 -07:00
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2011-07-04 10:23:46 +08:00
|
|
|
ignore_value(virCgroupPathOfController(cgroup,
|
|
|
|
VIR_CGROUP_CONTROLLER_DEVICES,
|
|
|
|
NULL, &controller));
|
2011-03-07 16:41:40 -07:00
|
|
|
detail = virAuditEncode("cgroup", VIR_AUDIT_STR(controller));
|
|
|
|
|
2011-03-07 16:17:26 -07:00
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2011-07-04 12:21:21 +01:00
|
|
|
"virt=%s resrc=cgroup reason=%s %s uuid=%s %s class=%s",
|
|
|
|
virt, reason, vmname, uuidstr,
|
2011-03-07 16:41:40 -07:00
|
|
|
detail ? detail : "cgroup=?", extra);
|
2011-03-07 16:17:26 -07:00
|
|
|
|
|
|
|
VIR_FREE(vmname);
|
2011-03-07 16:41:40 -07:00
|
|
|
VIR_FREE(controller);
|
|
|
|
VIR_FREE(detail);
|
2011-03-07 16:17:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditCgroupMajor:
|
2011-03-07 16:17:26 -07:00
|
|
|
* @vm: domain making the cgroups ACL change
|
|
|
|
* @cgroup: cgroup that manages the devices
|
|
|
|
* @reason: either "allow" or "deny"
|
|
|
|
* @maj: the major number of the device category
|
|
|
|
* @name: a textual name for that device category, alphabetic only
|
2011-03-08 20:06:26 -07:00
|
|
|
* @perms: string containing "r", "w", and/or "m" as appropriate
|
2011-03-07 16:17:26 -07:00
|
|
|
* @success: true if the cgroup operation succeeded
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted cgroup device ACL change.
|
|
|
|
*/
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditCgroupMajor(virDomainObjPtr vm, virCgroupPtr cgroup,
|
|
|
|
const char *reason, int maj, const char *name,
|
|
|
|
const char *perms, bool success)
|
2011-03-07 16:17:26 -07:00
|
|
|
{
|
|
|
|
char *extra;
|
|
|
|
|
2011-03-08 20:06:26 -07:00
|
|
|
if (virAsprintf(&extra, "major category=%s maj=%02X acl=%s",
|
|
|
|
name, maj, perms) < 0) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-03-07 16:17:26 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditCgroup(vm, cgroup, reason, extra, success);
|
2011-03-07 16:17:26 -07:00
|
|
|
|
|
|
|
VIR_FREE(extra);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditCgroupPath:
|
2011-03-07 16:17:26 -07:00
|
|
|
* @vm: domain making the cgroups ACL change
|
|
|
|
* @cgroup: cgroup that manages the devices
|
|
|
|
* @reason: either "allow" or "deny"
|
|
|
|
* @path: the device being adjusted
|
2011-03-08 20:06:26 -07:00
|
|
|
* @perms: string containing "r", "w", and/or "m" as appropriate
|
2011-03-07 16:17:26 -07:00
|
|
|
* @rc: > 0 if not a device, 0 if success, < 0 if failure
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted cgroup device ACL change to
|
|
|
|
* a specific device.
|
|
|
|
*/
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditCgroupPath(virDomainObjPtr vm, virCgroupPtr cgroup,
|
|
|
|
const char *reason, const char *path, const char *perms,
|
|
|
|
int rc)
|
2011-03-07 16:17:26 -07:00
|
|
|
{
|
|
|
|
char *detail;
|
|
|
|
char *rdev;
|
|
|
|
char *extra;
|
|
|
|
|
|
|
|
/* Nothing to audit for regular files. */
|
|
|
|
if (rc > 0)
|
|
|
|
return;
|
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
rdev = virDomainAuditGetRdev(path);
|
2011-03-07 16:17:26 -07:00
|
|
|
|
|
|
|
if (!(detail = virAuditEncode("path", path)) ||
|
2011-03-08 20:06:26 -07:00
|
|
|
virAsprintf(&extra, "path path=%s rdev=%s acl=%s",
|
|
|
|
path, VIR_AUDIT_STR(rdev), perms) < 0) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-15 19:35:43 -07:00
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditCgroup(vm, cgroup, reason, extra, rc == 0);
|
2011-02-15 19:35:43 -07:00
|
|
|
|
|
|
|
cleanup:
|
2011-03-07 16:17:26 -07:00
|
|
|
VIR_FREE(extra);
|
2011-02-15 19:35:43 -07:00
|
|
|
VIR_FREE(detail);
|
2011-03-07 16:17:26 -07:00
|
|
|
VIR_FREE(rdev);
|
2011-02-15 19:35:43 -07:00
|
|
|
}
|
|
|
|
|
2011-02-21 17:02:17 -07:00
|
|
|
/**
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
* virDomainAuditResource:
|
2011-02-21 17:02:17 -07:00
|
|
|
* @vm: domain making an integer resource change
|
|
|
|
* @resource: name of the resource: "mem" or "vcpu"
|
|
|
|
* @oldval: the old value of the resource
|
|
|
|
* @newval: the new value of the resource
|
|
|
|
* @reason: either "start" or "update"
|
|
|
|
* @success: true if the resource change succeeded
|
|
|
|
*
|
|
|
|
* Log an audit message about an attempted resource change.
|
|
|
|
*/
|
|
|
|
static void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditResource(virDomainObjPtr vm, const char *resource,
|
|
|
|
unsigned long long oldval, unsigned long long newval,
|
|
|
|
const char *reason, bool success)
|
2011-02-21 17:02:17 -07:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2011-02-21 17:02:17 -07:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2011-02-21 17:02:17 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2011-02-21 17:02:17 -07:00
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_RESOURCE, success,
|
2011-07-04 12:21:21 +01:00
|
|
|
"virt=%s resrc=%s reason=%s %s uuid=%s old-%s=%lld new-%s=%lld",
|
|
|
|
virt, resource, reason, vmname, uuidstr,
|
2011-02-21 17:02:17 -07:00
|
|
|
resource, oldval, resource, newval);
|
|
|
|
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditMemory(virDomainObjPtr vm,
|
|
|
|
unsigned long long oldmem, unsigned long long newmem,
|
|
|
|
const char *reason, bool success)
|
2011-02-21 17:02:17 -07:00
|
|
|
{
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
return virDomainAuditResource(vm, "mem", oldmem, newmem, reason, success);
|
2011-02-21 17:02:17 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditVcpu(virDomainObjPtr vm,
|
|
|
|
unsigned int oldvcpu, unsigned int newvcpu,
|
|
|
|
const char *reason, bool success)
|
2011-02-21 17:02:17 -07:00
|
|
|
{
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
return virDomainAuditResource(vm, "vcpu", oldvcpu, newvcpu, reason, success);
|
2011-02-21 17:02:17 -07:00
|
|
|
}
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
static void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditLifecycle(virDomainObjPtr vm, const char *op,
|
|
|
|
const char *reason, bool success)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2010-12-16 16:10:54 +00:00
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_MACHINE_CONTROL, success,
|
2012-04-20 15:13:51 +02:00
|
|
|
"virt=%s op=%s reason=%s %s uuid=%s vm-pid=%lld",
|
|
|
|
virt, op, reason, vmname, uuidstr, (long long)vm->pid);
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditStart(virDomainObjPtr vm, const char *reason, bool success)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 0 ; i < vm->def->ndisks ; i++) {
|
|
|
|
virDomainDiskDefPtr disk = vm->def->disks[i];
|
|
|
|
if (disk->src) /* Skips CDROM without media initially inserted */
|
2011-08-22 13:49:10 -06:00
|
|
|
virDomainAuditDisk(vm, NULL, disk->src, "start", true);
|
2010-12-16 16:10:54 +00:00
|
|
|
}
|
|
|
|
|
2011-07-04 12:00:33 +01:00
|
|
|
for (i = 0 ; i < vm->def->nfss ; i++) {
|
|
|
|
virDomainFSDefPtr fs = vm->def->fss[i];
|
|
|
|
virDomainAuditFS(vm, NULL, fs, "start", true);
|
|
|
|
}
|
|
|
|
|
2010-12-16 16:10:54 +00:00
|
|
|
for (i = 0 ; i < vm->def->nnets ; i++) {
|
|
|
|
virDomainNetDefPtr net = vm->def->nets[i];
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditNet(vm, NULL, net, "start", true);
|
2010-12-16 16:10:54 +00:00
|
|
|
}
|
|
|
|
|
2011-02-23 16:15:23 -07:00
|
|
|
for (i = 0 ; i < vm->def->nhostdevs ; i++) {
|
|
|
|
virDomainHostdevDefPtr hostdev = vm->def->hostdevs[i];
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditHostdev(vm, hostdev, "start", true);
|
2011-02-23 16:15:23 -07:00
|
|
|
}
|
|
|
|
|
2011-09-02 23:09:14 +08:00
|
|
|
for (i = 0 ; i < vm->def->nredirdevs ; i++) {
|
|
|
|
virDomainRedirdevDefPtr redirdev = vm->def->redirdevs[i];
|
|
|
|
virDomainAuditRedirdev(vm, redirdev, "start", true);
|
|
|
|
}
|
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditMemory(vm, 0, vm->def->mem.cur_balloon, "start", true);
|
|
|
|
virDomainAuditVcpu(vm, 0, vm->def->vcpus, "start", true);
|
2011-02-21 17:02:17 -07:00
|
|
|
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditLifecycle(vm, "start", reason, success);
|
2010-12-16 16:10:54 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditStop(virDomainObjPtr vm, const char *reason)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditLifecycle(vm, "stop", reason, true);
|
2010-12-16 16:10:54 +00:00
|
|
|
}
|
|
|
|
|
2011-03-08 14:28:51 -07:00
|
|
|
void
|
Move qemu_audit.h helpers into shared code
The LXC and UML drivers can both make use of auditing. Move
the qemu_audit.{c,h} files to src/conf/domain_audit.{c,h}
* src/conf/domain_audit.c: Rename from src/qemu/qemu_audit.c
* src/conf/domain_audit.h: Rename from src/qemu/qemu_audit.h
* src/Makefile.am: Remove qemu_audit.{c,h}, add domain_audit.{c,h}
* src/qemu/qemu_audit.h, src/qemu/qemu_cgroup.c,
src/qemu/qemu_command.c, src/qemu/qemu_driver.c,
src/qemu/qemu_hotplug.c, src/qemu/qemu_migration.c,
src/qemu/qemu_process.c: Update for changed audit API names
2011-07-04 11:56:13 +01:00
|
|
|
virDomainAuditSecurityLabel(virDomainObjPtr vm, bool success)
|
2010-12-16 16:10:54 +00:00
|
|
|
{
|
|
|
|
char uuidstr[VIR_UUID_STRING_BUFLEN];
|
|
|
|
char *vmname;
|
2011-07-04 12:21:21 +01:00
|
|
|
const char *virt;
|
2012-08-15 19:10:35 -03:00
|
|
|
int i;
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
virUUIDFormat(vm->def->uuid, uuidstr);
|
|
|
|
if (!(vmname = virAuditEncode("vm", vm->def->name))) {
|
2011-05-09 17:24:09 +08:00
|
|
|
VIR_WARN("OOM while encoding audit message");
|
2010-12-16 16:10:54 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-07-04 12:21:21 +01:00
|
|
|
if (!(virt = virDomainVirtTypeToString(vm->def->virtType))) {
|
|
|
|
VIR_WARN("Unexpected virt type %d while encoding audit message", vm->def->virtType);
|
|
|
|
virt = "?";
|
|
|
|
}
|
|
|
|
|
2012-08-15 19:10:35 -03:00
|
|
|
for (i = 0; i < vm->def->nseclabels; i++) {
|
|
|
|
VIR_AUDIT(VIR_AUDIT_RECORD_MACHINE_ID, success,
|
|
|
|
"virt=%s %s uuid=%s vm-ctx=%s img-ctx=%s model=%s",
|
|
|
|
virt, vmname, uuidstr,
|
|
|
|
VIR_AUDIT_STR(vm->def->seclabels[i]->label),
|
|
|
|
VIR_AUDIT_STR(vm->def->seclabels[i]->imagelabel),
|
|
|
|
VIR_AUDIT_STR(vm->def->seclabels[i]->model));
|
|
|
|
}
|
2010-12-16 16:10:54 +00:00
|
|
|
|
|
|
|
VIR_FREE(vmname);
|
|
|
|
}
|