parent
3a1294029e
commit
30953bc2a3
5 changed files with 14 additions and 7 deletions
|
@ -96,6 +96,7 @@ tikv = { version = "0.1.0", package = "tikv-client", optional = true }
|
||||||
tokio-stream = { version = "0.1.11", optional = true }
|
tokio-stream = { version = "0.1.11", optional = true }
|
||||||
tokio-util = { version = "0.7.4", optional = true, features = ["compat"] }
|
tokio-util = { version = "0.7.4", optional = true, features = ["compat"] }
|
||||||
trice = "0.2.0"
|
trice = "0.2.0"
|
||||||
|
ulid = { version = "1.0.0", features = ["serde"] }
|
||||||
url = "2.3.1"
|
url = "2.3.1"
|
||||||
|
|
||||||
[dependencies.js]
|
[dependencies.js]
|
||||||
|
@ -116,7 +117,6 @@ features = [
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
time = { version = "0.3.17", features = ["serde"] }
|
time = { version = "0.3.17", features = ["serde"] }
|
||||||
tokio = { version = "1.24.1", features = ["macros", "rt", "rt-multi-thread"] }
|
tokio = { version = "1.24.1", features = ["macros", "rt", "rt-multi-thread"] }
|
||||||
ulid = { version = "1.0.0", features = ["serde"] }
|
|
||||||
|
|
||||||
[target.'cfg(target_arch = "wasm32")'.dependencies]
|
[target.'cfg(target_arch = "wasm32")'.dependencies]
|
||||||
pharos = "0.5.3"
|
pharos = "0.5.3"
|
||||||
|
|
|
@ -162,6 +162,7 @@ pub fn synchronous(ctx: &Context<'_>, name: &str, args: Vec<Value>) -> Result<Va
|
||||||
"rand::int" => rand::int,
|
"rand::int" => rand::int,
|
||||||
"rand::string" => rand::string,
|
"rand::string" => rand::string,
|
||||||
"rand::time" => rand::time,
|
"rand::time" => rand::time,
|
||||||
|
"rand::ulid" => rand::ulid,
|
||||||
"rand::uuid::v4" => rand::uuid::v4,
|
"rand::uuid::v4" => rand::uuid::v4,
|
||||||
"rand::uuid::v7" => rand::uuid::v7,
|
"rand::uuid::v7" => rand::uuid::v7,
|
||||||
"rand::uuid" => rand::uuid,
|
"rand::uuid" => rand::uuid,
|
||||||
|
|
|
@ -7,6 +7,7 @@ use nanoid::nanoid;
|
||||||
use rand::distributions::{Alphanumeric, DistString};
|
use rand::distributions::{Alphanumeric, DistString};
|
||||||
use rand::prelude::IteratorRandom;
|
use rand::prelude::IteratorRandom;
|
||||||
use rand::Rng;
|
use rand::Rng;
|
||||||
|
use ulid::Ulid;
|
||||||
|
|
||||||
pub fn rand(_: ()) -> Result<Value, Error> {
|
pub fn rand(_: ()) -> Result<Value, Error> {
|
||||||
Ok(rand::random::<f64>().into())
|
Ok(rand::random::<f64>().into())
|
||||||
|
@ -120,6 +121,10 @@ pub fn time((range,): (Option<(i64, i64)>,)) -> Result<Value, Error> {
|
||||||
Ok(Datetime::from(i).into())
|
Ok(Datetime::from(i).into())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn ulid(_: ()) -> Result<Value, Error> {
|
||||||
|
Ok(Ulid::new().to_string().into())
|
||||||
|
}
|
||||||
|
|
||||||
pub fn uuid(_: ()) -> Result<Value, Error> {
|
pub fn uuid(_: ()) -> Result<Value, Error> {
|
||||||
Ok(Uuid::new().into())
|
Ok(Uuid::new().into())
|
||||||
}
|
}
|
||||||
|
|
|
@ -393,6 +393,7 @@ fn function_rand(i: &str) -> IResult<&str, &str> {
|
||||||
tag("rand::int"),
|
tag("rand::int"),
|
||||||
tag("rand::string"),
|
tag("rand::string"),
|
||||||
tag("rand::time"),
|
tag("rand::time"),
|
||||||
|
tag("rand::ulid"),
|
||||||
tag("rand::uuid::v4"),
|
tag("rand::uuid::v4"),
|
||||||
tag("rand::uuid::v7"),
|
tag("rand::uuid::v7"),
|
||||||
tag("rand::uuid"),
|
tag("rand::uuid"),
|
||||||
|
|
|
@ -155,12 +155,6 @@ impl From<Uuid> for Value {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl From<uuid::Uuid> for Value {
|
|
||||||
fn from(v: uuid::Uuid) -> Self {
|
|
||||||
Value::Uuid(Uuid(v))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<Param> for Value {
|
impl From<Param> for Value {
|
||||||
fn from(v: Param) -> Self {
|
fn from(v: Param) -> Self {
|
||||||
Value::Param(v)
|
Value::Param(v)
|
||||||
|
@ -401,6 +395,12 @@ impl From<Operation> for Value {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl From<uuid::Uuid> for Value {
|
||||||
|
fn from(v: uuid::Uuid) -> Self {
|
||||||
|
Value::Uuid(Uuid(v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl From<Vec<&str>> for Value {
|
impl From<Vec<&str>> for Value {
|
||||||
fn from(v: Vec<&str>) -> Self {
|
fn from(v: Vec<&str>) -> Self {
|
||||||
Value::Array(Array::from(v))
|
Value::Array(Array::from(v))
|
||||||
|
|
Loading…
Reference in a new issue