sylvia_iot_auth/models/
refresh_token.rs

1//! Traits and structs for refresh tokens.
2
3use std::error::Error as StdError;
4
5use async_trait::async_trait;
6use chrono::{DateTime, Utc};
7
8/// The item content.
9#[derive(Debug, PartialEq)]
10pub struct RefreshToken {
11    pub refresh_token: String,
12    pub expires_at: DateTime<Utc>,
13    pub scope: Option<String>,
14    pub client_id: String,
15    pub redirect_uri: String,
16    pub user_id: String,
17}
18
19/// The query condition to get item(s).
20#[derive(Default)]
21pub struct QueryCond<'a> {
22    pub refresh_token: Option<&'a str>,
23    pub client_id: Option<&'a str>,
24    pub user_id: Option<&'a str>,
25}
26
27/// Model operations.
28#[async_trait]
29pub trait RefreshTokenModel: Sync {
30    /// To create and initialize the table/collection.
31    async fn init(&self) -> Result<(), Box<dyn StdError>>;
32
33    /// To get an item.
34    async fn get(&self, refresh_token: &str) -> Result<Option<RefreshToken>, Box<dyn StdError>>;
35
36    /// To add an item.
37    async fn add(&self, token: &RefreshToken) -> Result<(), Box<dyn StdError>>;
38
39    /// To delete one or more items.
40    async fn del(&self, cond: &QueryCond) -> Result<(), Box<dyn StdError>>;
41}
42
43/// The expiration time of the refresh token in seconds.
44pub const EXPIRES: i64 = 14 * 86400;