Radish alpha
r
Radicle CI broker
Radicle
Git (anonymous pull)
Log in to clone via SSH
feat(adapter): enrich adapter run context
jchrist committed 2 years ago
commit c3d223d7fc328a609b73a2585122aafbcba969a2
parent c7a2572e805c4c9271cabeee0451028d58bf1d20
11 files changed +995 -422
modified Cargo.lock
@@ -3,6 +3,22 @@
version = 3

[[package]]
+
name = "adler"
+
version = "1.0.2"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "f26201604c87b1e01bd3d98f8d5d9a8fcbb815e8cedb41ffccbeb4bf593a35fe"
+

+
[[package]]
+
name = "aead"
+
version = "0.5.2"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "d122413f284cf2d62fb1b7db97e02edb8cda96d769b16e443a4f6195e35662b0"
+
dependencies = [
+
 "crypto-common",
+
 "generic-array",
+
]
+

+
[[package]]
name = "aes"
version = "0.8.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -14,6 +30,20 @@ dependencies = [
]

[[package]]
+
name = "aes-gcm"
+
version = "0.10.3"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "831010a0f742e1209b3bcea8fab6a8e149051ba6099432c8cb2cc117dec3ead1"
+
dependencies = [
+
 "aead",
+
 "aes",
+
 "cipher",
+
 "ctr",
+
 "ghash",
+
 "subtle",
+
]
+

+
[[package]]
name = "aho-corasick"
version = "1.1.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -48,9 +78,12 @@ dependencies = [

[[package]]
name = "amplify_num"
-
version = "0.5.0"
+
version = "0.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ddce3bc63e807ea02065e8d8b702695f3d302ae4158baddff8b0ce5c73947251"
+
checksum = "9681187211554ab98f138ba159e90861b136c20afc680dcff2ba82d020721e27"
+
dependencies = [
+
 "wasm-bindgen",
+
]

[[package]]
name = "amplify_syn"
@@ -64,6 +97,12 @@ dependencies = [
]

[[package]]
+
name = "anyhow"
+
version = "1.0.79"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "080e9890a082662b09c1ad45f567faeeb47f22b5fb23895fbe1e651e718e25ca"
+

+
[[package]]
name = "ascii"
version = "1.1.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -83,9 +122,9 @@ checksum = "4cbbc9d0964165b47557570cce6c952866c2678457aca742aafc9fb771d30270"

[[package]]
name = "base16ct"
-
version = "0.1.1"
+
version = "0.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "349a06037c7bf932dd7e7d1f653678b2038b9ad46a74102f1fc7bd7872678cce"
+
checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf"

[[package]]
name = "base32"
@@ -94,6 +133,18 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "23ce669cd6c8588f79e15cf450314f9638f967fc5770ff1c7c1deb0925ea7cfa"

[[package]]
+
name = "base64"
+
version = "0.13.1"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "9e1b586273c5702936fe7b7d6896644d8be71e6314cfe09d3167c95f712589e8"
+

+
[[package]]
+
name = "base64"
+
version = "0.21.7"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567"
+

+
[[package]]
name = "base64ct"
version = "1.6.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -101,13 +152,13 @@ checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b"

[[package]]
name = "bcrypt-pbkdf"
-
version = "0.9.0"
+
version = "0.10.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "3806a8db60cf56efee531616a34a6aaa9a114d6da2add861b0fa4a188881b2c7"
+
checksum = "6aeac2e1fe888769f34f05ac343bbef98b14d1ffb292ab69d4608b3abc86f2a2"
dependencies = [
 "blowfish",
 "pbkdf2",
-
 "sha2 0.10.8",
+
 "sha2",
]

[[package]]
@@ -118,24 +169,24 @@ checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a"

[[package]]
name = "bitflags"
-
version = "2.4.1"
+
version = "2.4.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "327762f6e5a765692301e5bb513e0d9fef63be86bbc14528052b1cd3e6f03e07"
+
checksum = "ed570934406eb16438a4e976b1b4500774099c13b8cb96eec99f620f05090ddf"

[[package]]
name = "block-buffer"
-
version = "0.9.0"
+
version = "0.10.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "4152116fd6e9dadb291ae18fc1ec3575ed6d84c29642d97890f4b4a3417297e4"
+
checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71"
dependencies = [
 "generic-array",
]

[[package]]
-
name = "block-buffer"
-
version = "0.10.4"
+
name = "block-padding"
+
version = "0.3.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71"
+
checksum = "a8894febbff9f758034a5b8e12d87918f56dfc64a8e1fe757d65e29041538d93"
dependencies = [
 "generic-array",
]
@@ -163,6 +214,15 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b"

[[package]]
+
name = "cbc"
+
version = "0.1.2"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "26b52a9543ae338f279b96b0b9fed9c8093744685043739079ce85cd58f289a6"
+
dependencies = [
+
 "cipher",
+
]
+

+
[[package]]
name = "cc"
version = "1.0.83"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -179,6 +239,17 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"

[[package]]
+
name = "chacha20"
+
version = "0.9.1"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "c3613f74bd2eac03dad61bd53dbe620703d4371614fe0bc3b9f04dd36fe4e818"
+
dependencies = [
+
 "cfg-if",
+
 "cipher",
+
 "cpufeatures",
+
]
+

+
[[package]]
name = "cipher"
version = "0.4.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -190,46 +261,51 @@ dependencies = [

[[package]]
name = "const-oid"
-
version = "0.9.5"
+
version = "0.9.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "28c122c3980598d243d63d9a704629a2d748d101f278052ff068be5a4423ab6f"
+
checksum = "c2459377285ad874054d797f3ccebf984978aa39129f6eafde5cdc8315b612f8"

[[package]]
name = "cpufeatures"
-
version = "0.2.11"
+
version = "0.2.12"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ce420fe07aecd3e67c5f910618fe65e94158f6dcc0adf44e00d69ce2bdfe0fd0"
+
checksum = "53fe5e26ff1b7aef8bca9c6080520cfb8d9333c7568e1829cef191a9723e5504"
dependencies = [
 "libc",
]

[[package]]
-
name = "crossbeam-channel"
-
version = "0.5.9"
+
name = "crc32fast"
+
version = "1.3.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "14c3242926edf34aec4ac3a77108ad4854bffaa2e4ddc1824124ce59231302d5"
+
checksum = "b540bd8bc810d3885c6ea91e2018302f68baba2129ab3e88f32389ee9370880d"
dependencies = [
 "cfg-if",
-
 "crossbeam-utils",
]

[[package]]
-
name = "crossbeam-utils"
-
version = "0.8.17"
+
name = "crossbeam-channel"
+
version = "0.5.11"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "c06d96137f14f244c37f989d9fff8f95e6c18b918e71f36638f8c49112e4c78f"
+
checksum = "176dc175b78f56c0f321911d9c8eb2b77a78a4860b9c19db83835fea1a46649b"
dependencies = [
-
 "cfg-if",
+
 "crossbeam-utils",
]

[[package]]
+
name = "crossbeam-utils"
+
version = "0.8.19"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "248e3bacc7dc6baa3b21e405ee045c3047101a49145e7e9eca583ab4c2ca5345"
+

+
[[package]]
name = "crypto-bigint"
-
version = "0.4.9"
+
version = "0.5.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ef2b4b23cddf68b89b8f8069890e8c270d54e2d5fe1b143820234805e4cb17ef"
+
checksum = "0dc92fb57ca44df6db8059111ab3af99a63d5d0f8375d9972e319a379c6bab76"
dependencies = [
 "generic-array",
-
 "rand_core 0.6.4",
+
 "rand_core",
 "subtle",
 "zeroize",
]
@@ -260,19 +336,6 @@ dependencies = [
]

[[package]]
-
name = "curve25519-dalek"
-
version = "3.2.0"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "0b9fdf9972b2bd6af2d913799d9ebc165ea4d2e65878e329d9c6b372c4491b61"
-
dependencies = [
-
 "byteorder",
-
 "digest 0.9.0",
-
 "rand_core 0.5.1",
-
 "subtle",
-
 "zeroize",
-
]
-

-
[[package]]
name = "cypheraddr"
version = "0.3.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -333,31 +396,21 @@ dependencies = [

[[package]]
name = "der"
-
version = "0.6.1"
+
version = "0.7.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f1a467a65c5e759bce6e65eaf91cc29f466cdc57cb65777bd646872a8a1fd4de"
+
checksum = "fffa369a668c8af7dbf8b5e56c9f744fbd399949ed171606040001947de40b1c"
dependencies = [
 "const-oid",
-
 "pem-rfc7468",
 "zeroize",
]

[[package]]
name = "digest"
-
version = "0.9.0"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "d3dd60d1080a57a05ab032377049e0591415d2b31afd7028356dbf3cc6dcb066"
-
dependencies = [
-
 "generic-array",
-
]
-

