From 96baaddbe4bf9c5a79bc395f773d0594deac546d Mon Sep 17 00:00:00 2001 From: ilai Date: Thu, 26 Oct 2023 17:05:53 +0300 Subject: [PATCH] [cli] added --index-name option to `canopy start` Resolves #105 --- src/canopy_cli/cli.py | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/src/canopy_cli/cli.py b/src/canopy_cli/cli.py index 7fcf8757..7f08bd21 100644 --- a/src/canopy_cli/cli.py +++ b/src/canopy_cli/cli.py @@ -474,7 +474,10 @@ def chat(chat_service_url, baseline, debug, stream): @click.option("--config", "-c", default=None, help="Path to a canopy config file. Optional, otherwise configuration " "defaults will be used.") -def start(host: str, port: str, reload: bool, config: Optional[str]): +@click.option("--index-name", default=None, + help="Index name, if not provided already in as an environment variable") +def start(host: str, port: str, reload: bool, + config: Optional[str], index_name: Optional[str]): note_msg = ( "🚨 Note 🚨\n" "For debugging only. To run the Canopy service in production, run the command:" @@ -487,6 +490,16 @@ def start(host: str, port: str, reload: bool, config: Optional[str]): time.sleep(0.01) click.echo() + if index_name: + env_index_name = os.getenv("INDEX_NAME") + if env_index_name and index_name != env_index_name: + raise CLIError( + f"Index name provided via --index-name '{index_name}' does not match " + f"the index name provided via the INDEX_NAME environment variable " + f"'{env_index_name}'" + ) + os.environ["INDEX_NAME"] = index_name + click.echo(f"Starting Canopy service on {host}:{port}") start_service(host, port=port, reload=reload, config_file=config)