graphql-engine/v3/engine/Cargo.toml

71 lines
1.9 KiB
TOML
Raw Normal View History

[package]
name = "engine"
version.workspace = true
edition.workspace = true
license.workspace = true
build = "build.rs"
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
[[bin]]
name = "engine"
path = "bin/engine/main.rs"
[dependencies]
indexmap = { version = "2", features = ["serde"] }
thiserror = "1.0"
hasura-authn-core = { path = "../hasura-authn-core" }
lang-graphql = { path = "../lang-graphql" }
tracing-util = { path = "../tracing-util" }
ndc-client = { git = "https://github.com/hasura/ndc-spec.git", tag = "v0.1.0" }
open-dds = { path = "../open-dds" }
# util = { path = "../util" }
serde = "1.0.152"
serde_json = "1.0.92"
reqwest = { version = "^0.11", features = ["json", "multipart"] }
copy traces to stdout (#327) Outputs traces to stdout in addition to exporting via otlp. Stdout contains one JSON object per line, with a single span resource in each output line. This will make it quite a bit easier for me to get a quick look at what is going on in the engine during local development. The first commit makes the change using the existing opentelemetry crate versions. The second commit upgrades the opentelemetry dependencies. I thought I would include that just because I went to the trouble of figuring out how to do that upgrade. The JSON output is noisy, but can be formatted nicely with some shell functions. For example in nushell I use these functions to process the opentelemetry data coming via docker-compose or arion-compose log output: ```nu # Get log output from arion/docker-compose services with JSON parsing. If an # argument is given filters to logs from the given service def logs [ service?: string@docker_compose_services --file (-f): string = "./arion-compose.nix" # Use FILE instead of the default ./arion-compose.nix ] { let args = [$service] | compact let input = if ($file | path exists) { arion --file $file logs ...$args } else { docker-compose logs ...$args } $input | lines | parse -r '^(?<service>\S+)\s*\|\s*(?<log>.*)$' | where {|it| is_json $it.log} | update log {|it| $it.log | from json } | flatten } # Gets log output from a given docker-compose service, and extracts and formats # relevant opentelemetry data def otel [ service: string@docker_compose_services --file (-f): string = "./arion-compose.nix" # Use FILE instead of the default ./arion-compose.nix ] { logs $service -f $file | get resourceSpans | each {|it| $it.scopeSpans.0.spans.0 | select name attributes status } } # Helper to provide autocompletion for inputs to the logs command def docker_compose_services [] { let compose_file = if ("arion-compose.nix" | path exists) { arion cat | from json } else if ("docker-compose.yaml" | path exists) { open docker-compose.yaml } else { return [] } $compose_file | get services | columns } # Helper for the logs command def is_json [input: string] { ($input | from json | describe) =~ '^(record|table|list)' } ``` V3_GIT_ORIGIN_REV_ID: 38fd62f321a363a52b03d661b66d4dd49ac922de
2024-03-08 00:25:57 +03:00
opentelemetry = "0.21.0"
opentelemetry_sdk = "0.21.2"
schemars = { version = "0.8.12", features = ["smol_str"] }
async-trait = "0.1.67"
derive_more = "0.99.17"
base64 = "0.21.2"
transitive = "0.5.0"
lazy_static = "1.4.0"
strum = { version = "^0.25.0" }
strum_macros = { version = "^0.25.2" }
itertools = "0.10.5"
url = "2.4.1"
futures = "0.3.29"
# dependencies for authentication and execute
hasura-authn-webhook = { path = "../hasura-authn-webhook" }
hasura-authn-jwt = { path = "../hasura-authn-jwt" }
clap = { version = "4", features = ["derive", "env"] }
tokio = { version = "1.26.0", features = [
"macros",
"rt-multi-thread",
"signal",
"parking_lot",
] }
axum = { version = "0.6.20" }
tower-http = { version = "0.4", features = ["trace", "cors"] }
uuid = "1.3.0"
bincode = "1.3.3"
regex = "1.7.3"
json_value_merge = "2.0"
async-recursion= "1.0.5"
nonempty = "0.8"
# Dependencies to build and run build.rs file
[build-dependencies]
build-data = "0.1.5" # To set short commit-sha at build time
[dev-dependencies]
goldenfile = "1.4.5"
tokio-test = "0.4.2"
criterion = { version = "0.4", features = ["html_reports", "async_tokio"] }
[[bench]]
name = "execute"
harness = false