summaryrefslogtreecommitdiffstats
path: root/g4f/Provider
diff options
context:
space:
mode:
authorTekky <98614666+xtekky@users.noreply.github.com>2023-10-05 20:00:15 +0200
committerGitHub <noreply@github.com>2023-10-05 20:00:15 +0200
commit94264be980be6322c58a810ad4e346df5c0d12be (patch)
tree5b9b5dcb805534aaaf2a41a3f97dd91c3f10ed29 /g4f/Provider
parent~ | g4f v-0.1.4.8 - Fixed `g4f.Provider.Bing` (diff)
parentMerge pull request #1 from HexyeDEV/patch-3 (diff)
downloadgpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar.gz
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar.bz2
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar.lz
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar.xz
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.tar.zst
gpt4free-94264be980be6322c58a810ad4e346df5c0d12be.zip
Diffstat (limited to 'g4f/Provider')
-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()
+ }