[package]
edition = "2024"
name = "prestige"
version = "0.3.4"
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Prestige file reading and writing utilities and tools"
homepage = "https://github.com/jeffgrunewald/prestige"
readme = "README.md"
keywords = [
"s3",
"parquet",
"sink",
"streaming",
"iceberg",
]
categories = [
"asynchronous",
"encoding",
"filesystem",
]
license = "MIT OR Apache-2.0"
repository = "https://github.com/jeffgrunewald/prestige"
[features]
decimal = ["dep:rust_decimal"]
default = []
iceberg = [
"dep:iceberg",
"dep:iceberg-catalog-rest",
"dep:reqwest",
"dep:uuid",
"prestige-macros/iceberg",
]
iceberg-sql-catalog = [
"iceberg",
"dep:iceberg-catalog-sql",
]
iceberg-test-harness = ["iceberg"]
metrics = ["dep:metrics"]
opentelemetry = ["dep:opentelemetry"]
sqlx = ["dep:sqlx"]
sqlx-postgres = ["sqlx/postgres"]
[lib]
name = "prestige"
path = "src/lib.rs"
[[test]]
name = "iceberg_harness"
path = "tests/iceberg_harness.rs"
[[test]]
name = "iceberg_integration"
path = "tests/iceberg_integration.rs"
[[test]]
name = "roundtrip"
path = "tests/roundtrip.rs"
[dependencies.arrow]
version = "57"
features = ["ipc"]
[dependencies.arrow-row]
version = "57"
[dependencies.arrow-select]
version = "57"
[dependencies.async-trait]
version = "0"
[dependencies.aws-config]
version = "1"
features = [
"default-https-client",
"rt-tokio",
"credentials-process",
"sso",
]
default-features = false
[dependencies.aws-sdk-s3]
version = "1"
features = [
"sigv4a",
"default-https-client",
"rt-tokio",
]
default-features = false
[dependencies.aws-smithy-types-convert]
version = "0"
features = ["convert-streams"]
[dependencies.bytes]
version = "1"
[dependencies.chrono]
version = "0"
features = ["serde"]
[dependencies.config]
version = "0"
features = ["toml"]
default-features = false
[dependencies.derive_builder]
version = "0.20"
[dependencies.futures]
version = "0"
[dependencies.futures-util]
version = "0"
[dependencies.iceberg]
version = "0.8"
optional = true
[dependencies.iceberg-catalog-rest]
version = "0.8"
optional = true
[dependencies.iceberg-catalog-sql]
version = "0.8"
optional = true
[dependencies.metrics]
version = "0.24"
optional = true
[dependencies.opentelemetry]
version = "0.31"
features = ["metrics"]
optional = true
default-features = false
[dependencies.parquet]
version = "57"
features = ["async"]
[dependencies.prestige-macros]
version = "0.3.4"
[dependencies.regex]
version = "1"
[dependencies.reqwest]
version = "0.12"
features = ["json"]
optional = true
[dependencies.retainer]
version = "0.3"
[dependencies.rust_decimal]
version = "1"
features = ["serde"]
optional = true
[dependencies.serde]
version = "1"
features = ["derive"]
[dependencies.serde_arrow]
version = "0.14"
features = ["arrow-57"]
[dependencies.serde_bytes]
version = "0"
[dependencies.serde_json]
version = "1"
[dependencies.sha2]
version = "0"
[dependencies.sqlx]
version = "0"
features = [
"postgres",
"uuid",
"chrono",
"macros",
"runtime-tokio-rustls",
]
optional = true
[dependencies.super-visor]
version = "0"
[dependencies.tempfile]
version = "3"
[dependencies.thiserror]
version = "1"
[dependencies.tokio]
version = "1"
features = [
"fs",
"macros",
"rt-multi-thread",
]
default-features = false
[dependencies.tokio-stream]
version = "0"
[dependencies.tracing]
version = "0"
[dependencies.uuid]
version = "1"
features = [
"v4",
"v7",
]
optional = true
[dependencies.xxhash-rust]
version = "0.8"
features = ["xxh3"]
[dev-dependencies.futures]
version = "0"
[dev-dependencies.tempfile]
version = "3"
[dev-dependencies.tokio-util]
version = "0"
[dev-dependencies.uuid]
version = "1"
features = ["v4"]