Skip to main content

Utilities for AKMI integration and instrumentation (FastAPI helpers with OpenTelemetry and Prometheus support).

Project description

akmi-utils

A utility package for various functionalities including converting TOML files to YAML format, logging, and OpenTelemetry integration.

Prerequisites

  • Python 3.12 or higher
  • Poetry

Installation

  1. Clone the repository:

    git clone https://github.com/yourusername/akmi-utils.git
    cd akmi-utils
    
  2. Install dependencies using Poetry:

    poetry install
    

Usage

Converting TOML to YAML

To use the convert_toml_to_yaml function, follow these steps:

  1. Import the function in your script:

    from akmi_utils.convert_toml_yaml import convert_toml_to_yaml
    
  2. Call the function with the input TOML file path and output YAML file path:

    convert_toml_to_yaml('path/to/input.toml', 'path/to/output.yaml')
    

Logging Requests

To log requests in a FastAPI application, use the log_requests middleware:

  1. Import and add the middleware to your FastAPI app:
    from akmi_utils.logging import log_requests
    
    app = FastAPI()
    app.middleware('http')(log_requests)
    

OpenTelemetry Integration

To set up OpenTelemetry with FastAPI, use the setting_otlp function and PrometheusMiddleware:

  1. Import and configure OpenTelemetry in your FastAPI app:
    from akmi_utils.otel import setting_otlp, PrometheusMiddleware, metrics
    
    app = FastAPI()
    setting_otlp(app, app_name='your_app_name', endpoint='your_otlp_endpoint')
    app.add_middleware(PrometheusMiddleware, app_name='your_app_name')
    app.add_route('/metrics', metrics)
    

Running Tests

To run the tests, use the following command:

poetry run pytest

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

akmi_utils-0.1.9.0.tar.gz (9.5 kB view details)

Uploaded Source

Built Distribution

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

akmi_utils-0.1.9.0-py3-none-any.whl (9.1 kB view details)

Uploaded Python 3

File details

Details for the file akmi_utils-0.1.9.0.tar.gz.

File metadata

  • Download URL: akmi_utils-0.1.9.0.tar.gz
  • Upload date:
  • Size: 9.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.31

File hashes

Hashes for akmi_utils-0.1.9.0.tar.gz
Algorithm Hash digest
SHA256 1c53417a1735169a8d5d71924d97c06357d2de9ea5dfa698ea7664637fe076ff
MD5 16f01c029e622528d3fcfc7872a3193f
BLAKE2b-256 4432de121e4445a0a41d3c8274078cae8f9d88757ca82cf8fe4b43f2d66ed91c

See more details on using hashes here.

File details

Details for the file akmi_utils-0.1.9.0-py3-none-any.whl.

File metadata

File hashes

Hashes for akmi_utils-0.1.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9c797cadb6b3a9d4e4989334eeae9a8fbb086a769e0d593b53ea0a74809e19ee
MD5 4acbc5438abc6116c38b27a64466ef24
BLAKE2b-256 d9b09c73a1eb43c787a25e6431d85a6205ab42d84dd402ba816d7e9f4c35f837

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