mirror of
https://github.com/nitnelave/lldap.git
synced 2023-04-12 14:25:13 +00:00

The entire internals of the server now work using only NaiveDateTime, since we know they are all UTC. At the fringes (LDAP, GraphQL, JWT tokens) we convert back into UTC to make sure we have a clear API. This allows us to be compatible with Postgres (which doesn't support DateTime<UTC>, only NaiveDateTime). This change is backwards compatible since in SQlite with Sea-query/Sea-ORM, the UTC datetimes are stored without a timezone, as simple strings. It's the same format as NaiveDateTime. Fixes #87.
54 lines
1.4 KiB
Rust
54 lines
1.4 KiB
Rust
//! `SeaORM` Entity. Generated by sea-orm-codegen 0.10.3
|
|
|
|
use sea_orm::entity::prelude::*;
|
|
use serde::{Deserialize, Serialize};
|
|
|
|
use crate::domain::types::{GroupId, Uuid};
|
|
|
|
#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Serialize, Deserialize)]
|
|
#[sea_orm(table_name = "groups")]
|
|
pub struct Model {
|
|
#[sea_orm(primary_key, auto_increment = false)]
|
|
pub group_id: GroupId,
|
|
pub display_name: String,
|
|
pub creation_date: chrono::NaiveDateTime,
|
|
pub uuid: Uuid,
|
|
}
|
|
|
|
#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
|
|
pub enum Relation {
|
|
#[sea_orm(has_many = "super::memberships::Entity")]
|
|
Memberships,
|
|
}
|
|
|
|
impl Related<super::memberships::Entity> for Entity {
|
|
fn to() -> RelationDef {
|
|
Relation::Memberships.def()
|
|
}
|
|
}
|
|
|
|
impl ActiveModelBehavior for ActiveModel {}
|
|
|
|
impl From<Model> for crate::domain::types::Group {
|
|
fn from(group: Model) -> Self {
|
|
Self {
|
|
id: group.group_id,
|
|
display_name: group.display_name,
|
|
creation_date: group.creation_date,
|
|
uuid: group.uuid,
|
|
users: vec![],
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<Model> for crate::domain::types::GroupDetails {
|
|
fn from(group: Model) -> Self {
|
|
Self {
|
|
group_id: group.group_id,
|
|
display_name: group.display_name,
|
|
creation_date: group.creation_date,
|
|
uuid: group.uuid,
|
|
}
|
|
}
|
|
}
|