feat: Expose web panel config management in CLI

This commit is contained in:
ReturnFI
2025-11-10 13:24:32 +00:00
parent 56f6a36a8b
commit 4e435a623f
2 changed files with 73 additions and 0 deletions

View File

@ -719,6 +719,49 @@ def get_web_panel_services_status():
except Exception as e:
click.echo(f'{e}', err=True)
@cli.command('change-webpanel-exp')
@click.option('--minutes', '-m', required=True, help='New session expiration time in minutes', type=int)
def change_webpanel_exp(minutes: int):
"""Changes the session expiration time for the WebPanel."""
try:
cli_api.change_webpanel_expiration(minutes)
click.echo(f'WebPanel session expiration successfully updated to {minutes} minutes.')
click.echo('WebPanel service has been restarted.')
except Exception as e:
click.echo(f'{e}', err=True)
@cli.command('change-webpanel-root')
@click.option('--path', '-p', required=False, help='New root path. If not provided, a random one will be generated.', type=str)
def change_webpanel_root(path: str | None):
"""Changes the root path for the WebPanel."""
try:
cli_api.change_webpanel_root_path(path)
click.echo(f'WebPanel root path updated successfully.')
new_url = cli_api.get_webpanel_url()
click.echo(f'New URL is accessible on: {new_url}')
click.echo('WebPanel and Caddy services have been restarted.')
except Exception as e:
click.echo(f'{e}', err=True)
@cli.command('change-webpanel-domain-port')
@click.option('--domain', '-d', required=False, help='New domain for WebPanel', type=str)
@click.option('--port', '-p', required=False, help='New port for WebPanel', type=int)
def change_webpanel_domain_port(domain: str | None, port: int | None):
"""Changes the domain and/or port for the WebPanel."""
try:
if not domain and not port:
raise click.UsageError('Error: You must provide either --domain or --port, or both.')
cli_api.change_webpanel_domain_port(domain, port)
click.echo(f'WebPanel domain/port configuration updated successfully.')
new_url = cli_api.get_webpanel_url()
click.echo(f'New URL is accessible on: {new_url}')
click.echo('Caddy service has been restarted.')
except Exception as e:
click.echo(f'{e}', err=True)
@cli.command('get-services-status')
def get_services_status():

View File

@ -746,6 +746,36 @@ def reset_webpanel_credentials(new_username: str | None = None, new_password: st
run_cmd(cmd_args)
def change_webpanel_expiration(expiration_minutes: int):
'''Changes the session expiration time for the WebPanel.'''
if not expiration_minutes:
raise InvalidInputError('Error: Expiration minutes must be provided.')
run_cmd(
['bash', Command.SHELL_WEBPANEL.value, 'changeexp', str(expiration_minutes)]
)
def change_webpanel_root_path(root_path: str | None = None):
'''Changes the root path for the WebPanel. A new random path is generated if not provided.'''
cmd_args = ['bash', Command.SHELL_WEBPANEL.value, 'changeroot']
if root_path:
cmd_args.append(root_path)
run_cmd(cmd_args)
def change_webpanel_domain_port(domain: str | None = None, port: int | None = None):
'''Changes the domain and/or port for the WebPanel.'''
if not domain and not port:
raise InvalidInputError('Error: At least a new domain or new port must be provided.')
cmd_args = ['bash', Command.SHELL_WEBPANEL.value, 'changedomain']
if domain:
cmd_args.extend(['-d', domain])
if port:
cmd_args.extend(['-p', str(port)])
run_cmd(cmd_args)
def get_services_status() -> dict[str, bool] | None:
'''Gets the status of all project services.'''
if res := run_cmd(['bash', Command.SERVICES_STATUS.value]):