Skip to main content

A base library for microservices with Flask, JSON logging, and Prometheus telemetry.

Project description

CscTrackerPyCore

PyPI version Python versions License: MIT Code style: black

CscTrackerPyCore é uma biblioteca Python base desenvolvida para padronizar e acelerar o desenvolvimento de microserviços. Ela oferece integração nativa com Flask, fornecendo recursos essenciais como logging estruturado em JSON, telemetria com Prometheus, documentação automática via Swagger e gerenciamento de tarefas agendadas.

Principais Funcionalidades

  • Starter Facilitado: Inicialização rápida de aplicações Flask com suporte a CORS e tratamento de variáveis de ambiente.
  • Logging Estruturado: Formatação automática de logs em JSON com inclusão de requestId, appName e appVersion para melhor rastreabilidade.
  • Observabilidade:
    • Integração nativa com Prometheus para coleta de métricas de endpoints.
    • Interceptor de Requisições: Registro detalhado de chamadas HTTP (método, path, status, duração) com opção de persistência remota para auditoria.
  • Documentação Automática: Geração de especificação Swagger (OpenAPI) simplificada.
  • Processamento em Background: Integração com csctracker-queue-scheduler para execução de tarefas assíncronas e agendadas.
  • Repositórios Remotos: Abstração para comunicação entre serviços via HTTP com tratamento de headers e correlação.

Requisitos

  • Python 3.9+
  • Flask
  • Flask-CORS
  • Prometheus Flask Exporter
  • Flask Swagger Generator
  • Python JSON Logger
  • Python Dotenv

Instalação

As dependências podem ser instaladas via pip:

pip install csctracker-py-core

Ou via requirements.txt:

pip install -r requirements.txt

Configuração

A biblioteca é configurada principalmente via variáveis de ambiente, suportando arquivos .env localizados na pasta config/ (ex: config/dev.env).

Variáveis de Ambiente Suportadas

Variável Descrição Exemplo
PROFILE Perfil de configuração (define o arquivo .env) dev
PORT Porta de execução do servidor Flask 5000
LOG_LEVEL Nível de detalhamento do log INFO, DEBUG
LOG_REQUEST_BODY Se True, inclui o corpo da requisição nos logs True
LOG_RESPONSE_BODY Se True, inclui o corpo da resposta nos logs False
URL_BFF URL base para persistência de logs de requisição http://api-gateway/
API_TOKEN Token de autorização para chamadas externas seu_token_aqui
DEBUG Ativa o modo debug do Flask se definido como 1 0

Uso Didático

1. Inicialização do Starter

A classe Starter centraliza a configuração do Flask.

from csctracker_py_core.starter import Starter

# Inicializa o starter (static_folder define a pasta de arquivos estáticos)
# save_request=True ativa a persistência remota de logs de requisição
starter = Starter(save_request=False)

# Obtém a instância do Flask configurada
app = starter.get_app()

@app.route('/')
def hello():
    return {"message": "CscTrackerPyCore is running!"}

if __name__ == '__main__':
    starter.start()

2. Logging e Interceptação

Uma vez iniciado o Starter, todos os logs do sistema usarão o formato JSON e as requisições serão interceptadas automaticamente para gerar telemetria.

3. Acesso aos Repositórios

# Acesso ao repositório HTTP para chamadas externas padronizadas
http_repo = starter.get_http_repository()

Estrutura do Projeto

  • Starter: Orquestrador principal que configura Flask, CORS, Métricas e Swagger.
  • Configs: Gerencia o carregamento de variáveis de ambiente e a configuração do logger JSON.
  • Interceptor: Middleware Flask que captura dados de performance e logs de entrada/saída.
  • HttpRepository: Facilita requisições HTTP externas com injeção de headers de segurança e rastreio.
  • RequestInfo: Utilitário para gerenciar IDs de correlação (Correlation IDs) entre threads.

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_py_core-26.9.3.tar.gz (14.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_py_core-26.9.3-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file csctracker_py_core-26.9.3.tar.gz.

File metadata

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

File hashes

Hashes for csctracker_py_core-26.9.3.tar.gz
Algorithm Hash digest
SHA256 8edff2a66b08e0ecad99a07c3241cd3aa7cdd405b377209938711edcbab47209
MD5 d4399f63b79431d8701f9c60425a236d
BLAKE2b-256 c10136bddb8828bf3c1b59dd3c6ffdfa8aaabb4122f8edce670b214a6a1eeab6

See more details on using hashes here.

File details

Details for the file csctracker_py_core-26.9.3-py3-none-any.whl.

File metadata

File hashes

Hashes for csctracker_py_core-26.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7a68276b2958b4809dd3e4cee2e78e76151d0417cbef745aa01c343d7e2284a8
MD5 54a07c51b2d7be3eaaa953cab74e7b00
BLAKE2b-256 8dedc59c412f23c1af339aa6f19342f10dbda13e5f77fa439307ff7253ede0ea

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