|
|
from __future__ import annotations |
|
|
|
|
|
from aiohttp import ClientSession |
|
|
|
|
|
from ...typing import AsyncResult, Messages |
|
|
from ..base_provider import AsyncGeneratorProvider, ProviderModelMixin |
|
|
from ..helper import format_prompt |
|
|
from ...providers.response import FinishReason |
|
|
|
|
|
class Pizzagpt(AsyncGeneratorProvider, ProviderModelMixin): |
|
|
url = "https://www.pizzagpt.it" |
|
|
api_endpoint = "/api/chatx-completion" |
|
|
|
|
|
working = False |
|
|
|
|
|
default_model = 'gpt-4o-mini' |
|
|
models = [default_model] |
|
|
|
|
|
@classmethod |
|
|
async def create_async_generator( |
|
|
cls, |
|
|
model: str, |
|
|
messages: Messages, |
|
|
proxy: str = None, |
|
|
**kwargs |
|
|
) -> AsyncResult: |
|
|
headers = { |
|
|
"accept": "application/json", |
|
|
"accept-language": "en-US,en;q=0.9", |
|
|
"content-type": "application/json", |
|
|
"origin": cls.url, |
|
|
"referer": f"{cls.url}/en", |
|
|
"user-agent": "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/127.0.0.0 Safari/537.36", |
|
|
"x-secret": "Marinara" |
|
|
} |
|
|
async with ClientSession(headers=headers) as session: |
|
|
prompt = format_prompt(messages) |
|
|
data = { |
|
|
"question": prompt |
|
|
} |
|
|
async with session.post(f"{cls.url}{cls.api_endpoint}", json=data, proxy=proxy) as response: |
|
|
response.raise_for_status() |
|
|
response_json = await response.json() |
|
|
content = response_json.get("answer", response_json).get("content") |
|
|
if content: |
|
|
if "Misuse detected. please get in touch" in content: |
|
|
raise ValueError(content) |
|
|
yield content |
|
|
yield FinishReason("stop") |
|
|
|