Skip to main content

A library to integrate Ai with python

Project description

CscTrackerAiCore

CscTrackerAiCore é uma biblioteca Python desenvolvida para facilitar a integração com modelos de IA, especificamente o Google Gemini, oferecendo robustez através de rotação de chaves de API e observabilidade com ClickHouse.

Principais Funcionalidades

  • Integração com Google Gemini: Suporte para análise de textos e imagens (base64) utilizando os modelos generativos do Google, com suporte a filtragem por variante de modelo (pro ou flash).
  • Rotação Inteligente de Chaves (API Key Rotation):
    • Gerenciamento automático de múltiplas chaves de API (gratuitas e pagas).
    • Mecanismo de fallback: tenta chaves gratuitas primeiro e migra para pagas se necessário.
    • Suporte a seleção específica de variante de modelo (ex: garantir uso de pro ou flash).
    • Tratamento de limites de quota (Error 429) com suspensão temporária de chaves/modelos atingidos.
    • Retry automático em caso de falhas.
  • Telemetria e Observabilidade:
    • Integração nativa com ClickHouse para log de eventos.
    • Registro detalhado de uso de tokens (input, output e imagem).
    • Persistência dos prompts, respostas e metadados das tarefas para auditoria e análise.
  • Tratamento de Erros: Exceções customizadas para lidar com falhas específicas do serviço de IA.

Requisitos

  • Python 3.10+
  • Google GenAI SDK
  • Clickhouse Connect

Configuração e Uso

Exemplo Básico

from csctracker_ai_core.service.IaProcessor import IaProcessor

# Inicialização do processador
processor = IaProcessor(
    host="seu-clickhouse-host",
    google_free_keys=["chave1", "chave2"],
    google_paid_keys=["chave_paga1"]
)

# Realizando uma análise básica
resultado, tokens, event_id = processor.analisar_com_gemini(
    input_text="Qual a capital da França?",
    prompt="Responda de forma concisa.",
    task="pergunta_geral"
)

# Realizando uma análise forçando uma variante específica (ex: flash)
resultado_flash, tokens_flash, event_id_flash = processor.analisar_com_gemini(
    input_text="Resuma o histórico da IA.",
    prompt="Seja didático.",
    task="resumo_ia",
    model_variant="flash"
)

print(f"Resultado: {resultado}")
print(f"Tokens usados: {tokens}")

Instalação

As dependências podem ser instaladas via requirements.txt:

pip install -r requirements.txt

Estrutura do Projeto

  • IaProcessor: Classe principal para interface com a IA.
  • ApiKeyRotator: Gerencia o ciclo de vida e seleção das chaves de API.
  • ClickHouseDb: Responsável pela conexão e persistência de dados no ClickHouse.

Licença

Este projeto está sob a licença MIT. Consulte o arquivo LICENSE para mais detalhes.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

csctracker_ai_core-26.7.8.tar.gz (11.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

csctracker_ai_core-26.7.8-py3-none-any.whl (11.3 kB view details)

Uploaded Python 3

File details

Details for the file csctracker_ai_core-26.7.8.tar.gz.

File metadata

  • Download URL: csctracker_ai_core-26.7.8.tar.gz
  • Upload date:
  • Size: 11.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.25

File hashes

Hashes for csctracker_ai_core-26.7.8.tar.gz
Algorithm Hash digest
SHA256 2443a51578e38d47f827bfd68383122dee15ed97387f499b523bcccc30404d5b
MD5 48448327e3bb58beb41d5372a8fbfa71
BLAKE2b-256 4fbf2346a7c659283e659d8ea6783d5457f68d7545be207192bccf597f91d17d

See more details on using hashes here.

File details

Details for the file csctracker_ai_core-26.7.8-py3-none-any.whl.

File metadata

File hashes

Hashes for csctracker_ai_core-26.7.8-py3-none-any.whl
Algorithm Hash digest
SHA256 60a57a67252b6cc779e2750c445320e492c69584d892bce215165ac8a22e18bb
MD5 2ac9f785c7e5dd07b43ec10bf6862137
BLAKE2b-256 dbce344640b61dd21262adf5cb25fa05fdc063c787f21a45cac37cf8ddcc8b64

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page