#web-framework #framework #poem-web #async #tower-service #tower-layer

poem

Poem is a full-featured and easy-to-use web framework with the Rust programming language

211 releases (stable)

2.0.1 Mar 4, 2024
1.3.59 Nov 19, 2023
1.3.57 Jul 23, 2023
1.3.55 Feb 18, 2023
0.1.0 Aug 5, 2020

#10 in HTTP server

Download history 12053/week @ 2023-11-26 10553/week @ 2023-12-03 11992/week @ 2023-12-10 11556/week @ 2023-12-17 7418/week @ 2023-12-24 9715/week @ 2023-12-31 11973/week @ 2024-01-07 12722/week @ 2024-01-14 12229/week @ 2024-01-21 10512/week @ 2024-01-28 11060/week @ 2024-02-04 8874/week @ 2024-02-11 12149/week @ 2024-02-18 14101/week @ 2024-02-25 13276/week @ 2024-03-03 4317/week @ 2024-03-10

44,432 downloads per month
Used in 145 crates (58 directly)

MIT/Apache

745KB
17K SLoC

Poem Framework

A program is like a poem, you cannot write a poem without writing it. --- Dijkstra

A full-featured and easy-to-use web framework with the Rust programming language.


Features

  • Both Ease of use and performance.
  • Minimizing the use of generics.
  • Blazing fast and flexible routing.
  • tower::Service and tower::Layer compatibility.
  • Use poem-openapi to write APIs that comply with OAS3 specifications and automatically generate documents.

Crate features

To avoid compiling unused dependencies, Poem gates certain features, all of which are disabled by default:

Feature Description
server Server and listener APIs (enabled by default)
compression Support decompress request body and compress response body
cookie Support for Cookie
csrf Support for Cross-Site Request Forgery (CSRF) protection
multipart Support for Multipart
native-tls Support for HTTP server over TLS with native-tls
openssl-tls Support for HTTP server over TLS with openssl-tls
opentelemetry Support for opentelemetry
prometheus Support for Prometheus
redis-session Support for RedisSession
rustls Support for HTTP server over TLS with rustls
session Support for session
sse Support Server-Sent Events (SSE)
static-files Support static files endpoint
tempfile Support for tempfile
tower-compat Adapters for tower::Layer and tower::Service.
websocket Support for WebSocket
anyhow Integrate with anyhow crate.
eyre06 Integrate with version 0.6.x of the eyre crate.
i18n Support for internationalization
acme-native-roots Support for ACME(Automatic Certificate Management Environment)
acme-webpki-roots Support for ACME using webpki TLS roots rather than native TLS roots
tokio-metrics Integrate with tokio-metrics crate.
embed Integrate with rust-embed crate.
xml Integrate with quick-xml crate.
yaml Integrate with serde-yaml crate.

Safety

This crate uses #![forbid(unsafe_code)] to ensure everything is implemented in 100% Safe Rust.

Example

use poem::{get, handler, listener::TcpListener, web::Path, Route, Server};

#[handler]
fn hello(Path(name): Path<String>) -> String {
    format!("hello: {}", name)
}

#[tokio::main]
async fn main() -> Result<(), std::io::Error> {
    let app = Route::new().at("/hello/:name", get(hello));
    Server::new(TcpListener::bind("0.0.0.0:3000"))
      .run(app)
      .await
}

More examples can be found here.

MSRV

The minimum supported Rust version for this crate is 1.74.0.

Contributing

🎈 Thanks for your help improving the project! We are so happy to have you!

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Poem by you, shall be licensed as Apache, without any additional terms or conditions.

Dependencies

~13–36MB
~604K SLoC