dynoxide/actions/
execute_statement.rs1use crate::errors::{DynoxideError, Result};
2use crate::partiql;
3use crate::storage_backend::StorageBackend;
4use crate::types::{AttributeValue, Item};
5use serde::{Deserialize, Serialize};
6
7#[derive(Debug, Default, Deserialize)]
8pub struct ExecuteStatementRequest {
9 #[serde(rename = "Statement")]
10 pub statement: String,
11 #[serde(rename = "Parameters", default)]
12 pub parameters: Option<Vec<AttributeValue>>,
13 #[serde(rename = "Limit", default)]
14 pub limit: Option<usize>,
15 #[serde(rename = "NextToken", default)]
16 pub next_token: Option<String>,
17 #[serde(rename = "ConsistentRead", default)]
20 pub consistent_read: Option<bool>,
21 #[serde(rename = "ReturnConsumedCapacity", default)]
22 pub return_consumed_capacity: Option<String>,
23}
24
25#[derive(Debug, Default, Serialize)]
26pub struct ExecuteStatementResponse {
27 #[serde(rename = "Items", skip_serializing_if = "Option::is_none")]
28 pub items: Option<Vec<Item>>,
29 #[serde(rename = "NextToken", skip_serializing_if = "Option::is_none")]
30 pub next_token: Option<String>,
31 #[serde(rename = "ConsumedCapacity", skip_serializing_if = "Option::is_none")]
32 pub consumed_capacity: Option<crate::types::ConsumedCapacity>,
33}
34
35pub async fn execute<S: StorageBackend>(
36 storage: &S,
37 request: ExecuteStatementRequest,
38) -> Result<ExecuteStatementResponse> {
39 let stmt = partiql::parser::parse(&request.statement).map_err(|e| {
40 DynoxideError::ValidationException(format!("Statement wasn't well formed, got error: {e}"))
41 })?;
42
43 let params = request.parameters.unwrap_or_default();
44 let (items, size) =
45 partiql::executor::execute_measured(storage, &stmt, ¶ms, request.limit).await?;
46
47 let consumed_capacity = partiql::parser::table_name(&stmt).and_then(|table| {
53 let units = if matches!(stmt, partiql::parser::Statement::Select { .. }) {
54 crate::types::read_capacity_units_with_consistency(
55 size,
56 request.consistent_read.unwrap_or(false),
57 )
58 } else {
59 crate::types::write_capacity_units(size)
60 };
61 crate::types::consumed_capacity(table, units, &request.return_consumed_capacity)
62 });
63
64 Ok(ExecuteStatementResponse {
65 items,
66 next_token: None,
67 consumed_capacity,
68 })
69}