summaryrefslogtreecommitdiffstats
path: root/testing/binghuan/BingHuan.py
diff options
context:
space:
mode:
authorxtekky <98614666+xtekky@users.noreply.github.com>2023-07-11 20:27:55 +0200
committerGitHub <noreply@github.com>2023-07-11 20:27:55 +0200
commitc3b0919f7c22a214f4e5e15f884dcac6d70bb1b0 (patch)
treef52cd8d2ebcd0bde349fb8759c08696ef3614015 /testing/binghuan/BingHuan.py
parentMerge pull request #739 from bagusindrayana/wewordle (diff)
parentupdate encoding (diff)
downloadgpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar.gz
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar.bz2
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar.lz
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar.xz
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.tar.zst
gpt4free-c3b0919f7c22a214f4e5e15f884dcac6d70bb1b0.zip
Diffstat (limited to 'testing/binghuan/BingHuan.py')
-rw-r--r--testing/binghuan/BingHuan.py49
1 files changed, 49 insertions, 0 deletions
diff --git a/testing/binghuan/BingHuan.py b/testing/binghuan/BingHuan.py
new file mode 100644
index 00000000..8c859c08
--- /dev/null
+++ b/testing/binghuan/BingHuan.py
@@ -0,0 +1,49 @@
+import os,sys
+import json
+import subprocess
+# from ...typing import sha256, Dict, get_type_hints
+
+url = 'https://b.ai-huan.xyz'
+model = ['gpt-3.5-turbo', 'gpt-4']
+supports_stream = True
+needs_auth = False
+
+def _create_completion(model: str, messages: list, stream: bool, **kwargs):
+ path = os.path.dirname(os.path.realpath(__file__))
+ config = json.dumps({
+ 'messages': messages,
+ 'model': model}, separators=(',', ':'))
+ cmd = ['python', f'{path}/helpers/binghuan.py', config]
+
+ p = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
+
+ for line in iter(p.stdout.readline, b''):
+ yield line.decode('cp1252')
+
+
+
+# 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