mirror of
https://github.com/actix/examples
synced 2025-02-20 00:14:21 +01:00
chore: use redis-rs in session features
This commit is contained in:
parent
dd102ae65b
commit
f03f126d4f
51
Cargo.lock
generated
51
Cargo.lock
generated
@ -292,27 +292,6 @@ dependencies = [
|
|||||||
"prost",
|
"prost",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "actix-redis"
|
|
||||||
version = "0.12.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "38446dc11c743f4f0023b1067c7cfb8f2548f24418e31a193b324e35fa059279"
|
|
||||||
dependencies = [
|
|
||||||
"actix",
|
|
||||||
"actix-rt",
|
|
||||||
"actix-service",
|
|
||||||
"actix-tls",
|
|
||||||
"actix-web",
|
|
||||||
"backoff",
|
|
||||||
"derive_more",
|
|
||||||
"futures-core",
|
|
||||||
"log",
|
|
||||||
"redis-async",
|
|
||||||
"time",
|
|
||||||
"tokio 1.37.0",
|
|
||||||
"tokio-util 0.7.10",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "actix-router"
|
name = "actix-router"
|
||||||
version = "0.5.3"
|
version = "0.5.3"
|
||||||
@ -373,15 +352,13 @@ version = "0.9.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b671404ec72194d8af58c2bdaf51e3c477a0595056bd5010148405870dda8df2"
|
checksum = "b671404ec72194d8af58c2bdaf51e3c477a0595056bd5010148405870dda8df2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"actix",
|
|
||||||
"actix-redis",
|
|
||||||
"actix-service",
|
"actix-service",
|
||||||
"actix-utils",
|
"actix-utils",
|
||||||
"actix-web",
|
"actix-web",
|
||||||
"anyhow",
|
"anyhow",
|
||||||
"derive_more",
|
"derive_more",
|
||||||
"futures-core",
|
|
||||||
"rand 0.8.5",
|
"rand 0.8.5",
|
||||||
|
"redis",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"tracing",
|
"tracing",
|
||||||
@ -1586,17 +1563,6 @@ dependencies = [
|
|||||||
"tokio-util 0.7.10",
|
"tokio-util 0.7.10",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "backoff"
|
|
||||||
version = "0.4.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "b62ddb9cb1ec0a098ad4bbf9344d0713fa193ae1a80af55febcff2627b6a00c1"
|
|
||||||
dependencies = [
|
|
||||||
"getrandom 0.2.12",
|
|
||||||
"instant",
|
|
||||||
"rand 0.8.5",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "backtrace"
|
name = "backtrace"
|
||||||
version = "0.3.69"
|
version = "0.3.69"
|
||||||
@ -6031,21 +5997,6 @@ dependencies = [
|
|||||||
"url",
|
"url",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "redis-async"
|
|
||||||
version = "0.13.0"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "2777130e406c74c28b6cddc0194fcdc2553b5a8795eef9f6384bd3b70a07ba3f"
|
|
||||||
dependencies = [
|
|
||||||
"bytes 1.6.0",
|
|
||||||
"futures-channel",
|
|
||||||
"futures-sink",
|
|
||||||
"futures-util",
|
|
||||||
"log",
|
|
||||||
"tokio 1.37.0",
|
|
||||||
"tokio-util 0.7.10",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "redis-session-example"
|
name = "redis-session-example"
|
||||||
version = "1.0.0"
|
version = "1.0.0"
|
||||||
|
@ -5,7 +5,7 @@ edition = "2021"
|
|||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
actix-web.workspace = true
|
actix-web.workspace = true
|
||||||
actix-session = { workspace = true, features = ["redis-actor-session"] }
|
actix-session = { workspace = true, features = ["redis-rs-session"] }
|
||||||
|
|
||||||
env_logger.workspace = true
|
env_logger.workspace = true
|
||||||
log.workspace = true
|
log.workspace = true
|
||||||
|
@ -3,8 +3,8 @@
|
|||||||
//! Every request gets a session, corresponding to a cache entry and cookie.
|
//! Every request gets a session, corresponding to a cache entry and cookie.
|
||||||
//! At login, the session key changes and session state in cache re-assigns.
|
//! At login, the session key changes and session state in cache re-assigns.
|
||||||
//! At logout, session state in cache is removed and cookie is invalidated.
|
//! At logout, session state in cache is removed and cookie is invalidated.
|
||||||
//!
|
|
||||||
use actix_session::{storage::RedisActorSessionStore, Session, SessionMiddleware};
|
use actix_session::{storage::RedisSessionStore, Session, SessionMiddleware};
|
||||||
use actix_web::{
|
use actix_web::{
|
||||||
middleware, web,
|
middleware, web,
|
||||||
web::{get, post, resource},
|
web::{get, post, resource},
|
||||||
@ -81,16 +81,12 @@ async fn main() -> std::io::Result<()> {
|
|||||||
// authentication cookies for any user!
|
// authentication cookies for any user!
|
||||||
let private_key = actix_web::cookie::Key::generate();
|
let private_key = actix_web::cookie::Key::generate();
|
||||||
|
|
||||||
|
let store = RedisSessionStore::new("127.0.0.1:6379").await.unwrap();
|
||||||
|
|
||||||
HttpServer::new(move || {
|
HttpServer::new(move || {
|
||||||
App::new()
|
App::new()
|
||||||
// redis session middleware
|
// redis session middleware
|
||||||
.wrap(
|
.wrap(SessionMiddleware::builder(store.clone(), private_key.clone()).build())
|
||||||
SessionMiddleware::builder(
|
|
||||||
RedisActorSessionStore::new("127.0.0.1:6379"),
|
|
||||||
private_key.clone(),
|
|
||||||
)
|
|
||||||
.build(),
|
|
||||||
)
|
|
||||||
// enable logger - always register Actix Web Logger middleware last
|
// enable logger - always register Actix Web Logger middleware last
|
||||||
.wrap(middleware::Logger::default())
|
.wrap(middleware::Logger::default())
|
||||||
.service(resource("/").route(get().to(index)))
|
.service(resource("/").route(get().to(index)))
|
||||||
@ -112,15 +108,13 @@ mod test {
|
|||||||
#[actix_web::test]
|
#[actix_web::test]
|
||||||
async fn test_workflow() {
|
async fn test_workflow() {
|
||||||
let private_key = actix_web::cookie::Key::generate();
|
let private_key = actix_web::cookie::Key::generate();
|
||||||
|
let store = RedisSessionStore::new("127.0.0.1:6379").await.unwrap();
|
||||||
let srv = actix_test::start(move || {
|
let srv = actix_test::start(move || {
|
||||||
App::new()
|
App::new()
|
||||||
.wrap(
|
.wrap(
|
||||||
SessionMiddleware::builder(
|
SessionMiddleware::builder(store.clone(), private_key.clone())
|
||||||
RedisActorSessionStore::new("127.0.0.1:6379"),
|
.cookie_name("test-session".to_owned())
|
||||||
private_key.clone(),
|
.build(),
|
||||||
)
|
|
||||||
.cookie_name("test-session".to_owned())
|
|
||||||
.build(),
|
|
||||||
)
|
)
|
||||||
.wrap(middleware::Logger::default())
|
.wrap(middleware::Logger::default())
|
||||||
.service(resource("/").route(get().to(index)))
|
.service(resource("/").route(get().to(index)))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user