2022-05-30 15:32:26 +00:00
|
|
|
use crate::ctx::Context;
|
|
|
|
use crate::dbs::Options;
|
|
|
|
use crate::dbs::Statement;
|
2022-12-04 20:59:30 +00:00
|
|
|
use crate::dbs::Workable;
|
2022-05-30 15:32:26 +00:00
|
|
|
use crate::doc::Document;
|
|
|
|
use crate::err::Error;
|
|
|
|
use crate::sql::data::Data;
|
|
|
|
use crate::sql::operator::Operator;
|
|
|
|
use crate::sql::value::Value;
|
|
|
|
|
|
|
|
impl<'a> Document<'a> {
|
|
|
|
pub async fn alter(
|
|
|
|
&mut self,
|
|
|
|
ctx: &Context<'_>,
|
|
|
|
opt: &Options,
|
|
|
|
stm: &Statement<'_>,
|
|
|
|
) -> Result<(), Error> {
|
|
|
|
// Get the record id
|
|
|
|
let rid = self.id.as_ref().unwrap();
|
|
|
|
// Set default field values
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().def(rid);
|
2022-05-30 15:32:26 +00:00
|
|
|
// The statement has a data clause
|
|
|
|
if let Some(v) = stm.data() {
|
|
|
|
match v {
|
2022-12-04 20:59:30 +00:00
|
|
|
Data::PatchExpression(data) => {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let data = data.compute(¤t_ctx, opt).await?;
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().patch(data)?
|
2022-12-04 20:59:30 +00:00
|
|
|
}
|
|
|
|
Data::MergeExpression(data) => {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let data = data.compute(¤t_ctx, opt).await?;
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().merge(data)?
|
2022-12-04 20:59:30 +00:00
|
|
|
}
|
|
|
|
Data::ReplaceExpression(data) => {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let data = data.compute(¤t_ctx, opt).await?;
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().replace(data)?
|
2022-12-04 20:59:30 +00:00
|
|
|
}
|
|
|
|
Data::ContentExpression(data) => {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let data = data.compute(¤t_ctx, opt).await?;
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().replace(data)?
|
2022-12-04 20:59:30 +00:00
|
|
|
}
|
2022-05-30 15:32:26 +00:00
|
|
|
Data::SetExpression(x) => {
|
|
|
|
for x in x.iter() {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let v = x.2.compute(¤t_ctx, opt).await?;
|
2022-05-30 15:32:26 +00:00
|
|
|
match x.1 {
|
|
|
|
Operator::Equal => match v {
|
2023-06-19 18:41:13 +00:00
|
|
|
Value::None => self.current.to_mut().del(ctx, opt, &x.0).await?,
|
|
|
|
_ => self.current.to_mut().set(ctx, opt, &x.0, v).await?,
|
2022-05-30 15:32:26 +00:00
|
|
|
},
|
|
|
|
Operator::Inc => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().increment(ctx, opt, &x.0, v).await?
|
2022-05-30 15:32:26 +00:00
|
|
|
}
|
|
|
|
Operator::Dec => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().decrement(ctx, opt, &x.0, v).await?
|
2022-05-30 15:32:26 +00:00
|
|
|
}
|
2023-03-25 23:17:33 +00:00
|
|
|
Operator::Ext => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().extend(ctx, opt, &x.0, v).await?
|
2023-03-25 23:17:33 +00:00
|
|
|
}
|
2022-05-30 15:32:26 +00:00
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-05-18 08:04:40 +00:00
|
|
|
Data::UnsetExpression(i) => {
|
|
|
|
for i in i.iter() {
|
2023-06-20 11:48:20 +00:00
|
|
|
self.current.to_mut().del(ctx, opt, i).await?
|
2023-05-18 08:04:40 +00:00
|
|
|
}
|
|
|
|
}
|
2022-05-30 15:32:26 +00:00
|
|
|
Data::UpdateExpression(x) => {
|
2022-12-04 20:59:30 +00:00
|
|
|
// Duplicate context
|
|
|
|
let mut ctx = Context::new(ctx);
|
|
|
|
// Add insertable value
|
|
|
|
if let Workable::Insert(value) = &self.extras {
|
2023-05-06 20:49:34 +00:00
|
|
|
ctx.add_value("input", value);
|
2022-12-04 20:59:30 +00:00
|
|
|
}
|
|
|
|
// Process ON DUPLICATE KEY clause
|
2022-05-30 15:32:26 +00:00
|
|
|
for x in x.iter() {
|
2023-06-19 18:41:13 +00:00
|
|
|
let mut current_ctx = Context::new(&ctx);
|
|
|
|
current_ctx.add_cursor_doc(&self.current);
|
|
|
|
let v = x.2.compute(¤t_ctx, opt).await?;
|
2022-05-30 15:32:26 +00:00
|
|
|
match x.1 {
|
|
|
|
Operator::Equal => match v {
|
2023-06-19 18:41:13 +00:00
|
|
|
Value::None => self.current.to_mut().del(&ctx, opt, &x.0).await?,
|
|
|
|
_ => self.current.to_mut().set(&ctx, opt, &x.0, v).await?,
|
2022-05-30 15:32:26 +00:00
|
|
|
},
|
|
|
|
Operator::Inc => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().increment(&ctx, opt, &x.0, v).await?
|
2022-05-30 15:32:26 +00:00
|
|
|
}
|
|
|
|
Operator::Dec => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().decrement(&ctx, opt, &x.0, v).await?
|
2022-05-30 15:32:26 +00:00
|
|
|
}
|
2023-05-06 00:15:03 +00:00
|
|
|
Operator::Ext => {
|
2023-06-19 18:41:13 +00:00
|
|
|
self.current.to_mut().extend(&ctx, opt, &x.0, v).await?
|
2023-05-06 00:15:03 +00:00
|
|
|
}
|
2022-05-30 15:32:26 +00:00
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_ => unreachable!(),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
// Set default field values
|
2023-05-06 00:15:03 +00:00
|
|
|
self.current.to_mut().def(rid);
|
2022-05-30 15:32:26 +00:00
|
|
|
// Carry on
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|