oops forgot to actually check the token
This commit is contained in:
parent
9ee43b85ef
commit
3079bc40a7
2 changed files with 18 additions and 3 deletions
|
@ -69,10 +69,13 @@ impl UserAuthenticator {
|
||||||
) -> Result<(), AuthenticationError> {
|
) -> Result<(), AuthenticationError> {
|
||||||
let mut db = self.db.lock().await;
|
let mut db = self.db.lock().await;
|
||||||
|
|
||||||
match db.get_token(username).await? {
|
if let Some(user_token) = db.get_token(username).await? {
|
||||||
Some(_) => Ok(()),
|
if token == &user_token {
|
||||||
None => Err(AuthenticationError::InvalidToken),
|
return Ok(());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Err(AuthenticationError::InvalidToken)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,12 @@ impl From<String> for Password {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl PartialEq for Password {
|
||||||
|
fn eq(&self, other: &Self) -> bool {
|
||||||
|
self.0.expose_secret() == other.0.expose_secret()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Deserialize)]
|
#[derive(Debug, Clone, Deserialize)]
|
||||||
pub struct UserToken(pub SecretString);
|
pub struct UserToken(pub SecretString);
|
||||||
impl From<String> for UserToken {
|
impl From<String> for UserToken {
|
||||||
|
@ -19,6 +25,12 @@ impl From<String> for UserToken {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl PartialEq for UserToken {
|
||||||
|
fn eq(&self, other: &Self) -> bool {
|
||||||
|
self.0.expose_secret() == other.0.expose_secret()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Deserialize)]
|
#[derive(Debug, Clone, Deserialize)]
|
||||||
pub struct UserServerKey(pub SecretString);
|
pub struct UserServerKey(pub SecretString);
|
||||||
impl From<String> for UserServerKey {
|
impl From<String> for UserServerKey {
|
||||||
|
|
Loading…
Reference in a new issue