authentik-client 3.2024122.1

Making authentication simple.
Documentation
/*
 * authentik
 *
 * Making authentication simple.
 *
 * The version of the OpenAPI document: 2024.12.2
 * Contact: hello@goauthentik.io
 * Generated by: https://openapi-generator.tech
 */

use crate::models;
use serde::{Deserialize, Serialize};

/// TokenModel : Serializer for BaseGrantModel and RefreshToken
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct TokenModel {
    #[serde(rename = "pk")]
    pub pk: i32,
    #[serde(rename = "provider")]
    pub provider: models::OAuth2Provider,
    #[serde(rename = "user")]
    pub user: models::User,
    /// Check if token is expired yet.
    #[serde(rename = "is_expired")]
    pub is_expired: bool,
    #[serde(
        rename = "expires",
        default,
        with = "::serde_with::rust::double_option",
        skip_serializing_if = "Option::is_none"
    )]
    pub expires: Option<Option<String>>,
    #[serde(rename = "scope")]
    pub scope: Vec<String>,
    /// Get the token's id_token as JSON String
    #[serde(rename = "id_token")]
    pub id_token: String,
    #[serde(rename = "revoked", skip_serializing_if = "Option::is_none")]
    pub revoked: Option<bool>,
}

impl TokenModel {
    /// Serializer for BaseGrantModel and RefreshToken
    pub fn new(
        pk: i32,
        provider: models::OAuth2Provider,
        user: models::User,
        is_expired: bool,
        scope: Vec<String>,
        id_token: String,
    ) -> TokenModel {
        TokenModel {
            pk,
            provider,
            user,
            is_expired,
            expires: None,
            scope,
            id_token,
            revoked: None,
        }
    }
}