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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for akmi_utils-0.1.7.tar.gz
Algorithm Hash digest
SHA256 1653417204a5a4e70fc65abc40461ef2b650f61affc3f926776e23428f943562
MD5 7e551640cdd3faae7bcb738a4f9f0e54
BLAKE2b-256 0206a681b07b6ddd885d9eca669cbe872d5225af7a07427ce24e1134cef4444b

See more details on using hashes here.

File details

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

File metadata

  • Download URL: akmi_utils-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 8.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.31

File hashes

Hashes for akmi_utils-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 819f1312aee573844b11753069e2960b674ab1d2800af654ed2574cc5aff97e1
MD5 6c33aec49e658b647255378d918228d7
BLAKE2b-256 2b496e8fe71ead45cf552771bfefc37c9958ea7be94823e27b1bebf1ceaa705b

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