Skip to content

Провайдеры — поток данных

Gemini Text

PromptResult | str
    -> GeminiProvider.generate_text()
    -> google.genai.models.generate_content()
    -> response.text
    -> str

GeminiProvider.answer() делегирует в generate_text() для совместимости с LLMDispatcher.process().

Gemini JSON

PromptResult | str
    -> GeminiProvider.generate_json(schema=...)
    -> GenerateContentConfig(response_mime_type="application/json", response_schema=schema)
    -> response.text
    -> json.loads()
    -> optional Pydantic validation

Gemini Images

prompt: str
    -> GeminiProvider.generate_image_bytes()
    -> GenerateContentConfig(response_modalities=[IMAGE], image_config=...)
    -> first inline_data image part
    -> (bytes, actual_mime_type)

response_mime_type в этом пути не передается в GenerateContentConfig.response_mime_type; он используется только как fallback content type, если Gemini не вернул inline_data.mime_type. Если image_config.image_size равен 4K и Gemini отклоняет запрос, провайдер один раз повторяет его с image_size="2K".

Imagen Images

prompt: str
    -> GeminiProvider.generate_imagen_bytes()
    -> GenerateImagesConfig(output_mime_type=requested_mime)
    -> first generated_images image
    -> (bytes, actual_mime_type)

OpenAI Text

PromptResult | str
    -> OpenAIProvider.generate_text()
    -> chat.completions.create()
    -> choices[0].message.content
    -> str