2021-03-01 17:24:11 +00:00
|
|
|
use crate::settings::structs::Settings;
|
2020-07-10 18:15:41 +00:00
|
|
|
use jsonwebtoken::{decode, encode, DecodingKey, EncodingKey, Header, TokenData, Validation};
|
|
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
|
|
|
|
type Jwt = String;
|
|
|
|
|
|
|
|
#[derive(Debug, Serialize, Deserialize)]
|
|
|
|
pub struct Claims {
|
2021-03-13 18:16:35 +00:00
|
|
|
/// User id, for backward compatibility with client apps.
|
|
|
|
/// Claim [sub](Claims::sub) is used in server-side checks.
|
2020-07-10 18:15:41 +00:00
|
|
|
pub id: i32,
|
2021-03-13 18:16:35 +00:00
|
|
|
/// User id, standard claim by RFC 7519.
|
|
|
|
pub sub: i32,
|
2020-07-10 18:15:41 +00:00
|
|
|
pub iss: String,
|
2021-03-13 18:16:35 +00:00
|
|
|
/// Time when this token was issued as UNIX-timestamp in seconds
|
|
|
|
pub iat: i64,
|
2020-07-10 18:15:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Claims {
|
|
|
|
pub fn decode(jwt: &str) -> Result<TokenData<Claims>, jsonwebtoken::errors::Error> {
|
|
|
|
let v = Validation {
|
|
|
|
validate_exp: false,
|
|
|
|
..Validation::default()
|
|
|
|
};
|
|
|
|
decode::<Claims>(
|
|
|
|
&jwt,
|
2021-03-01 17:24:11 +00:00
|
|
|
&DecodingKey::from_secret(Settings::get().jwt_secret().as_ref()),
|
2020-07-10 18:15:41 +00:00
|
|
|
&v,
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-02-09 18:26:06 +00:00
|
|
|
pub fn jwt(user_id: i32, hostname: String) -> Result<Jwt, jsonwebtoken::errors::Error> {
|
2020-07-10 18:15:41 +00:00
|
|
|
let my_claims = Claims {
|
2021-02-09 18:26:06 +00:00
|
|
|
id: user_id,
|
2021-03-13 18:16:35 +00:00
|
|
|
sub: user_id,
|
2020-07-10 18:15:41 +00:00
|
|
|
iss: hostname,
|
2021-03-13 18:16:35 +00:00
|
|
|
iat: chrono::Utc::now().timestamp_millis() / 1000,
|
2020-07-10 18:15:41 +00:00
|
|
|
};
|
|
|
|
encode(
|
|
|
|
&Header::default(),
|
|
|
|
&my_claims,
|
2021-03-01 17:24:11 +00:00
|
|
|
&EncodingKey::from_secret(Settings::get().jwt_secret().as_ref()),
|
2020-07-10 18:15:41 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
}
|