photoncloud-monorepo/chainfire/crates/chainfire-api/Cargo.toml
centra d2149b6249 fix(lightningstor): Fix SigV4 canonicalization for AWS S3 auth
- Replace form_urlencoded with RFC 3986 compliant URI encoding
- Implement aws_uri_encode() matching AWS SigV4 spec exactly
- Unreserved chars (A-Z,a-z,0-9,-,_,.,~) not encoded
- All other chars percent-encoded with uppercase hex
- Preserve slashes in paths, encode in query params
- Normalize empty paths to '/' per AWS spec
- Fix test expectations (body hash, HMAC values)
- Add comprehensive SigV4 signature determinism test

This fixes the canonicalization mismatch that caused signature
validation failures in T047. Auth can now be enabled for production.

Refs: T058.S1
2025-12-12 06:23:46 +09:00

47 lines
1.1 KiB
TOML

[package]
name = "chainfire-api"
version.workspace = true
edition.workspace = true
license.workspace = true
rust-version.workspace = true
description = "gRPC API layer for Chainfire distributed KVS"
[features]
default = ["custom-raft"]
openraft-impl = ["openraft"]
custom-raft = []
[dependencies]
chainfire-types = { workspace = true }
chainfire-storage = { workspace = true }
chainfire-raft = { workspace = true, default-features = false, features = ["custom-raft"] }
chainfire-watch = { workspace = true }
# gRPC
tonic = { workspace = true }
prost = { workspace = true }
prost-types = { workspace = true }
# Async
tokio = { workspace = true }
tokio-stream = { workspace = true }
futures = { workspace = true }
async-trait = { workspace = true }
# Raft (optional, only for openraft-impl feature)
openraft = { workspace = true, optional = true }
# Serialization
bincode = { workspace = true }
# Utilities
tracing = { workspace = true }
[build-dependencies]
tonic-build = { workspace = true }
[dev-dependencies]
tokio = { workspace = true, features = ["rt-multi-thread", "macros"] }
[lints]
workspace = true