summaryrefslogtreecommitdiffstats
path: root/g4f/Provider
diff options
context:
space:
mode:
authorTekky <98614666+xtekky@users.noreply.github.com>2023-10-05 20:02:06 +0200
committerGitHub <noreply@github.com>2023-10-05 20:02:06 +0200
commit6dc250274096334778b5158f44e26cbc6a4266b6 (patch)
tree76240685a9dcc320535cf0ffb3a5b931b2a14b72 /g4f/Provider
parentAdd AiAsk, Chatgpt4Online, ChatgptDemo (diff)
parent~ | Merge pull request #984 from HexyeDEV/patch-2 (diff)
downloadgpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar.gz
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar.bz2
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar.lz
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar.xz
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.tar.zst
gpt4free-6dc250274096334778b5158f44e26cbc6a4266b6.zip
Diffstat (limited to '')
-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..bd29544d
--- /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:
+ message = messages[-1]["content"]
+ 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('abc'.encode() + message.encode()).hexdigest()
+ }