-
[[package]]
-
name = "digest"
version = "0.10.7"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292"
dependencies = [
-
 "block-buffer 0.10.4",
+
 "block-buffer",
 "const-oid",
 "crypto-common",
 "subtle",
@@ -371,19 +424,21 @@ checksum = "bdfd533a2fc01178c738c99412ae1f7e1ad2cb37c2e14bfd87e9d4618171c825"
dependencies = [
 "ct-codecs",
 "ed25519",
-
 "getrandom 0.2.11",
+
 "getrandom",
]

[[package]]
name = "ecdsa"
-
version = "0.14.8"
+
version = "0.16.9"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "413301934810f597c1d19ca71c8710e99a3f1ba28a0d2ebc01551a2daeea3c5c"
+
checksum = "ee27f32b5c5292967d2d4a9d7f1e0b0aed2c15daded5a60300e4abb9d8020bca"
dependencies = [
 "der",
+
 "digest",
 "elliptic-curve",
 "rfc6979",
-
 "signature",
+
 "signature 2.2.0",
+
 "spki",
]

[[package]]
@@ -392,37 +447,23 @@ version = "1.5.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "91cff35c70bba8a626e3185d8cd48cc11b5437e1a5bcd15b9b5fa3c64b6dfee7"
dependencies = [
-
 "signature",
-
]
-

-
[[package]]
-
name = "ed25519-dalek"
-
version = "1.0.1"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "c762bae6dcaf24c4c84667b8579785430908723d5c889f469d76a41d59cc7a9d"
-
dependencies = [
-
 "curve25519-dalek",
-
 "ed25519",
-
 "rand 0.7.3",
-
 "serde",
-
 "sha2 0.9.9",
-
 "zeroize",
+
 "signature 1.6.4",
]

[[package]]
name = "elliptic-curve"
-
version = "0.12.3"
+
version = "0.13.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "e7bb888ab5300a19b8e5bceef25ac745ad065f3c9f7efc6de1b91958110891d3"
+
checksum = "b5e6043086bf7973472e0c7dff2142ea0b680d30e18d9cc40f267efbf222bd47"
dependencies = [
 "base16ct",
 "crypto-bigint",
-
 "der",
-
 "digest 0.10.7",
+
 "digest",
 "ff",
 "generic-array",
 "group",
-
 "rand_core 0.6.4",
+
 "pkcs8",
+
 "rand_core",
 "sec1",
 "subtle",
 "zeroize",
@@ -430,9 +471,9 @@ dependencies = [

[[package]]
name = "env_logger"
-
version = "0.10.1"
+
version = "0.10.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "95b3f3e67048839cb0d0781f445682a35113da7121f7c949db0e2be96a4fbece"
+
checksum = "4cd405aab171cb85d6735e5c8d9db038c17d3ca007a4d2c25f337935c3d90580"
dependencies = [
 "humantime",
 "is-terminal",
@@ -454,7 +495,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a258e46cdc063eb8519c00b9fc845fc47bcfca4130e2f08e88665ceda8474245"
dependencies = [
 "libc",
-
 "windows-sys 0.52.0",
+
 "windows-sys",
]

[[package]]
@@ -465,15 +506,37 @@ checksum = "25cbce373ec4653f1a01a31e8a5e5ec0c622dc27ff9c4e6606eefef5cbbed4a5"

[[package]]
name = "ff"
-
version = "0.12.1"
+
version = "0.13.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "d013fc25338cc558c5c2cfbad646908fb23591e2404481826742b651c9af7160"
+
checksum = "ded41244b729663b1e574f1b4fb731469f69f79c17667b5d776b16cda0479449"
dependencies = [
-
 "rand_core 0.6.4",
+
 "rand_core",
 "subtle",
]

[[package]]
+
name = "filetime"
+
version = "0.2.23"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "1ee447700ac8aa0b2f2bd7bc4462ad686ba06baa6727ac149a2d6277f0d240fd"
+
dependencies = [
+
 "cfg-if",
+
 "libc",
+
 "redox_syscall",
+
 "windows-sys",
+
]
+

+
[[package]]
+
name = "flate2"
+
version = "1.0.28"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "46303f565772937ffe1d394a4fac6f411c6013172fadde9dcdb1e147a086940e"
+
dependencies = [
+
 "crc32fast",
+
 "miniz_oxide",
+
]
+

+
[[package]]
name = "form_urlencoded"
version = "1.2.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -490,28 +553,28 @@ checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a"
dependencies = [
 "typenum",
 "version_check",
+
 "zeroize",
]

[[package]]
name = "getrandom"
-
version = "0.1.16"
+
version = "0.2.12"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "8fc3cb4d91f53b50155bdcfd23f6a4c39ae1969c2ae85982b135750cccaf5fce"
+
checksum = "190092ea657667030ac6a35e305e62fc4dd69fd98ac98631e5d3a2b1575a12b5"
dependencies = [
 "cfg-if",
 "libc",
-
 "wasi 0.9.0+wasi-snapshot-preview1",
+
 "wasi",
]

[[package]]
-
name = "getrandom"
-
version = "0.2.11"
+
name = "ghash"
+
version = "0.5.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "fe9006bed769170c11f845cf00c7c1e9092aeb3f268e007c3e760ac68008070f"
+
checksum = "d930750de5717d2dd0b8c0d42c076c0e884c81a73e6cab859bbd2339c71e3e40"
dependencies = [
-
 "cfg-if",
-
 "libc",
-
 "wasi 0.11.0+wasi-snapshot-preview1",
+
 "opaque-debug",
+
 "polyval",
]

[[package]]
@@ -552,7 +615,7 @@ version = "0.18.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "fbf97ba92db08df386e10c8ede66a2a0369bd277090afd8710e19e38de9ec0cd"
dependencies = [
-
 "bitflags 2.4.1",
+
 "bitflags 2.4.2",
 "libc",
 "libgit2-sys",
 "log",
@@ -561,12 +624,12 @@ dependencies = [

[[package]]
name = "group"
-
version = "0.12.1"
+
version = "0.13.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "5dfbfb3a6cfbd390d5c9564ab283a0349b9b9fcd46a706c1eb10e0db70bfbac7"
+
checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63"
dependencies = [
 "ff",
-
 "rand_core 0.6.4",
+
 "rand_core",
 "subtle",
]

@@ -578,9 +641,9 @@ checksum = "290f1a1d9242c78d09ce40a5e87e7554ee637af1351968159f4952f028f75604"

[[package]]
name = "hermit-abi"
-
version = "0.3.3"
+
version = "0.3.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "d77f7ec81a6d05a3abb01ab6eb7590f6083d08449fe5a1c8b1e620283546ccb7"
+
checksum = "5d3d0e0f38255e7fa3cf31335b3a56f05febd18025f4db5ef7a0cfb4f8da651f"

[[package]]
name = "hmac"
@@ -588,7 +651,7 @@ version = "0.12.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e"
dependencies = [
-
 "digest 0.10.7",
+
 "digest",
]

[[package]]
@@ -623,18 +686,19 @@ version = "0.1.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a0c10553d664a4d0bcff9f4215d0aac67a639cc68ef660840afe309b807bc9f5"
dependencies = [
+
 "block-padding",
 "generic-array",
]

[[package]]
name = "is-terminal"
-
version = "0.4.9"
+
version = "0.4.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "cb0889898416213fab133e1d33a0e5858a48177452750691bde3666d0fdbaf8b"
+
checksum = "0bad00257d07be169d870ab665980b06cdb366d792ad690bf2e76876dc503455"
dependencies = [
 "hermit-abi",
 "rustix",
-
 "windows-sys 0.48.0",
+
 "windows-sys",
]

[[package]]
@@ -654,9 +718,9 @@ dependencies = [

[[package]]
name = "keccak"
-
version = "0.1.4"
+
version = "0.1.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "8f6d5ed8676d904364de097082f4e7d240b571b67989ced0240f08b7f966f940"
+
checksum = "ecc2af9a1119c51f12a14607e783cb977bde58bc069ff0c3da1095e635d70654"
dependencies = [
 "cpufeatures",
]
@@ -672,9 +736,9 @@ dependencies = [

[[package]]
name = "libc"
-
version = "0.2.151"
+
version = "0.2.152"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "302d7ab3130588088d277783b1e2d2e10c9e9e4a16dd9050e6ec93fb3e7048f4"
+
checksum = "13e3bf6590cbc649f4d1a3eefc9d5d6eb746f5200ffb04e5e142700b8faa56e7"

[[package]]
name = "libgit2-sys"
@@ -696,9 +760,9 @@ checksum = "4ec2a862134d2a7d32d7983ddcdd1c4923530833c9f2ea1a44fc5fa473989058"

[[package]]
name = "libz-sys"
-
version = "1.1.12"
+
version = "1.1.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "d97137b25e321a73eef1418d1d5d2eda4d77e12813f8e6dead84bc52c5870a7b"
+
checksum = "295c17e837573c8c821dbaeb3cceb3d745ad082f7572191409e69cbc1b3fd050"
dependencies = [
 "cc",
 "libc",
@@ -708,9 +772,9 @@ dependencies = [

[[package]]
name = "linux-raw-sys"
-
version = "0.4.12"
+
version = "0.4.13"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456"
+
checksum = "01cda141df6706de531b6c46c3a33ecca755538219bd484262fa09410c13539c"

[[package]]
name = "localtime"
@@ -729,9 +793,18 @@ checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f"

[[package]]
name = "memchr"
-
version = "2.6.4"
+
version = "2.7.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167"
+
checksum = "523dc4f511e55ab87b694dc30d0f820d60906ef06413f93d4d7a1385599cc149"
+

+
[[package]]
+
name = "miniz_oxide"
+
version = "0.7.1"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7"
+
dependencies = [
+
 "adler",
+
]

[[package]]
name = "multibase"
@@ -746,9 +819,15 @@ dependencies = [

[[package]]
name = "nonempty"
-
version = "0.8.1"
+
version = "0.5.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "9ff7ac1e5ea23db6d61ad103e91864675049644bf47c35912336352fa4e9c109"
+

+
[[package]]
+
name = "nonempty"
+
version = "0.9.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "aeaf4ad7403de93e699c191202f017118df734d3850b01e13a3a8b2e6953d3c9"
+
checksum = "995defdca0a589acfdd1bd2e8e3b896b4d4f7675a31fd14c32611440c7f608e6"
dependencies = [
 "serde",
]
@@ -765,7 +844,7 @@ dependencies = [
 "num-integer",
 "num-iter",
 "num-traits",
-
 "rand 0.8.5",
+
 "rand",
 "smallvec",
 "zeroize",
]
@@ -815,40 +894,56 @@ checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5"

[[package]]
name = "p256"
-
version = "0.11.1"
+
version = "0.13.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "51f44edd08f51e2ade572f141051021c5af22677e42b7dd28a88155151c33594"
+
checksum = "c9863ad85fa8f4460f9c48cb909d38a0d689dba1f6f6988a5e3e0d31071bcd4b"
dependencies = [
 "ecdsa",
 "elliptic-curve",
-
 "sha2 0.10.8",
+
 "primeorder",
+
 "sha2",
]

[[package]]
name = "p384"
-
version = "0.11.2"
+
version = "0.13.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "70786f51bcc69f6a4c0360e063a4cac5419ef7c5cd5b3c99ad70f3be5ba79209"
+
dependencies = [
+
 "ecdsa",
+
 "elliptic-curve",
+
 "primeorder",
+
 "sha2",
+
]
+

+
[[package]]
+
name = "p521"
+
version = "0.13.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "dfc8c5bf642dde52bb9e87c0ecd8ca5a76faac2eeed98dedb7c717997e1080aa"
+
checksum = "0fc9e2161f1f215afdfce23677034ae137bbd45016a880c2eb3ba8eb95f085b2"
dependencies = [
+
 "base16ct",
 "ecdsa",
 "elliptic-curve",
-
 "sha2 0.10.8",
+
 "primeorder",
+
 "rand_core",
+
 "sha2",
]

[[package]]
name = "pbkdf2"
-
version = "0.11.0"
+
version = "0.12.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "83a0692ec44e4cf1ef28ca317f14f8f07da2d95ec3fa01f86e4467b725e60917"
+
checksum = "f8ed6a7761f76e3b9f92dfb0a60a6a6477c61024b775147ff0973a02653abaf2"
dependencies = [
-
 "digest 0.10.7",
+
 "digest",
]

[[package]]
name = "pem-rfc7468"
-
version = "0.6.0"
+
version = "0.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "24d159833a9105500e0398934e205e0773f0b27529557134ecfc51c27646adac"
+
checksum = "88b39c9bfcfc231068454382784bb460aae594343fb030d46e9f50a645418412"
dependencies = [
 "base64ct",
]
@@ -861,21 +956,20 @@ checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e"

[[package]]
name = "pkcs1"
-
version = "0.4.1"
+
version = "0.7.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "eff33bdbdfc54cc98a2eca766ebdec3e1b8fb7387523d5c9c9a2891da856f719"
+
checksum = "c8ffb9f10fa047879315e6625af03c164b16962a5368d724ed16323b68ace47f"
dependencies = [
 "der",
 "pkcs8",
 "spki",
-
 "zeroize",
]

[[package]]
name = "pkcs8"
-
version = "0.9.0"
+
version = "0.10.2"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "9eca2c590a5f85da82668fa685c09ce2888b9430e83299debf1f34b65fd4a4ba"
+
checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7"
dependencies = [
 "der",
 "spki",
@@ -883,9 +977,32 @@ dependencies = [

[[package]]
name = "pkg-config"
-
version = "0.3.27"
+
version = "0.3.29"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "2900ede94e305130c13ddd391e0ab7cbaeb783945ae07a279c268cb05109c6cb"
+

+
[[package]]
+
name = "poly1305"
+
version = "0.8.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "8159bd90725d2df49889a078b54f4f79e87f1f8a8444194cdca81d38f5393abf"
+
dependencies = [
+
 "cpufeatures",
+
 "opaque-debug",
+
 "universal-hash",
+
]
+

+
[[package]]
+
name = "polyval"
+
version = "0.6.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "26072860ba924cbfa98ea39c8c19b4dd6a4a25423dbdf219c1eca91aa0cf6964"
+
checksum = "d52cff9d1d4dee5fe6d03729099f4a310a41179e0a10dbf542039873f2e826fb"
+
dependencies = [
+
 "cfg-if",
+
 "cpufeatures",
+
 "opaque-debug",
+
 "universal-hash",
+
]

[[package]]
name = "ppv-lite86"
@@ -904,6 +1021,15 @@ dependencies = [
]

[[package]]
+
name = "primeorder"
+
version = "0.13.6"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "353e1ca18966c16d9deb1c69278edbc5f194139612772bd9537af60ac231e1e6"
+
dependencies = [
+
 "elliptic-curve",
+
]
+

+
[[package]]
name = "proc-macro-error"
version = "1.0.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
@@ -929,18 +1055,27 @@ dependencies = [

[[package]]
name = "proc-macro2"
-
version = "1.0.70"
+
version = "1.0.78"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "39278fbbf5fb4f646ce651690877f89d1c5811a3d4acb27700c1cb3cdb78fd3b"
+
checksum = "e2422ad645d89c99f8f3e6b88a9fdeca7fabeac836b1002371c4367c8f984aae"
dependencies = [
 "unicode-ident",
]

[[package]]
+
name = "qcheck"
+
version = "1.0.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "b439bd4242da51d62d18c95e6a6add749346756b0d1a587dfd0cc22fa6b5f3f0"
+
dependencies = [
+
 "rand",
+
]
+

+
[[package]]
name = "quote"
-
version = "1.0.33"
+
version = "1.0.35"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae"
+
checksum = "291ec9ab5efd934aaf503a6466c5d5251535d108ee747472c3977cc5acc868ef"
dependencies = [
 "proc-macro2",
]
@@ -948,18 +1083,21 @@ dependencies = [
[[package]]
name = "radicle"
version = "0.2.0"
-
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#63469fd3bc45b7205ddc80e796e47da0d3d07ad5"
+
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#49584f4e732fb0039d2089f3c39fd56fc34a2ee3"
dependencies = [
 "amplify",
+
 "base64 0.21.7",
 "crossbeam-channel",
 "cyphernet",
 "fastrand",
 "git2",
+
 "libc",
 "localtime",
 "log",
 "multibase",
-
 "nonempty",
+
 "nonempty 0.9.0",
 "once_cell",
+
 "qcheck",
 "radicle-cob",
 "radicle-crypto",
 "radicle-git-ext",
@@ -981,21 +1119,23 @@ dependencies = [
 "pretty_env_logger",
 "radicle",
 "radicle-git-ext",
+
 "radicle-surf",
 "serde",
 "serde_json",
 "serde_yaml",
+
 "tempfile",
 "thiserror",
]

[[package]]
name = "radicle-cob"
version = "0.2.0"
-
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#63469fd3bc45b7205ddc80e796e47da0d3d07ad5"
+
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#49584f4e732fb0039d2089f3c39fd56fc34a2ee3"
dependencies = [
 "fastrand",
 "git2",
 "log",
-
 "nonempty",
+
 "nonempty 0.9.0",
 "once_cell",
 "radicle-crypto",
 "radicle-dag",
@@ -1008,12 +1148,14 @@ dependencies = [
[[package]]
name = "radicle-crypto"
version = "0.2.0"
-
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#63469fd3bc45b7205ddc80e796e47da0d3d07ad5"
+
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#49584f4e732fb0039d2089f3c39fd56fc34a2ee3"
dependencies = [
 "amplify",
 "cyphernet",
 "ec25519",
+
 "fastrand",
 "multibase",
+
 "qcheck",
 "radicle-git-ext",
 "radicle-ssh",
 "serde",
@@ -1026,7 +1168,7 @@ dependencies = [
[[package]]
name = "radicle-dag"
version = "0.2.0"
-
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#63469fd3bc45b7205ddc80e796e47da0d3d07ad5"
+
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#49584f4e732fb0039d2089f3c39fd56fc34a2ee3"
dependencies = [
 "fastrand",
]
@@ -1048,7 +1190,7 @@ dependencies = [
[[package]]
name = "radicle-ssh"
version = "0.2.0"
-
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#63469fd3bc45b7205ddc80e796e47da0d3d07ad5"
+
source = "git+https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git?branch=master#49584f4e732fb0039d2089f3c39fd56fc34a2ee3"
dependencies = [
 "byteorder",
 "log",
@@ -1063,16 +1205,22 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "db20136bbc9ae63f3fec8e5a6c369f4902fac2244501b5dfc6d668e43475aaa4"

[[package]]
-
name = "rand"
-
version = "0.7.3"
+
name = "radicle-surf"
+
version = "0.18.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "6a6b1679d49b24bbfe0c803429aa1874472f50d9b363131f0e89fc356b544d03"
+
checksum = "9403736ddf2be5e7de42928f94a5f68ef0785916171d009809d19b4202b58d83"
dependencies = [
-
 "getrandom 0.1.16",
-
 "libc",
-
 "rand_chacha 0.2.2",
-
 "rand_core 0.5.1",
-
 "rand_hc",
+
 "anyhow",
+
 "base64 0.13.1",
+
 "flate2",
+
 "git2",
+
 "log",
+
 "nonempty 0.5.0",
+
 "radicle-git-ext",
+
 "radicle-std-ext",
+
 "serde",
+
 "tar",
+
 "thiserror",
]

[[package]]
@@ -1081,18 +1229,8 @@ version = "0.8.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404"
dependencies = [
-
 "rand_chacha 0.3.1",
-
 "rand_core 0.6.4",
-
]
-

-
[[package]]
-
name = "rand_chacha"
-
version = "0.2.2"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f4c8ed856279c9737206bf725bf36935d8666ead7aa69b52be55af369d193402"
-
dependencies = [
-
 "ppv-lite86",
-
 "rand_core 0.5.1",
+
 "rand_chacha",
+
 "rand_core",
]

[[package]]
@@ -1102,16 +1240,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88"
dependencies = [
 "ppv-lite86",
-
 "rand_core 0.6.4",
-
]
-

-
[[package]]
-
name = "rand_core"
-
version = "0.5.1"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "90bde5296fc891b0cef12a6d03ddccc162ce7b2aff54160af9338f8d40df6d19"
-
dependencies = [
-
 "getrandom 0.1.16",
+
 "rand_core",
]

[[package]]
@@ -1120,16 +1249,7 @@ version = "0.6.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c"
dependencies = [
-
 "getrandom 0.2.11",
-
]
-

-
[[package]]
-
name = "rand_hc"
-
version = "0.2.0"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ca3129af7b92a17112d59ad498c6f81eaf463253766b90396d39ea7a39d6613c"
-
dependencies = [
-
 "rand_core 0.5.1",
+
 "getrandom",
]

[[package]]
@@ -1143,9 +1263,9 @@ dependencies = [

[[package]]
name = "regex"
-
version = "1.10.2"
+
version = "1.10.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "380b951a9c5e80ddfd6136919eef32310721aa4aacd4889a8d39124b026ab343"
+
checksum = "b62dbe01f0b06f9d8dc7d49e05a0785f153b00b2c227856282f671e0318c9b15"
dependencies = [
 "aho-corasick",
 "memchr",
@@ -1155,9 +1275,9 @@ dependencies = [

[[package]]
name = "regex-automata"
-
version = "0.4.3"
+
version = "0.4.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "5f804c7828047e88b2d32e2d7fe5a105da8ee3264f01902f796c8e067dc2483f"
+
checksum = "3b7fa1134405e2ec9353fd416b17f8dacd46c473d7d3fd1cf202706a14eb792a"
dependencies = [
 "aho-corasick",
 "memchr",
@@ -1172,47 +1292,46 @@ checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f"

[[package]]
name = "rfc6979"
-
version = "0.3.1"
+
version = "0.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "7743f17af12fa0b03b803ba12cd6a8d9483a587e89c69445e3909655c0b9fabb"
+
checksum = "f8dd2a808d456c4a54e300a23e9f5a67e122c3024119acbfd73e3bf664491cb2"
dependencies = [
-
 "crypto-bigint",
 "hmac",
-
 "zeroize",
+
 "subtle",
]

[[package]]
name = "rsa"
-
version = "0.7.2"
+
version = "0.9.6"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "094052d5470cbcef561cb848a7209968c9f12dfa6d668f4bca048ac5de51099c"
+
checksum = "5d0e5124fcb30e76a7e79bfee683a2746db83784b86289f6251b54b7950a0dfc"
dependencies = [
-
 "byteorder",
-
 "digest 0.10.7",
+
 "const-oid",
+
 "digest",
 "num-bigint-dig",
 "num-integer",
-
 "num-iter",
 "num-traits",
 "pkcs1",
 "pkcs8",
-
 "rand_core 0.6.4",
-
 "signature",
-
 "smallvec",
+
 "rand_core",
+
 "sha2",
+
 "signature 2.2.0",
+
 "spki",
 "subtle",
 "zeroize",
]

[[package]]
name = "rustix"
-
version = "0.38.28"
+
version = "0.38.30"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "72e572a5e8ca657d7366229cdde4bd14c4eb5499a9573d4d366fe1b599daa316"
+
checksum = "322394588aaf33c24007e8bb3238ee3e4c5c09c084ab32bc73890b99ff326bca"
dependencies = [
-
 "bitflags 2.4.1",
+
 "bitflags 2.4.2",
 "errno",
 "libc",
 "linux-raw-sys",
-
 "windows-sys 0.52.0",
+
 "windows-sys",
]

[[package]]
@@ -1223,9 +1342,9 @@ checksum = "f98d2aa92eebf49b69786be48e4477826b256916e84a57ff2a4f21923b48eb4c"

[[package]]
name = "sec1"
-
version = "0.3.0"
+
version = "0.7.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "3be24c1842290c45df0a7bf069e0c268a747ad05a192f2fd7dcfdbc1cba40928"
+
checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc"
dependencies = [
 "base16ct",
 "der",
@@ -1237,29 +1356,29 @@ dependencies = [

[[package]]
name = "serde"
-
version = "1.0.193"
+
version = "1.0.195"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "25dd9975e68d0cb5aa1120c288333fc98731bd1dd12f561e468ea4728c042b89"
+
checksum = "63261df402c67811e9ac6def069e4786148c4563f4b50fd4bf30aa370d626b02"
dependencies = [
 "serde_derive",
]

[[package]]
name = "serde_derive"
-
version = "1.0.193"
+
version = "1.0.195"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "43576ca501357b9b071ac53cdc7da8ef0cbd9493d8df094cd821777ea6e894d3"
+
checksum = "46fe8f8603d81ba86327b23a2e9cdf49e1255fb94a4c5f297f6ee0547178ea2c"
dependencies = [
 "proc-macro2",
 "quote",
-
 "syn 2.0.41",
+
 "syn 2.0.48",
]

[[package]]
name = "serde_json"
-
version = "1.0.108"
+
version = "1.0.111"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "3d1c7e3eac408d115102c4c24ad393e0821bb3a5df4d506a80f85f7a742a526b"
+
checksum = "176e46fa42316f18edd598015a5166857fc835ec732f5215eac6b7bdbf0a84f4"
dependencies = [
 "indexmap",
 "itoa",
@@ -1269,9 +1388,9 @@ dependencies = [

[[package]]
name = "serde_yaml"
-
version = "0.9.27"
+
version = "0.9.30"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "3cc7a1570e38322cfe4154732e5110f887ea57e22b76f4bfd32b5bdd3368666c"
+
checksum = "b1bf28c79a99f70ee1f1d83d10c875d2e70618417fda01ad1785e027579d9d38"
dependencies = [
 "indexmap",
 "itoa",
@@ -1282,26 +1401,13 @@ dependencies = [

[[package]]
name = "sha2"
-
version = "0.9.9"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "4d58a1e1bf39749807d89cf2d98ac2dfa0ff1cb3faa38fbb64dd88ac8013d800"
-
dependencies = [
-
 "block-buffer 0.9.0",
-
 "cfg-if",
-
 "cpufeatures",
-
 "digest 0.9.0",
-
 "opaque-debug",
-
]
-

-
[[package]]
-
name = "sha2"
version = "0.10.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8"
dependencies = [
 "cfg-if",
 "cpufeatures",
-
 "digest 0.10.7",
+
 "digest",
]

[[package]]
@@ -1310,7 +1416,7 @@ version = "0.10.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "75872d278a8f37ef87fa0ddbda7802605cb18344497949862c0d4dcb291eba60"
dependencies = [
-
 "digest 0.10.7",
+
 "digest",
 "keccak",
]

@@ -1319,22 +1425,28 @@ name = "signature"
version = "1.6.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "74233d3b3b2f6d4b006dc19dee745e73e2a6bfb6f93607cd3b02bd5b00797d7c"
+

+
[[package]]
+
name = "signature"
+
version = "2.2.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "77549399552de45a898a580c1b41d445bf730df867cc44e6c0233bbc4b8329de"
dependencies = [
-
 "digest 0.10.7",
-
 "rand_core 0.6.4",
+
 "digest",
+
 "rand_core",
]

[[package]]
name = "siphasher"
-
version = "0.3.11"
+
version = "1.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "38b58827f4464d87d377d175e90bf58eb00fd8716ff0a62f80356b5e61555d0d"
+
checksum = "54ac45299ccbd390721be55b412d41931911f654fa99e2cb8bfb57184b2061fe"

[[package]]
name = "smallvec"
-
version = "1.11.2"
+
version = "1.13.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "4dccd0940a2dcdf68d092b8cbab7dc0ad8fa938bf95787e1b916b0e3d0e8e970"
+
checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7"

[[package]]
name = "socks5-client"
@@ -1354,9 +1466,9 @@ checksum = "6e63cff320ae2c57904679ba7cb63280a3dc4613885beafb148ee7bf9aa9042d"

[[package]]
name = "spki"
-
version = "0.6.0"
+
version = "0.7.3"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "67cf02bbac7a337dc36e4f5a693db6c21e7863f45070f7064577eb4367a3212b"
+
checksum = "d91ed6c858b01f942cd56b37a94b3e0a1798290327d1236e4d9cf4eaca44d29d"
dependencies = [
 "base64ct",
 "der",
@@ -1393,34 +1505,51 @@ dependencies = [
]

[[package]]
+
name = "ssh-cipher"
+
version = "0.2.0"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "caac132742f0d33c3af65bfcde7f6aa8f62f0e991d80db99149eb9d44708784f"
+
dependencies = [
+
 "aes",
+
 "aes-gcm",
+
 "cbc",
+
 "chacha20",
+
 "cipher",
+
 "ctr",
+
 "poly1305",
+
 "ssh-encoding",
+
 "subtle",
+
]
+

+
[[package]]
name = "ssh-encoding"
-
version = "0.1.0"
+
version = "0.2.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "19cfdc32e0199062113edf41f344fbf784b8205a94600233c84eb838f45191e1"
+
checksum = "eb9242b9ef4108a78e8cd1a2c98e193ef372437f8c22be363075233321dd4a15"
dependencies = [
 "base64ct",
 "pem-rfc7468",
-
 "sha2 0.10.8",
+
 "sha2",
]

[[package]]
name = "ssh-key"
-
version = "0.5.1"
+
version = "0.6.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "288d8f5562af5a3be4bda308dd374b2c807b940ac370b5efa1c99311da91d9a1"
+
checksum = "01f8f4ea73476c0aa5d5e6a75ce1e8634e2c3f82005ef3bbed21547ac57f2bf7"
dependencies = [
-
 "aes",
 "bcrypt-pbkdf",
-
 "ctr",
-
 "ed25519-dalek",
 "p256",
 "p384",
-
 "rand_core 0.6.4",
+
 "p521",
+
 "rand_core",
 "rsa",
 "sec1",
-
 "sha2 0.10.8",
-
 "signature",
+
 "sha2",
+
 "signature 2.2.0",
+
 "ssh-cipher",
 "ssh-encoding",
+
 "subtle",
 "zeroize",
]

@@ -1443,9 +1572,9 @@ dependencies = [

[[package]]
name = "syn"
-
version = "2.0.41"
+
version = "2.0.48"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "44c8b28c477cc3bf0e7966561e3460130e1255f7a1cf71931075f1c5e7a7e269"
+
checksum = "0f3531638e407dfc0814761abb7c00a5b54992b849452a0646b7f65c9f770f3f"
dependencies = [
 "proc-macro2",
 "quote",
@@ -1453,45 +1582,56 @@ dependencies = [
]

[[package]]
+
name = "tar"
+
version = "0.4.40"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "b16afcea1f22891c49a00c751c7b63b2233284064f11a200fc624137c51e2ddb"
+
dependencies = [
+
 "filetime",
+
 "libc",
+
 "xattr",
+
]
+

+
[[package]]
name = "tempfile"
-
version = "3.8.1"
+
version = "3.9.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "7ef1adac450ad7f4b3c28589471ade84f25f731a7a0fe30d71dfa9f60fd808e5"
+
checksum = "01ce4141aa927a6d1bd34a041795abd0db1cccba5d5f24b009f694bdf3a1f3fa"
dependencies = [
 "cfg-if",
 "fastrand",
 "redox_syscall",
 "rustix",
-
 "windows-sys 0.48.0",
+
 "windows-sys",
]

[[package]]
name = "termcolor"
-
version = "1.4.0"
+
version = "1.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ff1bc3d3f05aff0403e8ac0d92ced918ec05b666a43f83297ccef5bea8a3d449"
+
checksum = "06794f8f6c5c898b3275aebefa6b8a1cb24cd2c6c79397ab15774837a0bc5755"
dependencies = [
 "winapi-util",
]

[[package]]
name = "thiserror"
-
version = "1.0.50"
+
version = "1.0.56"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f9a7210f5c9a7156bb50aa36aed4c95afb51df0df00713949448cf9e97d382d2"
+
checksum = "d54378c645627613241d077a3a79db965db602882668f9136ac42af9ecb730ad"
dependencies = [
 "thiserror-impl",
]

[[package]]
name = "thiserror-impl"
-
version = "1.0.50"
+
version = "1.0.56"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "266b2e40bc00e5a6c09c3584011e08b06f123c00362c92b975ba9843aaaa14b8"
+
checksum = "fa0faa943b50f3db30a20aa7e265dbc66076993efed8463e8de414e5d06d3471"
dependencies = [
 "proc-macro2",
 "quote",
-
 "syn 2.0.41",
+
 "syn 2.0.48",
]

[[package]]
@@ -1517,9 +1657,9 @@ checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825"

[[package]]
name = "unicode-bidi"
-
version = "0.3.14"
+
version = "0.3.15"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "6f2528f27a9eb2b21e69c95319b30bd0efd85d09c379741b0f78ea1d86be2416"
+
checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75"

[[package]]
name = "unicode-ident"
@@ -1537,10 +1677,20 @@ dependencies = [
]

[[package]]
+
name = "universal-hash"
+
version = "0.5.1"
+
source = "registry+https://github.com/rust-lang/crates.io-index"
+
checksum = "fc1de2c688dc15305988b563c3854064043356019f97a4b46276fe734c4f07ea"
+
dependencies = [
+
 "crypto-common",
+
 "subtle",
+
]
+

+
[[package]]
name = "unsafe-libyaml"
-
version = "0.2.9"
+
version = "0.2.10"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f28467d3e1d3c6586d8f25fa243f544f5800fec42d97032474e17222c2b75cfa"
+
checksum = "ab4c90930b95a82d00dc9e9ac071b4991924390d46cbd0dfe566148667605e4b"

[[package]]
name = "url"
@@ -1567,21 +1717,15 @@ checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f"

[[package]]
name = "wasi"
-
version = "0.9.0+wasi-snapshot-preview1"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "cccddf32554fecc6acb585f82a32a72e28b48f8c4c1883ddfeeeaa96f7d8e519"
-

-
[[package]]
-
name = "wasi"
version = "0.11.0+wasi-snapshot-preview1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423"

[[package]]
name = "wasm-bindgen"
-
version = "0.2.89"
+
version = "0.2.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "0ed0d4f68a3015cc185aff4db9506a015f4b96f95303897bfa23f846db54064e"
+
checksum = "b1223296a201415c7fad14792dbefaace9bd52b62d33453ade1c5b5f07555406"
dependencies = [
 "cfg-if",
 "wasm-bindgen-macro",
@@ -1589,24 +1733,24 @@ dependencies = [

[[package]]
name = "wasm-bindgen-backend"
-
version = "0.2.89"
+
version = "0.2.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "1b56f625e64f3a1084ded111c4d5f477df9f8c92df113852fa5a374dbda78826"
+
checksum = "fcdc935b63408d58a32f8cc9738a0bffd8f05cc7c002086c6ef20b7312ad9dcd"
dependencies = [
 "bumpalo",
 "log",
 "once_cell",
 "proc-macro2",
 "quote",
-
 "syn 2.0.41",
+
 "syn 2.0.48",
 "wasm-bindgen-shared",
]

[[package]]
name = "wasm-bindgen-macro"
-
version = "0.2.89"
+
version = "0.2.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "0162dbf37223cd2afce98f3d0785506dcb8d266223983e4b5b525859e6e182b2"
+
checksum = "3e4c238561b2d428924c49815533a8b9121c664599558a5d9ec51f8a1740a999"
dependencies = [
 "quote",
 "wasm-bindgen-macro-support",
@@ -1614,22 +1758,22 @@ dependencies = [

[[package]]
name = "wasm-bindgen-macro-support"
-
version = "0.2.89"
+
version = "0.2.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "f0eb82fcb7930ae6219a7ecfd55b217f5f0893484b7a13022ebb2b2bf20b5283"
+
checksum = "bae1abb6806dc1ad9e560ed242107c0f6c84335f1749dd4e8ddb012ebd5e25a7"
dependencies = [
 "proc-macro2",
 "quote",
-
 "syn 2.0.41",
+
 "syn 2.0.48",
 "wasm-bindgen-backend",
 "wasm-bindgen-shared",
]

[[package]]
name = "wasm-bindgen-shared"
-
version = "0.2.89"
+
version = "0.2.90"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "7ab9b36309365056cd639da3134bf87fa8f3d86008abf99e612384a6eecd459f"
+
checksum = "4d91413b1c31d7539ba5ef2451af3f0b833a005eb27a631cec32bc0635a8602b"

[[package]]
name = "winapi"
@@ -1664,35 +1808,11 @@ checksum = "712e227841d057c1ee1cd2fb22fa7e5a5461ae8e48fa2ca79ec42cfc1931183f"

[[package]]
name = "windows-sys"
-
version = "0.48.0"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "677d2418bec65e3338edb076e806bc1ec15693c5d0104683f2efe857f61056a9"
-
dependencies = [
-
 "windows-targets 0.48.5",
-
]
-

-
[[package]]
-
name = "windows-sys"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "282be5f36a8ce781fad8c8ae18fa3f9beff57ec1b52cb3de0789201425d9a33d"
dependencies = [
-
 "windows-targets 0.52.0",
-
]
-

-
[[package]]
-
name = "windows-targets"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c"
-
dependencies = [
-
 "windows_aarch64_gnullvm 0.48.5",
-
 "windows_aarch64_msvc 0.48.5",
-
 "windows_i686_gnu 0.48.5",
-
 "windows_i686_msvc 0.48.5",
-
 "windows_x86_64_gnu 0.48.5",
-
 "windows_x86_64_gnullvm 0.48.5",
-
 "windows_x86_64_msvc 0.48.5",
+
 "windows-targets",
]

[[package]]
@@ -1701,115 +1821,70 @@ version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "8a18201040b24831fbb9e4eb208f8892e1f50a37feb53cc7ff887feb8f50e7cd"
dependencies = [
-
 "windows_aarch64_gnullvm 0.52.0",
-
 "windows_aarch64_msvc 0.52.0",
-
 "windows_i686_gnu 0.52.0",
-
 "windows_i686_msvc 0.52.0",
-
 "windows_x86_64_gnu 0.52.0",
-
 "windows_x86_64_gnullvm 0.52.0",
-
 "windows_x86_64_msvc 0.52.0",
+
 "windows_aarch64_gnullvm",
+
 "windows_aarch64_msvc",
+
 "windows_i686_gnu",
+
 "windows_i686_msvc",
+
 "windows_x86_64_gnu",
+
 "windows_x86_64_gnullvm",
+
 "windows_x86_64_msvc",
]

[[package]]
name = "windows_aarch64_gnullvm"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8"
-

-
[[package]]
-
name = "windows_aarch64_gnullvm"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "cb7764e35d4db8a7921e09562a0304bf2f93e0a51bfccee0bd0bb0b666b015ea"

[[package]]
name = "windows_aarch64_msvc"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc"
-

-
[[package]]
-
name = "windows_aarch64_msvc"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "bbaa0368d4f1d2aaefc55b6fcfee13f41544ddf36801e793edbbfd7d7df075ef"

[[package]]
name = "windows_i686_gnu"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e"
-

-
[[package]]
-
name = "windows_i686_gnu"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "a28637cb1fa3560a16915793afb20081aba2c92ee8af57b4d5f28e4b3e7df313"

[[package]]
name = "windows_i686_msvc"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406"
-

-
[[package]]
-
name = "windows_i686_msvc"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ffe5e8e31046ce6230cc7215707b816e339ff4d4d67c65dffa206fd0f7aa7b9a"

[[package]]
name = "windows_x86_64_gnu"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e"
-

-
[[package]]
-
name = "windows_x86_64_gnu"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "3d6fa32db2bc4a2f5abeacf2b69f7992cd09dca97498da74a151a3132c26befd"

[[package]]
name = "windows_x86_64_gnullvm"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc"
-

-
[[package]]
-
name = "windows_x86_64_gnullvm"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "1a657e1e9d3f514745a572a6846d3c7aa7dbe1658c056ed9c3344c4109a6949e"

[[package]]
name = "windows_x86_64_msvc"
-
version = "0.48.5"
-
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538"
-

-
[[package]]
-
name = "windows_x86_64_msvc"
version = "0.52.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "dff9641d1cd4be8d1a070daf9e3773c5f67e78b4d9d42263020c057706765c04"

[[package]]
-
name = "zeroize"
-
version = "1.7.0"
+
name = "xattr"
+
version = "1.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d"
+
checksum = "8da84f1a25939b27f6820d92aed108f83ff920fdf11a7b19366c27c4cda81d4f"
dependencies = [
-
 "zeroize_derive",
+
 "libc",
+
 "linux-raw-sys",
+
 "rustix",
]

[[package]]
-
name = "zeroize_derive"
-
version = "1.4.2"
+
name = "zeroize"
+
version = "1.7.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
-
checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69"
-
dependencies = [
-
 "proc-macro2",
-
 "quote",
-
 "syn 2.0.41",
-
]
+
checksum = "525b4ec142c6b68a2d10f01f7bbf6755599ca3f81ea53b8431b7dd348f5fdb2d"
modified Cargo.toml
@@ -11,7 +11,12 @@ serde = { version = "1.0.193", features = ["derive"] }
serde_json = "1.0.108"
serde_yaml = "0.9.27"
thiserror = "1.0.50"
+
radicle-surf = { version = "0.18.0", default-features = false, features = ["serde"] }

[dependencies.radicle]
git = "https://seed.radicle.xyz/z3gqcJUoA1n9HaHKufZs5FCSGazv5.git"
branch = "master"
+
features = ["default", "test"]
+

+
[dev-dependencies]
+
tempfile = { version = "3.9.0" }
modified README.md
@@ -21,7 +21,25 @@ filters:
    - !Repository "rad:z2e6URdt1we1iG1BCVqtx8QVgsX4a"
    - !Or
      - !Branch "main"
+
      - !AnyPatchRef
+
~~~
+

+
OR if you only want to filter for patch COB updates (e.g. comments), to the specified repository:
+

+
~~~yaml
+
default_adapter: native
+
adapters:
+
  native:
+
    command: radicle-native-ci
+
    env:
+
      RADICLE_NATIVE_CI: /home/liw/radicle/radicle-native-ci/x/config.yaml
+
filters:
+
  - !And
+
    - !Repository "rad:z2e6URdt1we1iG1BCVqtx8QVgsX4a"
+
    - !And
      - !AnyPatch
+
      - !Not 
+
        - !AnyPatchRef 
~~~

This runs the native CI engine as an adapter, on any repository events
modified src/bin/broker-messages.rs
@@ -1,37 +1,44 @@
+
use radicle::git::RefString;
+
use radicle::Profile;
+
use radicle_ci_broker::filter::BrokerEvent;
use radicle_ci_broker::msg::{Oid, RepoId, Request, Response, RunId, RunResult};

fn main() {
    let rid = RepoId::from_urn("rad:zwTxygwuz5LDGBq255RA2CbNGrz8").expect("create rid");
    let commit =
        Oid::try_from("b4fb1e347be7db19f0859717062f94116b5bec9f").expect("create commit id");
-

-
    let trigger = Request::trigger(rid, commit);
-
    println!(
-
        "Trigger request:\n{}\n",
-
        serde_json::to_string(&trigger).expect("serizalize message")
-
    );
+
    let name = RefString::try_from("refs/namespaces/z6MkgEMYod7Hxfy9qCvDv5hYHkZ4ciWmLFgfvm3Wn1b2w2FV/refs/heads/patches/8d8232ddcb217fa1402eec4d955e227ef3bb5881").expect("create name");
+
    let be = BrokerEvent::RefChanged {
+
        rid,
+
        name,
+
        oid: commit,
+
        old: None,
+
    };
+
    let profile = Profile::load().expect("create profile");
+
    let trigger = Request::trigger(&profile, &be).expect("create trigger");
+
    println!("Trigger request:\n{}\n", trigger);

    let triggered = Response::triggered(RunId::from("any-string-works-as-run-id"));
    println!(
        "Triggered response:\n{}\n",
-
        serde_json::to_string(&triggered).expect("serizalize message")
+
        serde_json::to_string(&triggered).expect("serialize message")
    );

    let finished = Response::finished(RunResult::Success);
    println!(
        "Successful response:\n{}\n",
-
        serde_json::to_string(&finished).expect("serizalize message")
+
        serde_json::to_string(&finished).expect("serialize message")
    );

    let finished = Response::finished(RunResult::Failure);
    println!(
        "Failure response:\n{}\n",
-
        serde_json::to_string(&finished).expect("serizalize message")
+
        serde_json::to_string(&finished).expect("serialize message")
    );

    let finished = Response::finished(RunResult::Error("error message\nsecond line".into()));
    println!(
        "Error response:\n{}\n",
-
        serde_json::to_string(&finished).expect("serizalize message")
+
        serde_json::to_string(&finished).expect("serialize message")
    );
}
modified src/bin/ci-broker.rs
@@ -7,7 +7,7 @@ use std::{

use log::{debug, info};

-
use radicle::prelude::{Profile, RepoId};
+
use radicle::prelude::Profile;
use radicle_ci_broker::{
    config::{Adapter, Config},
    error::BrokerError,
@@ -15,7 +15,6 @@ use radicle_ci_broker::{
    filter::BrokerEvent,
    msg::{Request, Response, RunResult},
};
-
use radicle_git_ext::Oid;

fn main() {
    if let Err(e) = fallible_main() {
@@ -43,7 +42,7 @@ fn fallible_main() -> Result<(), BrokerError> {
    debug!("loaded configuration: {:#?}", config);

    let profile = Profile::load()?;
-
    let mut source = NodeEventSource::new(profile)?;
+
    let mut source = NodeEventSource::new(&profile)?;
    for filter in config.filters.iter() {
        source.allow(filter.clone());
    }
@@ -58,25 +57,28 @@ fn fallible_main() -> Result<(), BrokerError> {
    let mut counter = 0;
    loop {
        for e in source.event()? {
-
            match e {
-
                BrokerEvent::RefChanged { rid, name: _, oid } => {
-
                    counter += 1;
-
                    let ret = match run(adapter, rid, oid)? {
-
                        None => "unknown".into(),
-
                        Some(RunResult::Error(e)) => format!("ERROR: {}", e),
-
                        Some(RunResult::Failure) => "FAILED".into(),
-
                        Some(RunResult::Success) => "OK".into(),
-
                        Some(x) => format!("UNKNOWN: {:#?}", x),
-
                    };
-
                    println!("Run CI run #{}: {}, {} -> {}", counter, rid, oid, ret,);
-
                }
-
            }
+
            counter += 1;
+
            let req = Request::trigger(&profile, &e)?;
+
            let ret = match run(adapter, req)? {
+
                None => "unknown".into(),
+
                Some(RunResult::Error(e)) => format!("ERROR: {}", e),
+
                Some(RunResult::Failure) => "FAILED".into(),
+
                Some(RunResult::Success) => "OK".into(),
+
                Some(x) => format!("UNKNOWN: {:#?}", x),
+
            };
+
            let BrokerEvent::RefChanged {
+
                rid,
+
                oid,
+
                name: _,
+
                old: _,
+
            } = e;
+
            println!("Run CI run #{}: {}, {} -> {}", counter, rid, oid, ret,);
        }
    }
}

-
fn run(adapter: &Adapter, repo: RepoId, commit: Oid) -> Result<Option<RunResult>, BrokerError> {
-
    info!("Trigger on {}, {}", repo, commit);
+
fn run(adapter: &Adapter, req: Request) -> Result<Option<RunResult>, BrokerError> {
+
    info!("Trigger on {}", req);

    debug!("Spawning child process");
    let mut child = Command::new(&adapter.command)
@@ -88,7 +90,6 @@ fn run(adapter: &Adapter, repo: RepoId, commit: Oid) -> Result<Option<RunResult>

    {
        let stdin = child.stdin.take().expect("get stdin");
-
        let req = Request::trigger(repo, commit);
        req.to_writer(stdin)?;
    }

modified src/bin/filter-events.rs
@@ -1,6 +1,7 @@
//! Show broker events that are allowed by a filter. This is meant to
//! be helpful for testing a filter configuration.

+
use log::info;
use std::{error::Error, path::PathBuf};

use radicle::prelude::Profile;
@@ -27,10 +28,12 @@ fn fallible_main() -> Result<(), BrokerError> {
        return Err(BrokerError::Usage);
    };

+
    info!("using file: {:?}", filename);
+

    let config = Config::load(&filename)?;

    let profile = Profile::load()?;
-
    let mut source = NodeEventSource::new(profile)?;
+
    let mut source = NodeEventSource::new(&profile)?;
    for filter in config.filters.iter() {
        source.allow(filter.clone());
    }
modified src/bin/node-events.rs
@@ -28,7 +28,7 @@ fn fallible_main() -> Result<(), BrokerError> {
    info!("node event filters: {:#?}", filters);

    let profile = Profile::load()?;
-
    let mut source = NodeEventSource::new(profile)?;
+
    let mut source = NodeEventSource::new(&profile)?;
    for filter in filters {
        source.allow(filter);
    }
modified src/error.rs
@@ -38,4 +38,20 @@ pub enum BrokerError {
    /// Default adapter is not in list of adapters.
    #[error("default adapter is not in list of adapters")]
    UnknownDefaultAdapter(String),
+

+
    /// Error retrieving context to generate trigger from BrokerEvent
+
    #[error("could not generate trigger from event")]
+
    Trigger,
+

+
    #[error(transparent)]
+
    StorageError(#[from] radicle::storage::Error),
+

+
    #[error(transparent)]
+
    RepositoryError(#[from] radicle::storage::RepositoryError),
+

+
    #[error(transparent)]
+
    CobStoreError(#[from] radicle::cob::store::Error),
+

+
    #[error(transparent)]
+
    RadicleSurfError(#[from] radicle_surf::Error),
}
modified src/event.rs
@@ -26,7 +26,7 @@ pub struct NodeEventSource {
impl NodeEventSource {
    /// Create a new source of node events, for a given Radicle
    /// profile.
-
    pub fn new(profile: Profile) -> Result<Self, NodeEventError> {
+
    pub fn new(profile: &Profile) -> Result<Self, NodeEventError> {
        info!("subscribing to local node events");
        let node = radicle::Node::new(profile.socket());
        let events = node.subscribe(time::Duration::MAX)?;
modified src/filter.rs
@@ -27,9 +27,9 @@

use std::{fs::read, path::Path};

-
use radicle::{node::Event, storage::RefUpdate};
-

+
use radicle::node::NodeId;
use radicle::prelude::RepoId;
+
use radicle::{node::Event, storage::RefUpdate};
use radicle_git_ext::{ref_format::RefString, Oid};
use serde::{Deserialize, Serialize};

@@ -53,9 +53,15 @@ pub enum EventFilter {
    /// Event concerns any Radicle patch.
    AnyPatch,

-
    /// Event concerns a specific Radicle patch.
+
    /// Event concerns changes on specific Radicle patch.
    Patch(String),

+
    /// Event concerns changed refs on any Radicle patch branch.
+
    AnyPatchRef,
+

+
    /// Event concerns changed refs on the branch of the specified Radicle patch.
+
    PatchRef(String),
+

    /// Combine any number of filters that both must allow the events.
    And(Vec<Box<Self>>),

@@ -146,15 +152,18 @@ pub enum BrokerEvent {
        name: RefString,
        /// New git commit.
        oid: Oid,
+
        /// Old git commit
+
        old: Option<Oid>,
    },
}

impl BrokerEvent {
-
    fn new(rid: &RepoId, name: &RefString, oid: &Oid) -> Self {
+
    fn new(rid: &RepoId, name: &RefString, oid: &Oid, old: Option<Oid>) -> Self {
        Self::RefChanged {
            rid: *rid,
            name: name.clone(),
            oid: *oid,
+
            old,
        }
    }

@@ -171,10 +180,10 @@ impl BrokerEvent {
            for up in updated {
                match up {
                    RefUpdate::Created { name, oid } => {
-
                        events.push(Self::new(rid, name, oid));
+
                        events.push(Self::new(rid, name, oid, None));
                    }
-
                    RefUpdate::Updated { name, old: _, new } => {
-
                        events.push(Self::new(rid, name, new));
+
                    RefUpdate::Updated { name, old, new } => {
+
                        events.push(Self::new(rid, name, new, Some(*old)));
                    }
                    _ => (),
                }
@@ -187,21 +196,70 @@ impl BrokerEvent {

    /// Is this broker event allowed by a filter?
    pub fn is_allowed(&self, filter: &EventFilter) -> bool {
-
        let Self::RefChanged { rid, name, oid: _ } = self;
+
        let Self::RefChanged {
+
            rid,
+
            name,
+
            oid: _,
+
            old: _,
+
        } = self;
        match filter {
            EventFilter::Repository(wanted) => rid == wanted,
            EventFilter::RefSuffix(wanted) => name.ends_with(wanted),
            EventFilter::Branch(wanted) => name.ends_with(&format!("/refs/heads/{}", wanted)),
-
            EventFilter::AnyPatch => is_patch_ref(name).is_some(),
-
            EventFilter::Patch(wanted) => is_patch_ref(name) == Some(wanted),
+
            EventFilter::AnyPatch => is_patch_update(name).is_some(),
+
            EventFilter::Patch(wanted) => is_patch_update(name) == Some(wanted),
+
            EventFilter::AnyPatchRef => is_patch_ref(name).is_some(),
+
            EventFilter::PatchRef(wanted) => is_patch_ref(name) == Some(wanted),
            EventFilter::And(conds) => conds.iter().all(|cond| self.is_allowed(cond)),
            EventFilter::Or(conds) => conds.iter().any(|cond| self.is_allowed(cond)),
            EventFilter::Not(conds) => !conds.iter().any(|cond| self.is_allowed(cond)),
        }
    }
+

+
    pub fn name(&self) -> Option<&RefString> {
+
        match self {
+
            BrokerEvent::RefChanged { name, .. } => Some(name),
+
        }
+
    }
+

+
    /// Extract the NID from the RefString.
+
    /// The RefString will start with refs/namespaces/<nid>/...
+
    pub fn nid(&self) -> Option<NodeId> {
+
        if let Some(name) = self.name() {
+
            let mut parts = name.split('/');
+
            if let Some(nid) = parts.nth(2) {
+
                let parsed = nid.parse();
+
                if parsed.is_ok() {
+
                    return parsed.ok();
+
                }
+
            }
+
        }
+
        None
+
    }
+

+
    pub fn patch_id(&self) -> Option<Oid> {
+
        if let Some(name) = self.name() {
+
            let suffix = is_patch_update(name);
+
            if let Some(suffix_str) = suffix {
+
                return suffix_str.parse().ok();
+
            }
+
        }
+
        None
+
    }
+
}
+

+
pub fn is_patch_update(name: &str) -> Option<&str> {
+
    let mut parts = name.split("/refs/cobs/xyz.radicle.patch/");
+
    if let Some(suffix) = parts.nth(1) {
+
        if parts.next().is_none() {
+
            return Some(suffix);
+
        }
+
    }
+

+
    None
}

-
fn is_patch_ref(name: &str) -> Option<&str> {
+
pub fn is_patch_ref(name: &str) -> Option<&str> {
    let mut parts = name.split("/refs/heads/patches/");
    if let Some(suffix) = parts.nth(1) {
        if parts.next().is_none() {
@@ -214,7 +272,7 @@ fn is_patch_ref(name: &str) -> Option<&str> {

#[cfg(test)]
mod test {
-
    use super::is_patch_ref;
+
    use super::{is_patch_ref, is_patch_update};

    #[test]
    fn branch_is_not_patch() {
@@ -235,4 +293,34 @@ mod test {
            Some("bbb54a2c9314a528a4fff9d6c2aae874ed098433")
        );
    }
+

+
    #[test]
+
    fn branch_is_not_patch_update() {
+
        assert_eq!(
+
            is_patch_update(
+
                "refs/namespaces/z6MkuhvCnrcow7vzkyQzkuFixzpTa42iC2Cfa4DA8HRLCmys/refs/heads/main"
+
            ),
+
            None
+
        );
+
    }
+

+
    #[test]
+
    fn patch_branch_is_not_patch_update() {
+
        assert_eq!(
+
            is_patch_update(
+
                "refs/namespaces/z6MkuhvCnrcow7vzkyQzkuFixzpTa42iC2Cfa4DA8HRLCmys/refs/heads/patches/bbb54a2c9314a528a4fff9d6c2aae874ed098433"
+
            ),
+
            None
+
        );
+
    }
+

+
    #[test]
+
    fn patch_update() {
+
        assert_eq!(
+
            is_patch_update(
+
                "refs/namespaces/z6MkuhvCnrcow7vzkyQzkuFixzpTa42iC2Cfa4DA8HRLCmys/refs/cobs/xyz.radicle.patch/bbb54a2c9314a528a4fff9d6c2aae874ed098433"
+
            ),
+
            Some("bbb54a2c9314a528a4fff9d6c2aae874ed098433")
+
        );
+
    }
}
modified src/msg.rs
@@ -9,10 +9,18 @@ use std::{
    io::{BufRead, BufReader, Read, Write},
};

-
use serde::{Deserialize, Serialize};
-

pub use radicle::git::Oid;
+
use radicle::identity::Did;
+
use radicle::node::{Alias, AliasStore};
+
use radicle::patch::RevisionId;
pub use radicle::prelude::{NodeId, RepoId};
+
use radicle::storage::git::paths;
+
use radicle::storage::{ReadRepository, ReadStorage};
+
use radicle::{patch, Profile};
+
use serde::{Deserialize, Serialize};
+

+
use crate::error::BrokerError;
+
use crate::filter::{is_patch_update, BrokerEvent};

/// The type of a run identifier. For maximum generality, this is a
/// string rather than an integer.
@@ -73,13 +81,140 @@ impl fmt::Display for RunResult {
#[non_exhaustive]
pub enum Request {
    /// Trigger a run.
-
    Trigger { repo: RepoId, commit: Oid },
+
    Trigger {
+
        #[serde(flatten)]
+
        common: EventCommonFields,
+
        #[serde(flatten)]
+
        push: Option<PushEvent>,
+
        #[serde(flatten)]
+
        patch: Option<PatchEvent>,
+
    },
}

impl Request {
-
    /// Create an event to trigger a run.
-
    pub fn trigger(repo: RepoId, commit: Oid) -> Self {
-
        Self::Trigger { repo, commit }
+
    /// Create a request event to trigger a run.
+
    pub fn trigger(profile: &Profile, event: &BrokerEvent) -> Result<Self, BrokerError> {
+
        let BrokerEvent::RefChanged {
+
            rid,
+
            name,
+
            oid,
+
            old,
+
        } = event;
+
        let is_patch = is_patch_update(name).is_some();
+
        let repository = profile.storage.repository(*rid)?;
+
        let storage = &profile.storage;
+
        let repo = radicle_surf::Repository::open(paths::repository(storage, rid))?;
+
        let repo_project = repository.project()?;
+
        let repo_identity = repository.identity()?;
+
        let author = extract_author(profile, event)?;
+
        let push_info: Option<PushEvent>;
+
        let patch_info: Option<PatchEvent>;
+
        let event_type: String;
+
        if is_patch {
+
            event_type = "patch".to_string();
+
            let patch_id = event.patch_id().ok_or(BrokerError::Trigger)?;
+
            let patch = patch::Patches::open(&repository)?
+
                .get(&patch_id.into())?
+
                .ok_or(BrokerError::Trigger)?;
+
            push_info = None;
+

+
            let revs: Vec<Revision> = patch
+
                .revisions()
+
                .map(|(rid, r)| {
+
                    Ok::<Revision, BrokerError>(Revision {
+
                        id: rid.into(),
+
                        author: did_to_author(profile, r.author().id())?,
+
                        description: r.description().to_string(),
+
                        base: *r.base(),
+
                        oid: r.head(),
+
                        timestamp: r.timestamp().as_secs(),
+
                    })
+
                })
+
                .collect::<Result<Vec<Revision>, BrokerError>>()?;
+
            let patch_author_pk = radicle::crypto::PublicKey::from(author.id);
+
            let patch_latest_revision = patch
+
                .latest_by(&patch_author_pk)
+
                .ok_or(BrokerError::Trigger)?;
+
            let patch_head = patch_latest_revision.1.head();
+
            let patch_base = patch_latest_revision.1.base();
+
            let patch_commits: Vec<Oid> = repo
+
                .history(patch_head)?
+
                .take_while(|c| {
+
                    if let Ok(c) = c {
+
                        c.id != *patch_base
+
                    } else {
+
                        false
+
                    }
+
                })
+
                .map(|r| r.map(|c| c.id))
+
                .collect::<Result<Vec<Oid>, _>>()?;
+
            let patch_action = if patch.revisions().count() > 1 {
+
                "updated"
+
            } else {
+
                "created"
+
            };
+
            patch_info = Some(PatchEvent {
+
                action: patch_action.to_string(),
+
                patch: Patch {
+
                    id: patch_id,
+
                    author,
+
                    title: patch.title().to_string(),
+
                    state: State {
+
                        status: patch.state().to_string(),
+
                        conflicts: match patch.state() {
+
                            patch::State::Open { conflicts, .. } => conflicts.to_vec(),
+
                            _ => vec![],
+
                        },
+
                    },
+
                    before: *patch_base,
+
                    after: patch_head,
+
                    commits: patch_commits,
+
                    target: patch.target().head(&repository)?,
+
                    labels: patch.labels().map(|l| l.name().to_string()).collect(),
+
                    assignees: patch.assignees().collect(),
+
                    revisions: revs,
+
                },
+
            });
+
        } else {
+
            event_type = "push".to_string();
+
            let before_oid: Oid = old.unwrap_or(*oid);
+
            let push_commits: Vec<Oid> = repo
+
                .history(oid)?
+
                .take_while(|c| {
+
                    if let Ok(c) = c {
+
                        c.id != before_oid
+
                    } else {
+
                        false
+
                    }
+
                })
+
                .map(|r| r.map(|c| c.id))
+
                .collect::<Result<Vec<Oid>, _>>()?;
+
            push_info = Some(PushEvent {
+
                pusher: author,
+
                before: before_oid,
+
                after: *oid,
+
                commits: push_commits,
+
            });
+
            patch_info = None;
+
        };
+

+
        let common = EventCommonFields {
+
            event_type,
+
            repository: Repository {
+
                id: *rid,
+
                name: repo_project.name().to_string(),
+
                description: repo_project.description().to_string(),
+
                private: !repo_identity.visibility.is_public(),
+
                default_branch: repo_project.default_branch().to_string(),
+
                delegates: repository.delegates()?.iter().copied().collect(),
+
            },
+
        };
+

+
        Ok(Self::Trigger {
+
            common,
+
            push: push_info,
+
            patch: patch_info,
+
        })
    }

    /// Serialize the request as a single-line JSON, including the
@@ -105,6 +240,93 @@ impl Request {
    }
}

+
fn did_to_author(profile: &Profile, did: &Did) -> Result<Author, BrokerError> {
+
    let alias = profile.aliases().alias(did);
+
    Ok(Author { id: *did, alias })
+
}
+

+
fn extract_author(profile: &Profile, event: &BrokerEvent) -> Result<Author, BrokerError> {
+
    let nid = event.nid().ok_or(BrokerError::Trigger)?;
+
    did_to_author(profile, &Did::from(nid))
+
}
+

+
impl fmt::Display for Request {
+
    fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
+
        write!(
+
            f,
+
            "{}",
+
            serde_json::to_string(&self).map_err(|_| fmt::Error)?
+
        )
+
    }
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct EventCommonFields {
+
    pub event_type: String,
+
    pub repository: Repository,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct PushEvent {
+
    pub pusher: Author,
+
    pub before: Oid,
+
    pub after: Oid,
+
    pub commits: Vec<Oid>,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct PatchEvent {
+
    pub action: String,
+
    pub patch: Patch,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct Repository {
+
    pub id: RepoId,
+
    pub name: String,
+
    pub description: String,
+
    pub private: bool,
+
    pub default_branch: String,
+
    pub delegates: Vec<Did>,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct Author {
+
    pub id: Did,
+
    pub alias: Option<Alias>,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct State {
+
    pub status: String,
+
    pub conflicts: Vec<(RevisionId, Oid)>,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct Revision {
+
    pub id: Oid,
+
    pub author: Author,
+
    pub description: String,
+
    pub base: Oid,
+
    pub oid: Oid,
+
    pub timestamp: u64,
+
}
+

+
#[derive(Debug, Clone, Serialize, Deserialize)]
+
pub struct Patch {
+
    pub id: Oid,
+
    pub author: Author,
+
    pub title: String,
+
    pub state: State,
+
    pub before: Oid,
+
    pub after: Oid,
+
    pub commits: Vec<Oid>,
+
    pub target: Oid,
+
    pub labels: Vec<String>,
+
    pub assignees: Vec<Did>,
+
    pub revisions: Vec<Revision>,
+
}
+

/// A response message from the adapter child process to the broker.
#[derive(Debug, Clone, Serialize, Deserialize)]
#[serde(deny_unknown_fields)]
@@ -202,10 +424,148 @@ pub enum MessageError {
    DeserializeRequest(#[source] serde_json::Error),

    /// Failed to parse JSON as a response or a response.
-
    #[error("failed to read a JSON request from a file handle")]
+
    #[error("failed to read a JSON response from a file handle")]
    DeserializeResponse(#[source] serde_json::Error),

    /// Error from Radicle.
    #[error(transparent)]
    RadicleProfile(#[from] radicle::profile::Error),
}
+

+
#[cfg(test)]
+
mod tests {
+
    use crate::filter::BrokerEvent;
+
    use crate::msg::Request;
+
    use radicle::crypto::ssh::Keystore;
+
    use radicle::crypto::test::signer::MockSigner;
+
    use radicle::crypto::Signer;
+
    use radicle::git::raw::Oid;
+
    use radicle::git::RefString;
+
    use radicle::patch::{MergeTarget, Patches};
+
    use radicle::prelude::Did;
+
    use radicle::profile::{Config, Home};
+
    use radicle::storage::ReadRepository;
+
    use radicle::test::setup::Node;
+
    use radicle::Profile;
+

+
    #[test]
+
    fn trigger_push() {
+
        let root = tempfile::tempdir().unwrap();
+
        let ms = MockSigner::default();
+
        let alias = "broker_test_alias";
+
        let node = Node::new(root, ms, alias);
+
        let prj = node.project();
+
        let repo_head = prj.repo.head().unwrap().1;
+
        let cmt =
+
            radicle::test::fixtures::commit("my test commit", &[repo_head.into()], &prj.backend);
+
        let profile = Profile {
+
            home: Home::new(node.root.clone()).unwrap(),
+
            storage: node.storage,
+
            keystore: Keystore::new(&node.root),
+
            public_key: node.signer.public_key().to_owned(),
+
            config: Config::new(alias.parse().unwrap()),
+
        };
+

+
        let be = BrokerEvent::RefChanged {
+
            rid: prj.id,
+
            name: RefString::try_from(
+
                "refs/namespaces/$nid/refs/heads/master".replace("$nid", &profile.id().to_string()),
+
            )
+
            .unwrap(),
+
            oid: cmt,
+
            old: Some(repo_head),
+
        };
+

+
        let req = Request::trigger(&profile, &be).expect("expect request trigger");
+
        let Request::Trigger {
+
            common,
+
            push,
+
            patch,
+
        } = req;
+
        assert!(patch.is_none());
+
        assert!(push.is_some());
+
        assert_eq!(common.event_type, "push");
+
        assert_eq!(common.repository.id, prj.id);
+
        assert_eq!(common.repository.name, prj.repo.project().unwrap().name());
+

+
        let push = push.unwrap();
+
        assert_eq!(push.after, cmt);
+
        assert_eq!(push.before, repo_head);
+
        assert_eq!(push.commits, vec![cmt]);
+
        assert_eq!(push.pusher.id, Did::from(profile.id()));
+
    }
+

+
    #[test]
+
    fn trigger_patch() {
+
        let root = tempfile::tempdir().unwrap();
+
        let alias = "broker_test_alias";
+
        let node = Node::new(root, MockSigner::default(), alias);
+
        let prj = node.project();
+
        let repo_head = prj.repo.head().unwrap().1;
+
        let cmt =
+
            radicle::test::fixtures::commit("my test commit", &[repo_head.into()], &prj.backend);
+

+
        let mut patches = Patches::open(&prj.repo).unwrap();
+
        let patch_cob = patches
+
            .create(
+
                "my patch title",
+
                "my patch description",
+
                MergeTarget::Delegates,
+
                repo_head,
+
                cmt,
+
                &[],
+
                &node.signer,
+
            )
+
            .unwrap();
+

+
        let profile = Profile {
+
            home: Home::new(node.root.clone()).unwrap(),
+
            storage: node.storage,
+
            keystore: Keystore::new(&node.root),
+
            public_key: node.signer.public_key().to_owned(),
+
            config: Config::new(alias.parse().unwrap()),
+
        };
+

+
        let be = BrokerEvent::RefChanged {
+
            rid: prj.id,
+
            name: RefString::try_from(
+
                "refs/namespaces/$nid/refs/cobs/xyz.radicle.patch/$patchId"
+
                    .replace("$nid", &profile.id().to_string())
+
                    .replace("$patchId", &patch_cob.id.to_string()),
+
            )
+
            .unwrap(),
+
            oid: radicle_git_ext::Oid::from(Oid::from_str(&patch_cob.id.to_string()).unwrap()),
+
            old: None,
+
        };
+

+
        let req = Request::trigger(&profile, &be).expect("expect request trigger");
+
        let Request::Trigger {
+
            common,
+
            push,
+
            patch,
+
        } = req;
+
        assert!(patch.is_some());
+
        assert!(push.is_none());
+
        assert_eq!(common.event_type, "patch");
+
        assert_eq!(common.repository.id, prj.id);
+
        assert_eq!(common.repository.name, prj.repo.project().unwrap().name());
+

+
        let patch = patch.unwrap();
+
        assert_eq!(patch.action, "created");
+
        assert_eq!(patch.patch.id.to_string(), patch_cob.id.to_string());
+
        assert_eq!(patch.patch.title, patch_cob.title());
+
        assert_eq!(patch.patch.state.status, patch_cob.state().to_string());
+
        assert_eq!(patch.patch.target, repo_head);
+
        assert_eq!(patch.patch.revisions.len(), 1);
+
        let rev = patch.patch.revisions.first().unwrap();
+
        assert_eq!(rev.id.to_string(), patch_cob.id.to_string());
+
        assert_eq!(rev.base, repo_head);
+
        assert_eq!(rev.oid, cmt);
+
        assert_eq!(rev.author.id, Did::from(profile.id()));
+
        assert_eq!(rev.description, patch_cob.description());
+
        assert_eq!(rev.timestamp, patch_cob.timestamp().as_secs());
+
        assert_eq!(patch.patch.after, cmt);
+
        assert_eq!(patch.patch.before, repo_head);
+
        assert_eq!(patch.patch.commits, vec![cmt]);
+
    }
+
}