mirror of
https://github.com/actix/actix-extras.git
synced 2025-02-20 01:34:22 +01:00
75 lines
2.2 KiB
Markdown
75 lines
2.2 KiB
Markdown
# `actix-ws`
|
|
|
|
> WebSockets for Actix Web, without actors.
|
|
|
|
<!-- prettier-ignore-start -->
|
|
|
|
[data:image/s3,"s3://crabby-images/636f8/636f8e8a2d7a73d7f346352c955a70f7b14efcad" alt="crates.io"](https://crates.io/crates/actix-ws)
|
|
[data:image/s3,"s3://crabby-images/2bc46/2bc4692cbe6544cd7a4dca66c017ae837f8a8437" alt="Documentation"](https://docs.rs/actix-ws/0.3.0)
|
|
data:image/s3,"s3://crabby-images/e6032/e60325814203ab753288495174dfb42335287796" alt="Version"
|
|
data:image/s3,"s3://crabby-images/acbe4/acbe4b34d41df7f7bf306411fb97517952a0f395" alt="MIT or Apache 2.0 licensed"
|
|
<br />
|
|
[data:image/s3,"s3://crabby-images/e0054/e0054274ee2467a53395dcdb605564d67b9f4051" alt="Dependency Status"](https://deps.rs/crate/actix-ws/0.3.0)
|
|
[data:image/s3,"s3://crabby-images/76668/76668cd983abe5eb08a4ec2773354603a42a8012" alt="Download"](https://crates.io/crates/actix-ws)
|
|
[data:image/s3,"s3://crabby-images/21077/21077e9d244cffbf5f73a646090cff1990793500" alt="Chat on Discord"](https://discord.gg/NWpN5mmg3x)
|
|
|
|
<!-- prettier-ignore-end -->
|
|
|
|
## Example
|
|
|
|
```rust
|
|
use actix_web::{middleware::Logger, web, App, HttpRequest, HttpServer, Responder};
|
|
use actix_ws::Message;
|
|
|
|
async fn ws(req: HttpRequest, body: web::Payload) -> actix_web::Result<impl Responder> {
|
|
let (response, mut session, mut msg_stream) = actix_ws::handle(&req, body)?;
|
|
|
|
actix_web::rt::spawn(async move {
|
|
while let Some(Ok(msg)) = msg_stream.next().await {
|
|
match msg {
|
|
Message::Ping(bytes) => {
|
|
if session.pong(&bytes).await.is_err() {
|
|
return;
|
|
}
|
|
}
|
|
Message::Text(msg) => println!("Got text: {msg}"),
|
|
_ => break,
|
|
}
|
|
}
|
|
|
|
let _ = session.close(None).await;
|
|
});
|
|
|
|
Ok(response)
|
|
}
|
|
|
|
#[actix_web::main]
|
|
async fn main() -> std::io::Result<()> {
|
|
HttpServer::new(move || {
|
|
App::new()
|
|
.wrap(Logger::default())
|
|
.route("/ws", web::get().to(ws))
|
|
})
|
|
.bind("127.0.0.1:8080")?
|
|
.run()
|
|
.await?;
|
|
|
|
Ok(())
|
|
}
|
|
```
|
|
|
|
## Resources
|
|
|
|
- [API Documentation](https://docs.rs/actix-ws)
|
|
- [Example Chat Project](https://github.com/actix/examples/tree/master/websockets/chat-actorless)
|
|
- Minimum Supported Rust Version (MSRV): 1.75
|
|
|
|
## License
|
|
|
|
This project is licensed under either of
|
|
|
|
- Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
|
|
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
|
|
|
|
at your option.
|