diff options
author | Bagus Indrayana <bagusindrayanaindo@gmail.com> | 2023-07-11 19:43:02 +0200 |
---|---|---|
committer | Bagus Indrayana <bagusindrayanaindo@gmail.com> | 2023-07-11 19:43:02 +0200 |
commit | 570593150673558ebf4c9e270d2e921b942fcbfb (patch) | |
tree | 434ef0cb121cf611991449d6ff7a87aa33d7494b /testing/aiservice | |
parent | Update README.md (diff) | |
download | gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar.gz gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar.bz2 gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar.lz gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar.xz gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.tar.zst gpt4free-570593150673558ebf4c9e270d2e921b942fcbfb.zip |
Diffstat (limited to 'testing/aiservice')
-rw-r--r-- | testing/aiservice/AiService.py | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/testing/aiservice/AiService.py b/testing/aiservice/AiService.py new file mode 100644 index 00000000..287a39ef --- /dev/null +++ b/testing/aiservice/AiService.py @@ -0,0 +1,62 @@ +import os,sys +import requests +# from ...typing import get_type_hints + +url = "https://aiservice.vercel.app/api/chat/answer" +model = ['gpt-3.5-turbo'] +supports_stream = False +needs_auth = False + + +def _create_completion(model: str, messages: list, stream: bool, **kwargs): + base = '' + for message in messages: + base += '%s: %s\n' % (message['role'], message['content']) + base += 'assistant:' + + headers = { + "accept": "*/*", + "content-type": "text/plain;charset=UTF-8", + "sec-fetch-dest": "empty", + "sec-fetch-mode": "cors", + "sec-fetch-site": "same-origin", + "Referer": "https://aiservice.vercel.app/chat", + } + data = { + "input": base + } + response = requests.post(url, headers=headers, json=data) + if response.status_code == 200: + _json = response.json() + yield _json['data'] + else: + print(f"Error Occurred::{response.status_code}") + return None + + + +# params = f'g4f.Providers.{os.path.basename(__file__)[:-3]} supports: ' + \ +# '(%s)' % ', '.join( +# [f"{name}: {get_type_hints(_create_completion)[name].__name__}" for name in _create_completion.__code__.co_varnames[:_create_completion.__code__.co_argcount]]) + + +# Temporary For ChatCompletion Class +class ChatCompletion: + @staticmethod + def create(model: str, messages: list, provider: None or str, stream: bool = False, auth: str = False, **kwargs): + kwargs['auth'] = auth + + if provider and needs_auth and not auth: + print( + f'ValueError: {provider} requires authentication (use auth="cookie or token or jwt ..." param)', file=sys.stderr) + sys.exit(1) + + try: + return (_create_completion(model, messages, stream, **kwargs) + if stream else ''.join(_create_completion(model, messages, stream, **kwargs))) + except TypeError as e: + print(e) + arg: str = str(e).split("'")[1] + print( + f"ValueError: {provider} does not support '{arg}' argument", file=sys.stderr) + sys.exit(1)
\ No newline at end of file |