feat(shared): allow cli parametrized decorators (#1527)
This commit is contained in:
parent
2de1ce6e0d
commit
1561353b20
|
@ -17,8 +17,8 @@ DEFAULT_RETRY_QUEUE_FILEPATH = Path("retry_queue")
|
|||
|
||||
|
||||
@click.command()
|
||||
@cli_logging_options
|
||||
@cli_config_options
|
||||
@cli_logging_options()
|
||||
@cli_config_options()
|
||||
@click.option(
|
||||
"--retry-queue-filepath",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_RETRY_QUEUE_FILEPATH",
|
||||
|
|
|
@ -16,7 +16,7 @@ PYPO_HOME = "/var/tmp/airtime/pypo/"
|
|||
|
||||
|
||||
@click.command()
|
||||
@cli_logging_options
|
||||
@cli_logging_options()
|
||||
def cli(log_level: int, log_filepath: Optional[Path]):
|
||||
"""
|
||||
Run liquidsoap.
|
||||
|
|
|
@ -110,7 +110,7 @@ def liquidsoap_startup_test(telnet_lock, ls_host, ls_port):
|
|||
|
||||
|
||||
@click.command()
|
||||
@cli_logging_options
|
||||
@cli_logging_options()
|
||||
def cli(log_level: str, log_filepath: Optional[Path]):
|
||||
"""
|
||||
Run playout.
|
||||
|
|
|
@ -27,7 +27,7 @@ def api_client():
|
|||
|
||||
|
||||
@click.group()
|
||||
@cli_logging_options
|
||||
@cli_logging_options()
|
||||
def cli(log_level: str, log_filepath: Optional[Path]):
|
||||
"""
|
||||
A gateway between Liquidsoap and the API.
|
||||
|
|
|
@ -69,8 +69,8 @@ def cli():
|
|||
pass
|
||||
|
||||
@cli.command()
|
||||
@cli_config_options
|
||||
@cli_logging_options
|
||||
@cli_config_options()
|
||||
@cli_logging_options()
|
||||
def run(**kwargs):
|
||||
app = App(**kwargs)
|
||||
return app.run()
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
from pathlib import Path
|
||||
from typing import Callable
|
||||
from typing import Any, Callable, Optional
|
||||
|
||||
import click
|
||||
|
||||
|
@ -7,51 +7,61 @@ from .config import DEFAULT_ENV_PREFIX
|
|||
from .logging import INFO, LOG_LEVEL_MAP
|
||||
|
||||
|
||||
def cli_logging_options(func: Callable) -> Callable:
|
||||
"""
|
||||
Decorator function to add logging options to a click application.
|
||||
def cli_logging_options() -> Callable:
|
||||
def decorator(func: Callable) -> Callable:
|
||||
"""
|
||||
Decorator function to add logging options to a click application.
|
||||
|
||||
This decorator add the following arguments:
|
||||
- log_level: str
|
||||
- log_filepath: Optional[Path]
|
||||
"""
|
||||
func = click.option(
|
||||
"--log-level",
|
||||
"log_level",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_LOG_LEVEL",
|
||||
type=click.Choice(list(LOG_LEVEL_MAP.keys())),
|
||||
default=INFO.name,
|
||||
help="Name of the logging level.",
|
||||
)(func)
|
||||
This decorator add the following arguments:
|
||||
- log_level: str
|
||||
- log_filepath: Optional[Path]
|
||||
"""
|
||||
func = click.option(
|
||||
"--log-level",
|
||||
"log_level",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_LOG_LEVEL",
|
||||
type=click.Choice(list(LOG_LEVEL_MAP.keys())),
|
||||
default=INFO.name,
|
||||
help="Name of the logging level.",
|
||||
)(func)
|
||||
|
||||
func = click.option(
|
||||
"--log-filepath",
|
||||
"log_filepath",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_LOG_FILEPATH",
|
||||
type=click.Path(path_type=Path),
|
||||
help="Path to the logging file.",
|
||||
default=None,
|
||||
)(func)
|
||||
func = click.option(
|
||||
"--log-filepath",
|
||||
"log_filepath",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_LOG_FILEPATH",
|
||||
type=click.Path(path_type=Path),
|
||||
help="Path to the logging file.",
|
||||
default=None,
|
||||
)(func)
|
||||
|
||||
return func
|
||||
return func
|
||||
|
||||
return decorator
|
||||
|
||||
|
||||
def cli_config_options(func: Callable) -> Callable:
|
||||
"""
|
||||
Decorator function to add config file options to a click application.
|
||||
def cli_config_options(
|
||||
required: bool = False,
|
||||
default: Optional[Any] = None,
|
||||
) -> Callable:
|
||||
def decorator(func: Callable) -> Callable:
|
||||
"""
|
||||
Decorator function to add config file options to a click application.
|
||||
|
||||
This decorator add the following arguments:
|
||||
- config_filepath: Optional[Path]
|
||||
"""
|
||||
This decorator add the following arguments:
|
||||
- config_filepath: Optional[Path] or Path
|
||||
"""
|
||||
|
||||
func = click.option(
|
||||
"--c",
|
||||
"--config",
|
||||
"config_filepath",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_CONFIG_FILEPATH",
|
||||
type=click.Path(path_type=Path),
|
||||
help="Path to the config file.",
|
||||
default=None,
|
||||
)(func)
|
||||
func = click.option(
|
||||
"--c",
|
||||
"--config",
|
||||
"config_filepath",
|
||||
envvar=f"{DEFAULT_ENV_PREFIX}_CONFIG_FILEPATH",
|
||||
type=click.Path(path_type=Path),
|
||||
help="Path to the config file.",
|
||||
required=required,
|
||||
default=default,
|
||||
)(func)
|
||||
|
||||
return func
|
||||
return func
|
||||
|
||||
return decorator
|
||||
|
|
Loading…
Reference in New Issue