use crate::errors::{DynoxideError, Result};
use crate::partiql;
use crate::storage_backend::StorageBackend;
use crate::types::{AttributeValue, Item};
use serde::{Deserialize, Serialize};
#[derive(Debug, Default, Deserialize)]
pub struct ExecuteStatementRequest {
#[serde(rename = "Statement")]
pub statement: String,
#[serde(rename = "Parameters", default)]
pub parameters: Option<Vec<AttributeValue>>,
#[serde(rename = "Limit", default)]
pub limit: Option<usize>,
#[serde(rename = "NextToken", default)]
pub next_token: Option<String>,
#[serde(rename = "ConsistentRead", default)]
pub consistent_read: Option<bool>,
#[serde(rename = "ReturnConsumedCapacity", default)]
pub return_consumed_capacity: Option<String>,
}
#[derive(Debug, Default, Serialize)]
pub struct ExecuteStatementResponse {
#[serde(rename = "Items", skip_serializing_if = "Option::is_none")]
pub items: Option<Vec<Item>>,
#[serde(rename = "NextToken", skip_serializing_if = "Option::is_none")]
pub next_token: Option<String>,
#[serde(rename = "ConsumedCapacity", skip_serializing_if = "Option::is_none")]
pub consumed_capacity: Option<crate::types::ConsumedCapacity>,
}
pub async fn execute<S: StorageBackend>(
storage: &S,
request: ExecuteStatementRequest,
) -> Result<ExecuteStatementResponse> {
let stmt = partiql::parser::parse(&request.statement).map_err(|e| {
DynoxideError::ValidationException(format!("Statement wasn't well formed, got error: {e}"))
})?;
let params = request.parameters.unwrap_or_default();
let (items, size) =
partiql::executor::execute_measured(storage, &stmt, ¶ms, request.limit).await?;
let consumed_capacity = partiql::parser::table_name(&stmt).and_then(|table| {
let units = if matches!(stmt, partiql::parser::Statement::Select { .. }) {
crate::types::read_capacity_units_with_consistency(
size,
request.consistent_read.unwrap_or(false),
)
} else {
crate::types::write_capacity_units(size)
};
crate::types::consumed_capacity(table, units, &request.return_consumed_capacity)
});
Ok(ExecuteStatementResponse {
items,
next_token: None,
consumed_capacity,
})
}