use crate::models;
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct UserAssignedObjectPermission {
#[serde(rename = "pk")]
pub pk: i32,
#[serde(rename = "username")]
pub username: String,
#[serde(rename = "name")]
pub name: String,
#[serde(rename = "is_active", skip_serializing_if = "Option::is_none")]
pub is_active: Option<bool>,
#[serde(rename = "last_login", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub last_login: Option<Option<String>>,
#[serde(rename = "email", skip_serializing_if = "Option::is_none")]
pub email: Option<String>,
#[serde(rename = "attributes", skip_serializing_if = "Option::is_none")]
pub attributes: Option<std::collections::HashMap<String, serde_json::Value>>,
#[serde(rename = "uid")]
pub uid: String,
#[serde(rename = "permissions")]
pub permissions: Vec<models::UserObjectPermission>,
#[serde(rename = "is_superuser")]
pub is_superuser: bool,
}
impl UserAssignedObjectPermission {
pub fn new(pk: i32, username: String, name: String, uid: String, permissions: Vec<models::UserObjectPermission>, is_superuser: bool) -> UserAssignedObjectPermission {
UserAssignedObjectPermission {
pk,
username,
name,
is_active: None,
last_login: None,
email: None,
attributes: None,
uid,
permissions,
is_superuser,
}
}
}