diff options
author | H Lohaus <hlohaus@users.noreply.github.com> | 2024-01-22 04:33:19 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-22 04:33:19 +0100 |
commit | efbcc04d8ac45f5acf1e394d9445ad8569a0a127 (patch) | |
tree | fe9d386a04a280c8aaeec2faaa05819058801d12 /g4f/Provider/selenium/PerplexityAi.py | |
parent | ~ | to do list | survey: https://forms.gle/FhtGtUorygyJn7i48 (diff) | |
parent | Improve CreateImagesBing (diff) | |
download | gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar.gz gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar.bz2 gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar.lz gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar.xz gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.tar.zst gpt4free-efbcc04d8ac45f5acf1e394d9445ad8569a0a127.zip |
Diffstat (limited to 'g4f/Provider/selenium/PerplexityAi.py')
-rw-r--r-- | g4f/Provider/selenium/PerplexityAi.py | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/g4f/Provider/selenium/PerplexityAi.py b/g4f/Provider/selenium/PerplexityAi.py new file mode 100644 index 00000000..4796f709 --- /dev/null +++ b/g4f/Provider/selenium/PerplexityAi.py @@ -0,0 +1,106 @@ +from __future__ import annotations + +import time +from selenium.webdriver.common.by import By +from selenium.webdriver.support.ui import WebDriverWait +from selenium.webdriver.support import expected_conditions as EC +from selenium.webdriver.common.keys import Keys + +from ...typing import CreateResult, Messages +from ..base_provider import AbstractProvider +from ..helper import format_prompt +from ...webdriver import WebDriver, WebDriverSession + +class PerplexityAi(AbstractProvider): + url = "https://www.perplexity.ai" + working = True + supports_gpt_35_turbo = True + supports_stream = True + + @classmethod + def create_completion( + cls, + model: str, + messages: Messages, + stream: bool, + proxy: str = None, + timeout: int = 120, + webdriver: WebDriver = None, + virtual_display: bool = True, + copilot: bool = False, + **kwargs + ) -> CreateResult: + with WebDriverSession(webdriver, "", virtual_display=virtual_display, proxy=proxy) as driver: + prompt = format_prompt(messages) + + driver.get(f"{cls.url}/") + wait = WebDriverWait(driver, timeout) + + # Is page loaded? + wait.until(EC.visibility_of_element_located((By.CSS_SELECTOR, "textarea[placeholder='Ask anything...']"))) + + # Register WebSocket hook + script = """ +window._message = window._last_message = ""; +window._message_finished = false; +const _socket_send = WebSocket.prototype.send; +WebSocket.prototype.send = function(...args) { + if (!window.socket_onmessage) { + window._socket_onmessage = this; + this.addEventListener("message", (event) => { + if (event.data.startsWith("42")) { + let data = JSON.parse(event.data.substring(2)); + if (data[0] =="query_progress" || data[0] == "query_answered") { + let content = JSON.parse(data[1]["text"]); + if (data[1]["mode"] == "copilot") { + content = content[content.length-1]["content"]["answer"]; + content = JSON.parse(content); + } + window._message = content["answer"]; + if (!window._message_finished) { + window._message_finished = data[0] == "query_answered"; + } + } + } + }); + } + return _socket_send.call(this, ...args); +}; +""" + driver.execute_script(script) + + if copilot: + try: + # Check for account + driver.find_element(By.CSS_SELECTOR, "img[alt='User avatar']") + # Enable copilot + driver.find_element(By.CSS_SELECTOR, "button[data-testid='copilot-toggle']").click() + except: + raise RuntimeError("You need a account for copilot") + + # Submit prompt + driver.find_element(By.CSS_SELECTOR, "textarea[placeholder='Ask anything...']").send_keys(prompt) + driver.find_element(By.CSS_SELECTOR, "textarea[placeholder='Ask anything...']").send_keys(Keys.ENTER) + + # Stream response + script = """ +if(window._message && window._message != window._last_message) { + try { + return window._message.substring(window._last_message.length); + } finally { + window._last_message = window._message; + } +} else if(window._message_finished) { + return null; +} else { + return ''; +} +""" + while True: + chunk = driver.execute_script(script) + if chunk: + yield chunk + elif chunk != "": + break + else: + time.sleep(0.1)
\ No newline at end of file |