mirror of
				https://github.com/xtekky/gpt4free.git
				synced 2025-10-31 03:26:22 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import asyncio
 | |
| import json
 | |
| from aiohttp import ClientSession
 | |
| from ..typing import Messages, AsyncResult
 | |
| from .base_provider import AsyncGeneratorProvider
 | |
| 
 | |
| class Rocks(AsyncGeneratorProvider):
 | |
|     url = "https://api.airforce"
 | |
|     api_endpoint = "/chat/completions"
 | |
|     supports_message_history = True
 | |
|     supports_gpt_35_turbo = True
 | |
|     supports_gpt_4 = True
 | |
|     supports_stream = True
 | |
|     supports_system_message = True
 | |
|     working = True
 | |
| 
 | |
|     @classmethod
 | |
|     async def create_async_generator(
 | |
|         cls,
 | |
|         model: str,
 | |
|         messages: Messages,
 | |
|         proxy: str = None,
 | |
|         **kwargs
 | |
|     ) -> AsyncResult:
 | |
|         payload = {"messages":messages,"model":model,"max_tokens":4096,"temperature":1,"top_p":1,"stream":True}
 | |
| 
 | |
|         headers = {
 | |
|             "Accept": "application/json",
 | |
|             "Accept-Encoding": "gzip, deflate, br, zstd",
 | |
|             "Accept-Language": "en-US,en;q=0.9",
 | |
|             "Authorization": "Bearer missing api key",
 | |
|             "Origin": "https://llmplayground.net",
 | |
|             "Referer": "https://llmplayground.net/",
 | |
|             "Sec-Fetch-Dest": "empty",
 | |
|             "Sec-Fetch-Mode": "cors",
 | |
|             "Sec-Fetch-Site": "same-origin",
 | |
|             "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36",
 | |
|         }
 | |
| 
 | |
|         async with ClientSession() as session:
 | |
|             async with session.post(
 | |
|                 f"{cls.url}{cls.api_endpoint}",
 | |
|                 json=payload,
 | |
|                 proxy=proxy,
 | |
|                 headers=headers
 | |
|             ) as response:
 | |
|                 response.raise_for_status()
 | |
|                 last_chunk_time = asyncio.get_event_loop().time()
 | |
|                 
 | |
|                 async for line in response.content:
 | |
|                     current_time = asyncio.get_event_loop().time()
 | |
|                     if current_time - last_chunk_time > 5:
 | |
|                         return
 | |
|                     
 | |
|                     if line.startswith(b"\n"):
 | |
|                         pass
 | |
|                     elif "discord.com/invite/" in line.decode() or "discord.gg/" in line.decode():
 | |
|                         pass # trolled
 | |
|                     elif line.startswith(b"data: "):
 | |
|                         try:
 | |
|                             line = json.loads(line[6:])
 | |
|                         except json.JSONDecodeError:
 | |
|                             continue
 | |
|                         chunk = line["choices"][0]["delta"].get("content")
 | |
|                         if chunk:
 | |
|                             yield chunk
 | |
|                             last_chunk_time = current_time
 | |
|                     else:
 | |
|                         raise Exception(f"Unexpected line: {line}")
 | |
|                 return | 
