pub struct AuthenticationProvider<DataProviderImpl: DataProvider> { /* private fields */ }
Expand description
A clone of this struct is provided to each App instance in Actix as Data, thus providing access to the authentication system in each route.
Implementations§
Source§impl<DataProviderImpl: DataProvider> AuthenticationProvider<DataProviderImpl>
impl<DataProviderImpl: DataProvider> AuthenticationProvider<DataProviderImpl>
Sourcepub fn new(provider: DataProviderImpl, jwt_secret: Vec<u8>) -> Self
pub fn new(provider: DataProviderImpl, jwt_secret: Vec<u8>) -> Self
Creates a new AuthenticationProvider with the provided jwt_secret and data provider. The jwt secret is used to sign and verify the json web tokens, so it should be secret, long enough to be secure, and persistent over a period of days. Changing this token will invalidate all current sessions, but they may not be cleanly logged out if you set your own cookies in addition to the token.
Sourcepub async fn register(
&self,
account: DataProviderImpl::AccountType,
password: &str,
) -> ResponseResult<RegistrationOutcome<DataProviderImpl::AccountType>>
pub async fn register( &self, account: DataProviderImpl::AccountType, password: &str, ) -> ResponseResult<RegistrationOutcome<DataProviderImpl::AccountType>>
Registers the provided account with the provided password. See the documentation on RegistrationOutcome for details on what to do next.
#[post("/register")]
async fn register(auth: Data<ExampleAuthProvider>, dto: Json<RegistrationDto>) -> Response {
let dto = dto.into_inner();
Ok(
match auth.register(
ExampleAccount {
username: dto.username,
email: dto.email,
},
&dto.password,
)? {
RegistrationOutcome::Successful(_account) => {
HttpResponse::Ok()
.json(RegistrationResponseDto {
succeeded: true,
message: None,
})
.await?
}
RegistrationOutcome::InvalidEmail => {
HttpResponse::Ok()
.json(RegistrationResponseDto {
succeeded: false,
message: Some("Invalid Email".into()),
})
.await?
}
RegistrationOutcome::EmailTaken => {
HttpResponse::Ok()
.json(RegistrationResponseDto {
succeeded: false,
message: Some("Email is already taken".into()),
})
.await?
}
},
)
}
Sourcepub async fn login(
&self,
email: &str,
password: &str,
) -> ResponseResult<LoginOutcome<DataProviderImpl::AccountType>>
pub async fn login( &self, email: &str, password: &str, ) -> ResponseResult<LoginOutcome<DataProviderImpl::AccountType>>
Attempts to login to the specified account. See the documentation on LoginOutcome for details on what to do next.
#[post("/login")]
async fn login(auth: Data<ExampleAuthProvider>, dto: Json<LoginDto>) -> Response {
Ok(match auth.login(&dto.email, &dto.password)? {
LoginOutcome::Successful(account, cookie) => {
HttpResponse::Ok()
.cookie(CookieBuilder::new("username", account.username).finish()) //this is how you make information available to your frontend, note that anything in your account type is visible to users as it is encoded as a JWT!!!!!
.cookie(cookie)
.json(LoginResponseDto {
succeeded: true,
message: None,
})
.await?
}
LoginOutcome::InvalidEmailOrPassword => {
HttpResponse::Ok()
.json(LoginResponseDto {
succeeded: false,
message: Some("Invalid username or password".into()),
})
.await?
}
})
}
Sourcepub fn current_user(
&self,
request: &HttpRequest,
) -> ResponseResult<DataProviderImpl::AccountType>
pub fn current_user( &self, request: &HttpRequest, ) -> ResponseResult<DataProviderImpl::AccountType>
Gets the current user if a valid session is present on the provided HTTP request, otherwise returns a ResponseResult that when propagated with the actix-plus-error crate causes Actix web to return 401 Not Authorized.
#[get("/private_page")]
async fn private_page(request: HttpRequest, auth: Data<ExampleAuthProvider>) -> Response {
let account = auth.current_user(&request)?;
Ok(HttpResponse::Ok()
.body(format!("Hello {}", account.username))
.await?)
}
Trait Implementations§
Source§impl<DataProviderImpl: Clone + DataProvider> Clone for AuthenticationProvider<DataProviderImpl>
impl<DataProviderImpl: Clone + DataProvider> Clone for AuthenticationProvider<DataProviderImpl>
Source§fn clone(&self) -> AuthenticationProvider<DataProviderImpl>
fn clone(&self) -> AuthenticationProvider<DataProviderImpl>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl<DataProviderImpl> Freeze for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: Freeze,
impl<DataProviderImpl> RefUnwindSafe for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: RefUnwindSafe,
impl<DataProviderImpl> Send for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: Send,
impl<DataProviderImpl> Sync for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: Sync,
impl<DataProviderImpl> Unpin for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: Unpin,
impl<DataProviderImpl> UnwindSafe for AuthenticationProvider<DataProviderImpl>where
DataProviderImpl: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more