2020-08-06 12:34:25 +00:00
|
|
|
import logging
|
|
|
|
import os
|
|
|
|
|
2020-08-08 17:41:11 +00:00
|
|
|
from ..core import KIWI_CONF_NAME, Parser
|
2020-08-10 09:24:39 +00:00
|
|
|
from ..config import DefaultConfig, LoadedConfig
|
2020-08-06 12:34:25 +00:00
|
|
|
|
2020-08-08 17:41:11 +00:00
|
|
|
from ._utils import SubCommand
|
2020-08-06 12:34:25 +00:00
|
|
|
|
|
|
|
|
|
|
|
def user_input(config, key, prompt):
|
|
|
|
# prompt user as per argument
|
2020-08-10 09:24:39 +00:00
|
|
|
result = input("{} [{}] ".format(prompt, config[key])).strip()
|
2020-08-06 12:34:25 +00:00
|
|
|
|
|
|
|
# store result if present
|
|
|
|
if result:
|
|
|
|
config[key] = result
|
|
|
|
|
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
def is_executable(filename):
|
|
|
|
if filename is None:
|
|
|
|
return False
|
|
|
|
|
|
|
|
return os.path.isfile(filename) and os.access(filename, os.X_OK)
|
|
|
|
|
|
|
|
|
2020-08-08 17:41:11 +00:00
|
|
|
def find_exe(program_name):
|
|
|
|
for path in os.environ["PATH"].split(os.pathsep):
|
|
|
|
exe_file = os.path.join(path, program_name)
|
2020-08-10 12:05:19 +00:00
|
|
|
if is_executable(exe_file):
|
2020-08-08 17:41:11 +00:00
|
|
|
return exe_file
|
|
|
|
|
|
|
|
return None
|
|
|
|
|
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
def user_input_exe(config, key):
|
|
|
|
exe_file = config[key]
|
|
|
|
program_name = key.split(':')[1]
|
2020-08-08 17:41:11 +00:00
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
if not is_executable(exe_file):
|
|
|
|
logging.warning("Reconfiguring '%s' executable path.", program_name)
|
|
|
|
exe_file = find_exe(program_name)
|
|
|
|
|
|
|
|
if exe_file is not None:
|
|
|
|
logging.info("Found executable at '%s'.", exe_file)
|
|
|
|
config[key] = exe_file
|
|
|
|
else:
|
|
|
|
user_input(config, key, f"Enter path to '{program_name}' executable")
|
2020-08-08 17:41:11 +00:00
|
|
|
|
|
|
|
|
2020-08-06 12:34:25 +00:00
|
|
|
class InitCommand(SubCommand):
|
2020-08-10 09:24:39 +00:00
|
|
|
command = 'init'
|
2020-08-06 12:34:25 +00:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def setup(cls):
|
2020-08-10 09:24:39 +00:00
|
|
|
parser = Parser.get_subparsers().add_parser(
|
|
|
|
cls.command,
|
|
|
|
description="Create a new kiwi-config instance"
|
|
|
|
)
|
|
|
|
|
|
|
|
parser.add_argument(
|
|
|
|
'-f', '--force',
|
|
|
|
action='store_true',
|
2020-08-10 12:05:19 +00:00
|
|
|
help=f"Use default values even if {KIWI_CONF_NAME} is present"
|
2020-08-10 09:24:39 +00:00
|
|
|
)
|
2020-08-06 12:34:25 +00:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def run(cls):
|
2020-08-10 12:05:19 +00:00
|
|
|
logging.info(f"Initializing kiwi-config instance in '{os.getcwd()}'")
|
2020-08-06 12:34:25 +00:00
|
|
|
|
2020-08-10 09:24:39 +00:00
|
|
|
if Parser.get_args().force and os.path.isfile(KIWI_CONF_NAME):
|
2020-08-06 12:34:25 +00:00
|
|
|
logging.warning("Overwriting existing '%s'!", KIWI_CONF_NAME)
|
2020-08-10 09:24:39 +00:00
|
|
|
config = DefaultConfig.get()
|
|
|
|
else:
|
|
|
|
config = LoadedConfig.get()
|
2020-08-06 12:34:25 +00:00
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
# version
|
2020-08-10 09:24:39 +00:00
|
|
|
user_input(config, 'version', "Enter kiwi-config version for this instance")
|
2020-08-06 12:34:25 +00:00
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
# runtime
|
2020-08-10 09:24:39 +00:00
|
|
|
user_input(config, 'runtime:storage', "Enter local directory for service data")
|
2020-08-08 17:41:11 +00:00
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
# markers
|
2020-08-06 12:34:25 +00:00
|
|
|
user_input(config, 'markers:project', "Enter marker string for project directories")
|
|
|
|
user_input(config, 'markers:down', "Enter marker string for disabled projects")
|
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
# network
|
2020-08-06 12:34:25 +00:00
|
|
|
user_input(config, 'network:name', "Enter name for local docker network")
|
|
|
|
user_input(config, 'network:cidr', "Enter CIDR block for local docker network")
|
|
|
|
|
2020-08-10 12:05:19 +00:00
|
|
|
# executables
|
|
|
|
user_input_exe(config, 'executables:docker')
|
|
|
|
user_input_exe(config, 'executables:docker-compose')
|
|
|
|
user_input_exe(config, 'executables:sudo')
|
2020-08-06 12:34:25 +00:00
|
|
|
|
|
|
|
config.save()
|