mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2025-01-24 06:11:14 -05:00
Upgrade to bdk 4.0
To achieve this we also: - upgrade rust-bitcoin to 0.26 - upgrade bitcoin-harness to latest version (which also depends bitcoin 0.26) - upgrade to latest edcsa-fun - replace cross_curve_dleq proof with sigma_fun (to avoid an upgrade dance over there)
This commit is contained in:
parent
b3f49cf83e
commit
84bc2c82b7
248
Cargo.lock
generated
248
Cargo.lock
generated
@ -163,11 +163,11 @@ version = "0.5.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "fb4401f0a3622dad2e0763fa79e0eb328bc70fb7dccfdd645341f00d671247d6"
|
checksum = "fb4401f0a3622dad2e0763fa79e0eb328bc70fb7dccfdd645341f00d671247d6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures-sink",
|
"futures-sink",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
"memchr",
|
"memchr",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -212,7 +212,7 @@ dependencies = [
|
|||||||
"instant",
|
"instant",
|
||||||
"pin-project 1.0.4",
|
"pin-project 1.0.4",
|
||||||
"rand 0.8.2",
|
"rand 0.8.2",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -253,9 +253,9 @@ checksum = "904dfeac50f3cdaba28fc6f57fdcddb75f49ed61346676a78c4ffe55877802fd"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bdk"
|
name = "bdk"
|
||||||
version = "0.3.0"
|
version = "0.4.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e2fd4c84e2baef750794e7c3f317e37c0c611ef7b29c9a9f18c7e51940dbfdb5"
|
checksum = "daeccaea73c9fc27e218e2a4402070707fb8354afd30fecd4a1c9a0bea8b79c4"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"bdk-macros",
|
"bdk-macros",
|
||||||
@ -268,14 +268,14 @@ dependencies = [
|
|||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"sled",
|
"sled",
|
||||||
"tokio 0.2.25",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bdk-macros"
|
name = "bdk-macros"
|
||||||
version = "0.2.0"
|
version = "0.3.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f62874901df222eb0fc3bad6e425bc2a935287b8110be0d1ad6d729af86cf6e1"
|
checksum = "b96757dbe9c7e0a8f0635c5366464d9c713528e111f47490e96385f70d6a67a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
@ -289,16 +289,20 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "cdcf67bb7ba7797a081cd19009948ab533af7c355d5caf1d08c777582d351e9c"
|
checksum = "cdcf67bb7ba7797a081cd19009948ab533af7c355d5caf1d08c777582d351e9c"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bit-vec"
|
name = "bincode"
|
||||||
version = "0.6.3"
|
version = "1.3.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "349f9b6a179ed607305526ca489b34ad0a41aed5f7980fa90eb03160b69598fb"
|
checksum = "f30d3a39baa26f9651f17b375061f3233dde33424a8b72b0dbe93a68a0bc896d"
|
||||||
|
dependencies = [
|
||||||
|
"byteorder",
|
||||||
|
"serde",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bitcoin"
|
name = "bitcoin"
|
||||||
version = "0.25.2"
|
version = "0.26.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "aefc9be9f17185f4ebccae6575d342063f775924d57df0000edb1880c0fb7095"
|
checksum = "1ec5f88a446d66e7474a3b8fa2e348320b574463fb78d799d90ba68f79f48e0e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bech32",
|
"bech32",
|
||||||
"bitcoin_hashes",
|
"bitcoin_hashes",
|
||||||
@ -309,7 +313,7 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "bitcoin-harness"
|
name = "bitcoin-harness"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/coblox/bitcoin-harness-rs?rev=ae2f6cd547496e680941c0910018bbe884128799#ae2f6cd547496e680941c0910018bbe884128799"
|
source = "git+https://github.com/coblox/bitcoin-harness-rs#640acbf079c728231866b59cd830770b64871cc0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"base64 0.12.3",
|
"base64 0.12.3",
|
||||||
@ -323,7 +327,7 @@ dependencies = [
|
|||||||
"serde_json",
|
"serde_json",
|
||||||
"testcontainers 0.11.0",
|
"testcontainers 0.11.0",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tracing",
|
"tracing",
|
||||||
"url",
|
"url",
|
||||||
]
|
]
|
||||||
@ -339,9 +343,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bitcoincore-rpc-json"
|
name = "bitcoincore-rpc-json"
|
||||||
version = "0.12.0"
|
version = "0.13.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "76d488ec31e9cb6726c361be5160f7d2aaace89a0681acf1f476b8fada770b6e"
|
checksum = "977e55a945ab1e3c446dea93267876703c15e07c7d6eeb1dfa1766b3190c560f"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitcoin",
|
"bitcoin",
|
||||||
"hex 0.3.2",
|
"hex 0.3.2",
|
||||||
@ -468,12 +472,6 @@ version = "1.4.2"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "ae44d1a3d5a19df61dd0c8beb138458ac2a53a7ac09eba97d55592540004306b"
|
checksum = "ae44d1a3d5a19df61dd0c8beb138458ac2a53a7ac09eba97d55592540004306b"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "bytes"
|
|
||||||
version = "0.5.6"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "0e4cec68f03f32e44924783795810fa50a7035d8c8ebe78580ad7e6c703fba38"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bytes"
|
name = "bytes"
|
||||||
version = "1.0.1"
|
version = "1.0.1"
|
||||||
@ -652,23 +650,6 @@ dependencies = [
|
|||||||
"cfg-if 1.0.0",
|
"cfg-if 1.0.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "cross-curve-dleq"
|
|
||||||
version = "0.1.0"
|
|
||||||
source = "git+https://github.com/comit-network/cross-curve-dleq?rev=eddcdea1d1f16fa33ef581d1744014ece535c920#eddcdea1d1f16fa33ef581d1744014ece535c920"
|
|
||||||
dependencies = [
|
|
||||||
"bit-vec",
|
|
||||||
"curve25519-dalek 2.1.2",
|
|
||||||
"ecdsa_fun",
|
|
||||||
"generic-array 0.14.4",
|
|
||||||
"hex-literal",
|
|
||||||
"lazy_static",
|
|
||||||
"rand 0.7.3",
|
|
||||||
"serde",
|
|
||||||
"sha2 0.9.2",
|
|
||||||
"thiserror",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "crossbeam-epoch"
|
name = "crossbeam-epoch"
|
||||||
version = "0.9.1"
|
version = "0.9.1"
|
||||||
@ -758,20 +739,6 @@ dependencies = [
|
|||||||
"memchr",
|
"memchr",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "curve25519-dalek"
|
|
||||||
version = "2.1.2"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "434e1720189a637d44fe464f4df1e6eb900b4835255b14354497c78af37d9bb8"
|
|
||||||
dependencies = [
|
|
||||||
"byteorder",
|
|
||||||
"digest 0.8.1",
|
|
||||||
"rand_core 0.5.1",
|
|
||||||
"serde",
|
|
||||||
"subtle 2.4.0",
|
|
||||||
"zeroize 1.2.0",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "curve25519-dalek"
|
name = "curve25519-dalek"
|
||||||
version = "3.0.2"
|
version = "3.0.2"
|
||||||
@ -781,6 +748,7 @@ dependencies = [
|
|||||||
"byteorder",
|
"byteorder",
|
||||||
"digest 0.9.0",
|
"digest 0.9.0",
|
||||||
"rand_core 0.5.1",
|
"rand_core 0.5.1",
|
||||||
|
"serde",
|
||||||
"subtle 2.4.0",
|
"subtle 2.4.0",
|
||||||
"zeroize 1.2.0",
|
"zeroize 1.2.0",
|
||||||
]
|
]
|
||||||
@ -885,11 +853,14 @@ checksum = "212d0f5754cb6769937f4501cc0e67f4f4483c8d2c3e1e922ee9edbe4ab4c7c0"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ecdsa_fun"
|
name = "ecdsa_fun"
|
||||||
version = "0.3.2-alpha.0"
|
version = "0.4.2-alpha.0"
|
||||||
source = "git+https://github.com/LLFourn/secp256kfun?rev=cdfbc766045ea678a41780919d6228dd5acee3be#cdfbc766045ea678a41780919d6228dd5acee3be"
|
source = "git+https://github.com/LLFourn/secp256kfun#8538ef22498170960a9769df2700c1986cc540fd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
|
"bincode",
|
||||||
|
"rand_chacha 0.2.2",
|
||||||
"secp256kfun",
|
"secp256kfun",
|
||||||
"serde",
|
"serde",
|
||||||
|
"sigma_fun",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -908,7 +879,7 @@ version = "1.0.1"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c762bae6dcaf24c4c84667b8579785430908723d5c889f469d76a41d59cc7a9d"
|
checksum = "c762bae6dcaf24c4c84667b8579785430908723d5c889f469d76a41d59cc7a9d"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"curve25519-dalek 3.0.2",
|
"curve25519-dalek",
|
||||||
"ed25519",
|
"ed25519",
|
||||||
"rand 0.7.3",
|
"rand 0.7.3",
|
||||||
"serde",
|
"serde",
|
||||||
@ -925,9 +896,9 @@ checksum = "e78d4f1cc4ae33bbfc157ed5d5a5ef3bc29227303d595861deb238fcec4e9457"
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "electrum-client"
|
name = "electrum-client"
|
||||||
version = "0.5.0-beta.1"
|
version = "0.6.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "aedfb48f66ab17ba3b2c69f8ff32f68d8b5dbc7839c0ca4e94237b835ca608dd"
|
checksum = "21453800c95bb1aaa57490458c42d60c6277cb8a3e386030ec2381d5c2d4fa77"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitcoin",
|
"bitcoin",
|
||||||
"log",
|
"log",
|
||||||
@ -1154,7 +1125,7 @@ dependencies = [
|
|||||||
"futures-io",
|
"futures-io",
|
||||||
"memchr",
|
"memchr",
|
||||||
"parking",
|
"parking",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"waker-fn",
|
"waker-fn",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -1204,7 +1175,7 @@ dependencies = [
|
|||||||
"futures-sink",
|
"futures-sink",
|
||||||
"futures-task",
|
"futures-task",
|
||||||
"memchr",
|
"memchr",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"pin-utils",
|
"pin-utils",
|
||||||
"proc-macro-hack",
|
"proc-macro-hack",
|
||||||
"proc-macro-nested",
|
"proc-macro-nested",
|
||||||
@ -1235,6 +1206,7 @@ version = "0.14.4"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "501466ecc8a30d1d3b7fc9229b122b2ce8ed6e9d9223f1138d4babb253e51817"
|
checksum = "501466ecc8a30d1d3b7fc9229b122b2ce8ed6e9d9223f1138d4babb253e51817"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
|
"serde",
|
||||||
"typenum",
|
"typenum",
|
||||||
"version_check",
|
"version_check",
|
||||||
]
|
]
|
||||||
@ -1285,7 +1257,7 @@ version = "0.3.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "6b67e66362108efccd8ac053abafc8b7a8d86a37e6e48fc4f6f7485eb5e9e6a5"
|
checksum = "6b67e66362108efccd8ac053abafc8b7a8d86a37e6e48fc4f6f7485eb5e9e6a5"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"fnv",
|
"fnv",
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"futures-sink",
|
"futures-sink",
|
||||||
@ -1293,7 +1265,7 @@ dependencies = [
|
|||||||
"http",
|
"http",
|
||||||
"indexmap",
|
"indexmap",
|
||||||
"slab",
|
"slab",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tokio-util",
|
"tokio-util",
|
||||||
"tracing",
|
"tracing",
|
||||||
"tracing-futures",
|
"tracing-futures",
|
||||||
@ -1353,25 +1325,6 @@ version = "0.4.2"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "644f9158b2f133fd50f5fb3242878846d9eb792e445c893805ff0e3824006e35"
|
checksum = "644f9158b2f133fd50f5fb3242878846d9eb792e445c893805ff0e3824006e35"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "hex-literal"
|
|
||||||
version = "0.2.1"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "961de220ec9a91af2e1e5bd80d02109155695e516771762381ef8581317066e0"
|
|
||||||
dependencies = [
|
|
||||||
"hex-literal-impl",
|
|
||||||
"proc-macro-hack",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "hex-literal-impl"
|
|
||||||
version = "0.2.2"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "853f769599eb31de176303197b7ba4973299c38c7a7604a6bc88c3eef05b9b46"
|
|
||||||
dependencies = [
|
|
||||||
"proc-macro-hack",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hmac"
|
name = "hmac"
|
||||||
version = "0.7.1"
|
version = "0.7.1"
|
||||||
@ -1419,7 +1372,7 @@ version = "0.2.3"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7245cd7449cc792608c3c8a9eaf69bd4eabbabf802713748fd739c98b82f0747"
|
checksum = "7245cd7449cc792608c3c8a9eaf69bd4eabbabf802713748fd739c98b82f0747"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"fnv",
|
"fnv",
|
||||||
"itoa",
|
"itoa",
|
||||||
]
|
]
|
||||||
@ -1430,7 +1383,7 @@ version = "0.4.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "2861bd27ee074e5ee891e8b539837a9430012e249d7f0ca2d795650f579c1994"
|
checksum = "2861bd27ee074e5ee891e8b539837a9430012e249d7f0ca2d795650f579c1994"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"http",
|
"http",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -1452,7 +1405,7 @@ version = "0.14.2"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "12219dc884514cb4a6a03737f4413c0e01c23a1b059b0156004b23f1e19dccbe"
|
checksum = "12219dc884514cb4a6a03737f4413c0e01c23a1b059b0156004b23f1e19dccbe"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures-channel",
|
"futures-channel",
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
@ -1464,7 +1417,7 @@ dependencies = [
|
|||||||
"itoa",
|
"itoa",
|
||||||
"pin-project 1.0.4",
|
"pin-project 1.0.4",
|
||||||
"socket2",
|
"socket2",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tower-service",
|
"tower-service",
|
||||||
"tracing",
|
"tracing",
|
||||||
"want",
|
"want",
|
||||||
@ -1476,10 +1429,10 @@ version = "0.5.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905"
|
checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"hyper",
|
"hyper",
|
||||||
"native-tls",
|
"native-tls",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tokio-native-tls",
|
"tokio-native-tls",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -1592,7 +1545,8 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "jsonrpc_client"
|
name = "jsonrpc_client"
|
||||||
version = "0.5.0"
|
version = "0.5.0"
|
||||||
source = "git+https://github.com/thomaseizinger/rust-jsonrpc-client?rev=f60c839481c1ac68909ada0141a3a3bf085bb1af#f60c839481c1ac68909ada0141a3a3bf085bb1af"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "18fb8fc4b9e0b44f34346238c1e39e59067747ae7913b2e3d903b56e6c2c8062"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"jsonrpc_client_macro",
|
"jsonrpc_client_macro",
|
||||||
@ -1605,7 +1559,8 @@ dependencies = [
|
|||||||
[[package]]
|
[[package]]
|
||||||
name = "jsonrpc_client_macro"
|
name = "jsonrpc_client_macro"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/thomaseizinger/rust-jsonrpc-client?rev=f60c839481c1ac68909ada0141a3a3bf085bb1af#f60c839481c1ac68909ada0141a3a3bf085bb1af"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "d5f3d1e50fefe4252d2e44c805663e73a8c0b2002b73f834ea055c8ed7fc46a8"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"quote",
|
"quote",
|
||||||
"syn",
|
"syn",
|
||||||
@ -1663,7 +1618,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "d5133112ce42be9482f6a87be92a605dd6bbc9e93c297aee77d172ff06908f3a"
|
checksum = "d5133112ce42be9482f6a87be92a605dd6bbc9e93c297aee77d172ff06908f3a"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"atomic",
|
"atomic",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures",
|
"futures",
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
"libp2p-core",
|
"libp2p-core",
|
||||||
@ -1753,7 +1708,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "2705dc94b01ab9e3779b42a09bbf3712e637ed213e875c30face247291a85af0"
|
checksum = "2705dc94b01ab9e3779b42a09bbf3712e637ed213e875c30face247291a85af0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"asynchronous-codec",
|
"asynchronous-codec",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures",
|
"futures",
|
||||||
"libp2p-core",
|
"libp2p-core",
|
||||||
"log",
|
"log",
|
||||||
@ -1770,8 +1725,8 @@ version = "0.29.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "4aca322b52a0c5136142a7c3971446fb1e9964923a526c9cc6ef3b7c94e57778"
|
checksum = "4aca322b52a0c5136142a7c3971446fb1e9964923a526c9cc6ef3b7c94e57778"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"curve25519-dalek 3.0.2",
|
"curve25519-dalek",
|
||||||
"futures",
|
"futures",
|
||||||
"lazy_static",
|
"lazy_static",
|
||||||
"libp2p-core",
|
"libp2p-core",
|
||||||
@ -1793,7 +1748,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "d37637a4b33b5390322ccc068a33897d0aa541daf4fec99f6a7efbf37295346e"
|
checksum = "d37637a4b33b5390322ccc068a33897d0aa541daf4fec99f6a7efbf37295346e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"async-trait",
|
"async-trait",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures",
|
"futures",
|
||||||
"libp2p-core",
|
"libp2p-core",
|
||||||
"libp2p-swarm",
|
"libp2p-swarm",
|
||||||
@ -1838,7 +1793,7 @@ dependencies = [
|
|||||||
"libp2p-core",
|
"libp2p-core",
|
||||||
"log",
|
"log",
|
||||||
"socket2",
|
"socket2",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -1967,9 +1922,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "miniscript"
|
name = "miniscript"
|
||||||
version = "4.0.3"
|
version = "5.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "74ff4ece4ff5498718a232e92d53273903609c739052f5edf2a1a42c59586348"
|
checksum = "71f455be59a359d50370c4f587afbc5739c862e684c5afecae80ab93e7474b4e"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bitcoin",
|
"bitcoin",
|
||||||
"serde",
|
"serde",
|
||||||
@ -2000,13 +1955,13 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "monero"
|
name = "monero"
|
||||||
version = "0.9.1"
|
version = "0.10.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d53d4207d0bd4d1eb3323e33a64f9ea99e5e3d257d5cd7a659fad5be48c8b9af"
|
checksum = "f1bcc1c3dcf247dbbad3aa6497c7393d860c7e89de1f0d05438b63feb0cea9a0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"base58-monero",
|
"base58-monero",
|
||||||
"byteorder",
|
"byteorder",
|
||||||
"curve25519-dalek 2.1.2",
|
"curve25519-dalek",
|
||||||
"fixed-hash 0.3.2",
|
"fixed-hash 0.3.2",
|
||||||
"hex 0.4.2",
|
"hex 0.4.2",
|
||||||
"keccak-hash 0.3.0",
|
"keccak-hash 0.3.0",
|
||||||
@ -2029,7 +1984,7 @@ dependencies = [
|
|||||||
"serde_json",
|
"serde_json",
|
||||||
"spectral",
|
"spectral",
|
||||||
"testcontainers 0.12.0",
|
"testcontainers 0.12.0",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tracing",
|
"tracing",
|
||||||
"tracing-log",
|
"tracing-log",
|
||||||
"tracing-subscriber",
|
"tracing-subscriber",
|
||||||
@ -2075,7 +2030,7 @@ version = "0.10.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "10ddc0eb0117736f19d556355464fc87efc8ad98b29e3fd84f02531eb6e90840"
|
checksum = "10ddc0eb0117736f19d556355464fc87efc8ad98b29e3fd84f02531eb6e90840"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures",
|
"futures",
|
||||||
"log",
|
"log",
|
||||||
"pin-project 1.0.4",
|
"pin-project 1.0.4",
|
||||||
@ -2404,12 +2359,6 @@ dependencies = [
|
|||||||
"syn",
|
"syn",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "pin-project-lite"
|
|
||||||
version = "0.1.11"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "c917123afa01924fc84bb20c4c03f004d9c38e5127e3c039bbf7f4b9c76a2f6b"
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "pin-project-lite"
|
name = "pin-project-lite"
|
||||||
version = "0.2.4"
|
version = "0.2.4"
|
||||||
@ -2559,7 +2508,7 @@ version = "0.7.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "9e6984d2f1a23009bd270b8bb56d0926810a3d483f59c987d77969e9d8e840b2"
|
checksum = "9e6984d2f1a23009bd270b8bb56d0926810a3d483f59c987d77969e9d8e840b2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"prost-derive",
|
"prost-derive",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -2569,7 +2518,7 @@ version = "0.7.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "32d3ebd75ac2679c2af3a92246639f9fcc8a442ee420719cc4fe195b98dd5fa3"
|
checksum = "32d3ebd75ac2679c2af3a92246639f9fcc8a442ee420719cc4fe195b98dd5fa3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"heck",
|
"heck",
|
||||||
"itertools",
|
"itertools",
|
||||||
"log",
|
"log",
|
||||||
@ -2600,7 +2549,7 @@ version = "0.7.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "b518d7cdd93dab1d1122cf07fa9a60771836c668dde9d9e2a139f957f0d9f1bb"
|
checksum = "b518d7cdd93dab1d1122cf07fa9a60771836c668dde9d9e2a139f957f0d9f1bb"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"prost",
|
"prost",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -2918,7 +2867,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "fd281b1030aa675fb90aa994d07187645bb3c8fc756ca766e7c3070b439de9de"
|
checksum = "fd281b1030aa675fb90aa994d07187645bb3c8fc756ca766e7c3070b439de9de"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"base64 0.13.0",
|
"base64 0.13.0",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"encoding_rs",
|
"encoding_rs",
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
@ -2933,11 +2882,11 @@ dependencies = [
|
|||||||
"mime",
|
"mime",
|
||||||
"native-tls",
|
"native-tls",
|
||||||
"percent-encoding",
|
"percent-encoding",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"serde",
|
"serde",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"serde_urlencoded",
|
"serde_urlencoded",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tokio-native-tls",
|
"tokio-native-tls",
|
||||||
"url",
|
"url",
|
||||||
"wasm-bindgen",
|
"wasm-bindgen",
|
||||||
@ -3063,9 +3012,9 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "secp256k1"
|
name = "secp256k1"
|
||||||
version = "0.19.0"
|
version = "0.20.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "c6179428c22c73ac0fbb7b5579a56353ce78ba29759b3b8575183336ea74cdfb"
|
checksum = "733b114f058f260c0af7591434eef4272ae1a8ec2751766d3cb89c6df8d5e450"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"rand 0.6.5",
|
"rand 0.6.5",
|
||||||
"secp256k1-sys",
|
"secp256k1-sys",
|
||||||
@ -3074,17 +3023,17 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "secp256k1-sys"
|
name = "secp256k1-sys"
|
||||||
version = "0.3.0"
|
version = "0.4.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "11553d210db090930f4432bea123b31f70bbf693ace14504ea2a35e796c28dd2"
|
checksum = "67e4b6455ee49f5901c8985b88f98fb0a0e1d90a6661f5a03f4888bd987dad29"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cc",
|
"cc",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "secp256kfun"
|
name = "secp256kfun"
|
||||||
version = "0.3.2-alpha.0"
|
version = "0.4.2-alpha.0"
|
||||||
source = "git+https://github.com/LLFourn/secp256kfun?rev=cdfbc766045ea678a41780919d6228dd5acee3be#cdfbc766045ea678a41780919d6228dd5acee3be"
|
source = "git+https://github.com/LLFourn/secp256kfun#8538ef22498170960a9769df2700c1986cc540fd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"digest 0.9.0",
|
"digest 0.9.0",
|
||||||
"rand_core 0.5.1",
|
"rand_core 0.5.1",
|
||||||
@ -3096,8 +3045,8 @@ dependencies = [
|
|||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "secp256kfun_parity_backend"
|
name = "secp256kfun_parity_backend"
|
||||||
version = "0.1.3-alpha.0"
|
version = "0.1.4-alpha.0"
|
||||||
source = "git+https://github.com/LLFourn/secp256kfun?rev=cdfbc766045ea678a41780919d6228dd5acee3be#cdfbc766045ea678a41780919d6228dd5acee3be"
|
source = "git+https://github.com/LLFourn/secp256kfun#8538ef22498170960a9769df2700c1986cc540fd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"crunchy 0.2.2",
|
"crunchy 0.2.2",
|
||||||
"subtle 2.4.0",
|
"subtle 2.4.0",
|
||||||
@ -3253,6 +3202,19 @@ dependencies = [
|
|||||||
"lazy_static",
|
"lazy_static",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "sigma_fun"
|
||||||
|
version = "0.1.3-alpha.0"
|
||||||
|
source = "git+https://github.com/LLFourn/secp256kfun#8538ef22498170960a9769df2700c1986cc540fd"
|
||||||
|
dependencies = [
|
||||||
|
"curve25519-dalek",
|
||||||
|
"digest 0.9.0",
|
||||||
|
"generic-array 0.14.4",
|
||||||
|
"rand_core 0.5.1",
|
||||||
|
"secp256kfun",
|
||||||
|
"serde",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "signature"
|
name = "signature"
|
||||||
version = "1.3.0"
|
version = "1.3.0"
|
||||||
@ -3501,8 +3463,7 @@ dependencies = [
|
|||||||
"bitcoin-harness",
|
"bitcoin-harness",
|
||||||
"config",
|
"config",
|
||||||
"conquer-once",
|
"conquer-once",
|
||||||
"cross-curve-dleq",
|
"curve25519-dalek",
|
||||||
"curve25519-dalek 2.1.2",
|
|
||||||
"derivative",
|
"derivative",
|
||||||
"dialoguer",
|
"dialoguer",
|
||||||
"directories-next",
|
"directories-next",
|
||||||
@ -3521,6 +3482,7 @@ dependencies = [
|
|||||||
"port_check",
|
"port_check",
|
||||||
"prettytable-rs",
|
"prettytable-rs",
|
||||||
"rand 0.7.3",
|
"rand 0.7.3",
|
||||||
|
"rand_chacha 0.2.2",
|
||||||
"reqwest",
|
"reqwest",
|
||||||
"rust_decimal",
|
"rust_decimal",
|
||||||
"serde",
|
"serde",
|
||||||
@ -3528,6 +3490,7 @@ dependencies = [
|
|||||||
"serde_derive",
|
"serde_derive",
|
||||||
"serde_json",
|
"serde_json",
|
||||||
"sha2 0.9.2",
|
"sha2 0.9.2",
|
||||||
|
"sigma_fun",
|
||||||
"sled",
|
"sled",
|
||||||
"spectral",
|
"spectral",
|
||||||
"structopt",
|
"structopt",
|
||||||
@ -3536,7 +3499,7 @@ dependencies = [
|
|||||||
"testcontainers 0.12.0",
|
"testcontainers 0.12.0",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
"time",
|
"time",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"toml",
|
"toml",
|
||||||
"tracing",
|
"tracing",
|
||||||
"tracing-core",
|
"tracing-core",
|
||||||
@ -3737,17 +3700,6 @@ version = "0.1.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c"
|
checksum = "cda74da7e1a664f795bb1f8a87ec406fb89a02522cf6e50620d016add6dbbf5c"
|
||||||
|
|
||||||
[[package]]
|
|
||||||
name = "tokio"
|
|
||||||
version = "0.2.25"
|
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
|
||||||
checksum = "6703a273949a90131b290be1fe7b039d0fc884aa1935860dfcbe056f28cd8092"
|
|
||||||
dependencies = [
|
|
||||||
"bytes 0.5.6",
|
|
||||||
"pin-project-lite 0.1.11",
|
|
||||||
"slab",
|
|
||||||
]
|
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio"
|
name = "tokio"
|
||||||
version = "1.0.2"
|
version = "1.0.2"
|
||||||
@ -3755,12 +3707,12 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "0ca04cec6ff2474c638057b65798f60ac183e5e79d3448bb7163d36a39cff6ec"
|
checksum = "0ca04cec6ff2474c638057b65798f60ac183e5e79d3448bb7163d36a39cff6ec"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"autocfg 1.0.1",
|
"autocfg 1.0.1",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"libc",
|
"libc",
|
||||||
"memchr",
|
"memchr",
|
||||||
"mio",
|
"mio",
|
||||||
"num_cpus",
|
"num_cpus",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"tokio-macros",
|
"tokio-macros",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -3782,7 +3734,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "f7d995660bd2b7f8c1568414c1126076c13fbb725c40112dc0120b78eb9b717b"
|
checksum = "f7d995660bd2b7f8c1568414c1126076c13fbb725c40112dc0120b78eb9b717b"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"native-tls",
|
"native-tls",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -3792,8 +3744,8 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "76066865172052eb8796c686f0b441a93df8b08d40a950b062ffb9a426f00edd"
|
checksum = "76066865172052eb8796c686f0b441a93df8b08d40a950b062ffb9a426f00edd"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
@ -3802,12 +3754,12 @@ version = "0.6.1"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "12ae4751faa60b9f96dd8344d74592e5a17c0c9a220413dbc6942d14139bbfcc"
|
checksum = "12ae4751faa60b9f96dd8344d74592e5a17c0c9a220413dbc6942d14139bbfcc"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures-core",
|
"futures-core",
|
||||||
"futures-sink",
|
"futures-sink",
|
||||||
"log",
|
"log",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"tokio 1.0.2",
|
"tokio",
|
||||||
"tokio-stream",
|
"tokio-stream",
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -3833,7 +3785,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "9f47026cdc4080c07e49b37087de021820269d996f581aac150ef9e5583eefe3"
|
checksum = "9f47026cdc4080c07e49b37087de021820269d996f581aac150ef9e5583eefe3"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"cfg-if 1.0.0",
|
"cfg-if 1.0.0",
|
||||||
"pin-project-lite 0.2.4",
|
"pin-project-lite",
|
||||||
"tracing-attributes",
|
"tracing-attributes",
|
||||||
"tracing-core",
|
"tracing-core",
|
||||||
]
|
]
|
||||||
@ -3992,7 +3944,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
|
|||||||
checksum = "35581ff83d4101e58b582e607120c7f5ffb17e632a980b1f38334d76b36908b2"
|
checksum = "35581ff83d4101e58b582e607120c7f5ffb17e632a980b1f38334d76b36908b2"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"asynchronous-codec",
|
"asynchronous-codec",
|
||||||
"bytes 1.0.1",
|
"bytes",
|
||||||
"futures-io",
|
"futures-io",
|
||||||
"futures-util",
|
"futures-util",
|
||||||
]
|
]
|
||||||
@ -4283,7 +4235,7 @@ version = "1.1.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "bc614d95359fd7afc321b66d2107ede58b246b844cf5d8a0adcca413e439f088"
|
checksum = "bc614d95359fd7afc321b66d2107ede58b246b844cf5d8a0adcca413e439f088"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"curve25519-dalek 3.0.2",
|
"curve25519-dalek",
|
||||||
"rand_core 0.5.1",
|
"rand_core 0.5.1",
|
||||||
"zeroize 1.2.0",
|
"zeroize 1.2.0",
|
||||||
]
|
]
|
||||||
|
@ -18,28 +18,28 @@ async-trait = "0.1"
|
|||||||
atty = "0.2"
|
atty = "0.2"
|
||||||
backoff = { git = "https://github.com/ihrwein/backoff", rev = "9d03992a83dfdc596be26276d4e5c5254a4b11a2", features = ["tokio"] }
|
backoff = { git = "https://github.com/ihrwein/backoff", rev = "9d03992a83dfdc596be26276d4e5c5254a4b11a2", features = ["tokio"] }
|
||||||
base64 = "0.12"
|
base64 = "0.12"
|
||||||
bdk = { version = "0.3" }
|
bdk = { version = "0.4" }
|
||||||
bitcoin = { version = "0.25", features = ["rand", "use-serde"] }
|
bitcoin = { version = "0.26", features = ["rand", "use-serde"] }
|
||||||
bitcoin-harness = { git = "https://github.com/coblox/bitcoin-harness-rs", rev = "ae2f6cd547496e680941c0910018bbe884128799" }
|
bitcoin-harness = { git = "https://github.com/coblox/bitcoin-harness-rs" }
|
||||||
config = { version = "0.10", default-features = false, features = ["toml"] }
|
config = { version = "0.10", default-features = false, features = ["toml"] }
|
||||||
conquer-once = "0.3"
|
conquer-once = "0.3"
|
||||||
cross-curve-dleq = { git = "https://github.com/comit-network/cross-curve-dleq", rev = "eddcdea1d1f16fa33ef581d1744014ece535c920", features = ["serde"] }
|
curve25519-dalek = "3"
|
||||||
curve25519-dalek = "2"
|
|
||||||
derivative = "2"
|
derivative = "2"
|
||||||
dialoguer = "0.7"
|
dialoguer = "0.7"
|
||||||
directories-next = "2"
|
directories-next = "2"
|
||||||
ecdsa_fun = { git = "https://github.com/LLFourn/secp256kfun", rev = "cdfbc766045ea678a41780919d6228dd5acee3be", features = ["libsecp_compat", "serde"] }
|
ecdsa_fun = { git = "https://github.com/LLFourn/secp256kfun", features = ["libsecp_compat", "serde"] }
|
||||||
ed25519-dalek = { version = "1.0.0-pre.4", features = ["serde"] }# Cannot be 1 because they depend on curve25519-dalek version 3
|
ed25519-dalek = { version = "1.0.0-pre.4", features = ["serde"] }# Cannot be 1 because they depend on curve25519-dalek version 3
|
||||||
futures = { version = "0.3", default-features = false }
|
futures = { version = "0.3", default-features = false }
|
||||||
libp2p = { version = "0.34", default-features = false, features = ["tcp-tokio", "yamux", "mplex", "dns", "noise", "request-response"] }
|
libp2p = { version = "0.34", default-features = false, features = ["tcp-tokio", "yamux", "mplex", "dns", "noise", "request-response"] }
|
||||||
libp2p-async-await = { git = "https://github.com/comit-network/rust-libp2p-async-await", rev = "1429cd780204624b4d244e7d8179fe6ff77988c3" }
|
libp2p-async-await = { git = "https://github.com/comit-network/rust-libp2p-async-await", rev = "1429cd780204624b4d244e7d8179fe6ff77988c3" }
|
||||||
log = { version = "0.4", features = ["serde"] }
|
log = { version = "0.4", features = ["serde"] }
|
||||||
miniscript = { version = "4", features = ["serde"] }
|
miniscript = { version = "5", features = ["serde"] }
|
||||||
monero = { version = "0.9", features = ["serde_support"] }
|
monero = { version = "0.10", features = ["serde_support"] }
|
||||||
monero-harness = { path = "../monero-harness" }
|
monero-harness = { path = "../monero-harness" }
|
||||||
pem = "0.8"
|
pem = "0.8"
|
||||||
prettytable-rs = "0.8"
|
prettytable-rs = "0.8"
|
||||||
rand = "0.7"
|
rand = "0.7"
|
||||||
|
rand_chacha = "0.2.0"
|
||||||
reqwest = { version = "0.11", default-features = false }
|
reqwest = { version = "0.11", default-features = false }
|
||||||
rust_decimal = "1.10"
|
rust_decimal = "1.10"
|
||||||
serde = { version = "1", features = ["derive"] }
|
serde = { version = "1", features = ["derive"] }
|
||||||
@ -47,6 +47,7 @@ serde_cbor = "0.11"
|
|||||||
serde_derive = "1.0"
|
serde_derive = "1.0"
|
||||||
serde_json = "1"
|
serde_json = "1"
|
||||||
sha2 = "0.9"
|
sha2 = "0.9"
|
||||||
|
sigma_fun = { git = "https://github.com/LLFourn/secp256kfun", features = ["ed25519", "serde"] }
|
||||||
sled = "0.34"
|
sled = "0.34"
|
||||||
structopt = "0.3"
|
structopt = "0.3"
|
||||||
strum = { version = "0.20", features = ["derive"] }
|
strum = { version = "0.20", features = ["derive"] }
|
||||||
|
@ -28,8 +28,13 @@ use ::bitcoin::{
|
|||||||
};
|
};
|
||||||
use anyhow::{anyhow, bail, Result};
|
use anyhow::{anyhow, bail, Result};
|
||||||
use async_trait::async_trait;
|
use async_trait::async_trait;
|
||||||
use ecdsa_fun::{adaptor::Adaptor, fun::Point, nonce::Deterministic, ECDSA};
|
use ecdsa_fun::{
|
||||||
use miniscript::{Descriptor, Segwitv0};
|
adaptor::{Adaptor, HashTranscript},
|
||||||
|
fun::Point,
|
||||||
|
nonce::Deterministic,
|
||||||
|
ECDSA,
|
||||||
|
};
|
||||||
|
use miniscript::{descriptor::Wsh, Descriptor, Segwitv0};
|
||||||
use rand::{CryptoRng, RngCore};
|
use rand::{CryptoRng, RngCore};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use sha2::Sha256;
|
use sha2::Sha256;
|
||||||
@ -93,7 +98,10 @@ impl SecretKey {
|
|||||||
|
|
||||||
// self = a, Y = S_b, digest = tx_refund
|
// self = a, Y = S_b, digest = tx_refund
|
||||||
pub fn encsign(&self, Y: PublicKey, digest: SigHash) -> EncryptedSignature {
|
pub fn encsign(&self, Y: PublicKey, digest: SigHash) -> EncryptedSignature {
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<
|
||||||
|
HashTranscript<Sha256, rand_chacha::ChaCha20Rng>,
|
||||||
|
Deterministic<Sha256>,
|
||||||
|
>::default();
|
||||||
|
|
||||||
adaptor.encrypted_sign(&self.inner, &Y.0, &digest.into_inner())
|
adaptor.encrypted_sign(&self.inner, &Y.0, &digest.into_inner())
|
||||||
}
|
}
|
||||||
@ -108,6 +116,12 @@ impl From<PublicKey> for Point {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl From<Point> for PublicKey {
|
||||||
|
fn from(p: Point) -> Self {
|
||||||
|
Self(p)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl From<Scalar> for SecretKey {
|
impl From<Scalar> for SecretKey {
|
||||||
fn from(scalar: Scalar) -> Self {
|
fn from(scalar: Scalar) -> Self {
|
||||||
let ecdsa = ECDSA::<()>::default();
|
let ecdsa = ECDSA::<()>::default();
|
||||||
@ -157,7 +171,7 @@ pub fn verify_encsig(
|
|||||||
digest: &SigHash,
|
digest: &SigHash,
|
||||||
encsig: &EncryptedSignature,
|
encsig: &EncryptedSignature,
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<HashTranscript<Sha256>, Deterministic<Sha256>>::default();
|
||||||
|
|
||||||
if adaptor.verify_encrypted_signature(
|
if adaptor.verify_encrypted_signature(
|
||||||
&verification_key.0,
|
&verification_key.0,
|
||||||
@ -187,7 +201,7 @@ pub fn build_shared_output_descriptor(A: Point, B: Point) -> Descriptor<bitcoin:
|
|||||||
let miniscript = miniscript::Miniscript::<bitcoin::PublicKey, Segwitv0>::from_str(&miniscript)
|
let miniscript = miniscript::Miniscript::<bitcoin::PublicKey, Segwitv0>::from_str(&miniscript)
|
||||||
.expect("a valid miniscript");
|
.expect("a valid miniscript");
|
||||||
|
|
||||||
Descriptor::Wsh(miniscript)
|
Descriptor::Wsh(Wsh::new(miniscript).expect("a valid descriptor"))
|
||||||
}
|
}
|
||||||
|
|
||||||
#[async_trait]
|
#[async_trait]
|
||||||
@ -244,7 +258,7 @@ pub trait GetNetwork {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn recover(S: PublicKey, sig: Signature, encsig: EncryptedSignature) -> Result<SecretKey> {
|
pub fn recover(S: PublicKey, sig: Signature, encsig: EncryptedSignature) -> Result<SecretKey> {
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<HashTranscript<Sha256>, Deterministic<Sha256>>::default();
|
||||||
|
|
||||||
let s = adaptor
|
let s = adaptor
|
||||||
.recover_decryption_key(&S.0, &sig, &encsig)
|
.recover_decryption_key(&S.0, &sig, &encsig)
|
||||||
|
@ -5,7 +5,7 @@ use crate::bitcoin::{
|
|||||||
use ::bitcoin::{util::bip143::SigHashCache, OutPoint, SigHash, SigHashType, TxIn, TxOut, Txid};
|
use ::bitcoin::{util::bip143::SigHashCache, OutPoint, SigHash, SigHashType, TxIn, TxOut, Txid};
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use ecdsa_fun::Signature;
|
use ecdsa_fun::Signature;
|
||||||
use miniscript::{Descriptor, NullCtx};
|
use miniscript::{Descriptor, DescriptorTrait};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::{collections::HashMap, ops::Add};
|
use std::{collections::HashMap, ops::Add};
|
||||||
|
|
||||||
@ -78,7 +78,7 @@ impl TxCancel {
|
|||||||
|
|
||||||
let tx_out = TxOut {
|
let tx_out = TxOut {
|
||||||
value: tx_lock.lock_amount().as_sat() - TX_FEE,
|
value: tx_lock.lock_amount().as_sat() - TX_FEE,
|
||||||
script_pubkey: cancel_output_descriptor.script_pubkey(NullCtx),
|
script_pubkey: cancel_output_descriptor.script_pubkey(),
|
||||||
};
|
};
|
||||||
|
|
||||||
let transaction = Transaction {
|
let transaction = Transaction {
|
||||||
@ -90,7 +90,7 @@ impl TxCancel {
|
|||||||
|
|
||||||
let digest = SigHashCache::new(&transaction).signature_hash(
|
let digest = SigHashCache::new(&transaction).signature_hash(
|
||||||
0, // Only one input: lock_input (lock transaction)
|
0, // Only one input: lock_input (lock transaction)
|
||||||
&tx_lock.output_descriptor.witness_script(NullCtx),
|
&tx_lock.output_descriptor.script_code(),
|
||||||
tx_lock.lock_amount().as_sat(),
|
tx_lock.lock_amount().as_sat(),
|
||||||
SigHashType::All,
|
SigHashType::All,
|
||||||
);
|
);
|
||||||
@ -146,7 +146,7 @@ impl TxCancel {
|
|||||||
let mut tx_cancel = self.inner;
|
let mut tx_cancel = self.inner;
|
||||||
tx_lock
|
tx_lock
|
||||||
.output_descriptor
|
.output_descriptor
|
||||||
.satisfy(&mut tx_cancel.input[0], satisfier, NullCtx)?;
|
.satisfy(&mut tx_cancel.input[0], satisfier)?;
|
||||||
|
|
||||||
Ok(tx_cancel)
|
Ok(tx_cancel)
|
||||||
}
|
}
|
||||||
|
@ -4,7 +4,7 @@ use crate::bitcoin::{
|
|||||||
};
|
};
|
||||||
use ::bitcoin::{util::psbt::PartiallySignedTransaction, OutPoint, TxIn, TxOut, Txid};
|
use ::bitcoin::{util::psbt::PartiallySignedTransaction, OutPoint, TxIn, TxOut, Txid};
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use miniscript::{Descriptor, NullCtx};
|
use miniscript::{Descriptor, DescriptorTrait};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
|
||||||
#[derive(Debug, Clone, Serialize, Deserialize, PartialEq)]
|
#[derive(Debug, Clone, Serialize, Deserialize, PartialEq)]
|
||||||
@ -20,7 +20,7 @@ impl TxLock {
|
|||||||
{
|
{
|
||||||
let lock_output_descriptor = build_shared_output_descriptor(A.0, B.0);
|
let lock_output_descriptor = build_shared_output_descriptor(A.0, B.0);
|
||||||
let address = lock_output_descriptor
|
let address = lock_output_descriptor
|
||||||
.address(wallet.get_network().await, NullCtx)
|
.address(wallet.get_network().await)
|
||||||
.expect("can derive address from descriptor");
|
.expect("can derive address from descriptor");
|
||||||
|
|
||||||
let psbt = wallet.build_tx_lock_psbt(address, amount).await?;
|
let psbt = wallet.build_tx_lock_psbt(address, amount).await?;
|
||||||
@ -54,9 +54,7 @@ impl TxLock {
|
|||||||
.extract_tx()
|
.extract_tx()
|
||||||
.output
|
.output
|
||||||
.iter()
|
.iter()
|
||||||
.position(|output| {
|
.position(|output| output.script_pubkey == self.output_descriptor.script_pubkey())
|
||||||
output.script_pubkey == self.output_descriptor.script_pubkey(NullCtx)
|
|
||||||
})
|
|
||||||
.expect("transaction contains lock output")
|
.expect("transaction contains lock output")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@ use crate::bitcoin::{Address, PublicKey, PunishTimelock, Transaction, TxCancel};
|
|||||||
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType};
|
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType};
|
||||||
use anyhow::Result;
|
use anyhow::Result;
|
||||||
use ecdsa_fun::Signature;
|
use ecdsa_fun::Signature;
|
||||||
use miniscript::NullCtx;
|
use miniscript::DescriptorTrait;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
@ -21,7 +21,7 @@ impl TxPunish {
|
|||||||
|
|
||||||
let digest = SigHashCache::new(&tx_punish).signature_hash(
|
let digest = SigHashCache::new(&tx_punish).signature_hash(
|
||||||
0, // Only one input: cancel transaction
|
0, // Only one input: cancel transaction
|
||||||
&tx_cancel.output_descriptor.witness_script(NullCtx),
|
&tx_cancel.output_descriptor.script_code(),
|
||||||
tx_cancel.amount().as_sat(),
|
tx_cancel.amount().as_sat(),
|
||||||
SigHashType::All,
|
SigHashType::All,
|
||||||
);
|
);
|
||||||
@ -64,7 +64,7 @@ impl TxPunish {
|
|||||||
let mut tx_punish = self.inner;
|
let mut tx_punish = self.inner;
|
||||||
tx_cancel
|
tx_cancel
|
||||||
.output_descriptor
|
.output_descriptor
|
||||||
.satisfy(&mut tx_punish.input[0], satisfier, NullCtx)?;
|
.satisfy(&mut tx_punish.input[0], satisfier)?;
|
||||||
|
|
||||||
Ok(tx_punish)
|
Ok(tx_punish)
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ use crate::bitcoin::{
|
|||||||
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType, Txid};
|
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType, Txid};
|
||||||
use anyhow::{bail, Context, Result};
|
use anyhow::{bail, Context, Result};
|
||||||
use ecdsa_fun::Signature;
|
use ecdsa_fun::Signature;
|
||||||
use miniscript::NullCtx;
|
use miniscript::DescriptorTrait;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
@ -22,7 +22,7 @@ impl TxRedeem {
|
|||||||
|
|
||||||
let digest = SigHashCache::new(&tx_redeem).signature_hash(
|
let digest = SigHashCache::new(&tx_redeem).signature_hash(
|
||||||
0, // Only one input: lock_input (lock transaction)
|
0, // Only one input: lock_input (lock transaction)
|
||||||
&tx_lock.output_descriptor.witness_script(NullCtx),
|
&tx_lock.output_descriptor.script_code(),
|
||||||
tx_lock.lock_amount().as_sat(),
|
tx_lock.lock_amount().as_sat(),
|
||||||
SigHashType::All,
|
SigHashType::All,
|
||||||
);
|
);
|
||||||
@ -69,7 +69,7 @@ impl TxRedeem {
|
|||||||
let mut tx_redeem = self.inner;
|
let mut tx_redeem = self.inner;
|
||||||
tx_lock
|
tx_lock
|
||||||
.output_descriptor
|
.output_descriptor
|
||||||
.satisfy(&mut tx_redeem.input[0], satisfier, NullCtx)?;
|
.satisfy(&mut tx_redeem.input[0], satisfier)?;
|
||||||
|
|
||||||
Ok(tx_redeem)
|
Ok(tx_redeem)
|
||||||
}
|
}
|
||||||
|
@ -5,7 +5,7 @@ use crate::bitcoin::{
|
|||||||
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType, Txid};
|
use ::bitcoin::{util::bip143::SigHashCache, SigHash, SigHashType, Txid};
|
||||||
use anyhow::{bail, Context, Result};
|
use anyhow::{bail, Context, Result};
|
||||||
use ecdsa_fun::Signature;
|
use ecdsa_fun::Signature;
|
||||||
use miniscript::NullCtx;
|
use miniscript::DescriptorTrait;
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
@ -20,7 +20,7 @@ impl TxRefund {
|
|||||||
|
|
||||||
let digest = SigHashCache::new(&tx_punish).signature_hash(
|
let digest = SigHashCache::new(&tx_punish).signature_hash(
|
||||||
0, // Only one input: cancel transaction
|
0, // Only one input: cancel transaction
|
||||||
&tx_cancel.output_descriptor.witness_script(NullCtx),
|
&tx_cancel.output_descriptor.script_code(),
|
||||||
tx_cancel.amount().as_sat(),
|
tx_cancel.amount().as_sat(),
|
||||||
SigHashType::All,
|
SigHashType::All,
|
||||||
);
|
);
|
||||||
@ -67,7 +67,7 @@ impl TxRefund {
|
|||||||
let mut tx_refund = self.inner;
|
let mut tx_refund = self.inner;
|
||||||
tx_cancel
|
tx_cancel
|
||||||
.output_descriptor
|
.output_descriptor
|
||||||
.satisfy(&mut tx_refund.input[0], satisfier, NullCtx)?;
|
.satisfy(&mut tx_refund.input[0], satisfier)?;
|
||||||
|
|
||||||
Ok(tx_refund)
|
Ok(tx_refund)
|
||||||
}
|
}
|
||||||
|
@ -125,14 +125,12 @@ impl BuildTxLockPsbt for Wallet {
|
|||||||
output_amount: Amount,
|
output_amount: Amount,
|
||||||
) -> Result<PartiallySignedTransaction> {
|
) -> Result<PartiallySignedTransaction> {
|
||||||
tracing::debug!("building tx lock");
|
tracing::debug!("building tx lock");
|
||||||
let (psbt, _details) = self.inner.lock().await.create_tx(
|
let wallet = self.inner.lock().await;
|
||||||
bdk::TxBuilder::with_recipients(vec![(
|
|
||||||
output_address.script_pubkey(),
|
let mut tx_builder = wallet.build_tx();
|
||||||
output_amount.as_sat(),
|
tx_builder.add_recipient(output_address.script_pubkey(), output_amount.as_sat());
|
||||||
)])
|
tx_builder.fee_rate(FeeRate::from_sat_per_vb(5.0)); // todo: get actual fee
|
||||||
// todo: get actual fee
|
let (psbt, _details) = tx_builder.finish()?;
|
||||||
.fee_rate(FeeRate::from_sat_per_vb(5.0)),
|
|
||||||
)?;
|
|
||||||
tracing::debug!("tx lock built");
|
tracing::debug!("tx lock built");
|
||||||
Ok(psbt)
|
Ok(psbt)
|
||||||
}
|
}
|
||||||
|
@ -27,5 +27,6 @@ pub mod protocol;
|
|||||||
pub mod seed;
|
pub mod seed;
|
||||||
pub mod trace;
|
pub mod trace;
|
||||||
|
|
||||||
|
mod monero_ext;
|
||||||
mod network;
|
mod network;
|
||||||
mod serde_peer_id;
|
mod serde_peer_id;
|
||||||
|
20
swap/src/monero_ext.rs
Normal file
20
swap/src/monero_ext.rs
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
use crate::bitcoin::Scalar;
|
||||||
|
use ecdsa_fun::fun::marker::{Mark, NonZero, Secret};
|
||||||
|
|
||||||
|
pub trait ScalarExt {
|
||||||
|
fn to_secpfun_scalar(&self) -> ecdsa_fun::fun::Scalar;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ScalarExt for crate::monero::Scalar {
|
||||||
|
fn to_secpfun_scalar(&self) -> Scalar<Secret, NonZero> {
|
||||||
|
let mut little_endian_bytes = self.to_bytes();
|
||||||
|
|
||||||
|
little_endian_bytes.reverse();
|
||||||
|
let big_endian_bytes = little_endian_bytes;
|
||||||
|
|
||||||
|
ecdsa_fun::fun::Scalar::from_bytes(big_endian_bytes)
|
||||||
|
.expect("valid scalar")
|
||||||
|
.mark::<NonZero>()
|
||||||
|
.expect("non-zero scalar")
|
||||||
|
}
|
||||||
|
}
|
@ -12,13 +12,14 @@ use anyhow::{Context, Error};
|
|||||||
use libp2p::PeerId;
|
use libp2p::PeerId;
|
||||||
use libp2p_async_await::BehaviourOutEvent;
|
use libp2p_async_await::BehaviourOutEvent;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
use sigma_fun::ext::dl_secp256k1_ed25519_eq::CrossCurveDLEQProof;
|
||||||
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
pub struct Message1 {
|
pub struct Message1 {
|
||||||
pub(crate) A: bitcoin::PublicKey,
|
pub(crate) A: bitcoin::PublicKey,
|
||||||
pub(crate) S_a_monero: monero::PublicKey,
|
pub(crate) S_a_monero: monero::PublicKey,
|
||||||
pub(crate) S_a_bitcoin: bitcoin::PublicKey,
|
pub(crate) S_a_bitcoin: bitcoin::PublicKey,
|
||||||
pub(crate) dleq_proof_s_a: cross_curve_dleq::Proof,
|
pub(crate) dleq_proof_s_a: CrossCurveDLEQProof,
|
||||||
pub(crate) v_a: monero::PrivateViewKey,
|
pub(crate) v_a: monero::PrivateViewKey,
|
||||||
pub(crate) redeem_address: bitcoin::Address,
|
pub(crate) redeem_address: bitcoin::Address,
|
||||||
pub(crate) punish_address: bitcoin::Address,
|
pub(crate) punish_address: bitcoin::Address,
|
||||||
|
@ -7,17 +7,23 @@ use crate::{
|
|||||||
},
|
},
|
||||||
execution_params::ExecutionParams,
|
execution_params::ExecutionParams,
|
||||||
monero,
|
monero,
|
||||||
|
monero_ext::ScalarExt,
|
||||||
protocol::{
|
protocol::{
|
||||||
alice::{Message1, Message3, TransferProof},
|
alice::{Message1, Message3, TransferProof},
|
||||||
bob::{EncryptedSignature, Message0, Message2, Message4},
|
bob::{EncryptedSignature, Message0, Message2, Message4},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
use anyhow::{anyhow, Context, Result};
|
use anyhow::{anyhow, bail, Context, Result};
|
||||||
use ecdsa_fun::{adaptor::Adaptor, nonce::Deterministic};
|
use ecdsa_fun::{
|
||||||
|
adaptor::{Adaptor, HashTranscript},
|
||||||
|
fun::marker::Mark,
|
||||||
|
nonce::Deterministic,
|
||||||
|
};
|
||||||
use libp2p::PeerId;
|
use libp2p::PeerId;
|
||||||
use rand::{CryptoRng, RngCore};
|
use rand::{CryptoRng, RngCore};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use sha2::Sha256;
|
use sha2::Sha256;
|
||||||
|
use sigma_fun::ext::dl_secp256k1_ed25519_eq::{CrossCurveDLEQ, CrossCurveDLEQProof};
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
@ -80,9 +86,11 @@ impl fmt::Display for AliceState {
|
|||||||
#[derive(Clone, Debug, Deserialize, Serialize, PartialEq)]
|
#[derive(Clone, Debug, Deserialize, Serialize, PartialEq)]
|
||||||
pub struct State0 {
|
pub struct State0 {
|
||||||
pub a: bitcoin::SecretKey,
|
pub a: bitcoin::SecretKey,
|
||||||
pub s_a: cross_curve_dleq::Scalar,
|
pub s_a: monero::Scalar,
|
||||||
pub v_a: monero::PrivateViewKey,
|
pub v_a: monero::PrivateViewKey,
|
||||||
pub dleq_proof_s_a: cross_curve_dleq::Proof,
|
pub(crate) S_a_monero: monero::PublicKey,
|
||||||
|
pub(crate) S_a_bitcoin: bitcoin::PublicKey,
|
||||||
|
pub dleq_proof_s_a: CrossCurveDLEQProof,
|
||||||
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
||||||
pub btc: bitcoin::Amount,
|
pub btc: bitcoin::Amount,
|
||||||
pub xmr: monero::Amount,
|
pub xmr: monero::Amount,
|
||||||
@ -104,16 +112,27 @@ impl State0 {
|
|||||||
R: RngCore + CryptoRng,
|
R: RngCore + CryptoRng,
|
||||||
{
|
{
|
||||||
let a = bitcoin::SecretKey::new_random(rng);
|
let a = bitcoin::SecretKey::new_random(rng);
|
||||||
let s_a = cross_curve_dleq::Scalar::random(rng);
|
|
||||||
let v_a = monero::PrivateViewKey::new_random(rng);
|
let v_a = monero::PrivateViewKey::new_random(rng);
|
||||||
let redeem_address = bitcoin_wallet.new_address().await?;
|
let redeem_address = bitcoin_wallet.new_address().await?;
|
||||||
let punish_address = redeem_address.clone();
|
let punish_address = redeem_address.clone();
|
||||||
let dleq_proof_s_a = cross_curve_dleq::Proof::new(rng, &s_a);
|
|
||||||
|
let dleq_proof_system =
|
||||||
|
CrossCurveDLEQ::<HashTranscript<Sha256, rand_chacha::ChaCha20Rng>>::new(
|
||||||
|
(*ecdsa_fun::fun::G).mark::<ecdsa_fun::fun::marker::Normal>(),
|
||||||
|
curve25519_dalek::constants::ED25519_BASEPOINT_POINT,
|
||||||
|
);
|
||||||
|
|
||||||
|
let s_a = monero::Scalar::random(rng);
|
||||||
|
let (dleq_proof_s_a, (S_a_bitcoin, S_a_monero)) = dleq_proof_system.prove(&s_a, rng);
|
||||||
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
a,
|
a,
|
||||||
s_a,
|
s_a,
|
||||||
v_a,
|
v_a,
|
||||||
|
S_a_bitcoin: S_a_bitcoin.into(),
|
||||||
|
S_a_monero: monero::PublicKey {
|
||||||
|
point: S_a_monero.compress(),
|
||||||
|
},
|
||||||
dleq_proof_s_a,
|
dleq_proof_s_a,
|
||||||
redeem_address,
|
redeem_address,
|
||||||
punish_address,
|
punish_address,
|
||||||
@ -125,13 +144,26 @@ impl State0 {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub fn receive(self, msg: Message0) -> Result<State1> {
|
pub fn receive(self, msg: Message0) -> Result<State1> {
|
||||||
msg.dleq_proof_s_b.verify(
|
let dleq_proof_system =
|
||||||
msg.S_b_bitcoin.clone().into(),
|
CrossCurveDLEQ::<HashTranscript<Sha256, rand_chacha::ChaCha20Rng>>::new(
|
||||||
msg.S_b_monero
|
(*ecdsa_fun::fun::G).mark::<ecdsa_fun::fun::marker::Normal>(),
|
||||||
.point
|
curve25519_dalek::constants::ED25519_BASEPOINT_POINT,
|
||||||
.decompress()
|
);
|
||||||
.ok_or_else(|| anyhow!("S_b is not a monero curve point"))?,
|
|
||||||
)?;
|
let valid = dleq_proof_system.verify(
|
||||||
|
&msg.dleq_proof_s_b,
|
||||||
|
(
|
||||||
|
msg.S_b_bitcoin.into(),
|
||||||
|
msg.S_b_monero
|
||||||
|
.point
|
||||||
|
.decompress()
|
||||||
|
.ok_or_else(|| anyhow!("S_b is not a monero curve point"))?,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
if !valid {
|
||||||
|
bail!("Bob's dleq proof doesn't verify")
|
||||||
|
}
|
||||||
|
|
||||||
let v = self.v_a + msg.v_b;
|
let v = self.v_a + msg.v_b;
|
||||||
|
|
||||||
@ -139,6 +171,8 @@ impl State0 {
|
|||||||
a: self.a,
|
a: self.a,
|
||||||
B: msg.B,
|
B: msg.B,
|
||||||
s_a: self.s_a,
|
s_a: self.s_a,
|
||||||
|
S_a_monero: self.S_a_monero,
|
||||||
|
S_a_bitcoin: self.S_a_bitcoin,
|
||||||
S_b_monero: msg.S_b_monero,
|
S_b_monero: msg.S_b_monero,
|
||||||
S_b_bitcoin: msg.S_b_bitcoin,
|
S_b_bitcoin: msg.S_b_bitcoin,
|
||||||
v,
|
v,
|
||||||
@ -159,12 +193,14 @@ impl State0 {
|
|||||||
pub struct State1 {
|
pub struct State1 {
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
|
S_a_monero: monero::PublicKey,
|
||||||
|
S_a_bitcoin: bitcoin::PublicKey,
|
||||||
S_b_monero: monero::PublicKey,
|
S_b_monero: monero::PublicKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
v_a: monero::PrivateViewKey,
|
v_a: monero::PrivateViewKey,
|
||||||
dleq_proof_s_a: cross_curve_dleq::Proof,
|
dleq_proof_s_a: CrossCurveDLEQProof,
|
||||||
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
||||||
btc: bitcoin::Amount,
|
btc: bitcoin::Amount,
|
||||||
xmr: monero::Amount,
|
xmr: monero::Amount,
|
||||||
@ -179,10 +215,8 @@ impl State1 {
|
|||||||
pub fn next_message(&self) -> Message1 {
|
pub fn next_message(&self) -> Message1 {
|
||||||
Message1 {
|
Message1 {
|
||||||
A: self.a.public(),
|
A: self.a.public(),
|
||||||
S_a_monero: monero::PublicKey::from_private_key(&monero::PrivateKey {
|
S_a_monero: self.S_a_monero,
|
||||||
scalar: self.s_a.into_ed25519(),
|
S_a_bitcoin: self.S_a_bitcoin,
|
||||||
}),
|
|
||||||
S_a_bitcoin: self.s_a.into_secp256k1().into(),
|
|
||||||
dleq_proof_s_a: self.dleq_proof_s_a.clone(),
|
dleq_proof_s_a: self.dleq_proof_s_a.clone(),
|
||||||
v_a: self.v_a,
|
v_a: self.v_a,
|
||||||
redeem_address: self.redeem_address.clone(),
|
redeem_address: self.redeem_address.clone(),
|
||||||
@ -214,7 +248,7 @@ impl State1 {
|
|||||||
pub struct State2 {
|
pub struct State2 {
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
S_b_monero: monero::PublicKey,
|
S_b_monero: monero::PublicKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -284,7 +318,7 @@ impl State2 {
|
|||||||
pub struct State3 {
|
pub struct State3 {
|
||||||
pub a: bitcoin::SecretKey,
|
pub a: bitcoin::SecretKey,
|
||||||
pub B: bitcoin::PublicKey,
|
pub B: bitcoin::PublicKey,
|
||||||
pub s_a: cross_curve_dleq::Scalar,
|
pub s_a: monero::Scalar,
|
||||||
pub S_b_monero: monero::PublicKey,
|
pub S_b_monero: monero::PublicKey,
|
||||||
pub S_b_bitcoin: bitcoin::PublicKey,
|
pub S_b_bitcoin: bitcoin::PublicKey,
|
||||||
pub v: monero::PrivateViewKey,
|
pub v: monero::PrivateViewKey,
|
||||||
@ -332,7 +366,7 @@ impl State3 {
|
|||||||
pub struct State4 {
|
pub struct State4 {
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
S_b_monero: monero::PublicKey,
|
S_b_monero: monero::PublicKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -352,9 +386,7 @@ impl State4 {
|
|||||||
where
|
where
|
||||||
W: monero::Transfer,
|
W: monero::Transfer,
|
||||||
{
|
{
|
||||||
let S_a = monero::PublicKey::from_private_key(&monero::PrivateKey {
|
let S_a = monero::PublicKey::from_private_key(&monero::PrivateKey { scalar: self.s_a });
|
||||||
scalar: self.s_a.into_ed25519(),
|
|
||||||
});
|
|
||||||
let S_b = self.S_b_monero;
|
let S_b = self.S_b_monero;
|
||||||
|
|
||||||
let (tx_lock_proof, fee) = monero_wallet
|
let (tx_lock_proof, fee) = monero_wallet
|
||||||
@ -425,7 +457,7 @@ impl State4 {
|
|||||||
pub struct State5 {
|
pub struct State5 {
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
S_b_monero: monero::PublicKey,
|
S_b_monero: monero::PublicKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -475,7 +507,7 @@ impl State5 {
|
|||||||
pub struct State6 {
|
pub struct State6 {
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
S_b_monero: monero::PublicKey,
|
S_b_monero: monero::PublicKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -496,13 +528,13 @@ impl State6 {
|
|||||||
&self,
|
&self,
|
||||||
bitcoin_wallet: &W,
|
bitcoin_wallet: &W,
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<HashTranscript<Sha256>, Deterministic<Sha256>>::default();
|
||||||
|
|
||||||
let tx_redeem = bitcoin::TxRedeem::new(&self.tx_lock, &self.redeem_address);
|
let tx_redeem = bitcoin::TxRedeem::new(&self.tx_lock, &self.redeem_address);
|
||||||
|
|
||||||
let sig_a = self.a.sign(tx_redeem.digest());
|
let sig_a = self.a.sign(tx_redeem.digest());
|
||||||
let sig_b =
|
let sig_b =
|
||||||
adaptor.decrypt_signature(&self.s_a.into_secp256k1(), self.tx_redeem_encsig.clone());
|
adaptor.decrypt_signature(&self.s_a.to_secpfun_scalar(), self.tx_redeem_encsig.clone());
|
||||||
|
|
||||||
let sig_tx_redeem =
|
let sig_tx_redeem =
|
||||||
tx_redeem.add_signatures(&self.tx_lock, (self.a.public(), sig_a), (self.B, sig_b))?;
|
tx_redeem.add_signatures(&self.tx_lock, (self.a.public(), sig_a), (self.B, sig_b))?;
|
||||||
|
@ -15,7 +15,10 @@ use crate::{
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
use anyhow::{Context, Result};
|
use anyhow::{Context, Result};
|
||||||
use ecdsa_fun::{adaptor::Adaptor, nonce::Deterministic};
|
use ecdsa_fun::{
|
||||||
|
adaptor::{Adaptor, HashTranscript},
|
||||||
|
nonce::Deterministic,
|
||||||
|
};
|
||||||
use futures::{
|
use futures::{
|
||||||
future::{select, Either},
|
future::{select, Either},
|
||||||
pin_mut,
|
pin_mut,
|
||||||
@ -61,9 +64,7 @@ pub async fn lock_xmr<W>(
|
|||||||
where
|
where
|
||||||
W: Transfer,
|
W: Transfer,
|
||||||
{
|
{
|
||||||
let S_a = monero::PublicKey::from_private_key(&monero::PrivateKey {
|
let S_a = monero::PublicKey::from_private_key(&monero::PrivateKey { scalar: state3.s_a });
|
||||||
scalar: state3.s_a.into_ed25519(),
|
|
||||||
});
|
|
||||||
|
|
||||||
let public_spend_key = S_a + state3.S_b_monero;
|
let public_spend_key = S_a + state3.S_b_monero;
|
||||||
let public_view_key = state3.v.public();
|
let public_view_key = state3.v.public();
|
||||||
@ -103,24 +104,24 @@ pub fn build_bitcoin_redeem_transaction(
|
|||||||
encrypted_signature: EncryptedSignature,
|
encrypted_signature: EncryptedSignature,
|
||||||
tx_lock: &TxLock,
|
tx_lock: &TxLock,
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: ecdsa_fun::fun::Scalar,
|
||||||
B: bitcoin::PublicKey,
|
B: bitcoin::PublicKey,
|
||||||
redeem_address: &bitcoin::Address,
|
redeem_address: &bitcoin::Address,
|
||||||
) -> Result<bitcoin::Transaction> {
|
) -> Result<bitcoin::Transaction> {
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<HashTranscript<Sha256>, Deterministic<Sha256>>::default();
|
||||||
|
|
||||||
let tx_redeem = bitcoin::TxRedeem::new(tx_lock, redeem_address);
|
let tx_redeem = bitcoin::TxRedeem::new(tx_lock, redeem_address);
|
||||||
|
|
||||||
bitcoin::verify_encsig(
|
bitcoin::verify_encsig(
|
||||||
B,
|
B,
|
||||||
s_a.into_secp256k1().into(),
|
bitcoin::PublicKey::from(s_a.clone()),
|
||||||
&tx_redeem.digest(),
|
&tx_redeem.digest(),
|
||||||
&encrypted_signature,
|
&encrypted_signature,
|
||||||
)
|
)
|
||||||
.context("Invalid encrypted signature received")?;
|
.context("Invalid encrypted signature received")?;
|
||||||
|
|
||||||
let sig_a = a.sign(tx_redeem.digest());
|
let sig_a = a.sign(tx_redeem.digest());
|
||||||
let sig_b = adaptor.decrypt_signature(&s_a.into_secp256k1(), encrypted_signature);
|
let sig_b = adaptor.decrypt_signature(&s_a, encrypted_signature);
|
||||||
|
|
||||||
let tx = tx_redeem
|
let tx = tx_redeem
|
||||||
.add_signatures(&tx_lock, (a.public(), sig_a), (B, sig_b))
|
.add_signatures(&tx_lock, (a.public(), sig_a), (B, sig_b))
|
||||||
@ -224,13 +225,11 @@ where
|
|||||||
pub fn extract_monero_private_key(
|
pub fn extract_monero_private_key(
|
||||||
published_refund_tx: bitcoin::Transaction,
|
published_refund_tx: bitcoin::Transaction,
|
||||||
tx_refund: TxRefund,
|
tx_refund: TxRefund,
|
||||||
s_a: cross_curve_dleq::Scalar,
|
s_a: monero::Scalar,
|
||||||
a: bitcoin::SecretKey,
|
a: bitcoin::SecretKey,
|
||||||
S_b_bitcoin: bitcoin::PublicKey,
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
) -> Result<monero::PrivateKey> {
|
) -> Result<monero::PrivateKey> {
|
||||||
let s_a = monero::PrivateKey {
|
let s_a = monero::PrivateKey { scalar: s_a };
|
||||||
scalar: s_a.into_ed25519(),
|
|
||||||
};
|
|
||||||
|
|
||||||
let tx_refund_sig = tx_refund
|
let tx_refund_sig = tx_refund
|
||||||
.extract_signature_by_key(published_refund_tx, a.public())
|
.extract_signature_by_key(published_refund_tx, a.public())
|
||||||
|
@ -11,6 +11,7 @@ use crate::{
|
|||||||
execution_params::ExecutionParams,
|
execution_params::ExecutionParams,
|
||||||
monero,
|
monero,
|
||||||
monero::CreateWalletForOutput,
|
monero::CreateWalletForOutput,
|
||||||
|
monero_ext::ScalarExt,
|
||||||
protocol::{
|
protocol::{
|
||||||
alice,
|
alice,
|
||||||
alice::{
|
alice::{
|
||||||
@ -199,7 +200,7 @@ async fn run_until_internal(
|
|||||||
*encrypted_signature,
|
*encrypted_signature,
|
||||||
&state3.tx_lock,
|
&state3.tx_lock,
|
||||||
state3.a.clone(),
|
state3.a.clone(),
|
||||||
state3.s_a,
|
state3.s_a.to_secpfun_scalar(),
|
||||||
state3.B,
|
state3.B,
|
||||||
&state3.redeem_address,
|
&state3.redeem_address,
|
||||||
) {
|
) {
|
||||||
|
@ -10,6 +10,7 @@ use anyhow::{Context, Error, Result};
|
|||||||
use libp2p::PeerId;
|
use libp2p::PeerId;
|
||||||
use libp2p_async_await::BehaviourOutEvent;
|
use libp2p_async_await::BehaviourOutEvent;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
|
use sigma_fun::ext::dl_secp256k1_ed25519_eq::CrossCurveDLEQProof;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
@ -17,7 +18,7 @@ pub struct Message0 {
|
|||||||
pub(crate) B: crate::bitcoin::PublicKey,
|
pub(crate) B: crate::bitcoin::PublicKey,
|
||||||
pub(crate) S_b_monero: monero::PublicKey,
|
pub(crate) S_b_monero: monero::PublicKey,
|
||||||
pub(crate) S_b_bitcoin: crate::bitcoin::PublicKey,
|
pub(crate) S_b_bitcoin: crate::bitcoin::PublicKey,
|
||||||
pub(crate) dleq_proof_s_b: cross_curve_dleq::Proof,
|
pub(crate) dleq_proof_s_b: CrossCurveDLEQProof,
|
||||||
pub(crate) v_b: crate::monero::PrivateViewKey,
|
pub(crate) v_b: crate::monero::PrivateViewKey,
|
||||||
pub(crate) refund_address: bitcoin::Address,
|
pub(crate) refund_address: bitcoin::Address,
|
||||||
}
|
}
|
||||||
|
@ -8,17 +8,24 @@ use crate::{
|
|||||||
execution_params::ExecutionParams,
|
execution_params::ExecutionParams,
|
||||||
monero,
|
monero,
|
||||||
monero::{monero_private_key, InsufficientFunds, TransferProof},
|
monero::{monero_private_key, InsufficientFunds, TransferProof},
|
||||||
|
monero_ext::ScalarExt,
|
||||||
protocol::{
|
protocol::{
|
||||||
alice::{Message1, Message3},
|
alice::{Message1, Message3},
|
||||||
bob::{EncryptedSignature, Message0, Message2, Message4},
|
bob::{EncryptedSignature, Message0, Message2, Message4},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
use anyhow::{anyhow, Result};
|
use anyhow::{anyhow, bail, Result};
|
||||||
use ecdsa_fun::{adaptor::Adaptor, nonce::Deterministic, Signature};
|
use ecdsa_fun::{
|
||||||
|
adaptor::{Adaptor, HashTranscript},
|
||||||
|
fun::marker::Mark,
|
||||||
|
nonce::Deterministic,
|
||||||
|
Signature,
|
||||||
|
};
|
||||||
use monero_harness::rpc::wallet::BlockHeight;
|
use monero_harness::rpc::wallet::BlockHeight;
|
||||||
use rand::{CryptoRng, RngCore};
|
use rand::{CryptoRng, RngCore};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use sha2::Sha256;
|
use sha2::Sha256;
|
||||||
|
use sigma_fun::ext::dl_secp256k1_ed25519_eq::{CrossCurveDLEQ, CrossCurveDLEQProof};
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
@ -73,9 +80,11 @@ impl fmt::Display for BobState {
|
|||||||
#[derive(Clone, Debug, Deserialize, Serialize, PartialEq)]
|
#[derive(Clone, Debug, Deserialize, Serialize, PartialEq)]
|
||||||
pub struct State0 {
|
pub struct State0 {
|
||||||
b: bitcoin::SecretKey,
|
b: bitcoin::SecretKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
|
S_b_monero: monero::PublicKey,
|
||||||
|
S_b_bitcoin: bitcoin::PublicKey,
|
||||||
v_b: monero::PrivateViewKey,
|
v_b: monero::PrivateViewKey,
|
||||||
dleq_proof_s_b: cross_curve_dleq::Proof,
|
dleq_proof_s_b: CrossCurveDLEQProof,
|
||||||
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
#[serde(with = "::bitcoin::util::amount::serde::as_sat")]
|
||||||
btc: bitcoin::Amount,
|
btc: bitcoin::Amount,
|
||||||
xmr: monero::Amount,
|
xmr: monero::Amount,
|
||||||
@ -97,14 +106,25 @@ impl State0 {
|
|||||||
) -> Self {
|
) -> Self {
|
||||||
let b = bitcoin::SecretKey::new_random(rng);
|
let b = bitcoin::SecretKey::new_random(rng);
|
||||||
|
|
||||||
let s_b = cross_curve_dleq::Scalar::random(rng);
|
let s_b = monero::Scalar::random(rng);
|
||||||
let v_b = monero::PrivateViewKey::new_random(rng);
|
let v_b = monero::PrivateViewKey::new_random(rng);
|
||||||
let dleq_proof_s_b = cross_curve_dleq::Proof::new(rng, &s_b);
|
|
||||||
|
let dleq_proof_system =
|
||||||
|
CrossCurveDLEQ::<HashTranscript<Sha256, rand_chacha::ChaCha20Rng>>::new(
|
||||||
|
(*ecdsa_fun::fun::G).mark::<ecdsa_fun::fun::marker::Normal>(),
|
||||||
|
curve25519_dalek::constants::ED25519_BASEPOINT_POINT,
|
||||||
|
);
|
||||||
|
|
||||||
|
let (dleq_proof_s_b, (S_b_bitcoin, S_b_monero)) = dleq_proof_system.prove(&s_b, rng);
|
||||||
|
|
||||||
Self {
|
Self {
|
||||||
b,
|
b,
|
||||||
s_b,
|
s_b,
|
||||||
v_b,
|
v_b,
|
||||||
|
S_b_bitcoin: bitcoin::PublicKey::from(S_b_bitcoin),
|
||||||
|
S_b_monero: monero::PublicKey {
|
||||||
|
point: S_b_monero.compress(),
|
||||||
|
},
|
||||||
btc,
|
btc,
|
||||||
xmr,
|
xmr,
|
||||||
dleq_proof_s_b,
|
dleq_proof_s_b,
|
||||||
@ -118,10 +138,8 @@ impl State0 {
|
|||||||
pub fn next_message(&self) -> Message0 {
|
pub fn next_message(&self) -> Message0 {
|
||||||
Message0 {
|
Message0 {
|
||||||
B: self.b.public(),
|
B: self.b.public(),
|
||||||
S_b_monero: monero::PublicKey::from_private_key(&monero::PrivateKey {
|
S_b_monero: self.S_b_monero,
|
||||||
scalar: self.s_b.into_ed25519(),
|
S_b_bitcoin: self.S_b_bitcoin,
|
||||||
}),
|
|
||||||
S_b_bitcoin: self.s_b.into_secp256k1().into(),
|
|
||||||
dleq_proof_s_b: self.dleq_proof_s_b.clone(),
|
dleq_proof_s_b: self.dleq_proof_s_b.clone(),
|
||||||
v_b: self.v_b,
|
v_b: self.v_b,
|
||||||
refund_address: self.refund_address.clone(),
|
refund_address: self.refund_address.clone(),
|
||||||
@ -132,13 +150,26 @@ impl State0 {
|
|||||||
where
|
where
|
||||||
W: BuildTxLockPsbt + GetNetwork,
|
W: BuildTxLockPsbt + GetNetwork,
|
||||||
{
|
{
|
||||||
msg.dleq_proof_s_a.verify(
|
let dleq_proof_system =
|
||||||
msg.S_a_bitcoin.clone().into(),
|
CrossCurveDLEQ::<HashTranscript<Sha256, rand_chacha::ChaCha20Rng>>::new(
|
||||||
msg.S_a_monero
|
(*ecdsa_fun::fun::G).mark::<ecdsa_fun::fun::marker::Normal>(),
|
||||||
.point
|
curve25519_dalek::constants::ED25519_BASEPOINT_POINT,
|
||||||
.decompress()
|
);
|
||||||
.ok_or_else(|| anyhow!("S_a is not a monero curve point"))?,
|
|
||||||
)?;
|
let valid = dleq_proof_system.verify(
|
||||||
|
&msg.dleq_proof_s_a,
|
||||||
|
(
|
||||||
|
msg.S_a_bitcoin.clone().into(),
|
||||||
|
msg.S_a_monero
|
||||||
|
.point
|
||||||
|
.decompress()
|
||||||
|
.ok_or_else(|| anyhow!("S_a is not a monero curve point"))?,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
if !valid {
|
||||||
|
bail!("Alice's dleq proof doesn't verify")
|
||||||
|
}
|
||||||
|
|
||||||
let tx_lock = bitcoin::TxLock::new(wallet, self.btc, msg.A, self.b.public()).await?;
|
let tx_lock = bitcoin::TxLock::new(wallet, self.btc, msg.A, self.b.public()).await?;
|
||||||
let v = msg.v_a + self.v_b;
|
let v = msg.v_a + self.v_b;
|
||||||
@ -166,7 +197,7 @@ impl State0 {
|
|||||||
pub struct State1 {
|
pub struct State1 {
|
||||||
A: bitcoin::PublicKey,
|
A: bitcoin::PublicKey,
|
||||||
b: bitcoin::SecretKey,
|
b: bitcoin::SecretKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
S_a_monero: monero::PublicKey,
|
S_a_monero: monero::PublicKey,
|
||||||
S_a_bitcoin: bitcoin::PublicKey,
|
S_a_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -194,7 +225,7 @@ impl State1 {
|
|||||||
bitcoin::verify_sig(&self.A, &tx_cancel.digest(), &msg.tx_cancel_sig)?;
|
bitcoin::verify_sig(&self.A, &tx_cancel.digest(), &msg.tx_cancel_sig)?;
|
||||||
bitcoin::verify_encsig(
|
bitcoin::verify_encsig(
|
||||||
self.A,
|
self.A,
|
||||||
self.s_b.into_secp256k1().into(),
|
bitcoin::PublicKey::from(self.s_b.to_secpfun_scalar()),
|
||||||
&tx_refund.digest(),
|
&tx_refund.digest(),
|
||||||
&msg.tx_refund_encsig,
|
&msg.tx_refund_encsig,
|
||||||
)?;
|
)?;
|
||||||
@ -224,7 +255,7 @@ impl State1 {
|
|||||||
pub struct State2 {
|
pub struct State2 {
|
||||||
A: bitcoin::PublicKey,
|
A: bitcoin::PublicKey,
|
||||||
b: bitcoin::SecretKey,
|
b: bitcoin::SecretKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
S_a_monero: monero::PublicKey,
|
S_a_monero: monero::PublicKey,
|
||||||
S_a_bitcoin: bitcoin::PublicKey,
|
S_a_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -289,7 +320,7 @@ impl State2 {
|
|||||||
pub struct State3 {
|
pub struct State3 {
|
||||||
A: bitcoin::PublicKey,
|
A: bitcoin::PublicKey,
|
||||||
b: bitcoin::SecretKey,
|
b: bitcoin::SecretKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
S_a_monero: monero::PublicKey,
|
S_a_monero: monero::PublicKey,
|
||||||
S_a_bitcoin: bitcoin::PublicKey,
|
S_a_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
@ -314,9 +345,8 @@ impl State3 {
|
|||||||
where
|
where
|
||||||
W: monero::WatchForTransfer,
|
W: monero::WatchForTransfer,
|
||||||
{
|
{
|
||||||
let S_b_monero = monero::PublicKey::from_private_key(&monero::PrivateKey::from_scalar(
|
let S_b_monero =
|
||||||
self.s_b.into_ed25519(),
|
monero::PublicKey::from_private_key(&monero::PrivateKey::from_scalar(self.s_b));
|
||||||
));
|
|
||||||
let S = self.S_a_monero + S_b_monero;
|
let S = self.S_a_monero + S_b_monero;
|
||||||
|
|
||||||
if let Err(e) = xmr_wallet
|
if let Err(e) = xmr_wallet
|
||||||
@ -401,7 +431,7 @@ impl State3 {
|
|||||||
pub struct State4 {
|
pub struct State4 {
|
||||||
A: bitcoin::PublicKey,
|
A: bitcoin::PublicKey,
|
||||||
b: bitcoin::SecretKey,
|
b: bitcoin::SecretKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
S_a_bitcoin: bitcoin::PublicKey,
|
S_a_bitcoin: bitcoin::PublicKey,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
cancel_timelock: CancelTimelock,
|
cancel_timelock: CancelTimelock,
|
||||||
@ -536,11 +566,11 @@ impl State4 {
|
|||||||
bitcoin::TxCancel::new(&self.tx_lock, self.cancel_timelock, self.A, self.b.public());
|
bitcoin::TxCancel::new(&self.tx_lock, self.cancel_timelock, self.A, self.b.public());
|
||||||
let tx_refund = bitcoin::TxRefund::new(&tx_cancel, &self.refund_address);
|
let tx_refund = bitcoin::TxRefund::new(&tx_cancel, &self.refund_address);
|
||||||
|
|
||||||
let adaptor = Adaptor::<Sha256, Deterministic<Sha256>>::default();
|
let adaptor = Adaptor::<HashTranscript<Sha256>, Deterministic<Sha256>>::default();
|
||||||
|
|
||||||
let sig_b = self.b.sign(tx_refund.digest());
|
let sig_b = self.b.sign(tx_refund.digest());
|
||||||
let sig_a =
|
let sig_a =
|
||||||
adaptor.decrypt_signature(&self.s_b.into_secp256k1(), self.tx_refund_encsig.clone());
|
adaptor.decrypt_signature(&self.s_b.to_secpfun_scalar(), self.tx_refund_encsig.clone());
|
||||||
|
|
||||||
let signed_tx_refund = tx_refund.add_signatures(
|
let signed_tx_refund = tx_refund.add_signatures(
|
||||||
&tx_cancel.clone(),
|
&tx_cancel.clone(),
|
||||||
@ -568,7 +598,7 @@ impl State4 {
|
|||||||
pub struct State5 {
|
pub struct State5 {
|
||||||
#[serde(with = "monero_private_key")]
|
#[serde(with = "monero_private_key")]
|
||||||
s_a: monero::PrivateKey,
|
s_a: monero::PrivateKey,
|
||||||
s_b: cross_curve_dleq::Scalar,
|
s_b: monero::Scalar,
|
||||||
v: monero::PrivateViewKey,
|
v: monero::PrivateViewKey,
|
||||||
tx_lock: bitcoin::TxLock,
|
tx_lock: bitcoin::TxLock,
|
||||||
monero_wallet_restore_blockheight: u32,
|
monero_wallet_restore_blockheight: u32,
|
||||||
@ -579,9 +609,7 @@ impl State5 {
|
|||||||
where
|
where
|
||||||
W: monero::CreateWalletForOutput,
|
W: monero::CreateWalletForOutput,
|
||||||
{
|
{
|
||||||
let s_b = monero::PrivateKey {
|
let s_b = monero::PrivateKey { scalar: self.s_b };
|
||||||
scalar: self.s_b.into_ed25519(),
|
|
||||||
};
|
|
||||||
|
|
||||||
let s = self.s_a + s_b;
|
let s = self.s_a + s_b;
|
||||||
|
|
||||||
|
@ -137,6 +137,7 @@ impl IntoIterator for ElectrsArgs {
|
|||||||
Network::Testnet => args.push("--network=testnet".to_string()),
|
Network::Testnet => args.push("--network=testnet".to_string()),
|
||||||
Network::Regtest => args.push("--network=regtest".to_string()),
|
Network::Regtest => args.push("--network=regtest".to_string()),
|
||||||
Network::Bitcoin => {}
|
Network::Bitcoin => {}
|
||||||
|
Network::Signet => panic!("signet not yet supported"),
|
||||||
}
|
}
|
||||||
|
|
||||||
args.push("-vvvvv".to_string());
|
args.push("-vvvvv".to_string());
|
||||||
|
Loading…
Reference in New Issue
Block a user