#request-id #tower #hyper #axum #warp #unique-id #random

tower-request-id

A tower (hyper, axum, warp) service to add a unique id for every request

4 releases (2 breaking)

0.3.0 Dec 2, 2023
0.2.1 Dec 19, 2022
0.2.0 Nov 4, 2021
0.1.0 Sep 29, 2021

#382 in HTTP server

Download history 3406/week @ 2023-12-15 1271/week @ 2023-12-22 1446/week @ 2023-12-29 2635/week @ 2024-01-05 2818/week @ 2024-01-12 2834/week @ 2024-01-19 2677/week @ 2024-01-26 3365/week @ 2024-02-02 4616/week @ 2024-02-09 4692/week @ 2024-02-16 3724/week @ 2024-02-23 3837/week @ 2024-03-01 4818/week @ 2024-03-08 3864/week @ 2024-03-15 3870/week @ 2024-03-22 2678/week @ 2024-03-29

16,030 downloads per month

MIT license

11KB
53 lines

License Crates.io Docs.rs

tower-request-id

A tiny tower (hyper, axum, warp etc) service to generate a random id for each incoming request.

Usage

After adding the RequestIdLayer into the axum middlewares the request id is available in the [http::Request::extensions()]. For the tracing integration, please refer to the logging example.

Contributing

We appreciate all kinds of contributions, thank you!

Note on README

Most of the readme is automatically copied from the crate documentation by cargo-sync-readme. This way the readme is always in sync with the docs and examples are tested.

So if you find a part of the readme you'd like to change between <!-- cargo-sync-readme start --> and <!-- cargo-sync-readme end --> markers, don't edit README.md directly, but rather change the documentation on top of src/lib.rs and then synchronize the readme with:

cargo sync-readme

(make sure the cargo command is installed):

cargo install cargo-sync-readme

If you have rusty-hook installed the changes will apply automatically on commit.

License

This project is licensed under the MIT license.

Dependencies

~0.7–1MB
~18K SLoC