1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
use core::fmt;
use crate::{
path::Path,
value::{StringOrRef, ValueOrRef},
};
/// The [DynamoDB `begins_with` function][1]. True if the attribute specified by
/// the [`Path`] begins with a particular substring.
///
/// [`BeginsWith`] can take a string or a reference to an extended attribute
/// value. Here's an example.
///
/// ```
/// use dynamodb_expression::{condition::BeginsWith, value::Ref, Path};
/// # use pretty_assertions::assert_eq;
///
/// let begins_with = BeginsWith::new(Path::new_name("foo"), "T");
/// assert_eq!(r#"begins_with(foo, "T")"#, begins_with.to_string());
///
/// let begins_with = BeginsWith::new(Path::new_name("foo"), Ref::new("prefix"));
/// assert_eq!(r#"begins_with(foo, :prefix)"#, begins_with.to_string());
/// ```
///
/// See also: [`Path::begins_with`], [`Key::begins_with`], [`Ref`]
///
/// [1]: https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.OperatorsAndFunctions.html#Expressions.OperatorsAndFunctions.Functions
/// [`Key::begins_with`]: crate::key::Key::begins_with
/// [`Ref`]: crate::value::Ref
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct BeginsWith {
// `Path` is correct here
// https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.OperatorsAndFunctions.html#Expressions.OperatorsAndFunctions.Syntax
pub(crate) path: Path,
pub(crate) substr: ValueOrRef,
}
impl BeginsWith {
pub fn new<P, S>(path: P, substr: S) -> Self
where
P: Into<Path>,
// Per the docs below, this can be a string or a reference to an expression attribute value.
//
// > True if the attribute specified by path begins with a particular substring.
// >
// > Example: Check whether the first few characters of the front view picture URL are http://.
// >
// > begins_with (Pictures.FrontView, :v_sub)
// >
// > The expression attribute value :v_sub is a placeholder for http://.
//
// Source: https://docs.aws.amazon.com/amazondynamodb/latest/developerguide/Expressions.OperatorsAndFunctions.html#Expressions.OperatorsAndFunctions.Functions
S: Into<StringOrRef>,
{
Self {
path: path.into(),
substr: substr.into().into(),
}
}
}
impl fmt::Display for BeginsWith {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
write!(f, "begins_with({}, {})", self.path, self.substr)
}
}
#[cfg(test)]
mod test {
use pretty_assertions::assert_eq;
use crate::{value::Ref, Path};
use super::BeginsWith;
#[test]
fn string() {
let begins_with = BeginsWith::new(Path::new_indexed_field("foo", 3), "foo");
assert_eq!(r#"begins_with(foo[3], "foo")"#, begins_with.to_string());
let begins_with = BeginsWith::new(Path::new_indexed_field("foo", 3), String::from("foo"));
assert_eq!(r#"begins_with(foo[3], "foo")"#, begins_with.to_string());
#[allow(clippy::needless_borrow)]
let begins_with = BeginsWith::new(Path::new_indexed_field("foo", 3), &String::from("foo"));
assert_eq!(r#"begins_with(foo[3], "foo")"#, begins_with.to_string());
#[allow(clippy::needless_borrow)]
let begins_with = BeginsWith::new(Path::new_indexed_field("foo", 3), &"foo");
assert_eq!(r#"begins_with(foo[3], "foo")"#, begins_with.to_string());
}
#[test]
fn value_ref() {
let begins_with = BeginsWith::new(Path::new_indexed_field("foo", 3), Ref::from("prefix"));
assert_eq!("begins_with(foo[3], :prefix)", begins_with.to_string());
}
}