mirror of
https://github.com/hyperknot/openfreemap.git
synced 2026-05-21 14:02:15 +00:00
split to commands
This commit is contained in:
@@ -139,27 +139,7 @@ def debug_tmp(c):
|
|||||||
# put(c, SCRIPTS_DIR / 'http_host' / 'cron.d' / 'ofm_http_host', '/etc/cron.d/')
|
# put(c, SCRIPTS_DIR / 'http_host' / 'cron.d' / 'ofm_http_host', '/etc/cron.d/')
|
||||||
|
|
||||||
|
|
||||||
@click.command()
|
def get_connection(hostname, user, port):
|
||||||
@click.argument('hostname')
|
|
||||||
@click.option('--port', type=int, help='SSH port (if not in .ssh/config)')
|
|
||||||
@click.option('--user', help='SSH user (if not in .ssh/config)')
|
|
||||||
@click.option('--tile-gen', is_flag=True, help='Install tile-gen task')
|
|
||||||
@click.option('--http-host', is_flag=True, help='Install http-host task')
|
|
||||||
@click.option('--debug', is_flag=True)
|
|
||||||
@click.option(
|
|
||||||
'--skip-shared', is_flag=True, help='Skip the shared installtion step (useful for development)'
|
|
||||||
)
|
|
||||||
@click.option('--skip-cron', is_flag=True, help='Skip the cronjob (useful for development)')
|
|
||||||
def main(hostname, user, port, tile_gen, http_host, skip_shared, skip_cron, debug):
|
|
||||||
if not debug and not click.confirm(f'Run script on {hostname}?'):
|
|
||||||
return
|
|
||||||
|
|
||||||
if not tile_gen and not http_host and not debug:
|
|
||||||
tile_gen = click.confirm('Would you like to install tile-gen task?')
|
|
||||||
http_host = click.confirm('Would you like to install http-host task?')
|
|
||||||
if not tile_gen and not http_host:
|
|
||||||
return
|
|
||||||
|
|
||||||
ssh_passwd = dotenv_values(f'{CONFIG_DIR}/.env').get('SSH_PASSWD')
|
ssh_passwd = dotenv_values(f'{CONFIG_DIR}/.env').get('SSH_PASSWD')
|
||||||
|
|
||||||
if ssh_passwd:
|
if ssh_passwd:
|
||||||
@@ -177,19 +157,58 @@ def main(hostname, user, port, tile_gen, http_host, skip_shared, skip_cron, debu
|
|||||||
port=port,
|
port=port,
|
||||||
)
|
)
|
||||||
|
|
||||||
if debug:
|
return c
|
||||||
debug_tmp(c)
|
|
||||||
sys.exit()
|
|
||||||
|
|
||||||
if not skip_shared:
|
|
||||||
prepare_shared(c)
|
|
||||||
|
|
||||||
if tile_gen:
|
def common_options(func):
|
||||||
prepare_tile_gen(c)
|
"""Decorator to define common options."""
|
||||||
|
func = click.argument('hostname')(func)
|
||||||
|
func = click.option('--port', type=int, help='SSH port (if not in .ssh/config)')(func)
|
||||||
|
func = click.option('--user', help='SSH user (if not in .ssh/config)')(func)
|
||||||
|
return func
|
||||||
|
|
||||||
if http_host:
|
|
||||||
prepare_http_host(c, skip_cron=skip_cron)
|
@click.group()
|
||||||
|
def cli():
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command()
|
||||||
|
@common_options
|
||||||
|
def http_host_once(hostname, user, port):
|
||||||
|
if not click.confirm(f'Run script on {hostname}?'):
|
||||||
|
return
|
||||||
|
|
||||||
|
c = get_connection(hostname, user, port)
|
||||||
|
prepare_http_host(c, True)
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command()
|
||||||
|
@common_options
|
||||||
|
def http_host_autoupdate(hostname, user, port):
|
||||||
|
if not click.confirm(f'Run script on {hostname}?'):
|
||||||
|
return
|
||||||
|
|
||||||
|
c = get_connection(hostname, user, port)
|
||||||
|
prepare_http_host(c, False)
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command()
|
||||||
|
@common_options
|
||||||
|
def tile_gen(hostname, user, port):
|
||||||
|
if not click.confirm(f'Run script on {hostname}?'):
|
||||||
|
return
|
||||||
|
|
||||||
|
c = get_connection(hostname, user, port)
|
||||||
|
prepare_tile_gen(c)
|
||||||
|
|
||||||
|
|
||||||
|
@cli.command()
|
||||||
|
@common_options
|
||||||
|
def debug(hostname, user, port):
|
||||||
|
c = get_connection(hostname, user, port)
|
||||||
|
print(c)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
cli()
|
||||||
|
|||||||
Reference in New Issue
Block a user