[package]
edition = "2021"
name = "chewdata"
version = "3.6.1"
authors = ["Jean-Marc Fiaschi <jm.fiaschi@gmail.com>"]
build = false
include = [
"src/*",
"LICENSE-APACHE",
"LICENSE-MIT",
"README.md",
]
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Extract Transform and Load data"
homepage = "https://www.chewdata.org"
readme = "README.md"
categories = [
"encoding",
"network-programming",
"data-structures",
]
license = "MIT OR Apache-2.0"
repository = "https://github.com/jmfiaschi/chewdata"
[package.metadata.docs.rs]
all-features = true
rustdoc-args = [
"--cfg",
"docs_rs",
]
[features]
apm = [
"dep:opentelemetry",
"dep:opentelemetry-jaeger",
]
bucket = [
"dep:aws-sdk-s3",
"dep:aws-config",
"dep:async-compat",
]
csv = ["dep:csv"]
curl = [
"dep:bytes",
"dep:hyper",
"dep:smol-hyper",
"dep:jsonwebtoken",
"dep:http-body-util",
"dep:http",
"dep:http-cache-semantics",
"dep:cacache",
"dep:webpki-roots",
"dep:rustls",
"dep:futures-rustls",
"http-serde",
"rand",
]
default = ["log-release"]
log-release = ["tracing/release_max_level_info"]
log-release-trace = ["tracing/release_max_level_trace"]
mongodb = [
"dep:mongodb",
"dep:async-compat",
]
ordered = [
"serde_json/preserve_order",
"toml/preserve_order",
]
parquet = [
"dep:parquet",
"dep:byteorder",
"dep:arrow-json",
"dep:bytes",
"dep:arrow-integration-test",
]
psql = [
"sqlx",
"sqlx/postgres",
]
toml = ["dep:toml"]
xml = ["dep:quick-xml"]
[lib]
name = "chewdata"
path = "src/lib.rs"
[[bin]]
name = "chewdata"
path = "src/main.rs"
[dependencies.anyhow]
version = "1.0.100"
default-features = false
[dependencies.arrow-integration-test]
version = "57.2.0"
optional = true
default-features = false
[dependencies.arrow-json]
version = "57.2.0"
optional = true
default-features = false
[dependencies.async-channel]
version = "2.5.0"
default-features = false
[dependencies.async-compat]
version = "0.2.5"
optional = true
default-features = false
[dependencies.async-fs]
version = "2.2.0"
[dependencies.async-lock]
version = "3.4.2"
[dependencies.async-process]
version = "2.5.0"
default-features = false
[dependencies.async-stream]
version = "0.3.6"
default-features = false
[dependencies.async-task]
version = "4.7.1"
[dependencies.async-trait]
version = "0.1.89"
default-features = false
[dependencies.aws-config]
version = "1.8.12"
optional = true
[dependencies.aws-sdk-s3]
version = "1.120.0"
features = [
"sigv4a",
"rustls",
"rt-tokio",
"behavior-version-latest",
]
optional = true
default-features = false
[dependencies.base16ct]
version = "1.0.0"
features = ["alloc"]
default-features = false
[dependencies.base64]
version = "0.22.1"
features = ["std"]
default-features = false
[dependencies.byteorder]
version = "1.5.0"
features = ["std"]
optional = true
default-features = false
[dependencies.bytes]
version = "1.11.0"
features = ["std"]
optional = true
default-features = false
[dependencies.cacache]
version = "13.1.0"
features = ["async-std"]
optional = true
default-features = false
[dependencies.chrono]
version = "0.4.43"
features = [
"std",
"clock",
]
default-features = false
[dependencies.clap]
version = "4.5.54"
[dependencies.csv]
version = "1.4.0"
optional = true
default-features = false
[dependencies.dashmap]
version = "6.1.0"
default-features = false
[dependencies.deser-hjson]
version = "2.2.5"
default-features = false
[dependencies.env_applier]
version = "1.1.2"
default-features = false
[dependencies.fake]
version = "4.4.0"
features = ["random_color"]
default-features = false
[dependencies.futures]
version = "0.3.31"
features = [
"std",
"async-await",
"executor",
]
default-features = false
[dependencies.futures-rustls]
version = "0.26.0"
optional = true
default-features = false
[dependencies.glob]
version = "0.3.3"
default-features = false
[dependencies.http]
version = "1.4.0"
optional = true
[dependencies.http-body-util]
version = "0.1.3"
optional = true
default-features = false
[dependencies.http-cache-semantics]
version = "2.1.0"
optional = true
default-features = false
[dependencies.http-serde]
version = "2.1.1"
optional = true
[dependencies.hyper]
version = "1.8.1"
features = [
"http1",
"client",
"http2",
]
optional = true
default-features = false
[dependencies.json_value_merge]
version = "2.0.1"
default-features = false
[dependencies.json_value_remove]
version = "1.1.0"
default-features = false
[dependencies.json_value_resolve]
version = "1.1.0"
default-features = false
[dependencies.json_value_search]
version = "1.1.0"
default-features = false
[dependencies.jsonwebtoken]
version = "10.3.0"
features = [
"use_pem",
"rust_crypto",
]
optional = true
default-features = false
[dependencies.macro_rules_attribute]
version = "0.2.2"
default-features = false
[dependencies.mime]
version = "0.3.17"
default-features = false
[dependencies.mongodb]
version = "3.5.0"
optional = true
[dependencies.opentelemetry]
version = "0.21"
features = ["trace"]
optional = true
default-features = false
[dependencies.opentelemetry-jaeger]
version = "0.20"
features = ["rt-async-std"]
optional = true
default-features = false
[dependencies.parquet]
version = "57.2.0"
features = [
"cli",
"arrow",
"flate2-rust_backened",
"brotli",
"lz4",
"zstd",
"snap",
]
optional = true
default-features = false
[dependencies.quick-xml]
version = "0.39.0"
features = ["serialize"]
optional = true
default-features = false
[dependencies.rand]
version = "0.9.2"
features = [
"std_rng",
"thread_rng",
]
optional = true
default-features = false
[dependencies.regex]
version = "1.12.2"
[dependencies.rustls]
version = "0.23.36"
features = [
"log",
"std",
"ring",
]
optional = true
default-features = false
[dependencies.serde]
version = "1.0.228"
features = ["derive"]
default-features = false
[dependencies.serde-with-expand-env]
version = "1.1.0"
default-features = false
[dependencies.serde_json]
version = "1.0.148"
features = ["std"]
default-features = false
[dependencies.serde_yaml]
version = "0.9.33"
default-features = false
[dependencies.sha2]
version = "0.10.9"
features = [
"oid",
"std",
]
default-features = false
[dependencies.sha3]
version = "0.10.8"
features = [
"oid",
"std",
]
default-features = false
[dependencies.smol]
version = "2.0.2"
[dependencies.smol-hyper]
version = "0.1.1"
features = ["smol"]
optional = true
default-features = false
[dependencies.smol-macros]
version = "0.1.1"
[dependencies.smol-timeout]
version = "0.6.1"
[dependencies.sqlx]
version = "0.8.6"
features = [
"runtime-async-std-rustls",
"_unstable-all-types",
]
optional = true
default-features = false
[dependencies.tera]
version = "1.20.1"
features = ["builtins"]
default-features = false
[dependencies.toml]
version = "0.9.8"
features = [
"parse",
"display",
"serde",
]
optional = true
default-features = false
[dependencies.tracing]
version = "0.1.44"
features = [
"std",
"attributes",
]
default-features = false
[dependencies.tracing-appender]
version = "0.2.4"
default-features = false
[dependencies.tracing-opentelemetry]
version = "0.22"
features = ["tracing-log"]
default-features = false
[dependencies.tracing-subscriber]
version = "0.3.22"
features = [
"std",
"fmt",
"env-filter",
"tracing-log",
"json",
"ansi",
]
default-features = false
[dependencies.uuid]
version = "1.19.0"
features = [
"std",
"v4",
]
[dependencies.version]
version = "3.0"
default-features = false
[dependencies.webpki-roots]
version = "1.0.5"
optional = true
[dev-dependencies.criterion]
version = "0.8.1"
features = [
"default",
"csv_output",
"html_reports",
"async_futures",
"async_smol",
]
default-features = false
[profile.release]
lto = true