use log::{debug, error, trace};
use sqlx::{sqlite::SqliteRow, Column, Row, TypeInfo};
pub trait FromSqliteRow {
fn to_document(
&self,
fields: Option<Vec<&str>>,
) -> Result<bson::Document, async_graphql::Error>;
}
impl FromSqliteRow for SqliteRow {
fn to_document(
&self,
fields: Option<Vec<&str>>,
) -> Result<bson::Document, async_graphql::Error> {
debug!("Converting SqliteRow to Document");
let mut document = bson::Document::new();
for column in self.columns() {
let column_name = column.name();
trace!("Column: {}", column_name);
if let Some(fields) = &fields {
if !fields.contains(&column_name) {
trace!("Skipping column: {}", column_name);
continue;
}
}
let column_type = column.type_info().name();
trace!("Column type: {}", column_type);
match column_type {
"VARCHAR" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"CHAR" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"UUID" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"TEXT" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"DATETIME" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"TIMESTAMP" => {
let value: Option<&str> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"INT" => {
let value: Option<i64> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"INTEGER" => {
let value: Option<i64> = self.try_get(column_name)?;
document.insert(column_name, value);
}
"BOOL" => {
let value: Option<bool> = self.try_get(column_name)?;
document.insert(column_name, value);
}
_ => {
error!("Unsupported column type: {}", column_type);
return Err(async_graphql::Error::new(format!(
"Unsupported column type: {}",
column_type
)));
}
}
}
trace!("{:?}", document);
Ok(document)
}
}