From 5db58fd87f230fbe5bae599bb4b120ab42cad3be Mon Sep 17 00:00:00 2001 From: "t.me/xtekky" <98614666+xtekky@users.noreply.github.com> Date: Sat, 24 Jun 2023 03:47:00 +0200 Subject: gpt4free v2, first release --- g4f/__init__.py | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 g4f/__init__.py (limited to 'g4f/__init__.py') 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) -- cgit v1.2.3