Skip to main content

A FastAPI middleware for logging requests and responses in NDJSON format

Project description

MIT License

Logo

FastAPI-Logger

FastAPI-Logger is a middleware that provides easy-to-use request and response logging for FastAPI applications. It supports log rotation, custom log directory, and handles sensitive data securely by redacting sensitive headers.


Features

  • Logs all incoming requests and outgoing responses.
  • Supports log rotation with customizable file size and backup count.
  • Handles sensitive data by redacting headers like Authorization.
  • Outputs logs in JSON format for easy integration with log management tools.
  • Flexible configuration for log directory and file size.

Requirements

  • Python 3.12 or higher
  • FastAPI framework

Installation

Create and activate a virtual environment and then install FastAPI & fastapi_ndjson_logger:

pip install "fastapi[standard]" fastapi_ndjson_logger

Example

Create a new FastAPI app and add the middleware to it:

import os

from fastapi import FastAPI
from fastapi_ndjson_logger import RequestResponseLogging

# Create logs directory if it doesn't exist
os.makedirs("logs/request_response_logs", exist_ok=True)

app = FastAPI()
app.add_middleware(
    RequestResponseLogging,
    og_dir=os.path.join("logs", "request_response_logs"),  # Directory for log files
    max_mbytes=8,  # 8 MB max file size
    backup_count=3,  # Keep up to 3 rotated files
)

# Add routes to the app
@app.get("/")
async def read_root():
    return {"Hello": "World"}

Run it

uvicorn app.main:app --reload

Check the logs

cat logs/request_response_logs/app_log.ndjson

Configuration Parameters

Parameter Description Default Value
log_dir Directory to store log files app_logs
max_mbytes Maximum size of a log file in Mega bytes before rotation 8 (8 MB)
backup_count Number of rotated files to retain 5

Support

For any questions or issues, feel free to open an issue on the GitHub repository.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contributing

Contributions are welcome! Please see the CONTRIBUTING.md for guidelines on how to submit improvements and bug fixes. Also, please see the CODE_OF_CONDUCT.md.

Author

Rajath Kumar K S

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

fastapi_ndjson_logger-0.1.4.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

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

fastapi_ndjson_logger-0.1.4-py3-none-any.whl (4.9 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_ndjson_logger-0.1.4.tar.gz.

File metadata

  • Download URL: fastapi_ndjson_logger-0.1.4.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.7

File hashes

Hashes for fastapi_ndjson_logger-0.1.4.tar.gz
Algorithm Hash digest
SHA256 7d526c9272ff04673db3556e9f28ce8511fe48eafd5b577d5aa8fdc6c9d8cc29
MD5 2c0cd49861596640db693b4f3fa46a8e
BLAKE2b-256 f27e9e58d60c112a876d8173fd0e833e817203eea179e834e50f2d33b835ce26

See more details on using hashes here.

File details

Details for the file fastapi_ndjson_logger-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_ndjson_logger-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 56c579ebb02a49fa05b44a147a33cf1d5e70e8624db4b1e9f3c216ef9873c5fa
MD5 1a7d0a0373dc1028a15b7ee137efbae7
BLAKE2b-256 7b210e5121d6d3c51b1ec33bbd18aed8f4fb0eb884d7091c6c5c6e197664f737

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