Skip to content

Commit

Permalink
update env method
Browse files Browse the repository at this point in the history
  • Loading branch information
RexWzh committed Apr 4, 2024
1 parent de73f3c commit 7a53e57
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 30 deletions.
68 changes: 52 additions & 16 deletions askchat/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,33 @@
import asyncio
from pathlib import Path
import click
from dotenv import set_key
import os

# Main environment file
CONFIG_PATH = Path.home() / ".askchat"
CONFIG_FILE = CONFIG_PATH / ".env"
MAIN_ENV_PATH = Path.home() / '.askchat' / '.env'
ENV_PATH = Path.home() / '.askchat' / 'envs'

raw_env_text = f""""# Description: Env file for askchat.
# Current version: {__version__}
# The base url of the API (with suffix /v1)
# This will override OPENAI_API_BASE_URL if both are set.
OPENAI_API_BASE=""
# The base url of the API (without suffix /v1)
OPENAI_API_BASE_URL=""
# Your API key
OPENAI_API_KEY=""
# The default model name
# You can use `askchat --all-valid-models` to see supported models
OPENAI_API_MODEL=""
"""

# Autocompletion
# environment name completion
class EnvNameCompletionType(click.ParamType):
Expand Down Expand Up @@ -42,20 +62,36 @@ async def show_resp(chat, **options):
print() # add a newline if the message doesn't end with one
return msg

def write_config(config_file, api_key, model, base_url, api_base):
"""Write the environment variables to a config file."""
def write_var(f, var, value, desc):
value = value if value else ""
f.write(f"\n\n# {desc}\n")
f.write(f'{var}="{value}"')
def set_keys(config_file, keys):
"""Set multiple keys in the config file."""
for key, value in keys.items():
if value:
set_key(config_file, key, value)

def raw_config(config_file:str):
"""Empty config file."""
if not CONFIG_PATH.exists():
CONFIG_PATH.mkdir(parents=True)
with open(config_file, "w") as f:
f.write("#Description: Env file for askchat.\n" +\
"#Current version: " + __version__)
# write the environment table
write_var(f, "OPENAI_API_BASE", api_base, "The base url of the API (with suffix /v1)" +\
"\n# This will override OPENAI_API_BASE_URL if both are set.")
write_var(f, "OPENAI_API_BASE_URL", base_url, "The base url of the API (without suffix /v1)")

write_var(f, "OPENAI_API_KEY", api_key, "Your API key")
write_var(f, "OPENAI_API_MODEL", model, "The model name\n" +\
"# You can use `askchat --all-valid-models` to see supported models")
f.write(raw_env_text)

def init_config(config_file:str):
"""Initialize the config file with the current environment variables."""
raw_config(config_file)
set_keys(config_file, {
"OPENAI_API_KEY": os.getenv("OPENAI_API_KEY"),
"OPENAI_API_MODEL": os.getenv("OPENAI_API_MODEL"),
"OPENAI_API_BASE_URL": os.getenv("OPENAI_API_BASE_URL"),
"OPENAI_API_BASE": os.getenv("OPENAI_API_BASE"),
})

def write_config(config_file, api_key, model, base_url, api_base, overwrite=False):
"""Write the environment variables to a config file."""
if overwrite or not config_file.exists():
raw_config(config_file)
set_keys(config_file, {
"OPENAI_API_KEY": api_key,
"OPENAI_API_MODEL": model,
"OPENAI_API_BASE_URL": base_url,
"OPENAI_API_BASE": api_base,
})
14 changes: 4 additions & 10 deletions askchat/askenv.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ def new(name, api_key, base_url, api_base, model):
click.confirm("Do you want to continue?", abort=True)
else:
click.echo(f"Environment '{name}' created.")
write_config(config_path, api_key, model, base_url, api_base)
write_config(config_path, api_key, model, base_url, api_base, overwrite=True)

@cli.command()
@click.argument('name', required=False, type=EnvNameCompletionType())
Expand Down Expand Up @@ -120,16 +120,10 @@ def config(name, api_key, base_url, api_base, model):
return
config_path = ENV_PATH / f'{name}.env' if name else MAIN_ENV_PATH
if not config_path.exists():
click.echo(f"Environment '{config_path}' not found.")
click.echo(f"Environment '{config_path}' not found." +\
"Use `askenv new` to create a new environment." )
return
if api_key:
set_key(config_path, "OPENAI_API_KEY", api_key)
if base_url:
set_key(config_path, "OPENAI_API_BASE_URL", base_url)
if api_base:
set_key(config_path, "OPENAI_API_BASE", api_base)
if model:
set_key(config_path, "OPENAI_API_MODEL", model)
write_config(config_path, api_key, model, base_url, api_base)
click.echo(f"Environment {config_path} updated.")

if __name__ == '__main__':
Expand Down
7 changes: 3 additions & 4 deletions askchat/cli.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
from chattool import Chat, debug_log
from pathlib import Path
from askchat import (
show_resp, write_config
show_resp, write_config, init_config
, ENV_PATH, MAIN_ENV_PATH
, CONFIG_PATH, CONFIG_FILE
, EnvNameCompletionType, ChatFileCompletionType
Expand Down Expand Up @@ -37,12 +37,11 @@ def setup():
def generate_config_callback(ctx, param, value):
"""Generate a configuration file by environment table."""
if not value: return
api_key, model = os.getenv("OPENAI_API_KEY"), os.getenv("OPENAI_API_MODEL")
base_url, api_base = os.getenv("OPENAI_API_BASE_URL"), os.getenv("OPENAI_API_BASE")
os.makedirs(CONFIG_PATH, exist_ok=True)
# save the config file
if os.path.exists(CONFIG_FILE):
click.confirm(f"Overwrite the existing configuration file {CONFIG_FILE}?", abort=True)
write_config(CONFIG_FILE, api_key, model, base_url, api_base)
init_config(CONFIG_FILE)
print("Created config file at", CONFIG_FILE)
ctx.exit()

Expand Down

0 comments on commit 7a53e57

Please sign in to comment.