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.7.7.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.7.7-py3-none-any.whl (15.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: csctracker_py_core-26.7.7.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.7.7.tar.gz
Algorithm Hash digest
SHA256 2673b5e3a99aba20eb79b4f8c1ce894d2bfc3682c58f15f0ab0592ff809d2f61
MD5 8367530ab82af5c1272fba4054bbc639
BLAKE2b-256 b99db151cfc06bcf5595c570c85cddac3233dce01fcc568199c8dc9ee82116c1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for csctracker_py_core-26.7.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ad44373cc2b13f5de07dbfc624d7002d5f95d16421d7ea172a1dcdcbad2eebe6
MD5 73d0933194c9ad0c0dd6b44154e5e5a5
BLAKE2b-256 c9c6d55e9fcccd1e706f38a4d4f7eab00ae58113fecaebf7fe9986a9187ba6de

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