diff options
author | t.me/xtekky <98614666+xtekky@users.noreply.github.com> | 2023-06-24 03:47:00 +0200 |
---|---|---|
committer | t.me/xtekky <98614666+xtekky@users.noreply.github.com> | 2023-06-24 03:47:00 +0200 |
commit | 5db58fd87f230fbe5bae599bb4b120ab42cad3be (patch) | |
tree | 770be13bca77c5d04dfe3265f378431df788706f /g4f/__init__.py | |
parent | Merge pull request #664 from LopeKinz/main (diff) | |
download | gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar.gz gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar.bz2 gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar.lz gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar.xz gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.tar.zst gpt4free-5db58fd87f230fbe5bae599bb4b120ab42cad3be.zip |
Diffstat (limited to '')
-rw-r--r-- | g4f/__init__.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/g4f/__init__.py b/g4f/__init__.py new file mode 100644 index 00000000..a0b4bac6 --- /dev/null +++ b/g4f/__init__.py @@ -0,0 +1,39 @@ +import sys +from . import Provider +from g4f.models import Model, ModelUtils + + +class ChatCompletion: + @staticmethod + def create(model: Model.model or str, messages: list, provider: Provider.Provider = None, stream: bool = False, auth: str = False, **kwargs): + kwargs['auth'] = auth + + if provider and provider.needs_auth and not auth: + print( + f'ValueError: {provider.__name__} requires authentication (use auth="cookie or token or jwt ..." param)', file=sys.stderr) + sys.exit(1) + + try: + if isinstance(model, str): + try: + model = ModelUtils.convert[model] + except KeyError: + raise Exception(f'The model: {model} does not exist') + + engine = model.best_provider if not provider else provider + + if not engine.supports_stream and stream == True: + print( + f"ValueError: {engine.__name__} does not support 'stream' argument", file=sys.stderr) + sys.exit(1) + + print(f'Using {engine.__name__} provider') + + return (engine._create_completion(model.name, messages, stream, **kwargs) + if stream else ''.join(engine._create_completion(model.name, messages, stream, **kwargs))) + except TypeError as e: + print(e) + arg: str = str(e).split("'")[1] + print( + f"ValueError: {engine.__name__} does not support '{arg}' argument", file=sys.stderr) + sys.exit(1) |