diff options
author | Tekky <98614666+xtekky@users.noreply.github.com> | 2023-08-17 14:50:35 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-17 14:50:35 +0200 |
commit | e8066c1df55c429a72e0770ee0e30a0ffc03f019 (patch) | |
tree | c8bc44917ea03909cf586140f984ff0814bc30ea /g4f/Provider/You.py | |
parent | ~ | small fixes & new pypi version | v-0.0.1.9 (diff) | |
parent | refactor: refactor provider (diff) | |
download | gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar.gz gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar.bz2 gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar.lz gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar.xz gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.tar.zst gpt4free-e8066c1df55c429a72e0770ee0e30a0ffc03f019.zip |
Diffstat (limited to '')
-rw-r--r-- | g4f/Provider/You.py | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/g4f/Provider/You.py b/g4f/Provider/You.py new file mode 100644 index 00000000..0d8114a8 --- /dev/null +++ b/g4f/Provider/You.py @@ -0,0 +1,59 @@ +import re +import urllib.parse + +from curl_cffi import requests + +from ..typing import Any, CreateResult +from .base_provider import BaseProvider + + +class You(BaseProvider): + url = "https://you.com" + working = True + supports_gpt_35_turbo = True + + @staticmethod + def create_completion( + model: str, + messages: list[dict[str, str]], + stream: bool, + **kwargs: Any, + ) -> CreateResult: + url_param = _create_url_param(messages) + headers = _create_header() + url = f"https://you.com/api/streamingSearch?{url_param}" + response = requests.get( + url, + headers=headers, + impersonate="chrome107", + ) + response.raise_for_status() + yield _parse_output(response.text) + + +def _create_url_param(messages: list[dict[str, str]]): + prompt = messages.pop()["content"] + chat = _convert_chat(messages) + param = {"q": prompt, "domain": "youchat", "chat": chat} + return urllib.parse.urlencode(param) + + +def _convert_chat(messages: list[dict[str, str]]): + message_iter = iter(messages) + return [ + {"question": user["content"], "answer": assistant["content"]} + for user, assistant in zip(message_iter, message_iter) + ] + + +def _create_header(): + return { + "accept": "text/event-stream", + "referer": "https://you.com/search?fromSearchBar=true&tbm=youchat", + } + + +def _parse_output(output: str) -> str: + regex = r"^data:\s{\"youChatToken\": \"(.*)\"}$" + tokens = [token for token in re.findall(regex, output, re.MULTILINE)] + return "".join(tokens) |