diff --git a/backend/build.sbt b/backend/build.sbt index 9ea6ccf..c0a7ff9 100644 --- a/backend/build.sbt +++ b/backend/build.sbt @@ -1,4 +1,4 @@ -val scala3Version = "3.3.0" +val scala3Version = "3.3.1" maintainer := "timzaak" @@ -26,6 +26,7 @@ lazy val app = project libraryDependencies ++= Seq( "org.eclipse.jetty" % "jetty-webapp" % "11.0.15" % "container;compile", + "org.postgresql" % "postgresql" % "42.6.0", "org.bouncycastle" % "bcprov-jdk18on" % "1.72", // for x25519, "org.scalameta" %% "munit" % "0.7.29" % Test ) diff --git a/client/Cargo.lock b/client/Cargo.lock index 0f7f2e8..6d90d9a 100644 --- a/client/Cargo.lock +++ b/client/Cargo.lock @@ -844,7 +844,7 @@ dependencies = [ [[package]] name = "fornet" -version = "0.1.0" +version = "0.1.1" dependencies = [ "anyhow", "cfg-if", diff --git a/client/bin/Cargo.toml b/client/bin/Cargo.toml index 1094db0..d4c0b33 100644 --- a/client/bin/Cargo.toml +++ b/client/bin/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "fornet" -version = "0.1.0" +version = "0.1.1" edition = "2021" [[bin]] diff --git a/protobuf/config.proto b/protobuf/config.proto index 4f8ae2d..23cb5a9 100644 --- a/protobuf/config.proto +++ b/protobuf/config.proto @@ -8,30 +8,29 @@ option java_package = "com.timzaak.fornet.protobuf"; enum Protocol { Protocol_TCP = 0; - Protocol_UDP = 1; + Protocol_UDP = 1; //webrtc-rs only support udp } message Interface { optional string name = 1; - repeated string address = 2; - int32 listen_port = 3; + repeated string address = 2; //ip + int32 listen_port = 3; // wirguard port, webrtc does not need it // optional string private_key = 4; // this is no needed now, we may support it in future version repeated string dns = 5; optional uint32 mtu = 6; optional string pre_up = 7; - optional string post_up = 8; + optional string post_up = 8; // wireguard relay need it optional string pre_down = 9; - optional string post_down = 10; + optional string post_down = 10; // wireguard relay need it Protocol protocol = 11; } message Peer { - optional string endpoint = 1; - repeated string allowed_ip = 2; - string public_key = 3; - uint32 persistence_keep_alive = 4; - // This is for tcp - repeated string address = 5; + optional string endpoint = 1; // wireguard relay + repeated string allowed_ip = 2; // ACL, but now wireguard normal node does not support this + string public_key = 3; + uint32 persistence_keep_alive = 4; // wireguard param, can used for webrtc + repeated string address = 5; // ip, should be contained by allowed_ip? } diff --git a/relay/.gitignore b/relay/.gitignore new file mode 100644 index 0000000..d06748c --- /dev/null +++ b/relay/.gitignore @@ -0,0 +1,8 @@ +/target +.idea +*dist* +*node_modules* +/workflow +build/ +.DS_Store +turn_server.dev.toml \ No newline at end of file diff --git a/relay/Cargo.lock b/relay/Cargo.lock new file mode 100644 index 0000000..a7e63a4 --- /dev/null +++ b/relay/Cargo.lock @@ -0,0 +1,2272 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "addr2line" +version = "0.21.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8a30b2e23b9e17a9f90641c7ab1549cd9b44f296d3ccbf309d2863cfe398a0cb" +dependencies = [ + "gimli", +] + +[[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" +checksum = "ac1f845298e95f983ff1944b728ae08b8cebab80d684f0a832ed0fc74dfa27e2" +dependencies = [ + "cfg-if", + "cipher", + "cpufeatures", +] + +[[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" +checksum = "b2969dcb958b36655471fc61f7e416fa76033bdd4bfed0678d8fee1e2d07a1f0" +dependencies = [ + "memchr", +] + +[[package]] +name = "anstream" +version = "0.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2ab91ebe16eb252986481c5b62f6098f3b698a45e34b5b98200cf20dd2484a44" +dependencies = [ + "anstyle", + "anstyle-parse", + "anstyle-query", + "anstyle-wincon", + "colorchoice", + "utf8parse", +] + +[[package]] +name = "anstyle" +version = "1.0.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7079075b41f533b8c61d2a4d073c4676e1f8b249ff94a393b0595db304e0dd87" + +[[package]] +name = "anstyle-parse" +version = "0.2.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "317b9a89c1868f5ea6ff1d9539a69f45dffc21ce321ac1fd1160dfa48c8e2140" +dependencies = [ + "utf8parse", +] + +[[package]] +name = "anstyle-query" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5ca11d4be1bab0c8bc8734a9aa7bf4ee8316d462a08c6ac5052f888fef5b494b" +dependencies = [ + "windows-sys", +] + +[[package]] +name = "anstyle-wincon" +version = "3.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f0699d10d2f4d628a98ee7b57b289abbc98ff3bad977cb3152709d4bf2330628" +dependencies = [ + "anstyle", + "windows-sys", +] + +[[package]] +name = "anyhow" +version = "1.0.75" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4668cab20f66d8d020e1fbc0ebe47217433c1b6c8f2040faf858554e394ace6" + +[[package]] +name = "arc-swap" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bddcadddf5e9015d310179a59bb28c4d4b9920ad0f11e8e14dbadf654890c9a6" + +[[package]] +name = "asn1-rs" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f6fd5ddaf0351dff5b8da21b2fb4ff8e08ddd02857f0bf69c47639106c0fff0" +dependencies = [ + "asn1-rs-derive", + "asn1-rs-impl", + "displaydoc", + "nom", + "num-traits", + "rusticata-macros", + "thiserror", + "time", +] + +[[package]] +name = "asn1-rs-derive" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "726535892e8eae7e70657b4c8ea93d26b8553afb1ce617caee529ef96d7dee6c" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", + "synstructure", +] + +[[package]] +name = "asn1-rs-impl" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2777730b2039ac0f95f093556e61b6d26cebed5393ca6f152717777cec3a42ed" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", +] + +[[package]] +name = "async-trait" +version = "0.1.73" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bc00ceb34980c03614e35a3a4e218276a0a824e911d07651cd0d858a51e8c0f0" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "atomic-waker" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0" + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "backtrace" +version = "0.3.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2089b7e3f35b9dd2d0ed921ead4f6d318c27680d4a5bd167b3ee120edb105837" +dependencies = [ + "addr2line", + "cc", + "cfg-if", + "libc", + "miniz_oxide", + "object", + "rustc-demangle", +] + +[[package]] +name = "base16ct" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c7f02d4ea65f2c1853089ffd8d2787bdbc63de2f0d29dedbcf8ccdfa0ccd4cf" + +[[package]] +name = "base64" +version = "0.21.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ba43ea6f343b788c8764558649e08df62f86c6ef251fdaeb1ffd010a9ae50a2" + +[[package]] +name = "base64ct" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8c3c1a368f70d6cf7302d78f8f7093da241fb8e8807c05cc9e51a125895a6d5b" + +[[package]] +name = "bincode" +version = "1.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b1f45e9417d87227c7a56d22e471c6206462cba514c7590c09aff4cf6d1ddcad" +dependencies = [ + "serde", +] + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "block-buffer" +version = "0.10.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3078c7629b62d3f0439517fa394996acacc5cbc91c5a20d8c658e77abd503a71" +dependencies = [ + "generic-array", +] + +[[package]] +name = "block-padding" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a8894febbff9f758034a5b8e12d87918f56dfc64a8e1fe757d65e29041538d93" +dependencies = [ + "generic-array", +] + +[[package]] +name = "bumpalo" +version = "3.14.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f30e7476521f6f8af1a1c4c0b8cc94f0bee37d91763d0ca2665f299b6cd8aec" + +[[package]] +name = "byteorder" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1fd0f2584146f6f2ef48085050886acf353beff7305ebd1ae69500e27c67f64b" + +[[package]] +name = "bytes" +version = "1.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a2bd12c1caf447e69cd4528f47f94d203fd2582878ecb9e9465484c4148a8223" + +[[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" +checksum = "f1174fb0b6ec23863f8b971027804a42614e347eafb0a95bf0b12cdae21fc4d0" +dependencies = [ + "libc", +] + +[[package]] +name = "ccm" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ae3c82e4355234767756212c570e29833699ab63e6ffd161887314cc5b43847" +dependencies = [ + "aead", + "cipher", + "ctr", + "subtle", +] + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "cipher" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "773f3b9af64447d2ce9850330c473515014aa235e6a783b02db81ff39e4a3dad" +dependencies = [ + "crypto-common", + "inout", +] + +[[package]] +name = "clap" +version = "4.4.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d04704f56c2cde07f43e8e2c154b43f216dc5c92fc98ada720177362f953b956" +dependencies = [ + "clap_builder", +] + +[[package]] +name = "clap_builder" +version = "4.4.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0e231faeaca65ebd1ea3c737966bf858971cd38c3849107aa3ea7de90a804e45" +dependencies = [ + "anstream", + "anstyle", + "clap_lex", + "strsim", +] + +[[package]] +name = "clap_lex" +version = "0.5.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cd7cc57abe963c6d3b9d8be5b06ba7c8957a930305ca90304f24ef040aa6f961" + +[[package]] +name = "colorchoice" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "acbf1af155f9b9ef647e42cdc158db4b64a1b61f743629225fde6f3e0be2a7c7" + +[[package]] +name = "const-oid" +version = "0.9.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "28c122c3980598d243d63d9a704629a2d748d101f278052ff068be5a4423ab6f" + +[[package]] +name = "cpufeatures" +version = "0.2.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a17b76ff3a4162b0b27f354a0c87015ddad39d35f9c0c36607a3bdd175dde1f1" +dependencies = [ + "libc", +] + +[[package]] +name = "crc" +version = "3.0.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "86ec7a15cbe22e59248fc7eadb1907dab5ba09372595da4d73dd805ed4417dfe" +dependencies = [ + "crc-catalog", +] + +[[package]] +name = "crc-catalog" +version = "2.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9cace84e55f07e7301bae1c519df89cdad8cc3cd868413d3fdbdeca9ff3db484" + +[[package]] +name = "crypto-bigint" +version = "0.5.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "740fe28e594155f10cfc383984cbefd529d7396050557148f79cb0f621204124" +dependencies = [ + "generic-array", + "rand_core", + "subtle", + "zeroize", +] + +[[package]] +name = "crypto-common" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bfb12502f3fc46cca1bb51ac28df9d618d813cdc3d2f25b9fe775a34af26bb3" +dependencies = [ + "generic-array", + "rand_core", + "typenum", +] + +[[package]] +name = "ctr" +version = "0.9.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0369ee1ad671834580515889b80f2ea915f23b8be8d0daa4bbaf2ac5c7590835" +dependencies = [ + "cipher", +] + +[[package]] +name = "curve25519-dalek" +version = "4.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e89b8c6a2e4b1f45971ad09761aafb85514a84744b67a95e32c3cc1352d1f65c" +dependencies = [ + "cfg-if", + "cpufeatures", + "curve25519-dalek-derive", + "fiat-crypto", + "platforms", + "rustc_version", + "subtle", + "zeroize", +] + +[[package]] +name = "curve25519-dalek-derive" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "83fdaf97f4804dcebfa5862639bc9ce4121e82140bec2a987ac5140294865b5b" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "data-encoding" +version = "2.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c2e66c9d817f1720209181c316d28635c050fa304f9c79e47a520882661b7308" + +[[package]] +name = "der" +version = "0.7.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fffa369a668c8af7dbf8b5e56c9f744fbd399949ed171606040001947de40b1c" +dependencies = [ + "const-oid", + "pem-rfc7468", + "zeroize", +] + +[[package]] +name = "der-parser" +version = "8.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dbd676fbbab537128ef0278adb5576cf363cff6aa22a7b24effe97347cfab61e" +dependencies = [ + "asn1-rs", + "displaydoc", + "nom", + "num-bigint", + "num-traits", + "rusticata-macros", +] + +[[package]] +name = "deranged" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0f32d04922c60427da6f9fef14d042d9edddef64cb9d4ce0d64d0685fbeb1fd3" +dependencies = [ + "powerfmt", +] + +[[package]] +name = "digest" +version = "0.10.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9ed9a281f7bc9b7576e61468ba615a66a5c8cfdff42420a70aa82701a3b1e292" +dependencies = [ + "block-buffer", + "const-oid", + "crypto-common", + "subtle", +] + +[[package]] +name = "displaydoc" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "487585f4d0c6655fe74905e2504d8ad6908e4db67f744eb140876906c2f3175d" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "ecdsa" +version = "0.16.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a4b1e0c257a9e9f25f90ff76d7a68360ed497ee519c8e428d1825ef0000799d4" +dependencies = [ + "der", + "digest", + "elliptic-curve", + "rfc6979", + "signature", + "spki", +] + +[[package]] +name = "elliptic-curve" +version = "0.13.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d97ca172ae9dc9f9b779a6e3a65d308f2af74e5b8c921299075bdb4a0370e914" +dependencies = [ + "base16ct", + "crypto-bigint", + "digest", + "ff", + "generic-array", + "group", + "hkdf", + "pem-rfc7468", + "pkcs8", + "rand_core", + "sec1", + "subtle", + "zeroize", +] + +[[package]] +name = "ff" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ded41244b729663b1e574f1b4fb731469f69f79c17667b5d776b16cda0479449" +dependencies = [ + "rand_core", + "subtle", +] + +[[package]] +name = "fiat-crypto" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d0870c84016d4b481be5c9f323c24f65e31e901ae618f0e80f4308fb00de1d2d" + +[[package]] +name = "form_urlencoded" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a62bc1cf6f830c2ec14a513a9fb124d0a213a629668a4186f329db21fe045652" +dependencies = [ + "percent-encoding", +] + +[[package]] +name = "futures" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "23342abe12aba583913b2e62f22225ff9c950774065e4bfb61a19cd9770fec40" +dependencies = [ + "futures-channel", + "futures-core", + "futures-executor", + "futures-io", + "futures-sink", + "futures-task", + "futures-util", +] + +[[package]] +name = "futures-channel" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "955518d47e09b25bbebc7a18df10b81f0c766eaf4c4f1cccef2fca5f2a4fb5f2" +dependencies = [ + "futures-core", + "futures-sink", +] + +[[package]] +name = "futures-core" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4bca583b7e26f571124fe5b7561d49cb2868d79116cfa0eefce955557c6fee8c" + +[[package]] +name = "futures-executor" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ccecee823288125bd88b4d7f565c9e58e41858e47ab72e8ea2d64e93624386e0" +dependencies = [ + "futures-core", + "futures-task", + "futures-util", +] + +[[package]] +name = "futures-io" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4fff74096e71ed47f8e023204cfd0aa1289cd54ae5430a9523be060cdb849964" + +[[package]] +name = "futures-macro" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "89ca545a94061b6365f2c7355b4b32bd20df3ff95f02da9329b34ccc3bd6ee72" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "futures-sink" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f43be4fe21a13b9781a69afa4985b0f6ee0e1afab2c6f454a8cf30e2b2237b6e" + +[[package]] +name = "futures-task" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "76d3d132be6c0e6aa1534069c705a74a5997a356c0dc2f86a47765e5617c5b65" + +[[package]] +name = "futures-util" +version = "0.3.28" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "26b01e40b772d54cf6c6d721c1d1abd0647a0106a12ecaa1c186273392a69533" +dependencies = [ + "futures-channel", + "futures-core", + "futures-io", + "futures-macro", + "futures-sink", + "futures-task", + "memchr", + "pin-project-lite", + "pin-utils", + "slab", +] + +[[package]] +name = "generic-array" +version = "0.14.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "85649ca51fd72272d7821adaf274ad91c288277713d9c18820d8499a7ff69e9a" +dependencies = [ + "typenum", + "version_check", + "zeroize", +] + +[[package]] +name = "getrandom" +version = "0.2.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "be4136b2a15dd319360be1c07d9933517ccf0be8f16bf62a3bee4f0d618df427" +dependencies = [ + "cfg-if", + "libc", + "wasi", +] + +[[package]] +name = "ghash" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d930750de5717d2dd0b8c0d42c076c0e884c81a73e6cab859bbd2339c71e3e40" +dependencies = [ + "opaque-debug", + "polyval", +] + +[[package]] +name = "gimli" +version = "0.28.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6fb8d784f27acf97159b40fc4db5ecd8aa23b9ad5ef69cdd136d3bc80665f0c0" + +[[package]] +name = "group" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f0f9ef7462f7c099f518d754361858f86d8a07af53ba9af0fe635bbccb151a63" +dependencies = [ + "ff", + "rand_core", + "subtle", +] + +[[package]] +name = "hermit-abi" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d77f7ec81a6d05a3abb01ab6eb7590f6083d08449fe5a1c8b1e620283546ccb7" + +[[package]] +name = "hex" +version = "0.4.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7f24254aa9a54b5c858eaee2f5bccdb46aaf0e486a595ed5fd8f86ba55232a70" + +[[package]] +name = "hkdf" +version = "0.12.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "791a029f6b9fc27657f6f188ec6e5e43f6911f6f878e0dc5501396e09809d437" +dependencies = [ + "hmac", +] + +[[package]] +name = "hmac" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c49c37c09c17a53d937dfbb742eb3a961d65a994e6bcdcf37e7399d0cc8ab5e" +dependencies = [ + "digest", +] + +[[package]] +name = "idna" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7d20d6b07bfbc108882d88ed8e37d39636dcc260e15e30c45e6ba089610b917c" +dependencies = [ + "unicode-bidi", + "unicode-normalization", +] + +[[package]] +name = "inout" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a0c10553d664a4d0bcff9f4215d0aac67a639cc68ef660840afe309b807bc9f5" +dependencies = [ + "block-padding", + "generic-array", +] + +[[package]] +name = "interceptor" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5927883184e6a819b22d5e4f5f7bc7ca134fde9b2026fbddd8d95249746ba21e" +dependencies = [ + "async-trait", + "bytes", + "log", + "rand", + "rtcp", + "rtp", + "thiserror", + "tokio", + "waitgroup", + "webrtc-srtp", + "webrtc-util", +] + +[[package]] +name = "ipnet" +version = "2.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "28b29a3cd74f0f4598934efe3aeba42bae0eb4680554128851ebbecb02af14e6" + +[[package]] +name = "itoa" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "af150ab688ff2122fcef229be89cb50dd66af9e01a4ff320cc137eecc9bacc38" + +[[package]] +name = "js-sys" +version = "0.3.64" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c5f195fe497f702db0f318b07fdd68edb16955aed830df8363d837542f8f935a" +dependencies = [ + "wasm-bindgen", +] + +[[package]] +name = "lazy_static" +version = "1.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e2abad23fbc42b3700f2f279844dc832adb2b2eb069b2df918f455c4e18cc646" + +[[package]] +name = "libc" +version = "0.2.149" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a08173bc88b7955d1b3145aa561539096c421ac8debde8cbc3612ec635fee29b" + +[[package]] +name = "lock_api" +version = "0.4.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1cc9717a20b1bb222f333e6a92fd32f7d8a18ddc5a3191a11af45dcbf4dcd16" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "log" +version = "0.4.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b5e6163cb8c49088c2c36f57875e58ccd8c87c7427f7fbd50ea6710b2f3f2e8f" + +[[package]] +name = "md-5" +version = "0.10.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d89e7ee0cfbedfc4da3340218492196241d89eefb6dab27de5df917a6d2e78cf" +dependencies = [ + "cfg-if", + "digest", +] + +[[package]] +name = "memchr" +version = "2.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f665ee40bc4a3c5590afb1e9677db74a508659dfd71e126420da8274909a0167" + +[[package]] +name = "memoffset" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5de893c32cde5f383baa4c04c5d6dbdd735cfd4a794b0debdb2bb1b421da5ff4" +dependencies = [ + "autocfg", +] + +[[package]] +name = "minimal-lexical" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "68354c5c6bd36d73ff3feceb05efa59b6acb7626617f4962be322a825e61f79a" + +[[package]] +name = "miniz_oxide" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e7810e0be55b428ada41041c41f32c9f1a42817901b4ccf45fa3d4b6561e74c7" +dependencies = [ + "adler", +] + +[[package]] +name = "mio" +version = "0.8.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "927a765cd3fc26206e66b296465fa9d3e5ab003e651c1b3c060e7956d96b19d2" +dependencies = [ + "libc", + "wasi", + "windows-sys", +] + +[[package]] +name = "nix" +version = "0.26.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "598beaf3cc6fdd9a5dfb1630c2800c7acd31df7aaf0f565796fba2b53ca1af1b" +dependencies = [ + "bitflags", + "cfg-if", + "libc", + "memoffset", + "pin-utils", +] + +[[package]] +name = "nom" +version = "7.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d273983c5a657a70a3e8f2a01329822f3b8c8172b73826411a55751e404a0a4a" +dependencies = [ + "memchr", + "minimal-lexical", +] + +[[package]] +name = "nu-ansi-term" +version = "0.46.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "77a8165726e8236064dbb45459242600304b42a5ea24ee2948e18e023bf7ba84" +dependencies = [ + "overload", + "winapi", +] + +[[package]] +name = "num-bigint" +version = "0.4.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "608e7659b5c3d7cba262d894801b9ec9d00de989e8a82bd4bef91d08da45cdc0" +dependencies = [ + "autocfg", + "num-integer", + "num-traits", +] + +[[package]] +name = "num-integer" +version = "0.1.45" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "225d3389fb3509a24c93f5c29eb6bde2586b98d9f016636dff58d7c6f7569cd9" +dependencies = [ + "autocfg", + "num-traits", +] + +[[package]] +name = "num-traits" +version = "0.2.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "39e3200413f237f41ab11ad6d161bc7239c84dcb631773ccd7de3dfe4b5c267c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "num_cpus" +version = "1.16.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4161fcb6d602d4d2081af7c3a45852d875a03dd337a6bfdd6e06407b61342a43" +dependencies = [ + "hermit-abi", + "libc", +] + +[[package]] +name = "object" +version = "0.32.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9cf5f9dd3933bd50a9e1f149ec995f39ae2c496d31fd772c1fd45ebc27e902b0" +dependencies = [ + "memchr", +] + +[[package]] +name = "oid-registry" +version = "0.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9bedf36ffb6ba96c2eb7144ef6270557b52e54b20c0a8e1eb2ff99a6c6959bff" +dependencies = [ + "asn1-rs", +] + +[[package]] +name = "once_cell" +version = "1.18.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" + +[[package]] +name = "opaque-debug" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "624a8340c38c1b80fd549087862da4ba43e08858af025b236e509b6649fc13d5" + +[[package]] +name = "overload" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b15813163c1d831bf4a13c3610c05c0d03b39feb07f7e09fa234dac9b15aaf39" + +[[package]] +name = "p256" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c9863ad85fa8f4460f9c48cb909d38a0d689dba1f6f6988a5e3e0d31071bcd4b" +dependencies = [ + "ecdsa", + "elliptic-curve", + "primeorder", + "sha2", +] + +[[package]] +name = "p384" +version = "0.13.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70786f51bcc69f6a4c0360e063a4cac5419ef7c5cd5b3c99ad70f3be5ba79209" +dependencies = [ + "ecdsa", + "elliptic-curve", + "primeorder", + "sha2", +] + +[[package]] +name = "parking_lot" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "93f00c865fe7cabf650081affecd3871070f26767e7b2070a3ffae14c654b447" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets", +] + +[[package]] +name = "pem" +version = "3.0.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3163d2912b7c3b52d651a055f2c7eec9ba5cd22d26ef75b8dd3a59980b185923" +dependencies = [ + "base64", + "serde", +] + +[[package]] +name = "pem-rfc7468" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88b39c9bfcfc231068454382784bb460aae594343fb030d46e9f50a645418412" +dependencies = [ + "base64ct", +] + +[[package]] +name = "percent-encoding" +version = "2.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b2a4787296e9989611394c33f193f676704af1686e70b8f8033ab5ba9a35a94" + +[[package]] +name = "pin-project-lite" +version = "0.2.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8afb450f006bf6385ca15ef45d71d2288452bc3683ce2e2cacc0d18e4be60b58" + +[[package]] +name = "pin-utils" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8b870d8c151b6f2fb93e84a13146138f05d02ed11c7e7c54f8826aaaf7c9f184" + +[[package]] +name = "pkcs8" +version = "0.10.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f950b2377845cebe5cf8b5165cb3cc1a5e0fa5cfa3e1f7f55707d8fd82e0a7b7" +dependencies = [ + "der", + "spki", +] + +[[package]] +name = "platforms" +version = "3.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4503fa043bf02cee09a9582e9554b4c6403b2ef55e4612e96561d294419429f8" + +[[package]] +name = "polyval" +version = "0.6.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d52cff9d1d4dee5fe6d03729099f4a310a41179e0a10dbf542039873f2e826fb" +dependencies = [ + "cfg-if", + "cpufeatures", + "opaque-debug", + "universal-hash", +] + +[[package]] +name = "powerfmt" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "439ee305def115ba05938db6eb1644ff94165c5ab5e9420d1c1bcedbba909391" + +[[package]] +name = "ppv-lite86" +version = "0.2.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de" + +[[package]] +name = "primeorder" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c2fcef82c0ec6eefcc179b978446c399b3cdf73c392c35604e399eee6df1ee3" +dependencies = [ + "elliptic-curve", +] + +[[package]] +name = "proc-macro2" +version = "1.0.69" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "134c189feb4956b20f6f547d2cf727d4c0fe06722b20a0eec87ed445a97f92da" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "quote" +version = "1.0.33" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5267fca4496028628a95160fc423a33e8b2e6af8a5302579e322e4b520293cae" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "rand" +version = "0.8.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404" +dependencies = [ + "libc", + "rand_chacha", + "rand_core", +] + +[[package]] +name = "rand_chacha" +version = "0.3.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88" +dependencies = [ + "ppv-lite86", + "rand_core", +] + +[[package]] +name = "rand_core" +version = "0.6.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c" +dependencies = [ + "getrandom", +] + +[[package]] +name = "rcgen" +version = "0.11.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "52c4f3084aa3bc7dfbba4eff4fab2a54db4324965d8872ab933565e6fbd83bc6" +dependencies = [ + "pem", + "ring", + "time", + "x509-parser", + "yasna", +] + +[[package]] +name = "redox_syscall" +version = "0.3.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "567664f262709473930a4bf9e51bf2ebf3348f2e748ccc50dea20646858f8f29" +dependencies = [ + "bitflags", +] + +[[package]] +name = "regex" +version = "1.10.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "aaac441002f822bc9705a681810a4dd2963094b9ca0ddc41cb963a4c189189ea" +dependencies = [ + "aho-corasick", + "memchr", + "regex-automata", + "regex-syntax", +] + +[[package]] +name = "regex-automata" +version = "0.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5011c7e263a695dc8ca064cddb722af1be54e517a280b12a5356f98366899e5d" +dependencies = [ + "aho-corasick", + "memchr", + "regex-syntax", +] + +[[package]] +name = "regex-syntax" +version = "0.8.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c08c74e62047bb2de4ff487b251e4a92e24f48745648451635cec7d591162d9f" + +[[package]] +name = "relay" +version = "0.0.1" +dependencies = [ + "anyhow", + "clap", + "tokio", + "tracing", + "tracing-subscriber", + "webrtc", + "webrtc-ice", + "webrtc-util", +] + +[[package]] +name = "rfc6979" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f8dd2a808d456c4a54e300a23e9f5a67e122c3024119acbfd73e3bf664491cb2" +dependencies = [ + "hmac", + "subtle", +] + +[[package]] +name = "ring" +version = "0.16.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3053cf52e236a3ed746dfc745aa9cacf1b791d846bdaf412f60a8d7d6e17c8fc" +dependencies = [ + "cc", + "libc", + "once_cell", + "spin", + "untrusted", + "web-sys", + "winapi", +] + +[[package]] +name = "rtcp" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3677908cadfbecb4cc1da9a56a32524fae4ebdfa7c2ea93886e1b1e846488cb9" +dependencies = [ + "bytes", + "thiserror", + "webrtc-util", +] + +[[package]] +name = "rtp" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e60482acbe8afb31edf6b1413103b7bca7a65004c423b3c3993749a083994fbe" +dependencies = [ + "bytes", + "rand", + "serde", + "thiserror", + "webrtc-util", +] + +[[package]] +name = "rustc-demangle" +version = "0.1.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d626bb9dae77e28219937af045c257c28bfd3f69333c512553507f5f9798cb76" + +[[package]] +name = "rustc_version" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bfa0f585226d2e68097d4f95d113b15b83a82e819ab25717ec0590d9584ef366" +dependencies = [ + "semver", +] + +[[package]] +name = "rusticata-macros" +version = "4.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "faf0c4a6ece9950b9abdb62b1cfcf2a68b3b67a10ba445b3bb85be2a293d0632" +dependencies = [ + "nom", +] + +[[package]] +name = "rustls" +version = "0.21.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "cd8d6c9f025a446bc4d18ad9632e69aec8f287aa84499ee335599fabd20c3fd8" +dependencies = [ + "log", + "ring", + "rustls-webpki", + "sct", +] + +[[package]] +name = "rustls-webpki" +version = "0.101.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c7d5dece342910d9ba34d259310cae3e0154b873b35408b787b59bce53d34fe" +dependencies = [ + "ring", + "untrusted", +] + +[[package]] +name = "ryu" +version = "1.0.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1ad4cc8da4ef723ed60bced201181d83791ad433213d8c24efffda1eec85d741" + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + +[[package]] +name = "sct" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d53dcdb7c9f8158937a7981b48accfd39a43af418591a5d008c7b22b5e1b7ca4" +dependencies = [ + "ring", + "untrusted", +] + +[[package]] +name = "sdp" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4653054c30ebce63658762eb0d64e27673868a95564474811ae6c220cf767640" +dependencies = [ + "rand", + "substring", + "thiserror", + "url", +] + +[[package]] +name = "sec1" +version = "0.7.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d3e97a565f76233a6003f9f5c54be1d9c5bdfa3eccfb189469f11ec4901c47dc" +dependencies = [ + "base16ct", + "der", + "generic-array", + "pkcs8", + "subtle", + "zeroize", +] + +[[package]] +name = "semver" +version = "1.0.20" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "836fa6a3e1e547f9a2c4040802ec865b5d85f4014efe00555d7090a3dcaa1090" + +[[package]] +name = "serde" +version = "1.0.189" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8e422a44e74ad4001bdc8eede9a4570ab52f71190e9c076d14369f38b9200537" +dependencies = [ + "serde_derive", +] + +[[package]] +name = "serde_derive" +version = "1.0.189" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1e48d1f918009ce3145511378cf68d613e3b3d9137d67272562080d68a2b32d5" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "serde_json" +version = "1.0.107" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6b420ce6e3d8bd882e9b243c6eed35dbc9a6110c9769e74b584e0d68d1f20c65" +dependencies = [ + "itoa", + "ryu", + "serde", +] + +[[package]] +name = "sha1" +version = "0.10.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e3bf829a2d51ab4a5ddf1352d8470c140cadc8301b2ae1789db023f01cedd6ba" +dependencies = [ + "cfg-if", + "cpufeatures", + "digest", +] + +[[package]] +name = "sha2" +version = "0.10.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "793db75ad2bcafc3ffa7c68b215fee268f537982cd901d132f89c6343f3a3dc8" +dependencies = [ + "cfg-if", + "cpufeatures", + "digest", +] + +[[package]] +name = "sharded-slab" +version = "0.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f40ca3c46823713e0d4209592e8d6e826aa57e928f09752619fc696c499637f6" +dependencies = [ + "lazy_static", +] + +[[package]] +name = "signal-hook-registry" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d8229b473baa5980ac72ef434c4415e70c4b5e71b423043adb4ba059f89c99a1" +dependencies = [ + "libc", +] + +[[package]] +name = "signature" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5e1788eed21689f9cf370582dfc467ef36ed9c707f073528ddafa8d83e3b8500" +dependencies = [ + "digest", + "rand_core", +] + +[[package]] +name = "slab" +version = "0.4.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f92a496fb766b417c996b9c5e57daf2f7ad3b0bebe1ccfca4856390e3d3bb67" +dependencies = [ + "autocfg", +] + +[[package]] +name = "smallvec" +version = "1.11.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "942b4a808e05215192e39f4ab80813e599068285906cc91aa64f923db842bd5a" + +[[package]] +name = "smol_str" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "74212e6bbe9a4352329b2f68ba3130c15a3f26fe88ff22dbdc6cdd58fa85e99c" +dependencies = [ + "serde", +] + +[[package]] +name = "socket2" +version = "0.5.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4031e820eb552adee9295814c0ced9e5cf38ddf1e8b7d566d6de8e2538ea989e" +dependencies = [ + "libc", + "windows-sys", +] + +[[package]] +name = "spin" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6e63cff320ae2c57904679ba7cb63280a3dc4613885beafb148ee7bf9aa9042d" + +[[package]] +name = "spki" +version = "0.7.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d1e996ef02c474957d681f1b05213dfb0abab947b446a62d37770b23500184a" +dependencies = [ + "base64ct", + "der", +] + +[[package]] +name = "strsim" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "73473c0e59e6d5812c5dfe2a064a6444949f089e20eec9a2e5506596494e4623" + +[[package]] +name = "stun" +version = "0.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7beb1624a3ea34778d58d30e2b8606b4d29fe65e87c4d50b87ed30afd5c3830c" +dependencies = [ + "base64", + "crc", + "lazy_static", + "md-5", + "rand", + "ring", + "subtle", + "thiserror", + "tokio", + "url", + "webrtc-util", +] + +[[package]] +name = "substring" +version = "1.4.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "42ee6433ecef213b2e72f587ef64a2f5943e7cd16fbd82dbe8bc07486c534c86" +dependencies = [ + "autocfg", +] + +[[package]] +name = "subtle" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "81cdd64d312baedb58e21336b31bc043b77e01cc99033ce76ef539f78e965ebc" + +[[package]] +name = "syn" +version = "1.0.109" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "syn" +version = "2.0.38" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e96b79aaa137db8f61e26363a0c9b47d8b4ec75da28b7d1d614c2303e232408b" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "synstructure" +version = "0.12.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f36bdaa60a83aca3921b5259d5400cbf5e90fc51931376a9bd4a0eb79aa7210f" +dependencies = [ + "proc-macro2", + "quote", + "syn 1.0.109", + "unicode-xid", +] + +[[package]] +name = "thiserror" +version = "1.0.49" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1177e8c6d7ede7afde3585fd2513e611227efd6481bd78d2e82ba1ce16557ed4" +dependencies = [ + "thiserror-impl", +] + +[[package]] +name = "thiserror-impl" +version = "1.0.49" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "10712f02019e9288794769fba95cd6847df9874d49d871d062172f9dd41bc4cc" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "thread_local" +version = "1.1.7" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3fdd6f064ccff2d6567adcb3873ca630700f00b5ad3f060c25b5dcfd9a4ce152" +dependencies = [ + "cfg-if", + "once_cell", +] + +[[package]] +name = "time" +version = "0.3.30" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c4a34ab300f2dee6e562c10a046fc05e358b29f9bf92277f30c3c8d82275f6f5" +dependencies = [ + "deranged", + "itoa", + "powerfmt", + "serde", + "time-core", + "time-macros", +] + +[[package]] +name = "time-core" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ef927ca75afb808a4d64dd374f00a2adf8d0fcff8e7b184af886c3c87ec4a3f3" + +[[package]] +name = "time-macros" +version = "0.2.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4ad70d68dba9e1f8aceda7aa6711965dfec1cac869f311a51bd08b3a2ccbce20" +dependencies = [ + "time-core", +] + +[[package]] +name = "tinyvec" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "87cc5ceb3875bb20c2890005a4e226a4651264a5c75edb2421b52861a0a0cb50" +dependencies = [ + "tinyvec_macros", +] + +[[package]] +name = "tinyvec_macros" +version = "0.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20" + +[[package]] +name = "tokio" +version = "1.33.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4f38200e3ef7995e5ef13baec2f432a6da0aa9ac495b2c0e8f3b7eec2c92d653" +dependencies = [ + "backtrace", + "bytes", + "libc", + "mio", + "num_cpus", + "parking_lot", + "pin-project-lite", + "signal-hook-registry", + "socket2", + "tokio-macros", + "windows-sys", +] + +[[package]] +name = "tokio-macros" +version = "2.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "630bdcf245f78637c13ec01ffae6187cca34625e8c63150d424b59e55af2675e" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "tracing" +version = "0.1.39" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ee2ef2af84856a50c1d430afce2fdded0a4ec7eda868db86409b4543df0797f9" +dependencies = [ + "pin-project-lite", + "tracing-attributes", + "tracing-core", +] + +[[package]] +name = "tracing-attributes" +version = "0.1.27" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] + +[[package]] +name = "tracing-core" +version = "0.1.32" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54" +dependencies = [ + "once_cell", + "valuable", +] + +[[package]] +name = "tracing-log" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "78ddad33d2d10b1ed7eb9d1f518a5674713876e97e5bb9b7345a7984fbb4f922" +dependencies = [ + "lazy_static", + "log", + "tracing-core", +] + +[[package]] +name = "tracing-subscriber" +version = "0.3.17" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "30a651bc37f915e81f087d86e62a18eec5f79550c7faff886f7090b4ea757c77" +dependencies = [ + "nu-ansi-term", + "sharded-slab", + "smallvec", + "thread_local", + "tracing-core", + "tracing-log", +] + +[[package]] +name = "turn" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "58f4fcb97da0426e8146fe0e9b78cc13120161087256198701d12d9df77f7701" +dependencies = [ + "async-trait", + "base64", + "futures", + "log", + "md-5", + "rand", + "ring", + "stun", + "thiserror", + "tokio", + "webrtc-util", +] + +[[package]] +name = "typenum" +version = "1.17.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "42ff0bf0c66b8238c6f3b578df37d0b7848e55df8577b3f74f92a69acceeb825" + +[[package]] +name = "unicode-bidi" +version = "0.3.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "92888ba5573ff080736b3648696b70cafad7d250551175acbaa4e0385b3e1460" + +[[package]] +name = "unicode-ident" +version = "1.0.12" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b" + +[[package]] +name = "unicode-normalization" +version = "0.1.22" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c5713f0fc4b5db668a2ac63cdb7bb4469d8c9fed047b1d0292cc7b0ce2ba921" +dependencies = [ + "tinyvec", +] + +[[package]] +name = "unicode-xid" +version = "0.2.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c" + +[[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 = "untrusted" +version = "0.7.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a156c684c91ea7d62626509bce3cb4e1d9ed5c4d978f7b4352658f96a4c26b4a" + +[[package]] +name = "url" +version = "2.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "143b538f18257fac9cad154828a57c6bf5157e1aa604d4816b5995bf6de87ae5" +dependencies = [ + "form_urlencoded", + "idna", + "percent-encoding", +] + +[[package]] +name = "utf8parse" +version = "0.2.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "711b9620af191e0cdc7468a8d14e709c3dcdb115b36f838e601583af800a370a" + +[[package]] +name = "uuid" +version = "1.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "79daa5ed5740825c40b389c5e50312b9c86df53fccd33f281df655642b43869d" +dependencies = [ + "getrandom", +] + +[[package]] +name = "valuable" +version = "0.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "830b7e5d4d90034032940e4ace0d9a9a057e7a45cd94e6c007832e39edb82f6d" + +[[package]] +name = "version_check" +version = "0.9.4" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "49874b5167b65d7193b8aba1567f5c7d93d001cafc34600cee003eda787e483f" + +[[package]] +name = "waitgroup" +version = "0.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d1f50000a783467e6c0200f9d10642f4bc424e39efc1b770203e88b488f79292" +dependencies = [ + "atomic-waker", +] + +[[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.87" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7706a72ab36d8cb1f80ffbf0e071533974a60d0a308d01a5d0375bf60499a342" +dependencies = [ + "cfg-if", + "wasm-bindgen-macro", +] + +[[package]] +name = "wasm-bindgen-backend" +version = "0.2.87" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5ef2b6d3c510e9625e5fe6f509ab07d66a760f0885d858736483c32ed7809abd" +dependencies = [ + "bumpalo", + "log", + "once_cell", + "proc-macro2", + "quote", + "syn 2.0.38", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-macro" +version = "0.2.87" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dee495e55982a3bd48105a7b947fd2a9b4a8ae3010041b9e0faab3f9cd028f1d" +dependencies = [ + "quote", + "wasm-bindgen-macro-support", +] + +[[package]] +name = "wasm-bindgen-macro-support" +version = "0.2.87" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "54681b18a46765f095758388f2d0cf16eb8d4169b639ab575a8f5693af210c7b" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", + "wasm-bindgen-backend", + "wasm-bindgen-shared", +] + +[[package]] +name = "wasm-bindgen-shared" +version = "0.2.87" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca6ad05a4870b2bf5fe995117d3728437bd27d7cd5f06f13c17443ef369775a1" + +[[package]] +name = "web-sys" +version = "0.3.64" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9b85cbef8c220a6abc02aefd892dfc0fc23afb1c6a426316ec33253a3877249b" +dependencies = [ + "js-sys", + "wasm-bindgen", +] + +[[package]] +name = "webrtc" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d91e7cf018f7185552bf6a5dd839f4ed9827aea33b746763c9a215f84a0d0b34" +dependencies = [ + "arc-swap", + "async-trait", + "bytes", + "cfg-if", + "hex", + "interceptor", + "lazy_static", + "log", + "rand", + "rcgen", + "regex", + "ring", + "rtcp", + "rtp", + "rustls", + "sdp", + "serde", + "serde_json", + "sha2", + "smol_str", + "stun", + "thiserror", + "time", + "tokio", + "turn", + "url", + "waitgroup", + "webrtc-data", + "webrtc-dtls", + "webrtc-ice", + "webrtc-mdns", + "webrtc-media", + "webrtc-sctp", + "webrtc-srtp", + "webrtc-util", +] + +[[package]] +name = "webrtc-data" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a45d2461d0e0bf93f181e30eb0b40df32b8bf3efb89c53cebb1990e603e2067d" +dependencies = [ + "bytes", + "log", + "thiserror", + "tokio", + "webrtc-sctp", + "webrtc-util", +] + +[[package]] +name = "webrtc-dtls" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "32b140b953f986e97828aa33ec6318186b05d862bee689efbc57af04a243e832" +dependencies = [ + "aes", + "aes-gcm", + "async-trait", + "bincode", + "byteorder", + "cbc", + "ccm", + "der-parser", + "hkdf", + "hmac", + "log", + "p256", + "p384", + "rand", + "rand_core", + "rcgen", + "ring", + "rustls", + "sec1", + "serde", + "sha1", + "sha2", + "subtle", + "thiserror", + "tokio", + "webrtc-util", + "x25519-dalek", + "x509-parser", +] + +[[package]] +name = "webrtc-ice" +version = "0.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "66eb4b85646f1c52225779db3e1e7e873dede6db68cc9be080b648f1713083a3" +dependencies = [ + "arc-swap", + "async-trait", + "crc", + "log", + "rand", + "serde", + "serde_json", + "stun", + "thiserror", + "tokio", + "turn", + "url", + "uuid", + "waitgroup", + "webrtc-mdns", + "webrtc-util", +] + +[[package]] +name = "webrtc-mdns" +version = "0.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62bebbd40e7f8b630a0f1a74783dbfff1edfc0ccaae891c4689891156a8c4d8c" +dependencies = [ + "log", + "socket2", + "thiserror", + "tokio", + "webrtc-util", +] + +[[package]] +name = "webrtc-media" +version = "0.7.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1cfde3c7b9450b67d466bb2f02c6d9ff9514d33535eb9994942afd1f828839d1" +dependencies = [ + "byteorder", + "bytes", + "rand", + "rtp", + "thiserror", +] + +[[package]] +name = "webrtc-sctp" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1af6116b7f9703560c3ad0b32f67220b171bb1b59633b03563db8404d0e482ea" +dependencies = [ + "arc-swap", + "async-trait", + "bytes", + "crc", + "log", + "rand", + "thiserror", + "tokio", + "webrtc-util", +] + +[[package]] +name = "webrtc-srtp" +version = "0.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1db1f36c1c81e4b1e531c0b9678ba0c93809e196ce62122d87259bb71c03b9f" +dependencies = [ + "aead", + "aes", + "aes-gcm", + "byteorder", + "bytes", + "ctr", + "hmac", + "log", + "rtcp", + "rtp", + "sha1", + "subtle", + "thiserror", + "tokio", + "webrtc-util", +] + +[[package]] +name = "webrtc-util" +version = "0.8.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1adc96bee68417e1f4d19dd7698124a7f859db55ae2fd3eedbbb7e732f614735" +dependencies = [ + "async-trait", + "bitflags", + "bytes", + "cc", + "ipnet", + "lazy_static", + "libc", + "log", + "nix", + "rand", + "thiserror", + "tokio", + "winapi", +] + +[[package]] +name = "winapi" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5c839a674fcd7a98952e593242ea400abe93992746761e38641405d28b00f419" +dependencies = [ + "winapi-i686-pc-windows-gnu", + "winapi-x86_64-pc-windows-gnu", +] + +[[package]] +name = "winapi-i686-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ac3b87c63620426dd9b991e5ce0329eff545bccbbb34f3be09ff6fb6ab51b7b6" + +[[package]] +name = "winapi-x86_64-pc-windows-gnu" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +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", +] + +[[package]] +name = "windows-targets" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +dependencies = [ + "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_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" + +[[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_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" + +[[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_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" + +[[package]] +name = "x25519-dalek" +version = "2.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fb66477291e7e8d2b0ff1bcb900bf29489a9692816d79874bea351e7a8b6de96" +dependencies = [ + "curve25519-dalek", + "rand_core", + "serde", + "zeroize", +] + +[[package]] +name = "x509-parser" +version = "0.15.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7069fba5b66b9193bd2c5d3d4ff12b839118f6bcbef5328efafafb5395cf63da" +dependencies = [ + "asn1-rs", + "data-encoding", + "der-parser", + "lazy_static", + "nom", + "oid-registry", + "ring", + "rusticata-macros", + "thiserror", + "time", +] + +[[package]] +name = "yasna" +version = "0.5.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e17bb3549cc1321ae1296b9cdc2698e2b6cb1992adfa19a8c72e5b7a738f44cd" +dependencies = [ + "time", +] + +[[package]] +name = "zeroize" +version = "1.6.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2a0956f1ba7c7909bfb66c2e9e4124ab6f6482560f6628b5aaeba39207c9aad9" +dependencies = [ + "zeroize_derive", +] + +[[package]] +name = "zeroize_derive" +version = "1.4.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ce36e65b0d2999d2aafac989fb249189a141aee1f53c612c1f37d72631959f69" +dependencies = [ + "proc-macro2", + "quote", + "syn 2.0.38", +] diff --git a/relay/Cargo.toml b/relay/Cargo.toml new file mode 100644 index 0000000..ae35929 --- /dev/null +++ b/relay/Cargo.toml @@ -0,0 +1,21 @@ +[package] +name = "relay" +version = "0.0.1" +edition = "2021" + +# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html + +[dependencies] +tokio = { version = "1.32", features = ["macros", "rt-multi-thread", "net", "rt"] } +clap = "4.4" + +tracing-subscriber = "0.3.17" +tracing = "0.1.39" +webrtc = "0.9.0" + +webrtc-ice = "0.10.0" +webrtc-util = "0.8.0" +anyhow = "1" +#serde = "1" +#serde_json = "1" +[dev-dependencies] diff --git a/relay/README.md b/relay/README.md new file mode 100644 index 0000000..92e0c5c --- /dev/null +++ b/relay/README.md @@ -0,0 +1,19 @@ +test turn-rs and webrtc + + + +turn-server commit: 5ee052e8168ddad7a1c92c83c2cdc49c7a266885 +```shell + +#docker run -v $(pwd)/tun_server_config.toml:/etc/turn_server/config.toml quasipaa/turn-server + +## idea config +run --package turn-server --bin turn-server -- --config=$turn_server_config.toml + +``` +WebRTC 内容: https://github.com/timzaak/blog/issues/94 + +### Turn Server Run +```shell +./turn-server --config=~/turn_config.toml +``` \ No newline at end of file diff --git a/relay/src/main.rs b/relay/src/main.rs new file mode 100644 index 0000000..0567273 --- /dev/null +++ b/relay/src/main.rs @@ -0,0 +1,24 @@ +use tracing_subscriber; +mod simple; +mod reconnect; +mod simple_stun; + +mod simple_ice_api; + +mod simple_tcp; + + + + +#[tokio::main] +async fn main() -> anyhow::Result<()>{ + tracing_subscriber::fmt::init(); + //simple::simple().await.unwrap(); + //simple_stun::simple_stun().await.unwrap(); + //reconnect::reconnect().await.unwrap(); + + //simple_ice_api::simple_ice_api().await.unwrap(); + simple_tcp::simple_tcp().await.unwrap(); + tokio::signal::ctrl_c().await?; + Ok(()) +} \ No newline at end of file diff --git a/relay/src/reconnect.rs b/relay/src/reconnect.rs new file mode 100644 index 0000000..b1813e4 --- /dev/null +++ b/relay/src/reconnect.rs @@ -0,0 +1,248 @@ +use std::sync::Arc; +use std::time::Duration; +use tokio::sync::mpsc::Sender; + +use webrtc::api::media_engine::MediaEngine; +use webrtc::api::APIBuilder; +use webrtc::api::interceptor_registry::{configure_nack, configure_rtcp_reports}; +use webrtc::ice_transport::ice_candidate::RTCIceCandidate; +use webrtc::ice_transport::ice_credential_type::RTCIceCredentialType; +use webrtc::ice_transport::ice_server::RTCIceServer; +use webrtc::interceptor::registry::Registry; +use webrtc::peer_connection::configuration::RTCConfiguration; +use webrtc::peer_connection::offer_answer_options::RTCOfferOptions; +use webrtc::peer_connection::peer_connection_state::RTCPeerConnectionState; +use webrtc::peer_connection::policy::ice_transport_policy::RTCIceTransportPolicy; +use webrtc::peer_connection::RTCPeerConnection; + +const TURN_SERVER: &str = "turn:113.31.103.71:13478"; +const SELF_TURN_SERVER: &str = "turn:192.168.31.37:3478"; + + +fn get_relay_config(user_name:String) -> RTCConfiguration { + RTCConfiguration { + ice_servers: vec![RTCIceServer { + urls: vec![TURN_SERVER.to_owned()], + username: user_name.clone(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + }, RTCIceServer { + urls: vec![SELF_TURN_SERVER.to_owned()], + username: user_name.clone(), + credential: "test".to_owned(), + + credential_type: RTCIceCredentialType::Password, + }], + ice_transport_policy: RTCIceTransportPolicy::Relay, +//peer_identity: "offer".to_owned(), + ..Default::default() + } +} + +fn get_default_config() -> RTCConfiguration { + return RTCConfiguration { + ..Default::default() + }; +} + + +pub async fn reconnect() -> anyhow::Result<()> { + let (offer_sender, mut offer_receiver) = tokio::sync::mpsc::channel::(10); + let (answer_sender, mut answer_receiver) = tokio::sync::mpsc::channel::(10); + let (offer_close_sender, mut offer_close_receiver) = tokio::sync::mpsc::channel::<()>(5); + let (answer_close_sender, mut answer_close_receiver) = tokio::sync::mpsc::channel::<()>(5); + + + let answer_connection = answer(answer_sender, answer_close_sender).await?; + let offer_connection = offer(offer_sender, offer_close_sender).await?; + + let a_c = answer_connection.clone(); + let o_c = offer_connection.clone(); + + tokio::spawn(async move { + while let Some(candidate) = offer_receiver.recv().await { + tracing::info!("offer candidate: {candidate:?}"); + let _ = a_c.add_ice_candidate(candidate.to_json().unwrap()).await; + } + tracing::info!("offer listen candidate finish"); + }); + + tokio::spawn(async move { + while let Some(candidate) = answer_receiver.recv().await { + tracing::info!("answer candidate: {candidate:?}"); + let _ = o_c.add_ice_candidate(candidate.to_json().unwrap()).await; + } + tracing::info!("answer listen candidate finish"); + }); + + let offer = offer_connection.create_offer(None).await?; + offer_connection.set_local_description(offer.clone()).await?; + + // let mut gather_complete = offer_connection.gathering_complete_promise().await; + // let _ = gather_complete.recv().await; + // let offer = offer_connection.local_description().await.unwrap(); + + tracing::info!("Offer: {offer:?}"); + + answer_connection.set_remote_description(offer).await?; + + + let answer = answer_connection.create_answer(None).await?; + answer_connection.set_local_description(answer.clone()).await?; + + // let mut gather_complete= answer_connection.gathering_complete_promise().await; + // let _ = gather_complete.recv().await; + // let answer = answer_connection.local_description().await.unwrap(); + // tracing::info!("answer collect Session Description finish"); + + offer_connection.set_remote_description(answer).await?; + + tokio::spawn(async move { + while let Some(_) = offer_close_receiver.recv().await { + tokio::time::sleep(Duration::from_secs(2)).await; + let offer = offer_connection.create_offer(Some(RTCOfferOptions{ice_restart: true, ..Default::default()})).await.unwrap(); + offer_connection.set_local_description(offer.clone()).await.unwrap(); + let _ = answer_connection.set_remote_description(offer).await; + + let answer = answer_connection.create_answer(None).await.unwrap(); + answer_connection.set_local_description(answer.clone()).await.unwrap(); + let _ = offer_connection.set_remote_description(answer).await; + } + }); + + Ok(()) +} + +async fn answer(sender: Sender, close_sender: Sender<()>) -> anyhow::Result> { + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + //let config = RTCConfiguration::default(); + + + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(get_relay_config("answer".to_owned())).await?); + let w_pc = Arc::downgrade(&peer_connection); + let sender = Arc::new(sender); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + + let sender = sender.clone(); + Box::pin(async move { + if let Some(c) = c { + let _ = sender.send(c).await; + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + tracing::info!("answer peer connection state has changed: {s}"); + Box::pin(async { + //let _ = close_sender.send(()).await; + }) + })); + + peer_connection.on_data_channel(Box::new(move |d| { + let d_label = d.label().to_owned(); + let d_id = d.id(); + tracing::info!("New DataChannel {d_label} {d_id}"); + Box::pin(async move { + let d2 = Arc::clone(&d); + let d_label2 = d_label.clone(); + let d_id2 = d_id; + d.on_open(Box::new(move || { + tracing::info!("Data channel '{d_label2}'-'{d_id2}' open. Random messages will now be sent to any connected DataChannels every 5 seconds"); + Box::pin(async {}) + })); + d.on_message(Box::new(move |msg| { + let msg_str = String::from_utf8(msg.data.to_vec()).unwrap(); + tracing::info!("answer receive data label: {d_label}, data: {msg_str}"); + Box::pin(async {}) + })); + }) + })); + + + Ok(peer_connection) +} + +async fn offer(sender: Sender, close_sender: Sender<()>) -> anyhow::Result> { + //let (sender, receiver) = tokio::sync::mpsc::channel::(10); + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + + + //let config = RTCConfiguration::default(); + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(get_relay_config("offer".to_owned())).await?); + let w_pc = Arc::downgrade(&peer_connection); + let sender = Arc::new(sender); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + let sender = sender.clone(); + Box::pin(async move { + if let Some(c) = c { + let _ = sender.send(c).await; + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + tracing::info!("offer peer connection state has changed: {s}"); + let close_sender = close_sender.clone(); + Box::pin(async move { + if s == RTCPeerConnectionState::Failed { + let _ = close_sender.send(()).await; + } + }) + })); + + let data_channel = peer_connection.create_data_channel("data", None).await?; + + let dc = Arc::downgrade(&data_channel); + data_channel.on_open(Box::new(move || { + //let data_channel = data_channel.clone(); + tracing::info!("DataChannel Open"); + Box::pin(async move { + loop { + if let Some(data_channel) = dc.upgrade() { + data_channel.send_text("1".to_owned()).await; + tokio::time::sleep(Duration::from_secs(5)).await; + } else { + break; + } + } + // + }) + })); + Ok(peer_connection) +} diff --git a/relay/src/simple.rs b/relay/src/simple.rs new file mode 100644 index 0000000..c18092a --- /dev/null +++ b/relay/src/simple.rs @@ -0,0 +1,213 @@ +use std::sync::Arc; +use std::time::Duration; + +use webrtc::api::media_engine::MediaEngine; +use webrtc::api::APIBuilder; +use webrtc::api::interceptor_registry::{configure_nack, configure_rtcp_reports}; +use webrtc::ice_transport::ice_credential_type::RTCIceCredentialType; +use webrtc::ice_transport::ice_server::RTCIceServer; +use webrtc::interceptor::registry::Registry; +use webrtc::peer_connection::configuration::RTCConfiguration; +use webrtc::peer_connection::policy::ice_transport_policy::RTCIceTransportPolicy; +use webrtc::peer_connection::RTCPeerConnection; + +const TURN_SERVER: &str = "turn:113.31.103.71:13478"; +const SELF_TURN_SERVER: &str = "turn:192.168.31.37:3478"; + + +pub async fn simple() -> anyhow::Result<()> { + let answer_connection = answer().await?; + let offer_connection = offer().await?; + let offer = offer_connection.create_offer(None).await?; + offer_connection.set_local_description(offer.clone()).await?; + let mut gather_complete = offer_connection.gathering_complete_promise().await; + let _ = gather_complete.recv().await; + + + let offer = offer_connection.local_description().await.unwrap(); + tracing::info!("Offer: {offer:?}"); + + answer_connection.set_remote_description(offer).await?; + + + let answer = answer_connection.create_answer(None).await?; + answer_connection.set_local_description(answer.clone()).await?; + let mut gather_complete = answer_connection.gathering_complete_promise().await; + + let _ = gather_complete.recv().await; + + tracing::info!("answer collect Session Description finish"); + let answer_local_description = answer_connection.local_description().await.unwrap(); + //tracing::info!("answer description: {answer_local_description:?}"); + + + offer_connection.set_remote_description(answer_local_description).await?; + Ok(()) +} + +async fn answer() -> anyhow::Result> { + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + //let config = RTCConfiguration::default(); + + let config = RTCConfiguration { + ice_servers: vec![ + RTCIceServer { + urls: vec![TURN_SERVER.to_owned()], + username: "answer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + }, + RTCIceServer { + urls: vec![SELF_TURN_SERVER.to_owned()], + username: "answer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + }, + ], + ice_transport_policy: RTCIceTransportPolicy::Relay, + //peer_identity: "offer".to_owned(), + ..Default::default() + }; + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(config).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!("answer on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + tracing::info!("answer peer connection State has changed: {s}"); + + Box::pin(async {}) + })); + + peer_connection.on_data_channel(Box::new(move |d| { + let d_label = d.label().to_owned(); + let d_id = d.id(); + tracing::info!("New DataChannel {d_label} {d_id}"); + Box::pin(async move { + let d2 = Arc::clone(&d); + let d_label2 = d_label.clone(); + let d_id2 = d_id; + d.on_open(Box::new(move || { + tracing::info!("Data channel '{d_label2}'-'{d_id2}' open. Random messages will now be sent to any connected DataChannels every 5 seconds"); + Box::pin(async {}) + })); + d.on_message(Box::new(move |msg| { + let msg_str = String::from_utf8(msg.data.to_vec()).unwrap(); + tracing::info!("answer receive data label: {d_label}, data: {msg_str}"); + Box::pin(async {}) + })); + }) + })); + + + Ok(peer_connection) +} + +async fn offer() -> anyhow::Result> { + + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + let config = RTCConfiguration { + ice_servers: vec![ + RTCIceServer { + urls: vec![TURN_SERVER.to_owned()], + username: "offer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + }, + RTCIceServer { + urls: vec![SELF_TURN_SERVER.to_owned()], + username: "offer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + } + ], + ice_transport_policy: RTCIceTransportPolicy::Relay, + + //peer_identity: "answer".to_owned(), + ..Default::default() + }; + + //let config = RTCConfiguration::default(); + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(config).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!(" on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + println!("Peer Connection State has changed: {s}"); + + Box::pin(async {}) + })); + + let data_channel = peer_connection.create_data_channel("data", None).await?; + + let dc = Arc::downgrade(&data_channel); + data_channel.on_open(Box::new(move || { + //let data_channel = data_channel.clone(); + tracing::info!(" DataChannel Open"); + Box::pin(async move { + loop { + if let Some(data_channel) = dc.upgrade() { + data_channel.send_text("1".to_owned()).await; + tokio::time::sleep(Duration::from_secs(5)).await; + } else { + break; + } + } + // + }) + })); + Ok(peer_connection) +} diff --git a/relay/src/simple_ice_api.rs b/relay/src/simple_ice_api.rs new file mode 100644 index 0000000..f77e7c0 --- /dev/null +++ b/relay/src/simple_ice_api.rs @@ -0,0 +1,112 @@ +use std::sync::Arc; +use std::time::Duration; + +use webrtc_ice::agent::Agent; +use webrtc_ice::agent::agent_config::AgentConfig; +use webrtc_ice::candidate::Candidate; +use webrtc_ice::candidate::candidate_base::unmarshal_candidate; +use webrtc_ice::network_type::NetworkType; +use webrtc_ice::udp_network::UDPNetwork; +use webrtc_ice::url::Url; +use webrtc_util::Conn; + +//const TURN_SERVER: &str = "turn:113.31.103.71:13478"; +const SELF_TURN_SERVER: &str = "turn:192.168.31.37:3478"; + + +pub async fn simple_ice_api() -> anyhow::Result<()> { + let answer = create_agent().await?; + let offer = create_agent().await?; + //offer.gather_candidates()?; + //answer.gather_candidates()?; + + + let _offer = offer.clone(); + answer.on_candidate(Box::new(move |c|{ + let offer = _offer.clone(); + Box::pin(async move{ + if let Some(c) = c { + let c = c.marshal(); + tracing::info!("answer candidate: {c}"); + let c: Arc = Arc::new(unmarshal_candidate(&c).unwrap()); + offer.add_remote_candidate(&c); + } + }) + })); + + let _answer = answer.clone(); + offer.on_candidate(Box::new(move |c|{ + let answer = _answer.clone(); + Box::pin(async move{ + if let Some(c) = c { + let c = c.marshal(); + tracing::info!("offer candidate: {c}"); + let c: Arc = Arc::new(unmarshal_candidate(&c).unwrap()); + answer.add_remote_candidate(&c); + } + }) + })); + + + + let offer_credentials = offer.get_local_user_credentials().await; + let answer_credentials = answer.get_local_user_credentials().await; + + + + + offer.gather_candidates()?; + answer.gather_candidates()?; + + + + tokio::spawn(async move { + let (_cancel_tx1, cancel_rx1) = tokio::sync::mpsc::channel::<()>(1); + match answer.accept(cancel_rx1, offer_credentials.0, offer_credentials.1).await { + Ok(answer_conn) => { + let mut buf = vec![0u8; 1600]; + while let Ok(n) = answer_conn.recv(&mut buf).await { + tracing::info!("Received: '{}'", std::str::from_utf8(&buf[..n]).unwrap()); + } + } + Err(e) => { + tracing::warn!("answer error:{e}"); + } + } + + }); + + tokio::spawn(async move{ + let (_cancel_tx2, cancel_rx2) = tokio::sync::mpsc::channel::<()>(1); + tokio::time::sleep(Duration::from_secs(2)).await; + match offer.dial(cancel_rx2, answer_credentials.0, answer_credentials.1).await { + Ok(offer_conn) => { + loop { + let _ = offer_conn.send(b"123").await; + tokio::time::sleep(Duration::from_secs(5)).await; + } + } + Err(e) => tracing::warn!("offer error:{e}") + }; + + + }); + + Ok(()) +} + +async fn create_agent() -> anyhow::Result>{ + let config = AgentConfig { + urls: vec![Url::parse_url(SELF_TURN_SERVER).unwrap()], + udp_network: UDPNetwork::Ephemeral(Default::default()), + network_types: vec![NetworkType::Udp4], + ..Default::default() + }; + let ice_agent = Arc::new(Agent::new(config).await?); + ice_agent.on_connection_state_change(Box::new(move |c| { + println!("ICE Connection State has changed: {c}"); + Box::pin(async move {}) + })); + + return Ok(ice_agent); +} diff --git a/relay/src/simple_stun.rs b/relay/src/simple_stun.rs new file mode 100644 index 0000000..7b4c379 --- /dev/null +++ b/relay/src/simple_stun.rs @@ -0,0 +1,190 @@ +use std::sync::Arc; +use std::time::Duration; + +use webrtc::api::media_engine::MediaEngine; +use webrtc::api::APIBuilder; +use webrtc::api::interceptor_registry::{configure_nack, configure_rtcp_reports}; +use webrtc::ice_transport::ice_server::RTCIceServer; +use webrtc::interceptor::registry::Registry; +use webrtc::peer_connection::configuration::RTCConfiguration; +use webrtc::peer_connection::RTCPeerConnection; + +const STUN_SERVER: &str = "stun:google.de:3478"; +const SELF_STUN_SERVER: &str = "stun:192.168.31.37:3478"; + +fn get_config() -> RTCConfiguration{ + return RTCConfiguration { + ice_servers: vec![ + RTCIceServer { + urls: vec![STUN_SERVER.to_owned()], + ..Default::default() + }, + RTCIceServer { + urls: vec![SELF_STUN_SERVER.to_owned()], + ..Default::default() + } + ], + + ..Default::default() + }; +} + +pub async fn simple_stun() -> anyhow::Result<()> { + let answer_connection = answer().await?; + let offer_connection = offer().await?; + let offer = offer_connection.create_offer(None).await?; + offer_connection.set_local_description(offer.clone()).await?; + let mut gather_complete = offer_connection.gathering_complete_promise().await; + let _ = gather_complete.recv().await; + + + let offer = offer_connection.local_description().await.unwrap(); + tracing::info!("Offer: {offer:?}"); + + answer_connection.set_remote_description(offer).await?; + + + let answer = answer_connection.create_answer(None).await?; + answer_connection.set_local_description(answer.clone()).await?; + let mut gather_complete = answer_connection.gathering_complete_promise().await; + + let _ = gather_complete.recv().await; + + tracing::info!("answer collect Session Description finish"); + let answer_local_description = answer_connection.local_description().await.unwrap(); + //tracing::info!("answer description: {answer_local_description:?}"); + + + offer_connection.set_remote_description(answer_local_description).await?; + Ok(()) +} + +async fn answer() -> anyhow::Result> { + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + //let config = RTCConfiguration::default(); + + + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(get_config()).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!("answer on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + tracing::info!("answer peer connection State has changed: {s}"); + + Box::pin(async {}) + })); + + peer_connection.on_data_channel(Box::new(move |d| { + let d_label = d.label().to_owned(); + let d_id = d.id(); + tracing::info!("New DataChannel {d_label} {d_id}"); + Box::pin(async move { + let d2 = Arc::clone(&d); + let d_label2 = d_label.clone(); + let d_id2 = d_id; + d.on_open(Box::new(move || { + tracing::info!("Data channel '{d_label2}'-'{d_id2}' open. Random messages will now be sent to any connected DataChannels every 5 seconds"); + Box::pin(async {}) + })); + d.on_message(Box::new(move |msg| { + let msg_str = String::from_utf8(msg.data.to_vec()).unwrap(); + tracing::info!("answer receive data label: {d_label}, data: {msg_str}"); + Box::pin(async {}) + })); + }) + })); + + + Ok(peer_connection) +} + +async fn offer() -> anyhow::Result> { + + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + + + //let config = RTCConfiguration::default(); + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(get_config()).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!(" on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + println!("Peer Connection State has changed: {s}"); + + Box::pin(async {}) + })); + + let data_channel = peer_connection.create_data_channel("data", None).await?; + + let dc = Arc::downgrade(&data_channel); + data_channel.on_open(Box::new(move || { + //let data_channel = data_channel.clone(); + tracing::info!(" DataChannel Open"); + Box::pin(async move { + loop { + if let Some(data_channel) = dc.upgrade() { + data_channel.send_text("1".to_owned()).await; + tokio::time::sleep(Duration::from_secs(5)).await; + } else { + break; + } + } + // + }) + })); + Ok(peer_connection) +} diff --git a/relay/src/simple_tcp.rs b/relay/src/simple_tcp.rs new file mode 100644 index 0000000..7575d82 --- /dev/null +++ b/relay/src/simple_tcp.rs @@ -0,0 +1,206 @@ +use std::sync::Arc; +use std::time::Duration; + +use webrtc::api::media_engine::MediaEngine; +use webrtc::api::APIBuilder; +use webrtc::api::interceptor_registry::{configure_nack, configure_rtcp_reports}; +use webrtc::ice_transport::ice_credential_type::RTCIceCredentialType; +use webrtc::ice_transport::ice_server::RTCIceServer; +use webrtc::interceptor::registry::Registry; +use webrtc::peer_connection::configuration::RTCConfiguration; +use webrtc::peer_connection::policy::ice_transport_policy::RTCIceTransportPolicy; +use webrtc::peer_connection::RTCPeerConnection; + +//const TURN_SERVER: &str = "turn:113.31.103.71:13478"; +const SELF_TURN_SERVER: &str = "turn:192.168.31.37:3478?transport=tcp"; + + +//Attention: webrtc-rs now does not support +/*TODO: case url.proto == ProtoType::UDP && url.scheme == SchemeType::TURNS{ + case a.proxyDialer != nil && url.Proto == ProtoTypeTCP && (url.Scheme == SchemeTypeTURN || url.Scheme == SchemeTypeTURNS): + case url.Proto == ProtoTypeTCP && url.Scheme == SchemeTypeTURN: + case url.Proto == ProtoTypeTCP && url.Scheme == SchemeTypeTURNS:*/ +pub async fn simple_tcp() -> anyhow::Result<()> { + let answer_connection = answer().await?; + let offer_connection = offer().await?; + let offer = offer_connection.create_offer(None).await?; + offer_connection.set_local_description(offer.clone()).await?; + let mut gather_complete = offer_connection.gathering_complete_promise().await; + let _ = gather_complete.recv().await; + + + let offer = offer_connection.local_description().await.unwrap(); + tracing::info!("Offer: {offer:?}"); + + answer_connection.set_remote_description(offer).await?; + + + let answer = answer_connection.create_answer(None).await?; + answer_connection.set_local_description(answer.clone()).await?; + let mut gather_complete = answer_connection.gathering_complete_promise().await; + + let _ = gather_complete.recv().await; + + tracing::info!("answer collect Session Description finish"); + let answer_local_description = answer_connection.local_description().await.unwrap(); + //tracing::info!("answer description: {answer_local_description:?}"); + + + offer_connection.set_remote_description(answer_local_description).await?; + Ok(()) +} + +async fn answer() -> anyhow::Result> { + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + //let config = RTCConfiguration::default(); + + let config = RTCConfiguration { + ice_servers: vec![ + RTCIceServer { + urls: vec![SELF_TURN_SERVER.to_owned()], + username: "answer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + }, + ], + ice_transport_policy: RTCIceTransportPolicy::Relay, + //peer_identity: "offer".to_owned(), + ..Default::default() + }; + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(config).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!("answer on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + tracing::info!("answer peer connection State has changed: {s}"); + + Box::pin(async {}) + })); + + peer_connection.on_data_channel(Box::new(move |d| { + let d_label = d.label().to_owned(); + let d_id = d.id(); + tracing::info!("New DataChannel {d_label} {d_id}"); + Box::pin(async move { + let d2 = Arc::clone(&d); + let d_label2 = d_label.clone(); + let d_id2 = d_id; + d.on_open(Box::new(move || { + tracing::info!("Data channel '{d_label2}'-'{d_id2}' open. Random messages will now be sent to any connected DataChannels every 5 seconds"); + Box::pin(async {}) + })); + d.on_message(Box::new(move |msg| { + let msg_str = String::from_utf8(msg.data.to_vec()).unwrap(); + tracing::info!("answer receive data label: {d_label}, data: {msg_str}"); + Box::pin(async {}) + })); + }) + })); + + + Ok(peer_connection) +} + +async fn offer() -> anyhow::Result> { + + // let config = RTCConfiguration { + // ice_servers: vec![RTCIceServer { + // urls: vec!["stun:stun.l.google.com:19302".to_owned()], + // ..Default::default() + // }], + // ..Default::default() + // }; + let config = RTCConfiguration { + ice_servers: vec![ + RTCIceServer { + urls: vec![SELF_TURN_SERVER.to_owned()], + username: "offer".to_owned(), + credential: "test".to_owned(), + credential_type: RTCIceCredentialType::Password, + } + ], + ice_transport_policy: RTCIceTransportPolicy::Relay, + + //peer_identity: "answer".to_owned(), + ..Default::default() + }; + + //let config = RTCConfiguration::default(); + let mut m = MediaEngine::default(); + let mut registry = Registry::new(); + //register_default_interceptors(registry, &mut m); + registry = configure_nack(registry, &mut m); + registry = configure_rtcp_reports(registry); + let api = APIBuilder::new() + .with_media_engine(m) + .with_interceptor_registry(registry) + .build(); + + let peer_connection = Arc::new(api.new_peer_connection(config).await?); + let w_pc = Arc::downgrade(&peer_connection); + peer_connection.on_ice_candidate(Box::new(move |c| { + let w_pc2 = w_pc.clone(); + Box::pin(async move { + if let Some(c) = c { + if let Some(w_pc) = w_pc2.upgrade() { + let remote_description = w_pc.remote_description().await; + tracing::info!(" on ice connection: {remote_description:?}") + } + } + }) + })); + + + peer_connection.on_peer_connection_state_change(Box::new(move |s| { + println!("Peer Connection State has changed: {s}"); + + Box::pin(async {}) + })); + + let data_channel = peer_connection.create_data_channel("data", None).await?; + + let dc = Arc::downgrade(&data_channel); + data_channel.on_open(Box::new(move || { + //let data_channel = data_channel.clone(); + tracing::info!(" DataChannel Open"); + Box::pin(async move { + loop { + if let Some(data_channel) = dc.upgrade() { + data_channel.send_text("1".to_owned()).await; + tokio::time::sleep(Duration::from_secs(5)).await; + } else { + break; + } + } + // + }) + })); + Ok(peer_connection) +} diff --git a/relay/turn_server_config.toml b/relay/turn_server_config.toml new file mode 100644 index 0000000..49fe080 --- /dev/null +++ b/relay/turn_server_config.toml @@ -0,0 +1,89 @@ +[turn] +# turn server realm +# +# specify the domain where the server is located. +# for a single node, this configuration is fixed, +# but each node can be configured as a different domain. +# this is a good idea to divide the nodes by namespace. +#realm = "fornet" +realm = "localhost" +# turn server listen interfaces +# +# The address and port to which the UDP Server is bound. Multiple +# addresses can be bound at the same time. The binding address supports +# ipv4 and ipv6. +[[turn.interfaces]] +transport = "udp" +#transport = "tcp" +#bind = "0.0.0.0:13478" +bind = "0.0.0.0:3478" +# external address +# +# specify the node external address and port. +# for the case of exposing the service to the outside, +# you need to manually specify the server external IP +# address and service listening port. +#external = "113.31.103.71:13478" +external = "192.168.31.37:3478" + +#[[turn.interfaces]] +#transport = "tcp" +#bind = "127.0.0.1:3478" +#external = "127.0.0.1:3478" + +[controller] +# controller bind +# +# This option specifies the http server binding address used to control +# the turn server. +# +# Warn: This http server does not contain any means of authentication, +# and sensitive information and dangerous operations can be obtained +# through this service, please do not expose it directly to an unsafe +# environment. +listen = "127.0.0.1:3000" + +# Set the value of the Access-Control-Allow-Origin header. +# +# Access-Control-Allow-Origin is a header request that states whether the +# response is shared with requesting code. +allow_origin = "*" + +#[hooks] +## hooks bind uri +## +## This option is used to specify the http address of the hooks service. +## +## Warn: This http server does not contain any means of authentication, +## and sensitive information and dangerous operations can be obtained +## through this service, please do not expose it directly to an unsafe +## environment. +#bind = "http://127.0.0.1:8080" +# +## list of events followed by hooks +#sub_events = [ +# "allocated", +# "binding", +# "channel_bind", +# "create_permission", +# "refresh", +# "abort" +#] + +[log] +# log level +# +# An enum representing the available verbosity levels of the logger. +level = "info" + +# static user password +# +# This option can be used to specify the +# static identity authentication information used by the turn server for +# verification. Note: this is a high-priority authentication method, turn +# The server will try to use static authentication first, and then use +# external control service authentication. +[auth] +answer = "test" +offer = "test" +user = "pass" diff --git a/third/simple-windows-tun b/third/simple-windows-tun index 4c8e97b..a6b0f6b 160000 --- a/third/simple-windows-tun +++ b/third/simple-windows-tun @@ -1 +1 @@ -Subproject commit 4c8e97b260a58a76bb77da6cd7d88ea5b0894fc4 +Subproject commit a6b0f6b3703370052908adedd7ea205c69a33bc8 diff --git a/third/web-sugar b/third/web-sugar index 29360c5..b22519d 160000 --- a/third/web-sugar +++ b/third/web-sugar @@ -1 +1 @@ -Subproject commit 29360c5b4c82a2cd78b9efc19dc13fd78331b150 +Subproject commit b22519dacda311aa584f4dc42470f0ad9112b4ee