mirror of
https://github.com/ntex-rs/ntex-extras.git
synced 2025-04-03 21:07:40 +03:00
upgrade to service 0.4
This commit is contained in:
parent
fe92ba2e8c
commit
440c0073d0
10 changed files with 64 additions and 65 deletions
|
@ -1,6 +1,6 @@
|
|||
[package]
|
||||
name = "ntex-session"
|
||||
version = "0.1.0"
|
||||
version = "0.2.0"
|
||||
authors = ["ntex contributors <team@ntex.rs>"]
|
||||
description = "Session for ntex web framework."
|
||||
readme = "README.md"
|
||||
|
@ -22,7 +22,7 @@ default = ["cookie-session"]
|
|||
cookie-session = ["cookie/secure", "ntex/cookie"]
|
||||
|
||||
[dependencies]
|
||||
ntex = "0.5.14"
|
||||
ntex = "0.6.0-alpha.0"
|
||||
cookie = "0.16"
|
||||
derive_more = "0.99"
|
||||
futures = "0.3"
|
||||
|
@ -31,4 +31,4 @@ serde_json = "1.0"
|
|||
time = { version = "0.3", default-features = false, features = ["std"] }
|
||||
|
||||
[dev-dependencies]
|
||||
ntex = { version = "0.5", features=["tokio"] }
|
||||
ntex = { version = "0.6.0-alpha.0", features=["tokio"] }
|
||||
|
|
|
@ -15,17 +15,14 @@
|
|||
//! The constructors take a key as an argument. This is the private key
|
||||
//! for cookie session - when this value is changed, all session data is lost.
|
||||
|
||||
use std::collections::HashMap;
|
||||
use std::convert::Infallible;
|
||||
use std::rc::Rc;
|
||||
use std::task::{Context, Poll};
|
||||
use std::{collections::HashMap, convert::Infallible, rc::Rc};
|
||||
|
||||
use cookie::{Cookie, CookieJar, Key, SameSite};
|
||||
use derive_more::{Display, From};
|
||||
use futures::future::{FutureExt, LocalBoxFuture};
|
||||
use ntex::http::header::{HeaderValue, SET_COOKIE};
|
||||
use ntex::http::HttpMessage;
|
||||
use ntex::service::{Service, Transform};
|
||||
use ntex::http::{header::HeaderValue, header::SET_COOKIE, HttpMessage};
|
||||
use ntex::service::{Middleware, Service};
|
||||
use ntex::web::{DefaultError, ErrorRenderer, WebRequest, WebResponse, WebResponseError};
|
||||
use serde_json::error::Error as JsonError;
|
||||
use time::{Duration, OffsetDateTime};
|
||||
|
@ -281,10 +278,10 @@ impl CookieSession {
|
|||
}
|
||||
}
|
||||
|
||||
impl<S> Transform<S> for CookieSession {
|
||||
impl<S> Middleware<S> for CookieSession {
|
||||
type Service = CookieSessionMiddleware<S>;
|
||||
|
||||
fn new_transform(&self, service: S) -> Self::Service {
|
||||
fn create(&self, service: S) -> Self::Service {
|
||||
CookieSessionMiddleware { service, inner: self.0.clone() }
|
||||
}
|
||||
}
|
||||
|
@ -298,14 +295,13 @@ pub struct CookieSessionMiddleware<S> {
|
|||
impl<S, Err> Service<WebRequest<Err>> for CookieSessionMiddleware<S>
|
||||
where
|
||||
S: Service<WebRequest<Err>, Response = WebResponse>,
|
||||
S::Future: 'static,
|
||||
S::Error: 'static,
|
||||
Err: ErrorRenderer,
|
||||
Err::Container: From<CookieSessionError>,
|
||||
{
|
||||
type Response = WebResponse;
|
||||
type Error = S::Error;
|
||||
type Future = LocalBoxFuture<'static, Result<Self::Response, Self::Error>>;
|
||||
type Future<'f> = LocalBoxFuture<'f, Result<Self::Response, Self::Error>> where Self: 'f;
|
||||
|
||||
fn poll_ready(&self, cx: &mut Context) -> Poll<Result<(), Self::Error>> {
|
||||
self.service.poll_ready(cx)
|
||||
|
@ -320,7 +316,7 @@ where
|
|||
/// session state changes, then set-cookie is returned in response. As
|
||||
/// a user logs out, call session.purge() to set SessionStatus accordingly
|
||||
/// and this will trigger removal of the session cookie in the response.
|
||||
fn call(&self, req: WebRequest<Err>) -> Self::Future {
|
||||
fn call(&self, req: WebRequest<Err>) -> Self::Future<'_> {
|
||||
let inner = self.inner.clone();
|
||||
let (is_new, state) = self.inner.load(&req);
|
||||
let prolong_expiration = self.inner.expires_in.is_some();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue