start,shutdown,suspend,resume,delete merged into one (action)
This commit is contained in:
parent
ec69c1552f
commit
56f3647ec3
11 changed files with 15 additions and 32 deletions
44
commands/vm.py
Normal file → Executable file
44
commands/vm.py
Normal file → Executable file
|
|
@ -6,9 +6,9 @@ from decouple import config
|
|||
from .helper import OTPCredentials
|
||||
|
||||
|
||||
def vm_action(action, otp, vmid):
|
||||
data = {**otp.get_json(), "vmid": vmid}
|
||||
r = requests.post(f"{config('UCLOUD_API_SERVER')}/vm/{action}", json=data)
|
||||
def vm_command(command, otp, uuid):
|
||||
data = {**otp.get_json(), "uuid": uuid, "action": command}
|
||||
r = requests.post(f"{config('UCLOUD_API_SERVER')}/vm/action", json=data)
|
||||
return r
|
||||
|
||||
|
||||
|
|
@ -35,41 +35,23 @@ def create(name, realm, seed, specs, image_uuid):
|
|||
print(json.loads(r.content))
|
||||
|
||||
|
||||
@vm.command("start")
|
||||
@vm.command("action")
|
||||
@click.option("--name", required=True)
|
||||
@click.option("--realm", required=True)
|
||||
@click.option("--seed", required=True)
|
||||
@click.option("--vmid", required=True)
|
||||
def start(name, realm, seed, vmid):
|
||||
r = vm_action("start", OTPCredentials(name, realm, seed), vmid)
|
||||
@click.option("--uuid", required=True)
|
||||
@click.option("--command", required=True)
|
||||
def vm_action(name, realm, seed, uuid, command):
|
||||
r = vm_command(command, OTPCredentials(name, realm, seed), uuid)
|
||||
print(json.loads(r.content))
|
||||
|
||||
|
||||
@vm.command("suspend")
|
||||
@vm.command("status")
|
||||
@click.option("--name", required=True)
|
||||
@click.option("--realm", required=True)
|
||||
@click.option("--seed", required=True)
|
||||
@click.option("--vmid", required=True)
|
||||
def suspend(name, realm, seed, vmid):
|
||||
r = vm_action("suspend", OTPCredentials(name, realm, seed), vmid)
|
||||
print(json.loads(r.content))
|
||||
|
||||
|
||||
@vm.command("resume")
|
||||
@click.option("--name", required=True)
|
||||
@click.option("--realm", required=True)
|
||||
@click.option("--seed", required=True)
|
||||
@click.option("--vmid", required=True)
|
||||
def resume(name, realm, seed, vmid):
|
||||
r = vm_action("resume", OTPCredentials(name, realm, seed), vmid)
|
||||
print(json.loads(r.content))
|
||||
|
||||
|
||||
@vm.command("shutdown")
|
||||
@click.option("--name", required=True)
|
||||
@click.option("--realm", required=True)
|
||||
@click.option("--seed", required=True)
|
||||
@click.option("--vmid", required=True)
|
||||
def shutdown(name, realm, seed, vmid):
|
||||
r = vm_action("shutdown", OTPCredentials(name, realm, seed), vmid)
|
||||
@click.option("--uuid", required=True)
|
||||
def status(name, realm, seed, uuid):
|
||||
data = {"name": name, "realm": realm, "seed": seed, "uuid": uuid}
|
||||
r = requests.get(f"{config('UCLOUD_API_SERVER')}/vm/status", json=data)
|
||||
print(json.loads(r.content))
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue