Flask RequestID Middleware
A Flask middleware to log and set Request ID in the HTTP header.
Overview
This project provides a Flask middleware that ensures a unique Request ID is generated and logged for each incoming request. The Request ID is also included in the response back to the client.
Features
Generates a unique Request ID for each incoming request
Logs the Request ID using a log filter
Includes the Request ID in the response back to the client
Installation
To install the middleware, run the following command:
pip install flask-request-id-header-middleware
Usage
To use the middleware in your Flask application, simply import and initialize it:
from flask import Flask
from flask_request_id_header_middleware import RequestID
app = Flask(__name__)
RequestID(app)
Configuration
The middleware can be configured using the following settings:
REQUEST_ID_UNIQUE_VALUE_PREFIX
: a prefix that indicates a request ID should be considered unique
app.config['REQUEST_ID_UNIQUE_VALUE_PREFIX'] = 'MY-APP-'
In this example, any request ID that starts with MY-APP- will be considered unique, and will not be modified by the middleware.
For instance, if the client sends a request with the header X-Request-ID: MY-APP-12345, the middleware will not append a new request ID, and will instead return the original value.
Logging
The middleware uses a log filter to inject the current request ID into log records. To use the log filter, add it to your logging configuration:
from flask_request_id_header_middleware.log_filter import RequestIDLogFilter
logging.basicConfig()
logger = logging.getLogger()
logger.addFilter(RequestIDLogFilter())
Example
Here is an example of how to use the middleware in a Flask application:
from flask import Flask
from flask_request_id_header_middleware import RequestID
app = Flask(__name__)
RequestID(app)
@app.route("/")
def index():
return "Hello, World!"
if __name__ == "__main__":
app.run()
In this example, the middleware will generate a unique Request ID for each incoming request and log it using the log filter. The Request ID will also be included in the response back to the client.
Tests
To run the tests, run the following command:
flask --app manage.py test