2022-05-14 12:35:08 +00:00
|
|
|
use crate::ctx::Context;
|
2022-02-06 01:14:56 +00:00
|
|
|
use crate::dbs::Iterator;
|
|
|
|
use crate::dbs::Options;
|
2022-05-13 20:46:56 +00:00
|
|
|
use crate::dbs::Statement;
|
2022-02-15 01:00:30 +00:00
|
|
|
use crate::dbs::Transaction;
|
2022-02-06 01:14:56 +00:00
|
|
|
use crate::err::Error;
|
2022-03-07 18:11:44 +00:00
|
|
|
use crate::key::thing;
|
2022-02-06 01:14:56 +00:00
|
|
|
use crate::sql::array::Array;
|
2022-03-18 07:24:36 +00:00
|
|
|
use crate::sql::id::Id;
|
2022-02-06 01:14:56 +00:00
|
|
|
use crate::sql::model::Model;
|
2022-05-23 15:02:50 +00:00
|
|
|
use crate::sql::object::Object;
|
2022-02-06 01:14:56 +00:00
|
|
|
use crate::sql::table::Table;
|
|
|
|
use crate::sql::thing::Thing;
|
|
|
|
use crate::sql::value::Value;
|
|
|
|
use async_recursion::async_recursion;
|
|
|
|
|
|
|
|
impl Value {
|
2022-02-22 14:16:50 +00:00
|
|
|
#[cfg_attr(feature = "parallel", async_recursion)]
|
|
|
|
#[cfg_attr(not(feature = "parallel"), async_recursion(?Send))]
|
2022-05-01 22:25:53 +00:00
|
|
|
pub(crate) async fn iterate(
|
2022-02-06 01:14:56 +00:00
|
|
|
self,
|
2022-05-14 12:35:08 +00:00
|
|
|
ctx: &Context<'_>,
|
2022-02-06 21:06:52 +00:00
|
|
|
opt: &Options,
|
2022-02-15 03:33:16 +00:00
|
|
|
txn: &Transaction,
|
2022-05-13 20:46:56 +00:00
|
|
|
stm: &Statement<'_>,
|
2022-02-26 23:30:19 +00:00
|
|
|
ite: &mut Iterator,
|
2022-02-06 01:14:56 +00:00
|
|
|
) -> Result<(), Error> {
|
2022-02-25 22:42:14 +00:00
|
|
|
if ctx.is_ok() {
|
|
|
|
match self {
|
2022-05-23 15:02:50 +00:00
|
|
|
Value::Object(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
2022-05-13 20:46:56 +00:00
|
|
|
Value::Array(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Model(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Thing(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Table(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
v => ite.process(ctx, opt, txn, stm, None, v).await,
|
2022-02-25 22:42:14 +00:00
|
|
|
}
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Array {
|
2022-02-22 14:16:50 +00:00
|
|
|
#[cfg_attr(feature = "parallel", async_recursion)]
|
|
|
|
#[cfg_attr(not(feature = "parallel"), async_recursion(?Send))]
|
2022-05-01 22:25:53 +00:00
|
|
|
pub(crate) async fn iterate(
|
2022-02-06 01:14:56 +00:00
|
|
|
self,
|
2022-05-14 12:35:08 +00:00
|
|
|
ctx: &Context<'_>,
|
2022-02-06 21:06:52 +00:00
|
|
|
opt: &Options,
|
2022-02-15 03:33:16 +00:00
|
|
|
txn: &Transaction,
|
2022-05-13 20:46:56 +00:00
|
|
|
stm: &Statement<'_>,
|
2022-02-26 23:30:19 +00:00
|
|
|
ite: &mut Iterator,
|
2022-02-06 01:14:56 +00:00
|
|
|
) -> Result<(), Error> {
|
2022-05-04 16:14:40 +00:00
|
|
|
for v in self.into_iter() {
|
2022-02-25 22:42:14 +00:00
|
|
|
if ctx.is_ok() {
|
|
|
|
match v {
|
2022-05-23 15:02:50 +00:00
|
|
|
Value::Object(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
2022-05-13 20:46:56 +00:00
|
|
|
Value::Array(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Model(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Thing(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
Value::Table(v) => v.iterate(ctx, opt, txn, stm, ite).await?,
|
|
|
|
v => ite.process(ctx, opt, txn, stm, None, v).await,
|
2022-02-25 22:42:14 +00:00
|
|
|
}
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-05-23 15:02:50 +00:00
|
|
|
impl Object {
|
|
|
|
#[cfg_attr(feature = "parallel", async_recursion)]
|
|
|
|
#[cfg_attr(not(feature = "parallel"), async_recursion(?Send))]
|
|
|
|
pub(crate) async fn iterate(
|
|
|
|
self,
|
|
|
|
ctx: &Context<'_>,
|
|
|
|
opt: &Options,
|
|
|
|
txn: &Transaction,
|
|
|
|
stm: &Statement<'_>,
|
|
|
|
ite: &mut Iterator,
|
|
|
|
) -> Result<(), Error> {
|
|
|
|
if ctx.is_ok() {
|
|
|
|
if let Some(Value::Thing(id)) = self.get("id") {
|
|
|
|
id.clone().iterate(ctx, opt, txn, stm, ite).await?;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-02-06 01:14:56 +00:00
|
|
|
impl Model {
|
2022-05-01 22:25:53 +00:00
|
|
|
pub(crate) async fn iterate(
|
2022-02-06 01:14:56 +00:00
|
|
|
self,
|
2022-05-14 12:35:08 +00:00
|
|
|
ctx: &Context<'_>,
|
2022-02-06 21:06:52 +00:00
|
|
|
opt: &Options,
|
2022-02-15 03:33:16 +00:00
|
|
|
txn: &Transaction,
|
2022-05-13 20:46:56 +00:00
|
|
|
stm: &Statement<'_>,
|
2022-02-26 23:30:19 +00:00
|
|
|
ite: &mut Iterator,
|
2022-02-06 01:14:56 +00:00
|
|
|
) -> Result<(), Error> {
|
|
|
|
if ctx.is_ok() {
|
2022-05-06 16:02:44 +00:00
|
|
|
match self {
|
|
|
|
Model::Count(tb, c) => {
|
|
|
|
for _ in 0..c {
|
|
|
|
Thing {
|
|
|
|
tb: tb.to_string(),
|
|
|
|
id: Id::rand(),
|
|
|
|
}
|
2022-05-13 20:46:56 +00:00
|
|
|
.iterate(ctx, opt, txn, stm, ite)
|
2022-05-06 16:02:44 +00:00
|
|
|
.await?;
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
}
|
2022-05-06 16:02:44 +00:00
|
|
|
Model::Range(tb, b, e) => {
|
|
|
|
for x in b..=e {
|
|
|
|
Thing {
|
|
|
|
tb: tb.to_string(),
|
|
|
|
id: Id::from(x),
|
|
|
|
}
|
2022-05-13 20:46:56 +00:00
|
|
|
.iterate(ctx, opt, txn, stm, ite)
|
2022-05-06 16:02:44 +00:00
|
|
|
.await?;
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Thing {
|
2022-05-01 22:25:53 +00:00
|
|
|
pub(crate) async fn iterate(
|
2022-02-06 01:14:56 +00:00
|
|
|
self,
|
2022-05-14 12:35:08 +00:00
|
|
|
ctx: &Context<'_>,
|
2022-03-07 18:11:44 +00:00
|
|
|
opt: &Options,
|
|
|
|
txn: &Transaction,
|
2022-05-13 20:46:56 +00:00
|
|
|
stm: &Statement<'_>,
|
2022-03-07 18:11:44 +00:00
|
|
|
ite: &mut Iterator,
|
2022-02-06 01:14:56 +00:00
|
|
|
) -> Result<(), Error> {
|
2022-03-07 18:11:44 +00:00
|
|
|
if ctx.is_ok() {
|
|
|
|
let key = thing::new(opt.ns(), opt.db(), &self.tb, &self.id);
|
|
|
|
let val = txn.clone().lock().await.get(key).await?;
|
|
|
|
let val = match val {
|
|
|
|
Some(v) => Value::from(v),
|
|
|
|
None => Value::None,
|
|
|
|
};
|
2022-05-13 20:46:56 +00:00
|
|
|
ite.process(ctx, opt, txn, stm, Some(self), val).await;
|
2022-03-07 18:11:44 +00:00
|
|
|
}
|
2022-02-15 01:00:30 +00:00
|
|
|
Ok(())
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Table {
|
2022-05-01 22:25:53 +00:00
|
|
|
pub(crate) async fn iterate(
|
2022-02-06 01:14:56 +00:00
|
|
|
self,
|
2022-05-14 12:35:08 +00:00
|
|
|
ctx: &Context<'_>,
|
2022-03-07 18:11:44 +00:00
|
|
|
opt: &Options,
|
|
|
|
txn: &Transaction,
|
2022-05-13 20:46:56 +00:00
|
|
|
stm: &Statement<'_>,
|
2022-03-07 18:11:44 +00:00
|
|
|
ite: &mut Iterator,
|
2022-02-06 01:14:56 +00:00
|
|
|
) -> Result<(), Error> {
|
2022-03-07 18:11:44 +00:00
|
|
|
if ctx.is_ok() {
|
2022-05-04 21:59:37 +00:00
|
|
|
let beg = thing::prefix(opt.ns(), opt.db(), &self);
|
|
|
|
let end = thing::suffix(opt.ns(), opt.db(), &self);
|
2022-03-07 18:11:44 +00:00
|
|
|
let mut nxt: Option<Vec<u8>> = None;
|
|
|
|
loop {
|
|
|
|
if ctx.is_ok() {
|
|
|
|
let res = match nxt {
|
|
|
|
None => {
|
2022-03-18 07:21:22 +00:00
|
|
|
let min = beg.clone();
|
|
|
|
let max = end.clone();
|
2022-03-07 18:11:44 +00:00
|
|
|
txn.clone().lock().await.scan(min..max, 1000).await?
|
|
|
|
}
|
|
|
|
Some(ref mut beg) => {
|
2022-03-16 17:01:25 +00:00
|
|
|
beg.push(0x00);
|
2022-03-07 18:11:44 +00:00
|
|
|
let min = beg.clone();
|
2022-03-18 07:21:22 +00:00
|
|
|
let max = end.clone();
|
2022-03-07 18:11:44 +00:00
|
|
|
txn.clone().lock().await.scan(min..max, 1000).await?
|
|
|
|
}
|
|
|
|
};
|
|
|
|
if !res.is_empty() {
|
|
|
|
// Get total results
|
2022-03-21 13:48:59 +00:00
|
|
|
let n = res.len();
|
|
|
|
// Exit when settled
|
|
|
|
if n == 0 {
|
|
|
|
break;
|
|
|
|
}
|
2022-03-07 18:11:44 +00:00
|
|
|
// Loop over results
|
|
|
|
for (i, (k, v)) in res.into_iter().enumerate() {
|
|
|
|
if ctx.is_ok() {
|
|
|
|
// Ready the next
|
2022-03-21 13:48:59 +00:00
|
|
|
if n == i + 1 {
|
2022-03-07 18:11:44 +00:00
|
|
|
nxt = Some(k.clone());
|
|
|
|
}
|
|
|
|
// Parse the key-value
|
|
|
|
let k: crate::key::thing::Thing = (&k).into();
|
|
|
|
let v: crate::sql::value::Value = (&v).into();
|
|
|
|
let t = Thing::from((k.tb, k.id));
|
|
|
|
// Process the record
|
2022-05-13 20:46:56 +00:00
|
|
|
ite.process(ctx, opt, txn, stm, Some(t), v).await;
|
2022-03-07 18:11:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2022-02-15 01:00:30 +00:00
|
|
|
Ok(())
|
2022-02-06 01:14:56 +00:00
|
|
|
}
|
|
|
|
}
|