Helper for starlette to add request id in logger
Project description
starlette-request-id
starlette-request-id is a helper for starlette to add request id in logger.
Installation
starlette-request-id is available on PyPI. Use pip to install:
$ pip install starlette-request-id
Basic Usage
import httpx
import uvicorn
from starlette.applications import Starlette
from starlette.responses import PlainTextResponse
from starlette_request_id import REQUEST_ID_HEADER, RequestIdMiddleware, init_logger, request_id_ctx
LOGGING = {
"version": 1,
"disable_existing_loggers": 0,
"formatters": {
"default": {
"format": "[%(asctime)s] %(levelname)s [%(request_id)s] %(name)s | %(message)s",
"datefmt": "%d/%b/%Y %H:%M:%S",
}
},
"handlers": {
"stdout": {
"level": "INFO",
"class": "logging.StreamHandler",
"formatter": "default",
},
},
"loggers": {
"": {
"handlers": ["stdout"],
"propagate": True,
"level": "INFO",
},
},
}
def init_app():
init_logger(LOGGING)
app_ = Starlette()
app_.add_middleware(RequestIdMiddleware)
@app_.route("/")
def success(request):
httpx.post("https://www.example.org/", headers={REQUEST_ID_HEADER: request_id_ctx.get()})
return PlainTextResponse("OK", status_code=200)
return app_
app = init_app()
if __name__ == "__main__":
uvicorn.run(
app=app,
log_config=LOGGING,
)
curl 127.0.0.1:8000
[17/Jan/2021 18:31:19] INFO [N/A] uvicorn.error | Started server process [576540]
[17/Jan/2021 18:31:19] INFO [N/A] uvicorn.error | Waiting for application startup.
[17/Jan/2021 18:31:19] INFO [N/A] uvicorn.error | Application startup complete.
[17/Jan/2021 18:31:19] INFO [N/A] uvicorn.error | Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
[17/Jan/2021 18:31:22] INFO [22395fa2-e296-420e-93a1-5537e1ba0a62] uvicorn.access | 127.0.0.1:50372 - "GET / HTTP/1.1" 200
[17/Jan/2021 18:31:25] INFO [9ac6fa25-5048-4222-ac54-dd2c70e3e042] uvicorn.access | 127.0.0.1:50374 - "GET / HTTP/1.1" 200
License
starlette-request-id is developed and distributed under the Apache 2.0 license.
Reporting a Security Vulnerability
See our security policy.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for starlette-request-id-1.0.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b7bc40486951eba78b27d467a22d323355c2db86966d6ad9c1552cb52221688 |
|
MD5 | 6984e7ed9f4179ac0940a772630f24ff |
|
BLAKE2b-256 | d92d2b44ab75b4496bcef3d10b790b8aec5bb5d27d45955370593c20d6ce1007 |
Close
Hashes for starlette_request_id-1.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7adef40be82fd37eaf55a176d5de0186deb6363e1fcf5e927a7e561eb7fffbda |
|
MD5 | 88d69d4e5334b6f7029e2d33a82a9393 |
|
BLAKE2b-256 | 4668f70c3fcfc312c63f3d85b15d9afbf7f91905c30ede19014a3e6042075b97 |