2023-06-12 02:04:35 -06:00
|
|
|
use ::sqlx::{FromRow, Result};
|
2023-07-14 13:44:08 -06:00
|
|
|
use atuin_common::record::{EncryptedData, Record};
|
2023-06-12 02:04:35 -06:00
|
|
|
use atuin_server_database::models::{History, Session, User};
|
|
|
|
use sqlx::{postgres::PgRow, Row};
|
2023-09-28 19:56:40 -06:00
|
|
|
use time::PrimitiveDateTime;
|
2023-06-12 02:04:35 -06:00
|
|
|
|
|
|
|
pub struct DbUser(pub User);
|
|
|
|
pub struct DbSession(pub Session);
|
|
|
|
pub struct DbHistory(pub History);
|
2023-07-14 13:44:08 -06:00
|
|
|
pub struct DbRecord(pub Record<EncryptedData>);
|
2023-06-12 02:04:35 -06:00
|
|
|
|
|
|
|
impl<'a> FromRow<'a, PgRow> for DbUser {
|
|
|
|
fn from_row(row: &'a PgRow) -> Result<Self> {
|
|
|
|
Ok(Self(User {
|
|
|
|
id: row.try_get("id")?,
|
|
|
|
username: row.try_get("username")?,
|
|
|
|
email: row.try_get("email")?,
|
|
|
|
password: row.try_get("password")?,
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> ::sqlx::FromRow<'a, PgRow> for DbSession {
|
|
|
|
fn from_row(row: &'a PgRow) -> ::sqlx::Result<Self> {
|
|
|
|
Ok(Self(Session {
|
|
|
|
id: row.try_get("id")?,
|
|
|
|
user_id: row.try_get("user_id")?,
|
|
|
|
token: row.try_get("token")?,
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> ::sqlx::FromRow<'a, PgRow> for DbHistory {
|
|
|
|
fn from_row(row: &'a PgRow) -> ::sqlx::Result<Self> {
|
|
|
|
Ok(Self(History {
|
|
|
|
id: row.try_get("id")?,
|
|
|
|
client_id: row.try_get("client_id")?,
|
|
|
|
user_id: row.try_get("user_id")?,
|
|
|
|
hostname: row.try_get("hostname")?,
|
2023-09-28 19:56:40 -06:00
|
|
|
timestamp: row
|
|
|
|
.try_get::<PrimitiveDateTime, _>("timestamp")?
|
|
|
|
.assume_utc(),
|
2023-06-12 02:04:35 -06:00
|
|
|
data: row.try_get("data")?,
|
2023-09-28 19:56:40 -06:00
|
|
|
created_at: row
|
|
|
|
.try_get::<PrimitiveDateTime, _>("created_at")?
|
|
|
|
.assume_utc(),
|
2023-06-12 02:04:35 -06:00
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
2023-07-14 13:44:08 -06:00
|
|
|
|
|
|
|
impl<'a> ::sqlx::FromRow<'a, PgRow> for DbRecord {
|
|
|
|
fn from_row(row: &'a PgRow) -> ::sqlx::Result<Self> {
|
|
|
|
let timestamp: i64 = row.try_get("timestamp")?;
|
|
|
|
|
|
|
|
let data = EncryptedData {
|
|
|
|
data: row.try_get("data")?,
|
|
|
|
content_encryption_key: row.try_get("cek")?,
|
|
|
|
};
|
|
|
|
|
|
|
|
Ok(Self(Record {
|
|
|
|
id: row.try_get("client_id")?,
|
|
|
|
host: row.try_get("host")?,
|
|
|
|
parent: row.try_get("parent")?,
|
|
|
|
timestamp: timestamp as u64,
|
|
|
|
version: row.try_get("version")?,
|
|
|
|
tag: row.try_get("tag")?,
|
|
|
|
data,
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<DbRecord> for Record<EncryptedData> {
|
|
|
|
fn from(other: DbRecord) -> Record<EncryptedData> {
|
|
|
|
Record { ..other.0 }
|
|
|
|
}
|
|
|
|
}
|