From a57adbee970b93472ae28631c4e77e112b56c453 Mon Sep 17 00:00:00 2001 From: Heiner Lohaus Date: Fri, 3 Jan 2025 21:26:20 +0100 Subject: [PATCH] Fix websearch with special chars --- g4f/Provider/Copilot.py | 2 +- g4f/tools/web_search.py | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/g4f/Provider/Copilot.py b/g4f/Provider/Copilot.py index 76365da160d..e958acfdaed 100644 --- a/g4f/Provider/Copilot.py +++ b/g4f/Provider/Copilot.py @@ -138,7 +138,6 @@ def create_completion( if prompt is None: prompt = messages[-1]["content"] debug.log(f"Copilot: Use conversation: {conversation_id}") - yield Parameters(**{"conversation": conversation.get_dict(), "user": user, "prompt": prompt}) uploaded_images = [] if images is not None: @@ -200,6 +199,7 @@ def create_completion( if not is_started: raise RuntimeError(f"Invalid response: {last_msg}") finally: + yield Parameters(**{"conversation": conversation.get_dict(), "user": user, "prompt": prompt}) yield Parameters(**{"cookies": {c.name: c.value for c in session.cookies.jar}}) async def get_access_token_and_cookies(url: str, proxy: str = None, target: str = "ChatAI",): diff --git a/g4f/tools/web_search.py b/g4f/tools/web_search.py index bc57e84eb33..14ff6e42466 100644 --- a/g4f/tools/web_search.py +++ b/g4f/tools/web_search.py @@ -4,7 +4,7 @@ import json import hashlib from pathlib import Path -from urllib.parse import urlparse +from urllib.parse import urlparse, quote_plus from datetime import datetime import datetime import asyncio @@ -177,15 +177,15 @@ async def do_search(prompt: str, query: str = None, instructions: str = DEFAULT_ query = spacy_get_keywords(prompt) json_bytes = json.dumps({"query": query, **kwargs}, sort_keys=True).encode() md5_hash = hashlib.md5(json_bytes).hexdigest() - bucket_dir: Path = Path(get_cookies_dir()) / ".scrape_cache" / f"web_search:{datetime.date.today()}" + bucket_dir: Path = Path(get_cookies_dir()) / ".scrape_cache" / f"web_search" / f"{datetime.date.today()}" bucket_dir.mkdir(parents=True, exist_ok=True) - cache_file = bucket_dir / f"{query[:20]}.{md5_hash}.txt" + cache_file = bucket_dir / f"{quote_plus(query[:20])}.{md5_hash}.txt" if cache_file.exists(): - with open(cache_file, "r") as f: + with cache_file.open("r") as f: search_results = f.read() else: search_results = await search(query, **kwargs) - with open(cache_file, "w") as f: + with cache_file.open("w") as f: f.write(str(search_results)) new_prompt = f"""