zeroize: Allow versions newer than 1.3 for `aes-gcm-siv` (#33618)
`aes-gcm-siv` v0.10.3 has a constraints on maximum `zeroize` version, set to be 1.3 or below. At the same time, `cargo` does not want to construct a dependency graph with duplicate instances of a crate, when the first non-zero version of those instances are the same. That is, it refuses to build a workspace with both 1.3 and 1.4 versions of `zeroize`. `zeroize` is actually backward compatible, and `aes-gcm-siv` restriction is overly pessimistic. This package lifted this restriction in a newer versions, but we still depend on older versions and can not immediately update. In order to be able to use a version of `zeroize` newer than 1.3 we need to remove a similar restriction from `curve25519-dalek` as well.
This commit is contained in:
parent
6fd0dcb3eb
commit
01f1bf2799
|
@ -51,8 +51,7 @@ dependencies = [
|
|||
[[package]]
|
||||
name = "aes-gcm-siv"
|
||||
version = "0.10.3"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "589c637f0e68c877bbd59a4599bbe849cac8e5f3e4b5a3ebae8f528cd218dcdc"
|
||||
source = "git+https://github.com/RustCrypto/AEADs?rev=6105d7a5591aefa646a95d12b5e8d3f55a9214ef#6105d7a5591aefa646a95d12b5e8d3f55a9214ef"
|
||||
dependencies = [
|
||||
"aead",
|
||||
"aes",
|
||||
|
|
41
Cargo.toml
41
Cargo.toml
|
@ -418,6 +418,7 @@ wasm-bindgen = "0.2"
|
|||
winapi = "0.3.8"
|
||||
winreg = "0.50"
|
||||
x509-parser = "0.14.0"
|
||||
# See "zeroize versioning issues" below if you are updating this version.
|
||||
zeroize = { version = "1.3", default-features = false }
|
||||
zstd = "0.11.2"
|
||||
|
||||
|
@ -450,3 +451,43 @@ crossbeam-epoch = { git = "https://github.com/solana-labs/crossbeam", rev = "fd2
|
|||
# overrides in sync.
|
||||
solana-program = { path = "sdk/program" }
|
||||
solana-zk-token-sdk = { path = "zk-token-sdk" }
|
||||
#
|
||||
# === zeroize versioning issues ===
|
||||
#
|
||||
# A number of packages used explicit upper bound on the `zeroize` package, such
|
||||
# as `>=1, <1.4`. The problem is that cargo still does not duplicate `zeroize`
|
||||
# if a newer version is available and requested by another package and just
|
||||
# fails the whole dependency resolution process.
|
||||
#
|
||||
# This is described in
|
||||
#
|
||||
# https://doc.rust-lang.org/cargo/reference/specifying-dependencies.html#multiple-requirements
|
||||
#
|
||||
# So we have to patch `zeroize` dependency specifications in the projects that
|
||||
# introduce these constraints. They have already removed these constraints in
|
||||
# newer versions, but we have not updated yet. As we update, we need to remove
|
||||
# these patch requests.
|
||||
#
|
||||
# When our dependencies are upgraded, we can remove this patches. Before that
|
||||
# we might need to maintain these patches in sync with our full dependency
|
||||
# tree.
|
||||
|
||||
# Our dependency tree has `aes-gcm-siv` v0.10.3 and the `zeroize` restriction
|
||||
# was removed in the next commit just after the release. So it seems safe to
|
||||
# patch to this commit.
|
||||
#
|
||||
# `aes-gcm-siv` v0.10.3 release:
|
||||
#
|
||||
# https://github.com/RustCrypto/AEADs/releases/tag/aes-gcm-siv-v0.10.3
|
||||
#
|
||||
# Corresponds to commit
|
||||
#
|
||||
# https://github.com/RustCrypto/AEADs/commit/6f16f4577a1fc839a2346cf8c5531c85a44bf5c0
|
||||
#
|
||||
# Comparison with `6105d7a5591aefa646a95d12b5e8d3f55a9214ef` pinned here:
|
||||
#
|
||||
# https://github.com/RustCrypto/AEADs/compare/aes-gcm-siv-v0.10.3..6105d7a5591aefa646a95d12b5e8d3f55a9214ef
|
||||
#
|
||||
[patch.crates-io.aes-gcm-siv]
|
||||
git = "https://github.com/RustCrypto/AEADs"
|
||||
rev = "6105d7a5591aefa646a95d12b5e8d3f55a9214ef"
|
||||
|
|
Loading…
Reference in New Issue