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.1.tar.gz (14.2 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.1-py3-none-any.whl (15.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: csctracker_py_core-26.9.1.tar.gz
  • Upload date:
  • Size: 14.2 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.1.tar.gz
Algorithm Hash digest
SHA256 a82867c9d613c9287d4670d8ca02c4f8058d7ca7399ba8d410d82096ba51e8e2
MD5 764d5c8b8b54e6bcbddc3055720f9cab
BLAKE2b-256 f038045b897a8f364fa879becbb1d7f48c528a8c429e8f3989275115c612ccd1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for csctracker_py_core-26.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a222082b338526051ebd880fe00b522528532c89a6228ae54b518ff08e4b206a
MD5 1381318aeb8a5530a6df896488be552c
BLAKE2b-256 c881e6fe1a3568eb97b012f1debd47a5cef42a0a73f32b9b99f97cbd4ea9e6f4

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