Validate our UUIDs and fix some formatting inconsistencies

This commit is contained in:
Joshua Boniface 2018-06-06 12:28:15 -04:00
parent 2c09ee2a17
commit eeeb54c23d
2 changed files with 95 additions and 18 deletions

98
pvc.py
View File

@ -117,23 +117,22 @@ def define_vm(xml_config_file, target_hypervisor):
data = f_domxmlfile.read() data = f_domxmlfile.read()
f_domxmlfile.close() f_domxmlfile.close()
# Parse in the XML file # Parse the XML data
parsed_xml = lxml.objectify.fromstring(data) parsed_xml = lxml.objectify.fromstring(data)
dom_uuid = parsed_xml.uuid.text dom_uuid = parsed_xml.uuid.text
dom_name = parsed_xml.name.text dom_name = parsed_xml.name.text
print('Adding new VM with Name %s and UUID %s to database' % (domname, domuuid)) click.echo('Adding new VM with Name "{}" and UUID "{}" to database.'.format(dom_name, dom_uuid))
# Open a Zookeeper connection # Open a Zookeeper connection
zk = pvcf.startZKConnection(zk_host) zk = pvcf.startZKConnection(zk_host)
# Add the new domain to Zookeeper # Add the new domain to Zookeeper
transaction = zk.transaction() transaction = zk.transaction()
transaction.create('/domains/%s' % domuuid, domname.encode('ascii')) transaction.create('/domains/{}'.format(dom_uuid), domname.encode('ascii'))
transaction.create('/domains/%s/state' % domuuid, 'stop'.encode('ascii')) transaction.create('/domains/{}/state'.format(dom_uuid), 'stop'.encode('ascii'))
transaction.create('/domains/%s/hypervisor' % domuuid, target_hypervisor.encode('ascii')) transaction.create('/domains/{}/hypervisor'.format(dom_uuid), target_hypervisor.encode('ascii'))
transaction.create('/domains/%s/lasthypervisor' % domuuid, ''.encode('ascii')) transaction.create('/domains/{}/lasthypervisor'.format(dom_uuid), ''.encode('ascii'))
transaction.create('/domains/%s/name' % domuuid, data.encode('ascii')) transaction.create('/domains/{}/xml'.format(dom_uuid), data.encode('ascii'))
transaction.create('/domains/%s/xml' % domuuid, data.encode('ascii'))
results = transaction.commit() results = transaction.commit()
# Close the Zookeeper connection # Close the Zookeeper connection
@ -161,25 +160,45 @@ def undefine_vm(dom_name, dom_uuid):
Stop a virtual machine and remove it from the cluster database. Stop a virtual machine and remove it from the cluster database.
""" """
# Ensure at least one search method is set
if dom_name == None and dom_uuid == None:
click.echo("You must specify either a `--name` or `--uuid` value.")
return
# Open a Zookeeper connection # Open a Zookeeper connection
zk = pvcf.startZKConnection(zk_host) zk = pvcf.startZKConnection(zk_host)
# If the --name value was passed, get the UUID
if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
click.echo('Forcibly stopping VM "{}".'.format(dom_uuid))
# Set the domain into stop mode # Set the domain into stop mode
transaction = zk.transaction() transaction = zk.transaction()
transaction.set_data('/domains/%s/state' % domuuid, 'stop'.encode('ascii')) transaction.set_data('/domains/{}/state'.format(dom_uuid), 'stop'.encode('ascii'))
results = transaction.commit() results = transaction.commit()
# Wait for 3 seconds to allow state to flow to all hypervisors # Wait for 3 seconds to allow state to flow to all hypervisors
click.echo('Waiting for cluster to update.')
time.sleep(3) time.sleep(3)
# Delete the configurations # Delete the configurations
click.echo('Undefining VM "{}".'.format(dom_uuid))
transaction = zk.transaction() transaction = zk.transaction()
transaction.delete('/domains/%s/state' % domuuid) transaction.delete('/domains/{}/state'.format(dom_uuid))
transaction.delete('/domains/%s/hypervisor' % domuuid) transaction.delete('/domains/{}/hypervisor'.format(dom_uuid))
transaction.delete('/domains/%s/lasthypervisor' % domuuid) transaction.delete('/domains/{}/lasthypervisor'.format(dom_uuid))
transaction.delete('/domains/%s/xml' % domuuid) transaction.delete('/domains/{}/xml'.format(dom_uuid))
transaction.delete('/domains/%s' % domuuid) transaction.delete('/domains/{}'.format(dom_uuid))
results = transaction.commit() transaction.commit()
# Close the Zookeeper connection # Close the Zookeeper connection
pvcf.stopZKConnection(zk) pvcf.stopZKConnection(zk)
@ -218,7 +237,19 @@ def start_vm(dom_name, dom_uuid):
if dom_name != None: if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name) dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
print(dom_uuid)
print(dom_name)
# Set the VM to start # Set the VM to start
click.echo('Starting VM "{}".'.format(dom_uuid))
zk.set('/domains/%s/state' % dom_uuid, 'start'.encode('ascii')) zk.set('/domains/%s/state' % dom_uuid, 'start'.encode('ascii'))
# Close the Zookeeper connection # Close the Zookeeper connection
@ -258,7 +289,16 @@ def shutdown_vm(dom_name, dom_uuid):
if dom_name != None: if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name) dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Set the VM to start # Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
# Set the VM to shutdown
click.echo('Shutting down VM "{}".'.format(dom_uuid))
zk.set('/domains/%s/state' % dom_uuid, 'shutdown'.encode('ascii')) zk.set('/domains/%s/state' % dom_uuid, 'shutdown'.encode('ascii'))
# Close the Zookeeper connection # Close the Zookeeper connection
@ -298,7 +338,16 @@ def stop_vm(dom_name, dom_uuid):
if dom_name != None: if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name) dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
# Set the VM to start # Set the VM to start
click.echo('Forcibly stopping VM "{}".'.format(dom_uuid))
zk.set('/domains/%s/state' % dom_uuid, 'stop'.encode('ascii')) zk.set('/domains/%s/state' % dom_uuid, 'stop'.encode('ascii'))
# Close the Zookeeper connection # Close the Zookeeper connection
@ -346,6 +395,14 @@ def migrate_vm(dom_name, dom_uuid, target_hypervisor, force_migrate):
if dom_name != None: if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name) dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
current_hypervisor = zk.get('/domains/{}/hypervisor'.format(dom_uuid))[0].decode('ascii') current_hypervisor = zk.get('/domains/{}/hypervisor'.format(dom_uuid))[0].decode('ascii')
last_hypervisor = zk.get('/domains/{}/lasthypervisor'.format(dom_uuid))[0].decode('ascii') last_hypervisor = zk.get('/domains/{}/lasthypervisor'.format(dom_uuid))[0].decode('ascii')
@ -418,6 +475,14 @@ def unmigrate_vm(dom_name, dom_uuid):
if dom_name != None: if dom_name != None:
dom_uuid = pvcf.searchClusterByName(zk, dom_name) dom_uuid = pvcf.searchClusterByName(zk, dom_name)
# Verify we got a result or abort
if not validateUUID(dom_uuid):
if dom_name != None:
message_name = dom_name
else:
message_name = dom_uuid
click.echo("Could not find VM `{}` in the cluster!".format(message_name))
target_hypervisor = zk.get('/domains/{}/lasthypervisor'.format(dom_uuid))[0].decode('ascii') target_hypervisor = zk.get('/domains/{}/lasthypervisor'.format(dom_uuid))[0].decode('ascii')
if target_hypervisor == '': if target_hypervisor == '':
@ -541,6 +606,7 @@ node.add_command(flush_host)
node.add_command(ready_host) node.add_command(ready_host)
vm.add_command(define_vm) vm.add_command(define_vm)
vm.add_command(undefine_vm)
vm.add_command(start_vm) vm.add_command(start_vm)
vm.add_command(shutdown_vm) vm.add_command(shutdown_vm)
vm.add_command(stop_vm) vm.add_command(stop_vm)

15
pvcf.py
View File

@ -26,6 +26,17 @@ import lxml
import click import click
import operator import operator
#
# Validate a UUID
#
def validateUUID(dom_uuid):
try:
uuid.UUID(dom_uuid, version=4)
return True
except ValueError:
return False
# #
# Connect and disconnect from Zookeeper # Connect and disconnect from Zookeeper
# #
@ -178,7 +189,7 @@ def searchClusterByUUID(zk, uuid):
name = name_list[index] name = name_list[index]
except ValueError: except ValueError:
# We didn't find anything # We didn't find anything
return None, None return None
return name return name
@ -192,7 +203,7 @@ def searchClusterByName(zk, name):
uuid = uuid_list[index] uuid = uuid_list[index]
except ValueError: except ValueError:
# We didn't find anything # We didn't find anything
return None, None return None
return uuid return uuid