use crate::DbElement;
use crate::DbError;
use crate::DbImpl;
use crate::DbValue;
use crate::Query;
use crate::QueryIds;
use crate::QueryResult;
use crate::SearchQuery;
use crate::StorageData;
use crate::query_builder::search::SearchQueryBuilder;
#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
#[cfg_attr(feature = "openapi", derive(utoipa::ToSchema))]
#[cfg_attr(feature = "derive", derive(agdb::DbSerialize))]
#[cfg_attr(feature = "api", derive(agdb::TypeDefImpl))]
#[derive(Clone, Debug, PartialEq)]
pub struct SelectKeysQuery(pub QueryIds);
impl Query for SelectKeysQuery {
fn process<Store: StorageData>(&self, db: &DbImpl<Store>) -> Result<QueryResult, DbError> {
let mut result = QueryResult::default();
let db_ids = match &self.0 {
QueryIds::Ids(ids) => {
let mut db_ids = Vec::with_capacity(ids.len());
for query_id in ids {
db_ids.push(db.db_id(query_id)?);
}
db_ids
}
QueryIds::Search(search_query) => search_query.search(db)?,
};
result.elements.reserve(db_ids.len());
result.result = db_ids.len() as i64;
for id in db_ids {
result.elements.push(DbElement {
id,
from: db.from_id(id),
to: db.to_id(id),
values: db
.keys(id)?
.into_iter()
.map(|k| (k, DbValue::default()).into())
.collect(),
});
}
Ok(result)
}
}
impl Query for &SelectKeysQuery {
fn process<Store: StorageData>(&self, db: &DbImpl<Store>) -> Result<QueryResult, DbError> {
(*self).process(db)
}
}
impl SearchQueryBuilder for SelectKeysQuery {
fn search_mut(&mut self) -> &mut SearchQuery {
if let QueryIds::Search(search) = &mut self.0 {
search
} else {
panic!("Expected search query");
}
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
#[should_panic]
fn missing_search() {
SelectKeysQuery(QueryIds::Ids(vec![])).search_mut();
}
}