mirror of
https://github.com/OVERLORD7F/SVMU.git
synced 2025-10-01 21:52:47 +03:00
fixed #30
This commit is contained in:
@@ -53,7 +53,7 @@ def config_menu(base_url, api_key, config_relative_path):
|
|||||||
needs_reload = True
|
needs_reload = True
|
||||||
|
|
||||||
if sub_choice == "7":
|
if sub_choice == "7":
|
||||||
change_vm_uuids(config_relative_path)
|
change_vm_uuids(config_relative_path, base_url, api_key)
|
||||||
needs_reload = True
|
needs_reload = True
|
||||||
|
|
||||||
if sub_choice == "8":
|
if sub_choice == "8":
|
||||||
@@ -183,7 +183,7 @@ def change_iso_uuid(config_relative_path):
|
|||||||
print("No 'VM_Options' section in config file..")
|
print("No 'VM_Options' section in config file..")
|
||||||
config_show(config_relative_path)
|
config_show(config_relative_path)
|
||||||
|
|
||||||
def change_vm_uuids(config_relative_path): #change selected VM uuids in config
|
def change_vm_uuids(config_relative_path, base_url, api_key): #change selected VM uuids in config
|
||||||
config = configparser.ConfigParser()
|
config = configparser.ConfigParser()
|
||||||
config.read(config_relative_path)
|
config.read(config_relative_path)
|
||||||
# Remove old VM_List section if it exists, then add a fresh one
|
# Remove old VM_List section if it exists, then add a fresh one
|
||||||
@@ -197,6 +197,11 @@ def change_vm_uuids(config_relative_path): #change selected VM uuids in config
|
|||||||
vm_input = console.input("[bold yellow]>> [/]" )
|
vm_input = console.input("[bold yellow]>> [/]" )
|
||||||
if not vm_input:
|
if not vm_input:
|
||||||
break
|
break
|
||||||
|
# validate only the entered VM UUID via get_vm_name
|
||||||
|
vm_name = get_vm_name(base_url, "jwt " + api_key, vm_input)
|
||||||
|
if not vm_name:
|
||||||
|
console.print("[red bold]Invalid VM UUID (not found)")
|
||||||
|
continue
|
||||||
x += 1
|
x += 1
|
||||||
config.set('VM_List', f'uuid_{x}', vm_input)
|
config.set('VM_List', f'uuid_{x}', vm_input)
|
||||||
|
|
||||||
@@ -208,56 +213,6 @@ def change_vm_uuids(config_relative_path): #change selected VM uuids in config
|
|||||||
config_show(config_relative_path)
|
config_show(config_relative_path)
|
||||||
|
|
||||||
|
|
||||||
def config_edit(config_relative_path):
|
|
||||||
read_input = Prompt.ask("[bold yellow]Create new config file?[/]", choices=["Y", "N"], default="N", case_sensitive=False)
|
|
||||||
menu_choice = str(read_input)
|
|
||||||
if menu_choice == "Y" or menu_choice == "y":
|
|
||||||
base_url = input("Type SpaceVM Controller IP: ")
|
|
||||||
while check_ping(base_url) != True:
|
|
||||||
base_url = console.input("[bold red]No response.\nCheck and type SpaceVM Controller IP again: [/]")
|
|
||||||
|
|
||||||
api_key = input("Type your API Key: ")
|
|
||||||
while check_api_key(base_url, "jwt " + api_key) != 200:
|
|
||||||
api_key = console.input("[bold red]Check and type SpaceVM Controller API Key again: [/]")
|
|
||||||
show_data_pools(base_url, "jwt " + api_key)
|
|
||||||
data_pool_uuid = input("Type Data Pool UUID you wish to use: ")
|
|
||||||
|
|
||||||
config = configparser.ConfigParser()
|
|
||||||
config["General"] = {
|
|
||||||
"controller_ip": base_url,
|
|
||||||
"api_key": api_key,
|
|
||||||
"skip_startup_splash": "no",
|
|
||||||
}
|
|
||||||
config["Data_Pool"] = {"data_pool_uuid": data_pool_uuid}
|
|
||||||
|
|
||||||
#disk_interface=input("Specify preffered disk interface (virtio / ide / scsi / sata): ")
|
|
||||||
#preallocation=input("Specify allocation type for virtual disks (none / falloc / full / metadata): ")
|
|
||||||
#iso_uuid=input("Specify ISO uuid you wish to auto-mount during operations(none - skip this step): ")
|
|
||||||
#config["VM_Options"] = {
|
|
||||||
# "disk_interface": disk_interface,
|
|
||||||
# "preallocation": preallocation,
|
|
||||||
# "iso_uuid": iso_uuid
|
|
||||||
#}
|
|
||||||
|
|
||||||
with open(config_relative_path, "w") as configfile: #writing everything from above to config file
|
|
||||||
config.write(configfile)
|
|
||||||
|
|
||||||
print("Type VM UUIDs one by one (input ENTER to stop)")
|
|
||||||
with open(config_relative_path, "a") as file:
|
|
||||||
file.write("[VM_List]\n") #manually writing section for VMs
|
|
||||||
vm_input = []
|
|
||||||
x = 0
|
|
||||||
while vm_input != "":
|
|
||||||
vm_input = input(">> ")
|
|
||||||
if vm_input:
|
|
||||||
x += 1
|
|
||||||
file.write(f"uuid_{x} = {vm_input}\n")
|
|
||||||
|
|
||||||
console.print("[green bold]VM UUIDs have been written in config :pencil:")
|
|
||||||
console.print("[green bold]Configuration completed ! :white_check_mark:")
|
|
||||||
Prompt.ask("[green_yellow bold]Press ENTER to proceed.. :right_arrow_curving_down:")
|
|
||||||
cls()
|
|
||||||
|
|
||||||
def check_config(config_relative_path):
|
def check_config(config_relative_path):
|
||||||
"""Check if config exists and is valid"""
|
"""Check if config exists and is valid"""
|
||||||
# Only check if the file is empty and needs to be removed
|
# Only check if the file is empty and needs to be removed
|
||||||
@@ -338,6 +293,11 @@ def create_new_profile():
|
|||||||
vm_input = console.input("[bold yellow]>> [/]")
|
vm_input = console.input("[bold yellow]>> [/]")
|
||||||
if not vm_input:
|
if not vm_input:
|
||||||
break
|
break
|
||||||
|
# validate only the vm_input by fetching VM name
|
||||||
|
vm_name = get_vm_name(base_url, "jwt " + api_key, vm_input)
|
||||||
|
if not vm_name:
|
||||||
|
console.print("[red bold]Invalid VM UUID (not found)")
|
||||||
|
continue
|
||||||
x += 1
|
x += 1
|
||||||
file.write(f"uuid_{x} = {vm_input}\n")
|
file.write(f"uuid_{x} = {vm_input}\n")
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user