From 4d78e461b056df7a96f1d4b05ebc7e50eb437dce Mon Sep 17 00:00:00 2001 From: hanabi1224 Date: Thu, 5 Dec 2024 17:02:53 +0800 Subject: [PATCH] chore(f3): upgrade go-f3 to latest (#5035) --- Cargo.lock | 134 ++++++++--------- f3-sidecar/go.mod | 6 +- f3-sidecar/go.sum | 12 +- interop-tests/src/tests/go_app/go.mod | 2 +- interop-tests/src/tests/go_app/go.sum | 4 +- scripts/tests/api_compare/filter-list | 4 + src/cli/subcommands/f3_cmd.rs | 3 +- src/cli/subcommands/f3_cmd/tests.rs | 179 +++++++---------------- src/rpc/methods/f3/types.rs | 201 ++++++++------------------ templates/cli/f3/certificate.stpl | 2 +- 10 files changed, 197 insertions(+), 350 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index d2d6c1c9ff1..63c8e8b39b8 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -194,9 +194,9 @@ dependencies = [ [[package]] name = "anyhow" -version = "1.0.93" +version = "1.0.94" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c95c10ba0b00a02636238b814946408b1322d5ac4760326e6fb8ec956d85775" +checksum = "c1fd03a028ef38ba2276dce7e33fcd6369c158a1bca17946c4b1b701891c1ff7" dependencies = [ "backtrace", ] @@ -616,7 +616,7 @@ dependencies = [ "axum-core", "bytes", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "hyper 1.5.1", @@ -649,7 +649,7 @@ dependencies = [ "async-trait", "bytes", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "mime", @@ -1323,9 +1323,9 @@ dependencies = [ [[package]] name = "clap" -version = "4.5.21" +version = "4.5.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fb3b4b9e5a7c7514dfa52869339ee98b3156b0bfb4e8a77c4ff4babb64b1604f" +checksum = "69371e34337c4c984bbe322360c2547210bf632eb2814bbe78a6e87a2935bd2b" dependencies = [ "clap_builder", "clap_derive", @@ -1333,9 +1333,9 @@ dependencies = [ [[package]] name = "clap_builder" -version = "4.5.21" +version = "4.5.22" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "b17a95aa67cc7b5ebd32aa5370189aa0d79069ef1c64ce893bd30fb24bff20ec" +checksum = "6e24c1b4099818523236a8ca881d2b45db98dadfb4625cf6608c12069fcbbde1" dependencies = [ "anstream", "anstyle", @@ -2520,7 +2520,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "num-derive", "num-traits", "serde", @@ -2535,7 +2535,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "num-derive", "num-traits", "serde", @@ -2554,7 +2554,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "lazy_static", "num-derive", "num-traits", @@ -2572,7 +2572,7 @@ dependencies = [ "frc42_macros", "fvm_ipld_encoding", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "hex", "hex-literal", "num-derive", @@ -2596,7 +2596,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "num-derive", "num-traits", "serde", @@ -2620,7 +2620,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "ipld-core", "lazy_static", "multihash-codetable", @@ -2650,7 +2650,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "itertools 0.13.0", "lazy_static", "multihash-codetable", @@ -2677,7 +2677,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "indexmap 2.7.0", "integer-encoding", "num-derive", @@ -2701,7 +2701,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "integer-encoding", "lazy_static", "num-derive", @@ -2720,7 +2720,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "lazy_static", "num-derive", "num-traits", @@ -2738,7 +2738,7 @@ dependencies = [ "fvm_ipld_blockstore", "fvm_ipld_encoding", "fvm_shared 2.10.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "multihash-codetable", "num-derive", "num-traits", @@ -2760,7 +2760,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "log", "num-derive", "num-traits", @@ -2784,7 +2784,7 @@ dependencies = [ "fvm_ipld_hamt", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "integer-encoding", "itertools 0.13.0", "lazy_static", @@ -2797,7 +2797,7 @@ dependencies = [ "regex", "serde", "serde_repr", - "thiserror 2.0.3", + "thiserror 2.0.4", "unsigned-varint 0.8.0", ] @@ -3020,19 +3020,19 @@ dependencies = [ "futures", "fvm 2.10.0", "fvm 3.12.0", - "fvm 4.5.2", + "fvm 4.5.3", "fvm_ipld_blockstore", "fvm_ipld_encoding", "fvm_shared 2.10.0", "fvm_shared 3.12.0", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "gethostname", "git-version", "glob", "group", "hex", "hickory-resolver", - "http 1.1.0", + "http 1.2.0", "http-range-header", "human-repr", "human_bytes", @@ -3207,7 +3207,7 @@ dependencies = [ "frc42_macros", "fvm_ipld_encoding", "fvm_sdk", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "thiserror 1.0.69", ] @@ -3218,7 +3218,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "db7b4c371b1dcf025c4d243e09cda46e54ee13d8e81d6af54c47a996e299dfb3" dependencies = [ "fvm_sdk", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "thiserror 1.0.69", ] @@ -3248,7 +3248,7 @@ dependencies = [ "fvm_ipld_encoding", "fvm_ipld_hamt", "fvm_sdk", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "integer-encoding", "multihash-codetable", "num-traits", @@ -3514,9 +3514,9 @@ dependencies = [ [[package]] name = "fvm" -version = "4.5.2" +version = "4.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d2e154a4226aa9a7aa97939a8599388a2531030d08e02c600a6665fe7a49ff70" +checksum = "d590e1f94d84ffa49eb7d7d3ea8721af1d90e4b793af89095b9e8b0b816f0360" dependencies = [ "ambassador", "anyhow", @@ -3529,7 +3529,7 @@ dependencies = [ "fvm_ipld_blockstore", "fvm_ipld_encoding", "fvm_ipld_hamt", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "lazy_static", "log", "minstant", @@ -3582,7 +3582,7 @@ dependencies = [ "fvm_ipld_blockstore", "fvm_ipld_encoding", "fvm_sdk", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "multihash-codetable", "num-traits", "serde", @@ -3649,9 +3649,9 @@ dependencies = [ [[package]] name = "fvm_ipld_hamt" -version = "0.10.2" +version = "0.10.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8512ddaa098c324e0c6b0d8cccacdcbc08834509db11f52d5f5cd7f1f10a39f8" +checksum = "1cc4806b6cd89fd69b7d3910492d2309fad0be2fd223686411ebfc78e16af93b" dependencies = [ "anyhow", "byteorder", @@ -3669,13 +3669,13 @@ dependencies = [ [[package]] name = "fvm_sdk" -version = "4.5.2" +version = "4.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9dbf94dfcc8c3b1cb9463d6f6e9051eeb06e45a85ff6c17673c872857da6512b" +checksum = "63eba7c13c6eaf6130002a00c7ee4085b484e09503a6e6ca1951fa7460ecaad7" dependencies = [ "cid 0.11.1", "fvm_ipld_encoding", - "fvm_shared 4.5.2", + "fvm_shared 4.5.3", "lazy_static", "log", "num-traits", @@ -3746,9 +3746,9 @@ dependencies = [ [[package]] name = "fvm_shared" -version = "4.5.2" +version = "4.5.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8eb924e9fa1be96ae49c1de2c7dd24ed9fd83e4b4c653425a6889243bdd63282" +checksum = "2ae590927cdaefbf803c43952885cf172e4d8159464f1c82cad8dce22dc09b7b" dependencies = [ "anyhow", "arbitrary", @@ -3924,7 +3924,7 @@ dependencies = [ "fnv", "futures-core", "futures-sink", - "http 1.1.0", + "http 1.2.0", "indexmap 2.7.0", "slab", "tokio", @@ -4145,9 +4145,9 @@ dependencies = [ [[package]] name = "http" -version = "1.1.0" +version = "1.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "21b9ddb458710bc376481b842f5da65cdf31522de232c1ca8146abce2a358258" +checksum = "f16ca2af56261c99fba8bac40a10251ce8188205a4c448fbb745a2e4daa76fea" dependencies = [ "bytes", "fnv", @@ -4172,7 +4172,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "1efedce1fb8e6913f23e0c92de8e62cd5b772a67e7b3946df930a62566c93184" dependencies = [ "bytes", - "http 1.1.0", + "http 1.2.0", ] [[package]] @@ -4183,7 +4183,7 @@ checksum = "793429d76616a256bcb62c2a2ec2bed781c8307e797e2598c50010f2bee2544f" dependencies = [ "bytes", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "pin-project-lite", ] @@ -4258,7 +4258,7 @@ dependencies = [ "futures-channel", "futures-util", "h2 0.4.7", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "httparse", "httpdate", @@ -4276,7 +4276,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "08afdbb5c31130e3034af566421053ab03787c640246a446327f550d11bcb333" dependencies = [ "futures-util", - "http 1.1.0", + "http 1.2.0", "hyper 1.5.1", "hyper-util", "log", @@ -4310,7 +4310,7 @@ dependencies = [ "bytes", "futures-channel", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "hyper 1.5.1", "pin-project-lite", @@ -4860,7 +4860,7 @@ checksum = "548125b159ba1314104f5bb5f38519e03a41862786aa3925cf349aae9cdd546e" dependencies = [ "base64 0.22.1", "futures-util", - "http 1.1.0", + "http 1.2.0", "jsonrpsee-core", "pin-project", "rustls", @@ -4885,7 +4885,7 @@ dependencies = [ "bytes", "futures-timer", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "jsonrpsee-types", @@ -4933,7 +4933,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "82ad8ddc14be1d4290cd68046e7d1d37acd408efed6d3ca08aefcc3ad6da069c" dependencies = [ "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "hyper 1.5.1", @@ -4959,7 +4959,7 @@ version = "0.24.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a178c60086f24cc35bb82f57c651d0d25d99c4742b4d335de04e97fa1f08a8a1" dependencies = [ - "http 1.1.0", + "http 1.2.0", "serde", "serde_json", "thiserror 1.0.69", @@ -4971,7 +4971,7 @@ version = "0.24.7" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0fe322e0896d0955a3ebdd5bf813571c53fea29edd713bc315b76620b327e86d" dependencies = [ - "http 1.1.0", + "http 1.2.0", "jsonrpsee-client-transport", "jsonrpsee-core", "jsonrpsee-types", @@ -7229,7 +7229,7 @@ dependencies = [ "rustc-hash 2.1.0", "rustls", "socket2 0.5.8", - "thiserror 2.0.3", + "thiserror 2.0.4", "tokio", "tracing", ] @@ -7248,7 +7248,7 @@ dependencies = [ "rustls", "rustls-pki-types", "slab", - "thiserror 2.0.3", + "thiserror 2.0.4", "tinyvec", "tracing", "web-time", @@ -7539,7 +7539,7 @@ dependencies = [ "bytes", "futures-core", "futures-util", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "hyper 1.5.1", @@ -8579,7 +8579,7 @@ dependencies = [ "base64 0.22.1", "bytes", "futures", - "http 1.1.0", + "http 1.2.0", "httparse", "log", "rand", @@ -9026,11 +9026,11 @@ dependencies = [ [[package]] name = "thiserror" -version = "2.0.3" +version = "2.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "c006c85c7651b3cf2ada4584faa36773bd07bac24acfb39f3c431b36d7e667aa" +checksum = "2f49a1853cf82743e3b7950f77e0f4d622ca36cf4317cba00c767838bac8d490" dependencies = [ - "thiserror-impl 2.0.3", + "thiserror-impl 2.0.4", ] [[package]] @@ -9046,9 +9046,9 @@ dependencies = [ [[package]] name = "thiserror-impl" -version = "2.0.3" +version = "2.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f077553d607adc1caf65430528a576c757a71ed73944b66ebb58ef2bbd243568" +checksum = "8381894bb3efe0c4acac3ded651301ceee58a15d47c2e34885ed1908ad667061" dependencies = [ "proc-macro2", "quote", @@ -9253,9 +9253,9 @@ dependencies = [ [[package]] name = "tokio-util" -version = "0.7.12" +version = "0.7.13" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a" +checksum = "d7fcaa8d55a2bdd6b83ace262b016eca0d79ee02818c5c1bcdf0305114081078" dependencies = [ "bytes", "futures-core", @@ -9331,7 +9331,7 @@ dependencies = [ "base64 0.22.1", "bytes", "h2 0.4.7", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "http-body-util", "hyper 1.5.1", @@ -9395,7 +9395,7 @@ dependencies = [ "bitflags 2.6.0", "bytes", "futures-core", - "http 1.1.0", + "http 1.2.0", "http-body 1.0.1", "pin-project-lite", "tokio", @@ -10591,9 +10591,9 @@ dependencies = [ [[package]] name = "xml-rs" -version = "0.8.23" +version = "0.8.24" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "af310deaae937e48a26602b730250b4949e125f468f11e6990be3e5304ddd96f" +checksum = "ea8b391c9a790b496184c29f7f93b9ed5b16abb306c05415b68bcc16e4d06432" [[package]] name = "xmltree" diff --git a/f3-sidecar/go.mod b/f3-sidecar/go.mod index 6eb9d678255..a0f803aefd1 100644 --- a/f3-sidecar/go.mod +++ b/f3-sidecar/go.mod @@ -3,7 +3,7 @@ module f3-sidecar/v2 go 1.22.0 require ( - github.com/filecoin-project/go-f3 v0.7.2 + github.com/filecoin-project/go-f3 v0.7.3 github.com/filecoin-project/go-jsonrpc v0.7.0 github.com/filecoin-project/go-state-types v0.15.0 github.com/ipfs/go-cid v0.4.1 @@ -39,10 +39,10 @@ require ( github.com/go-task/slim-sprig/v3 v3.0.0 // indirect github.com/godbus/dbus/v5 v5.1.0 // indirect github.com/gogo/protobuf v1.3.2 // indirect - github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect + github.com/golang/groupcache v0.0.0-20241129210726-2c02b8208cf8 // indirect github.com/golang/snappy v0.0.4 // indirect github.com/google/gopacket v1.1.19 // indirect - github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b // indirect + github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467 // indirect github.com/google/uuid v1.6.0 // indirect github.com/gorilla/websocket v1.5.3 // indirect github.com/hashicorp/errwrap v1.1.0 // indirect diff --git a/f3-sidecar/go.sum b/f3-sidecar/go.sum index 4f4439b5488..a549ddebac6 100644 --- a/f3-sidecar/go.sum +++ b/f3-sidecar/go.sum @@ -63,8 +63,8 @@ github.com/filecoin-project/go-bitfield v0.2.4 h1:uZ7MeE+XfM5lqrHJZ93OnhQKc/rveW github.com/filecoin-project/go-bitfield v0.2.4/go.mod h1:CNl9WG8hgR5mttCnUErjcQjGvuiZjRqK9rHVBsQF4oM= github.com/filecoin-project/go-clock v0.1.0 h1:SFbYIM75M8NnFm1yMHhN9Ahy3W5bEZV9gd6MPfXbKVU= github.com/filecoin-project/go-clock v0.1.0/go.mod h1:4uB/O4PvOjlx1VCMdZ9MyDZXRm//gkj1ELEbxfI1AZs= -github.com/filecoin-project/go-f3 v0.7.2 h1:YQgxxSMzCSQniZqwDjyNkIRz3pnzCtOrtaS5ldIaUDA= -github.com/filecoin-project/go-f3 v0.7.2/go.mod h1:QoxuoK4aktNZD1R/unlhNbhV6TnlNTAbA/QODCnAjak= +github.com/filecoin-project/go-f3 v0.7.3 h1:nwRYRKaJs7AV3di/OQyj6tABeixBeL06DkJeoQrr5+0= +github.com/filecoin-project/go-f3 v0.7.3/go.mod h1:wDo5mPi4KXVuA7kvwLpmfVVv2Aw2ZwZk3iqMWr5BOT0= github.com/filecoin-project/go-jsonrpc v0.7.0 h1:mqA5pIOlBODx7ascY9cJdBAYonhgbdUOIn2dyYI1YBg= github.com/filecoin-project/go-jsonrpc v0.7.0/go.mod h1:lAUpS8BSVtKaA8+/CFUMA5dokMiSM7n0ehf8bHOFdpE= github.com/filecoin-project/go-state-types v0.15.0 h1:GaUSCti0tGMzLg7fVpRjtNVGBvirbMFzLfyWbR+qzWE= @@ -100,8 +100,8 @@ github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= github.com/golang/groupcache v0.0.0-20200121045136-8c9f03a8e57e/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= -github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da h1:oI5xCqsCo564l8iNU+DwB5epxmsaqB+rhGL0m5jtYqE= -github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= +github.com/golang/groupcache v0.0.0-20241129210726-2c02b8208cf8 h1:f+oWsMOmNPc8JmEHVZIycC7hBoQxHH9pNKQORJNozsQ= +github.com/golang/groupcache v0.0.0-20241129210726-2c02b8208cf8/go.mod h1:wcDNUvekVysuuOpQKo3191zZyTpiI6se1N1ULghS0sw= github.com/golang/lint v0.0.0-20180702182130-06c8688daad7/go.mod h1:tluoj9z5200jBnyusfRPU2LqT6J+DAorxEvtC7LHB+E= github.com/golang/mock v1.1.1/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= github.com/golang/mock v1.2.0/go.mod h1:oTYuIxOrZwtPieC+H1uAHpcLFnEyAGVDL/k47Jfbm0A= @@ -134,8 +134,8 @@ github.com/google/gopacket v1.1.19 h1:ves8RnFZPGiFnTS0uPQStjwru6uO6h+nlr9j6fL7kF github.com/google/gopacket v1.1.19/go.mod h1:iJ8V8n6KS+z2U1A8pUwu8bW5SyEMkXJB8Yo/Vo+TKTo= github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= -github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b h1:SXO0REt4iu865upYCk8aKBBJQ4BqoE0ReP23ClMu60s= -github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144= +github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467 h1:keEZFtbLJugfE0qHn+Ge1JCE71spzkchQobDf3mzS/4= +github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144= github.com/google/renameio v0.1.0/go.mod h1:KWCgfxg9yswjAJkECMjeO8J8rahYeXnNhOm40UhjYkI= github.com/google/subcommands v1.2.0/go.mod h1:ZjhPrFU+Olkh9WazFPsl27BQ4UPiG37m3yTrtFlrHVk= github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= diff --git a/interop-tests/src/tests/go_app/go.mod b/interop-tests/src/tests/go_app/go.mod index 39e3061067e..258c9f3adff 100644 --- a/interop-tests/src/tests/go_app/go.mod +++ b/interop-tests/src/tests/go_app/go.mod @@ -32,7 +32,7 @@ require ( github.com/godbus/dbus/v5 v5.1.0 // indirect github.com/gogo/protobuf v1.3.2 // indirect github.com/google/gopacket v1.1.19 // indirect - github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b // indirect + github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467 // indirect github.com/google/uuid v1.6.0 // indirect github.com/gorilla/websocket v1.5.3 // indirect github.com/hashicorp/errwrap v1.1.0 // indirect diff --git a/interop-tests/src/tests/go_app/go.sum b/interop-tests/src/tests/go_app/go.sum index 365164e2d45..cbbd812984b 100644 --- a/interop-tests/src/tests/go_app/go.sum +++ b/interop-tests/src/tests/go_app/go.sum @@ -115,8 +115,8 @@ github.com/google/gopacket v1.1.19 h1:ves8RnFZPGiFnTS0uPQStjwru6uO6h+nlr9j6fL7kF github.com/google/gopacket v1.1.19/go.mod h1:iJ8V8n6KS+z2U1A8pUwu8bW5SyEMkXJB8Yo/Vo+TKTo= github.com/google/martian v2.1.0+incompatible/go.mod h1:9I4somxYTbIHy5NJKHRl3wXiIaQGbYVAs8BPL6v8lEs= github.com/google/pprof v0.0.0-20181206194817-3ea8567a2e57/go.mod h1:zfwlbNMJ+OItoe0UupaVj+oy1omPYYDuagoSzA8v9mc= -github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b h1:SXO0REt4iu865upYCk8aKBBJQ4BqoE0ReP23ClMu60s= -github.com/google/pprof v0.0.0-20241122213907-cbe949e5a41b/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144= +github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467 h1:keEZFtbLJugfE0qHn+Ge1JCE71spzkchQobDf3mzS/4= +github.com/google/pprof v0.0.0-20241203143554-1e3fdc7de467/go.mod h1:vavhavw2zAxS5dIdcRluK6cSGGPlZynqzFM8NdvU144= github.com/google/uuid v1.1.2/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.3.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= diff --git a/scripts/tests/api_compare/filter-list b/scripts/tests/api_compare/filter-list index 84b318f69ec..594bbb1a160 100644 --- a/scripts/tests/api_compare/filter-list +++ b/scripts/tests/api_compare/filter-list @@ -14,3 +14,7 @@ !Filecoin.EthGetTransactionByBlockNumberAndIndex # TODO: https://github.com/ChainSafe/forest/issues/5006 !Filecoin.EthGetBlockReceipts +# F3Certificate serialization has been changed in https://github.com/filecoin-project/go-f3/pull/756 +# Unlist the below 2 methods once Lotus image is upgraded +!Filecoin.F3GetLatestCertificate +!Filecoin.F3GetCertificate diff --git a/src/cli/subcommands/f3_cmd.rs b/src/cli/subcommands/f3_cmd.rs index b0f91050f7d..aa797843be5 100644 --- a/src/cli/subcommands/f3_cmd.rs +++ b/src/cli/subcommands/f3_cmd.rs @@ -338,8 +338,7 @@ impl F3PowerTableCommands { .last() .context("lookback EC chain is empty")? .key - .clone() - .try_into()?; + .clone(); Ok((tsk, previous.supplemental_data.power_table)) } } diff --git a/src/cli/subcommands/f3_cmd/tests.rs b/src/cli/subcommands/f3_cmd/tests.rs index fa70722eec5..182ea20539d 100644 --- a/src/cli/subcommands/f3_cmd/tests.rs +++ b/src/cli/subcommands/f3_cmd/tests.rs @@ -73,142 +73,63 @@ fn test_progress_template() { fn test_finality_certificate_template() { // lotus f3 c get --output json 6204 let lotus_json = serde_json::json!({ - "GPBFTInstance": 6204, - "ECChain": [ - { - "Epoch": 2088927, - "Key": "AXGg5AIg1NBjOnFimwUueRXQQzvPbHZO6vXbvqNA1gcomlVrq5MBcaDkAiCaOt71j85kjjq3SZF0NQq03tauEW3iwscIr4Qw0wna+g==", - "PowerTable": { - "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" + "GPBFTInstance": 6204, + "ECChain": [ + { + "Key": [ + { + "/": "bafy2bzacedknayz2ofrjwbjopek5aqz3z5whmtxk6xn35i2a2ydsrgsvnovzg" }, - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 - ] - }, - { - "Epoch": 2088928, - "Key": "AXGg5AIgFn9g3q/ATrgWiWzUYZLrtN/POrkNWFPmUShj/MDqZ5IBcaDkAiACwpEW4PvUCOIsZRaYhF6W+L1bgGd2TUFLOkATNxvuGgFxoOQCILlKPpFgMxXYFcq2HslyxzBN9ZZ6iPrPSBI2uwT4tUAvAXGg5AIgwYDZ217HUZ6nGnm6fnNd5lhep2C02mSYkkjJPf5pOig=", - "PowerTable": { - "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" - }, - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 - ] - } - ], - "SupplementalData": { - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 + { + "/": "bafy2bzacecndvxxvr7hgjdr2w5ezc5bvbk2n5vvocfw6fqwhbcxyimgtbhnpu" + } ], + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "Epoch": 2088927, "PowerTable": { "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" } }, - "Signers": [ - 0, - 3 - ], - "Signature": "uYtvw/NWm2jKQj+d99UAG4aiPnpAMSrwAWIusv0XkjsOYYR0fyU4nUM++cAQGO47E2/J8WSDjstLgL+yMVAFC+Tgao4o9ILXIlhqhxObnNZ/Ehanajthif9SaRe1AO69", - "PowerTableDelta": [ - { - "ParticipantID": 3782, - "PowerDelta": "76347338653696", - "SigningKey": "lXSMTNEVmIdVxJV4clmW35jrlsBEfytNUGTWVih2dFlQ1k/7QQttsUGzpD5JoNaQ" + { + "Key": [ + { + "/": "bafy2bzacealh6yg6v7ae5oawrfwniyms5o2n7tz2xegvqu7gkeugh7ga5jtze" + }, + { + "/": "bafy2bzaceabmfeiw4d55ichcfrsrngeel2lprpk3qbtxmtkbjm5eaezxdpxbu" + }, + { + "/": "bafy2bzacec4uupurmazrlwavzk3b5slsy4ye35mwpkepvt2ici3lwbhywvac6" + }, + { + "/": "bafy2bzacedaybwo3l3dvdhvhdj43u7ttlxtfqxvhmc2nuzeysjemspp6ne5cq" + } + ], + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "Epoch": 2088928, + "PowerTable": { + "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" } - ] + } + ], + "SupplementalData": { + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "PowerTable": { + "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" + } + }, + "Signers": [ + 0, + 3 + ], + "Signature": "uYtvw/NWm2jKQj+d99UAG4aiPnpAMSrwAWIusv0XkjsOYYR0fyU4nUM++cAQGO47E2/J8WSDjstLgL+yMVAFC+Tgao4o9ILXIlhqhxObnNZ/Ehanajthif9SaRe1AO69", + "PowerTableDelta": [ + { + "ParticipantID": 3782, + "PowerDelta": "76347338653696", + "SigningKey": "lXSMTNEVmIdVxJV4clmW35jrlsBEfytNUGTWVih2dFlQ1k/7QQttsUGzpD5JoNaQ" + } + ] }); let cert: FinalityCertificate = serde_json::from_value(lotus_json).unwrap(); let template = FinalityCertificateTemplate::new(cert); diff --git a/src/rpc/methods/f3/types.rs b/src/rpc/methods/f3/types.rs index 5b33f034f27..7b692831850 100644 --- a/src/rpc/methods/f3/types.rs +++ b/src/rpc/methods/f3/types.rs @@ -118,21 +118,17 @@ impl From> for F3TipSet { pub struct ECTipSet { #[schemars(with = "String")] #[serde(with = "crate::lotus_json")] - pub key: F3TipSetKey, + pub key: TipsetKey, pub epoch: ChainEpoch, #[schemars(with = "String")] #[serde(with = "crate::lotus_json")] pub power_table: Cid, - pub commitments: [u8; 32], + #[schemars(with = "String")] + #[serde(with = "base64_standard")] + pub commitments: Vec, } lotus_json_with_self!(ECTipSet); -impl ECTipSet { - pub fn ec_tipset_key(&self) -> TipsetKey { - TipsetKey::try_from(self.key.clone()).expect("failed to convert F3TipSetKey to TipsetKey") - } -} - /// PowerEntry represents a single entry in the PowerTable, including ActorID and its StoragePower and PubKey. #[derive(Debug, Clone, Serialize, Deserialize, JsonSchema, Eq, PartialEq)] #[serde(rename_all = "PascalCase")] @@ -272,7 +268,9 @@ lotus_json_with_self!(F3Manifest); #[derive(PartialEq, Debug, Clone, Serialize, Deserialize, JsonSchema)] #[serde(rename_all = "PascalCase")] pub struct SupplementalData { - pub commitments: [u8; 32], + #[schemars(with = "String")] + #[serde(with = "base64_standard")] + pub commitments: Vec, #[schemars(with = "String")] #[serde(with = "crate::lotus_json")] pub power_table: Cid, @@ -311,7 +309,11 @@ pub struct FinalityCertificate { #[serde(with = "crate::lotus_json")] pub signature: Vec, #[schemars(with = "LotusJson>")] - #[serde(with = "crate::lotus_json")] + #[serde( + with = "crate::lotus_json", + default, + skip_serializing_if = "Vec::is_empty" + )] pub power_table_delta: Vec, } lotus_json_with_self!(FinalityCertificate); @@ -728,142 +730,63 @@ mod tests { fn f3_certificate_serde_roundtrip() { // lotus f3 c get --output json 6204 let lotus_json = serde_json::json!({ - "GPBFTInstance": 6204, - "ECChain": [ - { - "Epoch": 2088927, - "Key": "AXGg5AIg1NBjOnFimwUueRXQQzvPbHZO6vXbvqNA1gcomlVrq5MBcaDkAiCaOt71j85kjjq3SZF0NQq03tauEW3iwscIr4Qw0wna+g==", - "PowerTable": { - "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" - }, - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 - ] - }, - { - "Epoch": 2088928, - "Key": "AXGg5AIgFn9g3q/ATrgWiWzUYZLrtN/POrkNWFPmUShj/MDqZ5IBcaDkAiACwpEW4PvUCOIsZRaYhF6W+L1bgGd2TUFLOkATNxvuGgFxoOQCILlKPpFgMxXYFcq2HslyxzBN9ZZ6iPrPSBI2uwT4tUAvAXGg5AIgwYDZ217HUZ6nGnm6fnNd5lhep2C02mSYkkjJPf5pOig=", - "PowerTable": { - "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" + "GPBFTInstance": 6204, + "ECChain": [ + { + "Key": [ + { + "/": "bafy2bzacedknayz2ofrjwbjopek5aqz3z5whmtxk6xn35i2a2ydsrgsvnovzg" }, - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 - ] - } - ], - "SupplementalData": { - "Commitments": [ - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0, - 0 + { + "/": "bafy2bzacecndvxxvr7hgjdr2w5ezc5bvbk2n5vvocfw6fqwhbcxyimgtbhnpu" + } ], + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "Epoch": 2088927, "PowerTable": { "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" } }, - "Signers": [ - 0, - 3 - ], - "Signature": "uYtvw/NWm2jKQj+d99UAG4aiPnpAMSrwAWIusv0XkjsOYYR0fyU4nUM++cAQGO47E2/J8WSDjstLgL+yMVAFC+Tgao4o9ILXIlhqhxObnNZ/Ehanajthif9SaRe1AO69", - "PowerTableDelta": [ - { - "ParticipantID": 3782, - "PowerDelta": "76347338653696", - "SigningKey": "lXSMTNEVmIdVxJV4clmW35jrlsBEfytNUGTWVih2dFlQ1k/7QQttsUGzpD5JoNaQ" + { + "Key": [ + { + "/": "bafy2bzacealh6yg6v7ae5oawrfwniyms5o2n7tz2xegvqu7gkeugh7ga5jtze" + }, + { + "/": "bafy2bzaceabmfeiw4d55ichcfrsrngeel2lprpk3qbtxmtkbjm5eaezxdpxbu" + }, + { + "/": "bafy2bzacec4uupurmazrlwavzk3b5slsy4ye35mwpkepvt2ici3lwbhywvac6" + }, + { + "/": "bafy2bzacedaybwo3l3dvdhvhdj43u7ttlxtfqxvhmc2nuzeysjemspp6ne5cq" + } + ], + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "Epoch": 2088928, + "PowerTable": { + "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" } - ] + } + ], + "SupplementalData": { + "Commitments": "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=", + "PowerTable": { + "/": "bafy2bzaceazjn2promafvtkaquebfgc3xvhoavdbxwns4i54ilgnzch7pkgua" + } + }, + "Signers": [ + 0, + 3 + ], + "Signature": "uYtvw/NWm2jKQj+d99UAG4aiPnpAMSrwAWIusv0XkjsOYYR0fyU4nUM++cAQGO47E2/J8WSDjstLgL+yMVAFC+Tgao4o9ILXIlhqhxObnNZ/Ehanajthif9SaRe1AO69", + "PowerTableDelta": [ + { + "ParticipantID": 3782, + "PowerDelta": "76347338653696", + "SigningKey": "lXSMTNEVmIdVxJV4clmW35jrlsBEfytNUGTWVih2dFlQ1k/7QQttsUGzpD5JoNaQ" + } + ] }); let cert: FinalityCertificate = serde_json::from_value(lotus_json.clone()).unwrap(); let serialized = serde_json::to_value(cert.clone()).unwrap(); diff --git a/templates/cli/f3/certificate.stpl b/templates/cli/f3/certificate.stpl index 51defc73362..b33099aac83 100644 --- a/templates/cli/f3/certificate.stpl +++ b/templates/cli/f3/certificate.stpl @@ -9,6 +9,6 @@ Finalized Chain: Length: <%= cert.ec_chain.len() %> Epochs: <%= cert.chain_base().epoch %>-<%= cert.chain_head().epoch %> Chain: -<% for (i, ts) in cert.ec_chain.iter().take(MAX_TIPSETS).enumerate() { let tsk = ts.ec_tipset_key(); %> <% if i + 1 == cert.ec_chain.len() { %>└──<% } else { %>├──<% } %><%= ts.epoch %> (length: <%= tsk.len() %>): [<%= tsk.iter().take(MAX_TIPSET_KEYS).map(|i| i.to_string()).join(", ") %><% if tsk.len() > MAX_TIPSET_KEYS { %>, ...<% } %>] +<% for (i, ts) in cert.ec_chain.iter().take(MAX_TIPSETS).enumerate() { let tsk = &ts.key; %> <% if i + 1 == cert.ec_chain.len() { %>└──<% } else { %>├──<% } %><%= ts.epoch %> (length: <%= tsk.len() %>): [<%= tsk.iter().take(MAX_TIPSET_KEYS).map(|i| i.to_string()).join(", ") %><% if tsk.len() > MAX_TIPSET_KEYS { %>, ...<% } %>] <% } %><% if cert.ec_chain.len() > MAX_TIPSETS { let n_remaining = cert.ec_chain.len() - MAX_TIPSETS; %> └──...omitted the remaining <%= n_remaining %> tipsets. <% } %>Signed by <%= cert.signers.len() %> miner(s).