summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHexye <65314629+HexyeDEV@users.noreply.github.com>2023-10-04 22:45:34 +0200
committerGitHub <noreply@github.com>2023-10-04 22:45:34 +0200
commiteb13f3b01de69e03bc388d28365a211a9561ef79 (patch)
tree7d9d68b1f4284db4cf10b83c201815d7eaeab7f0
parent~ | g4f v-0.1.4.8 - Fixed `g4f.Provider.Bing` (diff)
downloadgpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar.gz
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar.bz2
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar.lz
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar.xz
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.tar.zst
gpt4free-eb13f3b01de69e03bc388d28365a211a9561ef79.zip
-rw-r--r--g4f/Provider/Cromicle.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/g4f/Provider/Cromicle.py b/g4f/Provider/Cromicle.py
new file mode 100644
index 00000000..9c2ae4bc
--- /dev/null
+++ b/g4f/Provider/Cromicle.py
@@ -0,0 +1,50 @@
+from __future__ import annotations
+
+from aiohttp import ClientSession
+from hashlib import sha256
+
+from ..typing import AsyncGenerator
+from .base_provider import AsyncGeneratorProvider
+
+
+class Cromicle(AsyncGeneratorProvider):
+ url = 'https://cromicle.top'
+ working = True
+ supports_gpt_35_turbo = True
+
+ @classmethod
+ async def create_async_generator(
+ cls,
+ model: str,
+ messages: list[dict[str, str]],
+ proxy: str = None,
+ **kwargs
+ ) -> AsyncGenerator:
+
+ async with ClientSession(
+ headers=_create_header()
+ ) as session:
+ async with session.post(
+ cls.url + '/chat',
+ proxy=proxy,
+ json=_create_payload(message, **kwargs)
+ ) as response:
+ response.raise_for_status()
+ async for stream in response.content.iter_any():
+ if stream:
+ yield stream.decode()
+
+
+def _create_header():
+ return {
+ 'accept': '*/*',
+ 'content-type': 'application/json',
+ }
+
+
+def _create_payload(message: str):
+ return {
+ 'message' : message,
+ 'token' : 'abc',
+ 'hash' : sha256(token.encode() + message.encode()).hexdigest()
+ }