dom0/qvm-usb: fixed missing input validation

This commit is contained in:
Alexandre Bezroutchko 2012-10-10 17:08:24 +02:00
parent b9b2077062
commit 17263c96b8

View File

@ -467,17 +467,23 @@ def usb_check_attached(backend_vm, device):
xs.transaction_end(xs_trans) xs.transaction_end(xs_trans)
return None return None
for vm in vms: for vm in vms:
# FIXME: validate vm? if not vm.isdigit():
print >> sys.stderr, "Invalid VM id"
continue
frontend_devs = xs.ls(xs_trans, '/local/domain/%d/backend/vusb/%s' % (backend_vm, vm)) frontend_devs = xs.ls(xs_trans, '/local/domain/%d/backend/vusb/%s' % (backend_vm, vm))
if frontend_devs is None: if frontend_devs is None:
continue continue
for frontend_dev in frontend_devs: for frontend_dev in frontend_devs:
# FIXME: validate frontend_dev? if not frontend_dev.isdigit():
print >> sys.stderr, "Invalid frontend in VM %s" % vm
continue
ports = xs.ls(xs_trans, '/local/domain/%d/backend/vusb/%s/%s/port' % (backend_vm, vm, frontend_dev)) ports = xs.ls(xs_trans, '/local/domain/%d/backend/vusb/%s/%s/port' % (backend_vm, vm, frontend_dev))
if ports is None: if ports is None:
continue continue
for port in ports: for port in ports:
# FIXME: validate ports? if not port.isdigit():
print >> sys.stderr, "Invalid port in VM %s frontend %s" % (vm, frontend)
continue
dev = xs.read(xs_trans, '/local/domain/%d/backend/vusb/%s/%s/port/%s' % (backend_vm, vm, frontend_dev, port)) dev = xs.read(xs_trans, '/local/domain/%d/backend/vusb/%s/%s/port/%s' % (backend_vm, vm, frontend_dev, port))
if dev == device: if dev == device:
frontend = "%s-%s" % (frontend_dev, port) frontend = "%s-%s" % (frontend_dev, port)