projects
/
invirt/packages/invirt-web.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
all details in email too, still just for CodeError
[invirt/packages/invirt-web.git]
/
code
/
controls.py
diff --git
a/code/controls.py
b/code/controls.py
index
d4afab0
..
57107ef
100644
(file)
--- a/
code/controls.py
+++ b/
code/controls.py
@@
-92,14
+92,12
@@
def bootMachine(machine, cdtype):
raise CodeError('"%s" on "control %s create %s'
% (err, machine.name, cdtype))
raise CodeError('"%s" on "control %s create %s'
% (err, machine.name, cdtype))
-def createVm(owner, contact, name, memory, disk_size, machine_type, cdrom, clone_from):
+def createVm(username, state, owner, contact, name, memory, disksize, machine_type, cdrom, clone_from):
"""Create a VM and put it in the database"""
# put stuff in the table
transaction = ctx.current.create_transaction()
try:
"""Create a VM and put it in the database"""
# put stuff in the table
transaction = ctx.current.create_transaction()
try:
- validation.validMemory(owner, memory)
- validation.validDisk(owner, disk_size * 1. / 1024)
- validation.validAddVm(owner)
+ validation.Validate(username, state, name=name, owner=owner, memory=memory, disksize=disksize/1024.)
res = meta.engine.execute('select nextval('
'\'"machines_machine_id_seq"\')')
id = res.fetchone()[0]
res = meta.engine.execute('select nextval('
'\'"machines_machine_id_seq"\')')
id = res.fetchone()[0]
@@
-115,7
+113,7
@@
def createVm(owner, contact, name, memory, disk_size, machine_type, cdrom, clone
machine.type_id = machine_type.type_id
ctx.current.save(machine)
disk = Disk(machine_id=machine.machine_id,
machine.type_id = machine_type.type_id
ctx.current.save(machine)
disk = Disk(machine_id=machine.machine_id,
- guest_device_name='hda', size=disk_size)
+ guest_device_name='hda', size=disksize)
open_nics = NIC.select_by(machine_id=None)
if not open_nics: #No IPs left!
raise CodeError("No IP addresses left! "
open_nics = NIC.select_by(machine_id=None)
if not open_nics: #No IPs left!
raise CodeError("No IP addresses left! "
@@
-198,8
+196,6
@@
def deleteVM(machine):
ctx.current.save(nic)
for disk in machine.disks:
ctx.current.delete(disk)
ctx.current.save(nic)
for disk in machine.disks:
ctx.current.delete(disk)
- for access in machine.acl:
- ctx.current.delete(access)
ctx.current.delete(machine)
transaction.commit()
except:
ctx.current.delete(machine)
transaction.commit()
except:
@@
-208,9
+204,9
@@
def deleteVM(machine):
for mname, dname in delete_disk_pairs:
remctl('web', 'lvremove', mname, dname)
for mname, dname in delete_disk_pairs:
remctl('web', 'lvremove', mname, dname)
-def commandResult(user, fields):
+def commandResult(username, state, fields):
start_time = 0
start_time = 0
- machine = validation.testMachineId(user, fields.getfirst('machine_id'))
+ machine = validation.Validate(username, state, machine_id=fields.getfirst('machine_id')).machine
action = fields.getfirst('action')
cdrom = fields.getfirst('cdrom')
if cdrom is not None and not CDROM.get(cdrom):
action = fields.getfirst('action')
cdrom = fields.getfirst('cdrom')
if cdrom is not None and not CDROM.get(cdrom):
@@
-235,7
+231,7
@@
def commandResult(user, fields):
raise CodeError('ERROR on remctl')
elif action == 'Power on':
raise CodeError('ERROR on remctl')
elif action == 'Power on':
- if validation.maxMemory(user, machine) < machine.memory:
+ if validation.maxMemory(username, state, machine) < machine.memory:
raise InvalidInput('action', 'Power on',
"You don't have enough free RAM quota "
"to turn on this machine.")
raise InvalidInput('action', 'Power on',
"You don't have enough free RAM quota "
"to turn on this machine.")
@@
-263,7
+259,7
@@
def commandResult(user, fields):
elif action == 'Delete VM':
deleteVM(machine)
elif action == 'Delete VM':
deleteVM(machine)
- d = dict(user=user,
+ d = dict(user=username,
command=action,
machine=machine)
return d
command=action,
machine=machine)
return d