Compare commits
1045 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7e7200a7c8 | |||
| 3f0d4846df | |||
| 9bfcdbe8e2 | |||
| 8c4885ce2c | |||
| 926389df89 | |||
| b55db00408 | |||
| cfcb64f7e5 | |||
| 9c6c5f5170 | |||
| f28888e3e7 | |||
| 9549bed8bb | |||
| 7c65d61d91 | |||
| ad2efb7e62 | |||
| a50c9bfa1a | |||
| 30cdbf535a | |||
| f5365cbca9 | |||
| 22e7cb887b | |||
| b571f1a881 | |||
| b1c4e3ded7 | |||
| 4694ded8bd | |||
| 7971573026 | |||
| c4780c8af2 | |||
| 246f0b3f52 | |||
| 7879d76592 | |||
| 0f62ea25d8 | |||
| 6dbe8205d6 | |||
| 1b94ad5c4c | |||
| 37be99ab8f | |||
| 6f5cee8c36 | |||
| 58d805ab72 | |||
| 68ad75f737 | |||
| 73ea2b5fec | |||
| a0b37daeb0 | |||
| c9972047f6 | |||
| ccdf698380 | |||
| c10ed5a2f3 | |||
| 600b6d2b03 | |||
| b1391bbb17 | |||
| a171103a80 | |||
| 3e2009aa9d | |||
| 4b6e942667 | |||
| a6723044b9 | |||
| f60a25ee2d | |||
| 770baefe35 | |||
| 1c3403d7e6 | |||
| 342fd869a2 | |||
| 6f7db4172f | |||
| 55fd7b8890 | |||
| a14b4dc80c | |||
| c81f6962d7 | |||
| 9f4ef6842b | |||
| 7ca0c06c87 | |||
| 57aa763a84 | |||
| ba5fecf6b3 | |||
| 35343509f9 | |||
| 42d8b06346 | |||
| f30f0e8316 | |||
| e1aaf509d1 | |||
| 8db5eadea6 | |||
| 4dda824d37 | |||
| 0579b3afb0 | |||
| d328c458e6 | |||
| c8651cddbb | |||
| cde2a1ab26 | |||
| 8d78c92c03 | |||
| af311c3d33 | |||
| 906bcf1634 | |||
| 843bd4f4fa | |||
| 9bbe4a96d0 | |||
| 974ac0691c | |||
| 1188e48313 | |||
| e7ed5f3de3 | |||
| d45b2de241 | |||
| 3d9cbf351f | |||
| 844e22d94d | |||
| 09c905910e | |||
| 8fd8bf8792 | |||
| 243658637c | |||
| 5603a79d49 | |||
| 0007a4cc74 | |||
| 3dafe02f0e | |||
| e62e9cde02 | |||
| cde53c02e7 | |||
| de64da8e20 | |||
| 683790b068 | |||
| f9c24c8a23 | |||
| 886bb95e18 | |||
| 214fd0caf5 | |||
| 4aeac1acd2 | |||
| 679be24074 | |||
| 36e07f546d | |||
| d264feaf22 | |||
| 32b7b7afdc | |||
| 7a50f0c3b2 | |||
| 091382ef30 | |||
| 2da6a2fbfa | |||
| d910a4e0ee | |||
| 672ab79421 | |||
| 1ad97adc7c | |||
| 2bd585a0ff | |||
| df0b0367a4 | |||
| bb9e26d745 | |||
| dc5c765ecb | |||
| 95e2e3d0d2 | |||
| 690c4164a7 | |||
| ee656aa3ef | |||
| 3d4123aca5 | |||
| 29a8e23f72 | |||
| a4c5407b04 | |||
| 75bc36a9e6 | |||
| b8e2fb46fb | |||
| eff931f9ca | |||
| e4d8d721c0 | |||
| 21335b5ff1 | |||
| dadfdacf14 | |||
| e3eeef4301 | |||
| 6a519f4a1a | |||
| fde8bd89b6 | |||
| 099013bc6d | |||
| 11eef024ea | |||
| cc6017db3b | |||
| 84c1679973 | |||
| b1d18a5974 | |||
| 5019b4b266 | |||
| 790e7a0e1e | |||
| 0b1b6947e8 | |||
| c79b2cfb78 | |||
| dd699bce9a | |||
| 5ce017ef3d | |||
| 59c1ce2639 | |||
| 4fb63d8892 | |||
| a3b4d04d02 | |||
| aa3af8faea | |||
| 20c7f0e96f | |||
| e21142f1bd | |||
| ba3a6eaeb5 | |||
| 9d0bc8ab9e | |||
| 0d65ca78c4 | |||
| 0505a4807d | |||
| 01aa06e488 | |||
| 3b8dd1f4a5 | |||
| 4a837ce28c | |||
| 696f6c399c | |||
| ac9290de27 | |||
| b026e9107f | |||
| 1347535e8f | |||
| 479327849a | |||
| 21611a9434 | |||
| 78d9030567 | |||
| 4feb168cf7 | |||
| f3c16476f9 | |||
| 4678059eaf | |||
| a69d4bb457 | |||
| 50e3f2be38 | |||
| 276edfd562 | |||
| 605f8fcde3 | |||
| 645c9b5e67 | |||
| f0e4d1a7cf | |||
| 055ec4bdd5 | |||
| 5761f9ac7f | |||
| 32620fd55f | |||
| abb5cdbe06 | |||
| 8cad2b0076 | |||
| bcd6c19a97 | |||
| 764a3a6228 | |||
| d17aa72829 | |||
| d62658f515 | |||
| e6d4095bf9 | |||
| 9ace9d6960 | |||
| 6c32ff9708 | |||
| 5eae62ae33 | |||
| 331483f86a | |||
| 4ee0aeb2b1 | |||
| 08354f7651 | |||
| f1f599dd09 | |||
| 51251668e3 | |||
| 6e72433f99 | |||
| e6957e7a99 | |||
| de2406a2c7 | |||
| 956a264106 | |||
| 9b62d18101 | |||
| 390730f304 | |||
| e134ef8e15 | |||
| 7bd1550195 | |||
| 134ab2f0d6 | |||
| 1a4e7433b2 | |||
| f211b1e366 | |||
| b2db208e6e | |||
| c9c0de1fba | |||
| 9d91a018b2 | |||
| 0f7e3fe53e | |||
| ae9c1b4070 | |||
| e0d98af04f | |||
| 81e31c0550 | |||
| 1c771df941 | |||
| adcd8703d3 | |||
| aee4c2d80d | |||
| 5e04f48500 | |||
| a7610a7a88 | |||
| 28e6e9140c | |||
| 17c2aecd99 | |||
| 85074f3ac8 | |||
| c7020da81c | |||
| 271a126556 | |||
| 7da444c7a4 | |||
| 2a7fd71416 | |||
| 6ffd211e51 | |||
| f61ed48240 | |||
| 8d3dc405a5 | |||
| 21bf0fb27b | |||
| 7313f56c01 | |||
| cfef9e96e6 | |||
| 8b9a5cf500 | |||
| ce94ce058f | |||
| 018e4d6079 | |||
| ebadd9799f | |||
| 268fa02b83 | |||
| cb525477e5 | |||
| 4d6d2f0d33 | |||
| c7f8b05604 | |||
| 2878e9be9d | |||
| 7b419c2b12 | |||
| 0049126a91 | |||
| 80c5194d8b | |||
| 27a6b99453 | |||
| 61982de511 | |||
| efd9883197 | |||
| ce4ae8d90c | |||
| 1d2722f994 | |||
| 7e109e7f2d | |||
| f7a0b305df | |||
| 746ec71a0d | |||
| 41a63a0985 | |||
| 5a149c5492 | |||
| 7ff0becf72 | |||
| 4c2967a733 | |||
| 2b80e5d1c9 | |||
| 4e7ff53214 | |||
| 9ec36e49b7 | |||
| cdfa5ee540 | |||
| 71853f69f3 | |||
| dd13073037 | |||
| 1010df1077 | |||
| 9eaf9cf491 | |||
| 8e96318478 | |||
| bedff1f258 | |||
| 71a10a9a8b | |||
| 54287666e8 | |||
| 6de829163d | |||
| 605aed6f20 | |||
| adb5ed7c30 | |||
| 2b019e57df | |||
| 30c07712e3 | |||
| 82c92501d9 | |||
| c2a871a1a7 | |||
| dfd7bd5889 | |||
| 5aee4b1660 | |||
| 68a7bb67de | |||
| 7ff043d8df | |||
| 31e93428cf | |||
| 5f56b3eeea | |||
| e69b05693a | |||
| 8ae2451340 | |||
| b3b3279345 | |||
| 94a451c79b | |||
| ec7b959028 | |||
| 7061beea6e | |||
| e408162e26 | |||
| 25ae3895cb | |||
| 60296f2a41 | |||
| 3b97844310 | |||
| c904d245d2 | |||
| d315a2a91b | |||
| 0741d05ab3 | |||
| 61aa920362 | |||
| 24b9b17e64 | |||
| 5e3e633c4b | |||
| 8e6d3c34e2 | |||
| f3cff902ba | |||
| 4fe1b4c26f | |||
| cb24a08b06 | |||
| 597a53d11a | |||
| 639deeb502 | |||
| 03e082725e | |||
| 3e3307887e | |||
| d85683aaa8 | |||
| e89ed985fc | |||
| b1fb8bb18c | |||
| 45ebd7c37a | |||
| 3506020e55 | |||
| eca77d684b | |||
| e263a4a21f | |||
| dc4353c682 | |||
| e1d8069967 | |||
| 060726b7a3 | |||
| f72ccb0f0d | |||
| 2ff6bfbdd8 | |||
| d4f0b4772b | |||
| 17d258d094 | |||
| 8288d38257 | |||
| 1cd560c85e | |||
| 9018642992 | |||
| 04e652441e | |||
| ccf5990bc7 | |||
| 3d7c9ee2b8 | |||
| ad35c4006e | |||
| 2ec790e851 | |||
| 8f8cec0785 | |||
| 4a80cd301b | |||
| 63524eceff | |||
| a477b007e1 | |||
| 5b81510325 | |||
| 3bef973326 | |||
| bc5bb271d8 | |||
| 158e3cb073 | |||
| 36fb0eba29 | |||
| 1b37e85418 | |||
| 6a93497c8f | |||
| b8ee3465f8 | |||
| a7dfb36a84 | |||
| 14a7b5bdc8 | |||
| ffbd76539a | |||
| bdcc19e86a | |||
| 7929bac685 | |||
| f590aad42c | |||
| ec23f3dcb7 | |||
| 9644eb4329 | |||
| 7a4c6e4ed4 | |||
| d5ad504104 | |||
| d684f6d7ae | |||
| 1ba6444e72 | |||
| dc08b1170a | |||
| f0d9703587 | |||
| aa78bf702c | |||
| cd9cdfa5bb | |||
| 7e1e86bc77 | |||
| 2178f2b509 | |||
| c08efef8ed | |||
| 6d29774744 | |||
| af6bab7703 | |||
| 7033f92d82 | |||
| 128dfa6d81 | |||
| 8ed808124e | |||
| 0deef37778 | |||
| d759462e4e | |||
| f36cb3a00b | |||
| 6428f90b5a | |||
| e2d00fb002 | |||
| 0b0ec075bb | |||
| dc556706c1 | |||
| cca4d21e7c | |||
| 01f4773a5d | |||
| 6d15b444a0 | |||
| 18a3366cf3 | |||
| ea161329dc | |||
| 02a621ed8b | |||
| 5784e7519f | |||
| 323d5fbb3c | |||
| 2d89ec51c5 | |||
| 8927824d59 | |||
| 665f093bcf | |||
| 4b77312bee | |||
| f4bee0eed0 | |||
| 905ffc257a | |||
| 2419beccaf | |||
| 2ad5893a78 | |||
| c8e2d25e7a | |||
| cfea2c3aa3 | |||
| f59dc2a361 | |||
| 72f9f58fce | |||
| 2f2dfff53d | |||
| c8f8c9cb07 | |||
| 9afc21170a | |||
| 97d06d3859 | |||
| b02ee65870 | |||
| d9cec11f63 | |||
| 81028c554f | |||
| ffc6f5e963 | |||
| 6fdf70c609 | |||
| ab2a9f24c3 | |||
| 73f3f8cfab | |||
| 20c77e6987 | |||
| 630b1259d1 | |||
| 8c50492d43 | |||
| ae56d3685c | |||
| 6295d28972 | |||
| 8a8faf03d1 | |||
| e09b2ab7d6 | |||
| 2553d633ae | |||
| f5bcb8be6f | |||
| 24823356fc | |||
| cfa8854ada | |||
| 17d5cea636 | |||
| fceef1afa6 | |||
| 6c62332409 | |||
| 650d3eeae0 | |||
| 9b7f98518c | |||
| 1ba23cf4b5 | |||
| 300df601fa | |||
| 699b032f2a | |||
| 7c86ef4cbc | |||
| 2dc3999c77 | |||
| 7b7cac5054 | |||
| 5f7270acc8 | |||
| 4e829ef540 | |||
| ba64c4f8b3 | |||
| 2b5c426d67 | |||
| ceec4da27d | |||
| af9df88a48 | |||
| 4ecd252561 | |||
| 19c1ef66c8 | |||
| 13e3a79a93 | |||
| d867e0e244 | |||
| 316e984b0a | |||
| 71b5477334 | |||
| c15a081e6f | |||
| add92c7b5e | |||
| 1080cf4afe | |||
| 4e2fae8878 | |||
| fbae1d7963 | |||
| 495aec39f5 | |||
| 06c9c54cdb | |||
| ba90e740e2 | |||
| 1f36b53b64 | |||
| 23fb48316a | |||
| 312cd65d20 | |||
| b3b4b5ff36 | |||
| 79e51252a8 | |||
| cc1c9a75b4 | |||
| 5813e9212b | |||
| 6ce743fbd5 | |||
| 025f5da39e | |||
| ddd9498c0b | |||
| b62e221aad | |||
| 69c8891f82 | |||
| c2326f35a6 | |||
| bda32cfef3 | |||
| b3425a6a6e | |||
| 9e7c77ca6a | |||
| 92a755dc6c | |||
| 39e75850ff | |||
| 4587d5da26 | |||
| 586d5f658b | |||
| 9912e445a4 | |||
| 02397832f4 | |||
| 03fa8c17d7 | |||
| 964955f740 | |||
| b1121dabb9 | |||
| caff2077ae | |||
| b980bfcab8 | |||
| 57822e3c0d | |||
| b98bf46675 | |||
| 1417eeeddb | |||
| 31389dd886 | |||
| 36cf36aaae | |||
| dd08621329 | |||
| ca7ee04e47 | |||
| 0130881616 | |||
| cde247df46 | |||
| 448b2353ab | |||
| 46e2c74a98 | |||
| ce79d5a3bc | |||
| fede9cc194 | |||
| c75c5e0903 | |||
| ec00918524 | |||
| 9a43595e04 | |||
| 49334c0540 | |||
| 4a2f30a581 | |||
| bbb3287029 | |||
| 6a82285342 | |||
| 494f1d5199 | |||
| 22ee87d87e | |||
| a8e62bde26 | |||
| 22df65aad7 | |||
| c4e86337e5 | |||
| 2d3bb78819 | |||
| 1ec11dda24 | |||
| 723b4b4754 | |||
| 4e239ac9b7 | |||
| dafb69d2d6 | |||
| e225c1ee1b | |||
| 1feb53cc87 | |||
| 4c919f520a | |||
| bb64d8c03e | |||
| 580cc58f42 | |||
| bc75dd7e15 | |||
| 40af0f94b0 | |||
| c9c68ab2cb | |||
| 26c5fa7262 | |||
| b5adf2bb42 | |||
| 254ea6af42 | |||
| a971694ff7 | |||
| 2d59236ee8 | |||
| 17322ccda2 | |||
| 3d2e7d32d9 | |||
| 0b93215941 | |||
| 8f4fd62957 | |||
| 4844ac953a | |||
| aab094984e | |||
| a5056007d4 | |||
| 9c77e15a2c | |||
| c8bd6b99fa | |||
| 081d6097b6 | |||
| 4820258270 | |||
| e41a59fddc | |||
| 130491e80f | |||
| 165e7d8b27 | |||
| 3c97d0d16b | |||
| 16ae72fbd9 | |||
| bc55c10e19 | |||
| a925c39642 | |||
| 4fa018540c | |||
| e2b69b79e7 | |||
| d23fb366e4 | |||
| be369c2023 | |||
| 7e90ff8b85 | |||
| f5c5b342bb | |||
| af9cf52b1e | |||
| 3d500c25c5 | |||
| 3b9fb9088d | |||
| c95b5f0982 | |||
| 7cca3c716a | |||
| 9348722b84 | |||
| fd1fb7ca7b | |||
| 6252b66724 | |||
| b770cab3f0 | |||
| 726a406797 | |||
| 4652d65874 | |||
| a4ca94ccef | |||
| e69552b19d | |||
| e3cc43487a | |||
| 41be555aa6 | |||
| bdc0bcbd56 | |||
| 0baa8b2c92 | |||
| 2ab969b2c6 | |||
| 9f2e7e16e5 | |||
| 1c99446bcc | |||
| 90d9c9ec41 | |||
| 2e38c5e38e | |||
| dbb7a27441 | |||
| 89c05387f8 | |||
| 7952277c4b | |||
| c5866db137 | |||
| 37187c79cc | |||
| 24839770ff | |||
| 0238499e33 | |||
| 3363230c4c | |||
| 1f8b373780 | |||
| 7ac3ec3598 | |||
| 77ae71eba4 | |||
| d4b836277e | |||
| b92ee84874 | |||
| 2eb0ce381a | |||
| 037cd54573 | |||
| 9f42f0152b | |||
| 5217edcca3 | |||
| e306effdac | |||
| dc2b1c6d2a | |||
| 4232801e80 | |||
| 96df3ad4ce | |||
| d614a2b81b | |||
| d27245e184 | |||
| 5dbfcadfdb | |||
| 035dada0e0 | |||
| 1d867156e3 | |||
| ed9be47ec4 | |||
| 3aa2e6c54d | |||
| eb96fc72b9 | |||
| 59cec6f03c | |||
| c0a0d89a90 | |||
| 3099f2ead3 | |||
| baf88ce10a | |||
| 362e7f2fea | |||
| d89081d8a1 | |||
| eeba17a01f | |||
| 25762900fa | |||
| 3bc7f281b4 | |||
| 3e23bdf3c0 | |||
| 5a89e894a9 | |||
| 795977a75d | |||
| 8dbddb7b7e | |||
| 4e057cd250 | |||
| b62c969a7c | |||
| be1ec79b01 | |||
| 5d10e62450 | |||
| 64acddead6 | |||
| 8bbf766eeb | |||
| d7cd942dec | |||
| a9124a63f9 | |||
| b0d7169b39 | |||
| d57b486bf4 | |||
| ef8ecd42a3 | |||
| 02e1dc01af | |||
| b29bd8bcc3 | |||
| 9ad9fd36e2 | |||
| bd61679c58 | |||
| 21e636616d | |||
| 9881a94757 | |||
| 76b07d487b | |||
| f04fc452dc | |||
| be90d03129 | |||
| 0a3e42700c | |||
| 55d554701c | |||
| 19c4769260 | |||
| 71aadc8e1b | |||
| 95340b5817 | |||
| dc2b25f152 | |||
| 12751665bb | |||
| 01b86bcc0d | |||
| c6ce8caaf7 | |||
| 5370bb9c47 | |||
| 265713b9d2 | |||
| cd3c951572 | |||
| 7e43ce1aed | |||
| c9af4721f3 | |||
| 0669369c77 | |||
| 6f94ab4937 | |||
| 0d3ca99dfa | |||
| 509391cde4 | |||
| 0fc0292b18 | |||
| 9a2a99e581 | |||
| 5ec7beec8a | |||
| 044fa93eec | |||
| 8c0ab7c697 | |||
| 3e6188ed13 | |||
| 45c51636a8 | |||
| 975af0c79b | |||
| 8d82a11b00 | |||
| 854d548c20 | |||
| de55ffd944 | |||
| c8866b1af2 | |||
| eb31e47e68 | |||
| 92b220ca4b | |||
| 0bcdf99475 | |||
| b8e2997c73 | |||
| c218cba96c | |||
| 8336d0612a | |||
| c958975fff | |||
| 33d044dd5a | |||
| c2d28740a5 | |||
| 58b5f113c6 | |||
| 9ab3a133d9 | |||
| 7a9fbbccc6 | |||
| f3b82fa032 | |||
| 49b8a843a4 | |||
| 5d385ba10f | |||
| da9468c36a | |||
| 2bd679c91f | |||
| f4d0a120bb | |||
| 027b0dbc39 | |||
| 130ac50834 | |||
| 5711230ae3 | |||
| 4db656d074 | |||
| 538bcf1d0a | |||
| 95080c3ecc | |||
| 17771b5742 | |||
| 48af0ae6b4 | |||
| 4c19187c78 | |||
| e1ec3594ea | |||
| ded7e51071 | |||
| b75199e4dc | |||
| a0ed1c8edd | |||
| a693fa9190 | |||
| e83e83abed | |||
| d03f769b14 | |||
| 86e9463c42 | |||
| 5376c2a4ba | |||
| cbeac10383 | |||
| 63a4bdf5a6 | |||
| 0e0a62938d | |||
| f1d0bd0bf4 | |||
| 404473c128 | |||
| a980d6f804 | |||
| c6a5e08188 | |||
| b2ed078e0f | |||
| 886e2ed5e7 | |||
| aa545ee6c6 | |||
| 62741889bc | |||
| 64c963e36e | |||
| d6f87c40ed | |||
| 39562e653a | |||
| e548d6f1f8 | |||
| 48def795d9 | |||
| e849cc065a | |||
| 95b95b2892 | |||
| df4587be62 | |||
| 80017d258d | |||
| 6d6d9d4359 | |||
| 59185f3b87 | |||
| c708a7cc12 | |||
| ea35a37d4c | |||
| e40d25a97b | |||
| cf903aa2e5 | |||
| 0a2e0d6a8f | |||
| 8eb3dbd191 | |||
| 58d15429de | |||
| a0661fecb2 | |||
| ea68d42886 | |||
| d4298c61a0 | |||
| 65ed611c24 | |||
| d713b926f8 | |||
| f305901a18 | |||
| 082a8ad8ee | |||
| 031092815b | |||
| ca8a6150c9 | |||
| 645cb88074 | |||
| 6b96e474f7 | |||
| f4fd08f64e | |||
| 78247b973b | |||
| 6b52132501 | |||
| d2f33180e2 | |||
| dc71f6e94d | |||
| cc7161c113 | |||
| bbb46ebd90 | |||
| bc3fd236d8 | |||
| ea95288940 | |||
| b182ed6925 | |||
| 017c9d2504 | |||
| 50c7d717c0 | |||
| b473aeb3be | |||
| ac10e03aec | |||
| fe2e1c29a2 | |||
| 2eee5195cc | |||
| 3bd4343a39 | |||
| 74feb065f9 | |||
| 65b819c649 | |||
| bd12305a68 | |||
| 4854e929ed | |||
| 5709c45a50 | |||
| a7f1242961 | |||
| 8b14321c4a | |||
| 5f88517e1d | |||
| dddc6eae57 | |||
| 8beb33fe92 | |||
| c7d8f3af97 | |||
| 1e84f87bf5 | |||
| bf5b8fab85 | |||
| 70ae45b6c9 | |||
| b0960091c1 | |||
| b97a12186f | |||
| 36496a519a | |||
| 87fad25ac3 | |||
| df3d478caa | |||
| 751e3ccd27 | |||
| 74a4546d72 | |||
| 2587d00b9e | |||
| cf25c331c0 | |||
| a24c7e4783 | |||
| 9ea725bf83 | |||
| fe78d4faf0 | |||
| 0df063f9f6 | |||
| ad8fdbdddf | |||
| 8d3aea969e | |||
| 96444509d0 | |||
| 078ca0b0d1 | |||
| aab91e424e | |||
| 273dc41559 | |||
| 61bc74148f | |||
| 5b14eecf82 | |||
| 2746cabecc | |||
| 666cbcf2cc | |||
| 30110aff65 | |||
| 1954c49ac2 | |||
| 70328ba114 | |||
| c43b2dc117 | |||
| 4a8a9096dd | |||
| 96ab4325e3 | |||
| 11e2ba33e7 | |||
| 95db26c35b | |||
| aed96b2d44 | |||
| 326d5fcec8 | |||
| 88d813b9c1 | |||
| e181a1cfb1 | |||
| afae6fc9a5 | |||
| 23c13a409a | |||
| 29091aab8e | |||
| 1d522143a2 | |||
| 775ce0f95d | |||
| b019786c5a | |||
| 9b9c01fb8f | |||
| 6c857b5daf | |||
| 5ea084d286 | |||
| fdbe3a1f6a | |||
| 5f4926dd49 | |||
| 1f132a4eaa | |||
| 097d2d51cc | |||
| a2078d997b | |||
| 558d4b899d | |||
| 4fcb98e839 | |||
| 702bb202a3 | |||
| 71ff2c04a0 | |||
| cb30384eaf | |||
| e911c2fbc0 | |||
| bb005a39f5 | |||
| ea72c37083 | |||
| a24dd8b9bc | |||
| b006c01397 | |||
| f7f2a51458 | |||
| 408396c900 | |||
| a97c913bb1 | |||
| dba5a9caef | |||
| 3e39573feb | |||
| ac312e9109 | |||
| 8a2a7dc0ce | |||
| 5b15ed6f15 | |||
| 9684b7ffbd | |||
| 0628565684 | |||
| 4f59678ded | |||
| 8a1d2af3cf | |||
| 57703af642 | |||
| 9dd4c5d871 | |||
| 4813cf6c18 | |||
| 29f48efe49 | |||
| 280ac34115 | |||
| 83b76c6b37 | |||
| 4120234155 | |||
| 42b444ddf8 | |||
| acd832d8e5 | |||
| 75a726ebbe | |||
| b9fbab6024 | |||
| 06ed8716a1 | |||
| beddd3dcee | |||
| bdc285dbbb | |||
| 4d02dfb899 | |||
| 80d6cb5c12 | |||
| 7422ab69ba | |||
| 60c8185bea | |||
| 9d3c7c0be8 | |||
| d6048fae52 | |||
| ddb7b0e872 | |||
| 4995dde705 | |||
| 63bfe4246f | |||
| 4654b360e0 | |||
| 7c5c19986a | |||
| 46edca0bd4 | |||
| b03a1f922d | |||
| 9616c90433 | |||
| ea49f0a265 | |||
| 2470c8b9b5 | |||
| 7d001965ec | |||
| 11b1089d83 | |||
| 52699d7598 | |||
| 87443dd624 | |||
| a02a1b0385 | |||
| e0f2fa6705 | |||
| 7949b07213 | |||
| bd20fd0b1f | |||
| 57d3d6fd0f | |||
| 06eff652dd | |||
| 246decac4a | |||
| a14ae298ae | |||
| 43188051d3 | |||
| 8aa15fa467 | |||
| f77b037ef7 | |||
| 75dbc5d790 | |||
| e6bcd706ff | |||
| 9a077a0928 | |||
| 11fd42e187 | |||
| 6e499e5996 | |||
| f98cc73a1f | |||
| db9bf4d3fa | |||
| b30628529d | |||
| 3be615f74f | |||
| a8ccd2ec17 | |||
| 2d71caf50a | |||
| 4d08d62fc2 | |||
| 40e5595d65 | |||
| 6780d58a98 | |||
| ccbf06f179 | |||
| e6ecf71cc3 | |||
| c66312ee96 | |||
| 808802aeb4 | |||
| fb38f24e5c | |||
| 65f148a5ad | |||
| 2bcdc5d11e | |||
| 5ecb03ffe9 | |||
| 8505989dad | |||
| ed5e865db7 | |||
| ea3194e0c3 | |||
| 190bff4ffe | |||
| c509555d15 | |||
| f0d66fdd88 | |||
| 14847d01b7 | |||
| f4711902bd | |||
| 32ad93c57e | |||
| c4a68dbbe6 | |||
| 1140503eba | |||
| d92d6877a4 | |||
| b9fed9f455 | |||
| 5e45f7d3a5 | |||
| 1133acd8bd | |||
| 08e6f3c4b7 | |||
| 0ed546b739 | |||
| b4f2233d2b | |||
| d8369eb4c9 | |||
| db3d379219 | |||
| a746738d48 | |||
| c67f0fb7f8 | |||
| 7c12a3422c | |||
| f047209baf | |||
| cc5a69d4f1 | |||
| 776d27a899 | |||
| 829dbb1695 | |||
| 52156e0c38 | |||
| 901275fd63 | |||
| 6c4f0bc2f4 | |||
| 052a9a71c2 | |||
| da094f0208 | |||
| 254302ec38 | |||
| a0a73421d0 | |||
| b7be48a1b3 | |||
| 870c4f73a8 | |||
| c2c883e840 | |||
| 4d7e21e0f2 | |||
| c0ffbb0cb2 | |||
| 5e600de932 | |||
| 70fcb8c046 | |||
| eb07ec8580 | |||
| f6a79ce7c3 | |||
| 80c81fa3d7 | |||
| 27e6539e98 | |||
| a2d10d9956 | |||
| 4ece8b7e8f | |||
| bb557985c0 | |||
| 3ebb24b2c8 | |||
| 142a2bb26b | |||
| 677d8c7fce | |||
| 3563ad67b2 | |||
| c11a4c23fa | |||
| 97b01db23e | |||
| a020f2ad1c | |||
| ce676c2bb5 | |||
| 4b0f3cc093 | |||
| 568ba1f4d9 | |||
| a096f9d54e | |||
| 5456b16e3b | |||
| 3b5eab5342 | |||
| a7d8613c9d | |||
| c720481a45 | |||
| e18946efe1 | |||
| 47ca0d0358 | |||
| 00f17c376a | |||
| 5283329914 | |||
| 29dd121282 | |||
| cd1d9d1a0d | |||
| b694e675e6 | |||
| 39cb6f6ec0 | |||
| 7a52124d53 | |||
| 2ec5616453 | |||
| ebaf99fadb | |||
| c534c4b91d | |||
| 85515fe16e | |||
| ec60966a85 | |||
| d1df407bac | |||
| 9ff4051b0f | |||
| fea9ec0f9f | |||
| d48d094672 | |||
| e1b511e788 | |||
| 1500d27ce5 | |||
| a0eba073ec | |||
| 2c3e716ba1 | |||
| b76051832f | |||
| d9b6823106 | |||
| c966680bba | |||
| 7f7d30c9b5 | |||
| b08dace119 | |||
| 58255857e5 | |||
| bd1d88e9e8 | |||
| edf38e6356 | |||
| e258f62a26 | |||
| 940427776c | |||
| 2f7d9254b8 | |||
| 67321d7d04 | |||
| e38a20fb58 | |||
| 8e45e3e995 | |||
| 2f63d916b6 | |||
| 0b465e1f09 | |||
| f93aab2f5b | |||
| 7ff06cfe3e | |||
| 8c7e7dfcd1 | |||
| 31ca88fd7f | |||
| 51b29a9dcf | |||
| d58c2da463 | |||
| 5644726a7b | |||
| e9ba34ba52 | |||
| a33e848d6d | |||
| 3da9d2944b | |||
| e2c9f69ab9 | |||
| 8a21f183f9 | |||
| cb2a89dceb | |||
| 502e23b42c | |||
| 2676c68b77 | |||
| c5252f348d | |||
| bd8cea3ba3 | |||
| 7ddc8e80e6 | |||
| 03a974ec34 | |||
| 5c841de6ae | |||
| 9a8218905e | |||
| f6fca0ad37 | |||
| 9a8c5c3708 | |||
| 52136d727b | |||
| edd5c363bb | |||
| 028bee804b | |||
| a16c566719 | |||
| 53444cf55a | |||
| 667d5f3033 | |||
| b51aac6047 | |||
| a21be84833 | |||
| 49f7c48b1b | |||
| 6943271942 | |||
| a872b478d2 | |||
| 11051ba929 | |||
| 10e28c6e5c | |||
| 78af0bff71 | |||
| 3d2dee3e1c | |||
| 25212f23ad | |||
| 96c0256154 | |||
| 033333bb52 | |||
| bf207abe55 | |||
| 4069b0349d | |||
| bca20e1dfd | |||
| f2e460a96b | |||
| 1bc94d8fd4 | |||
| a269bd8289 | |||
| b5b7b7255b | |||
| 52d06785fb | |||
| 894a46688a | |||
| 5d3550a569 | |||
| 1507938c65 | |||
| b43dab4f83 | |||
| 1bdb58571d | |||
| 41b37984a4 | |||
| b541d1a034 | |||
| bc25288d08 | |||
| 3a001e2f9f | |||
| 09cad3c589 | |||
| ab0180c5ce | |||
| a77f364466 | |||
| a9be8a6abd | |||
| 8de9f36b69 | |||
| 24e2eee547 | |||
| a74a99d81d | |||
| c09d3af92f | |||
| 76773c58d7 | |||
| fd90175e87 | |||
| 0eb859467e |
+1
-1
@@ -14,7 +14,7 @@ GEOIPUPDATE_LICENSE_KEY=xxx
|
|||||||
# List of space-separated database edition IDs. Edition IDs may
|
# List of space-separated database edition IDs. Edition IDs may
|
||||||
# consist of letters, digits, and dashes. For example, GeoIP2-City
|
# consist of letters, digits, and dashes. For example, GeoIP2-City
|
||||||
# would download the GeoIP2 City database (GeoIP2-City).
|
# would download the GeoIP2 City database (GeoIP2-City).
|
||||||
GEOIPUPDATE_EDITION_IDS=GeoLite2-Country
|
GEOIPUPDATE_EDITION_IDS=GeoLite2-City
|
||||||
# The number of hours between geoipupdate runs. If this is not set
|
# The number of hours between geoipupdate runs. If this is not set
|
||||||
# or is set to 0, geoipupdate will run once and exit.
|
# or is set to 0, geoipupdate will run once and exit.
|
||||||
GEOIPUPDATE_FREQUENCY=72
|
GEOIPUPDATE_FREQUENCY=72
|
||||||
|
|||||||
@@ -0,0 +1,16 @@
|
|||||||
|
# To get started with Dependabot version updates, you'll need to specify which
|
||||||
|
# package ecosystems to update and where the package manifests are located.
|
||||||
|
# Please see the documentation for all configuration options:
|
||||||
|
# https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates
|
||||||
|
|
||||||
|
version: 2
|
||||||
|
updates:
|
||||||
|
# Maintain dependencies for GitHub Actions
|
||||||
|
- package-ecosystem: "github-actions"
|
||||||
|
directory: "/"
|
||||||
|
schedule:
|
||||||
|
interval: "daily"
|
||||||
|
commit-message:
|
||||||
|
prefix: build
|
||||||
|
prefix-development: chore
|
||||||
|
include: scope
|
||||||
@@ -26,7 +26,7 @@ jobs:
|
|||||||
path: .github/workflows/support-files/notifications/deny.message
|
path: .github/workflows/support-files/notifications/deny.message
|
||||||
notification:
|
notification:
|
||||||
needs: cargo-deny
|
needs: cargo-deny
|
||||||
runs-on: ubuntu-20.04
|
runs-on: custom-runner-linux
|
||||||
steps:
|
steps:
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@@ -35,18 +35,23 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
name: report
|
name: report
|
||||||
path: .github/workflows/support-files/notifications
|
path: .github/workflows/support-files/notifications
|
||||||
- name: Keybase - Node Install
|
- name: install npm
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Matrix - Node Install
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: security
|
NYM_NOTIFICATION_KIND: security
|
||||||
NYM_PROJECT_NAME: "Daily security report"
|
NYM_PROJECT_NAME: "Daily security report"
|
||||||
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_AUDIT }}"
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
KEYBASE_NYM_CHANNEL: "security"
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -0,0 +1,121 @@
|
|||||||
|
name: Build and upload binaries to CI
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/**'
|
||||||
|
- 'explorer-api/**'
|
||||||
|
- 'gateway/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
- 'nym-api/**'
|
||||||
|
- 'nym-outfox/**'
|
||||||
|
- 'tools/nym-cli/**'
|
||||||
|
- 'tools/ts-rs-cli/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/**'
|
||||||
|
- 'explorer-api/**'
|
||||||
|
- 'gateway/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
- 'nym-api/**'
|
||||||
|
- 'nym-outfox/**'
|
||||||
|
- 'tools/nym-cli/**'
|
||||||
|
- 'tools/ts-rs-cli/**'
|
||||||
|
|
||||||
|
env:
|
||||||
|
NETWORK: mainnet
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
publish-nym:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
platform: [ubuntu-20.04]
|
||||||
|
|
||||||
|
runs-on: ${{ matrix.platform }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Prepare build output directory
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
OUTPUT_DIR: ci-builds/${{ github.ref_name }}
|
||||||
|
run: |
|
||||||
|
rm -rf ci-builds || true
|
||||||
|
mkdir -p $OUTPUT_DIR
|
||||||
|
echo $OUTPUT_DIR
|
||||||
|
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
|
- name: Build all binaries
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --release --all
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
target: wasm32-unknown-unknown
|
||||||
|
override: true
|
||||||
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Install wasm-opt
|
||||||
|
run: cargo install --version 0.112.0 wasm-opt
|
||||||
|
|
||||||
|
- name: Build release contracts
|
||||||
|
run: make wasm
|
||||||
|
|
||||||
|
- name: Prepare build output
|
||||||
|
shell: bash
|
||||||
|
env:
|
||||||
|
OUTPUT_DIR: ci-builds/${{ github.ref_name }}
|
||||||
|
run: |
|
||||||
|
cp target/release/nym-client $OUTPUT_DIR
|
||||||
|
cp target/release/nym-gateway $OUTPUT_DIR
|
||||||
|
cp target/release/nym-mixnode $OUTPUT_DIR
|
||||||
|
cp target/release/nym-socks5-client $OUTPUT_DIR
|
||||||
|
cp target/release/nym-api $OUTPUT_DIR
|
||||||
|
cp target/release/nym-network-requester $OUTPUT_DIR
|
||||||
|
cp target/release/nym-network-statistics $OUTPUT_DIR
|
||||||
|
cp target/release/nym-cli $OUTPUT_DIR
|
||||||
|
cp target/release/nym-credential-client $OUTPUT_DIR
|
||||||
|
cp target/release/explorer-api $OUTPUT_DIR
|
||||||
|
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/mixnet_contract.wasm $OUTPUT_DIR
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/vesting_contract.wasm $OUTPUT_DIR
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/nym_coconut_bandwidth.wasm $OUTPUT_DIR
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/nym_coconut_dkg.wasm $OUTPUT_DIR
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/cw3_flex_multisig.wasm $OUTPUT_DIR
|
||||||
|
cp contracts/target/wasm32-unknown-unknown/release/cw4_group.wasm $OUTPUT_DIR
|
||||||
|
|
||||||
|
- name: Deploy branch to CI www
|
||||||
|
continue-on-error: true
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CI_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-avzr"
|
||||||
|
SOURCE: "ci-builds/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CI_WWW_REMOTE_HOST }}
|
||||||
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/builds/
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
@@ -0,0 +1,59 @@
|
|||||||
|
name: Build and upload binaries to artifact storage
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
add_tokio_unstable:
|
||||||
|
description: 'True to add RUSTFLAGS="--cfg tokio_unstable"'
|
||||||
|
required: true
|
||||||
|
default: false
|
||||||
|
type: boolean
|
||||||
|
|
||||||
|
env:
|
||||||
|
NETWORK: mainnet
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
publish-nym:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
platform: [ubuntu-20.04]
|
||||||
|
|
||||||
|
runs-on: ${{ matrix.platform }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Sets env vars for tokio if set in manual dispatch inputs
|
||||||
|
run: |
|
||||||
|
echo 'RUSTFLAGS="--cfg tokio_unstable"' >> $GITHUB_ENV
|
||||||
|
if: github.event_name == 'workflow_dispatch' && inputs.add_tokio_unstable == true
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
|
- name: Build all binaries
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --release
|
||||||
|
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: nym-binaries-artifacts
|
||||||
|
path: |
|
||||||
|
target/release/nym-client
|
||||||
|
target/release/nym-gateway
|
||||||
|
target/release/nym-mixnode
|
||||||
|
target/release/nym-socks5-client
|
||||||
|
target/release/nym-api
|
||||||
|
target/release/nym-network-requester
|
||||||
|
target/release/nym-network-statistics
|
||||||
|
target/release/nym-cli
|
||||||
|
retention-days: 30
|
||||||
@@ -12,6 +12,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- name: Install rsync
|
- name: Install rsync
|
||||||
run: sudo apt-get install rsync
|
run: sudo apt-get install rsync
|
||||||
|
continue-on-error: true
|
||||||
- uses: rlespinasse/github-slug-action@v3.x
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
@@ -42,10 +43,10 @@ jobs:
|
|||||||
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/ts-${{ env.GITHUB_REF_SLUG }}-example
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/ts-${{ env.GITHUB_REF_SLUG }}-example
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
- name: Keybase - Node Install
|
- name: Matrix - Node Install
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: ts-packages
|
NYM_NOTIFICATION_KIND: ts-packages
|
||||||
NYM_PROJECT_NAME: "ts-packages"
|
NYM_PROJECT_NAME: "ts-packages"
|
||||||
@@ -53,11 +54,12 @@ jobs:
|
|||||||
NYM_CI_WWW_LOCATION: "ts-${{ env.GITHUB_REF_SLUG }}"
|
NYM_CI_WWW_LOCATION: "ts-${{ env.GITHUB_REF_SLUG }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-ts-packages"
|
|
||||||
IS_SUCCESS: "${{ job.status == 'success' }}"
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
+39
-29
@@ -2,21 +2,44 @@ name: Continuous integration
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'explorer-api/**'
|
||||||
|
- 'gateway/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
- 'nym-api/**'
|
||||||
|
- 'nym-outfox/**'
|
||||||
|
- 'tools/nym-cli/**'
|
||||||
|
- 'tools/ts-rs-cli/**'
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'explorer-api/**'
|
||||||
|
- 'gateway/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
- 'nym-api/**'
|
||||||
|
- 'nym-outfox/**'
|
||||||
|
- 'tools/nym-cli/**'
|
||||||
|
- 'tools/ts-rs-cli/**'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: [ self-hosted, custom-linux ]
|
runs-on: [ self-hosted, custom-linux ]
|
||||||
# Enable sccache via environment variable
|
# Enable sccache via environment variable
|
||||||
env:
|
env:
|
||||||
RUSTC_WRAPPER: /home/ubuntu/.cargo/bin/sccache
|
RUSTC_WRAPPER: /home/ubuntu/.cargo/bin/sccache
|
||||||
steps:
|
steps:
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@@ -41,47 +64,34 @@ jobs:
|
|||||||
command: build
|
command: build
|
||||||
args: --workspace
|
args: --workspace
|
||||||
|
|
||||||
|
- name: Build all examples
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --examples
|
||||||
|
|
||||||
- name: Run all tests
|
- name: Run all tests
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: test
|
command: test
|
||||||
args: --workspace --all-features
|
args: --workspace
|
||||||
|
|
||||||
- name: Run expensive tests
|
- name: Run expensive tests
|
||||||
if: github.ref == 'refs/heads/develop' || github.event.pull_request.base.ref == 'develop' || github.event.pull_request.base.ref == 'master'
|
if: github.ref == 'refs/heads/develop' || github.event.pull_request.base.ref == 'develop' || github.event.pull_request.base.ref == 'master'
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: test
|
command: test
|
||||||
args: --workspace --all-features -- --ignored
|
args: --workspace -- --ignored
|
||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
- uses: actions-rs/clippy-check@v1
|
||||||
name: Clippy checks
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
args: --workspace --all-features
|
args: --workspace
|
||||||
|
|
||||||
- name: Run clippy
|
- name: Run clippy
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: clippy
|
command: clippy
|
||||||
args: --workspace -- -D warnings
|
args: --workspace --all-targets -- -D warnings
|
||||||
|
|
||||||
# COCONUT stuff
|
|
||||||
|
|
||||||
- name: Build all binaries with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Run all tests with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Run clippy with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: clippy
|
|
||||||
args: --all-targets --features=coconut -- -D warnings
|
|
||||||
|
|||||||
@@ -0,0 +1,76 @@
|
|||||||
|
name: CD dev-portal
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: master
|
||||||
|
paths:
|
||||||
|
- 'documentation/dev-portal/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Install rsync
|
||||||
|
run: sudo apt-get install rsync
|
||||||
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: "16"
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
- name: Install mdbook
|
||||||
|
run: (test -x $HOME/.cargo/bin/mdbook || cargo install --vers "^0.4" mdbook)
|
||||||
|
- name: Install mdbook plugins
|
||||||
|
run: |
|
||||||
|
cargo install --vers "^0.2.0" mdbook-variables && cargo install \
|
||||||
|
--vers "^1.8.0" mdbook-admonish && cargo install --vers \
|
||||||
|
"^0.1.2" mdbook-last-changed && cargo install --vers "^0.1.2" \
|
||||||
|
mdbook-theme && cargo install --vers "^0.7.7" mdbook-linkcheck
|
||||||
|
- name: Clean website
|
||||||
|
run: cd documentation/dev-portal && mdbook clean
|
||||||
|
- name: Build website
|
||||||
|
run: cd documentation/dev-portal && mdbook build
|
||||||
|
- name: Deploy branch master to dev
|
||||||
|
continue-on-error: true
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CD_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/dev-portal/book/html/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CD_WWW_REMOTE_HOST_DEV }}
|
||||||
|
REMOTE_USER: ${{ secrets.CD_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CD_WWW_REMOTE_TARGET_DEVP }}/
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Deploy branch master to prod
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CD_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/dev-portal/book/html/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CD_WWW_REMOTE_HOST_PROD }}
|
||||||
|
REMOTE_USER: ${{ secrets.CD_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CD_WWW_REMOTE_TARGET_DEVP }}/
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Matrix - Node Install
|
||||||
|
run: npm install
|
||||||
|
working-directory: .github/workflows/support-files
|
||||||
|
- name: Matrix - Send Notification
|
||||||
|
env:
|
||||||
|
NYM_NOTIFICATION_KIND: cd-dev
|
||||||
|
NYM_PROJECT_NAME: "Dev portal CD"
|
||||||
|
NYM_CI_WWW_BASE: "${{ secrets.NYM_CD_WWW_BASE }}"
|
||||||
|
NYM_CI_WWW_LOCATION: "${{ env.GITHUB_REF_SLUG }}"
|
||||||
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_DEVP }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
uses: docker://keybaseio/client:stable-node
|
||||||
|
with:
|
||||||
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,82 @@
|
|||||||
|
name: CD docs
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: master
|
||||||
|
paths:
|
||||||
|
- 'documentation/docs/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Install rsync
|
||||||
|
run: sudo apt-get install rsync
|
||||||
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: "16"
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
- name: Build all binaries
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --release --all
|
||||||
|
- name: Install mdbook
|
||||||
|
run: (test -x $HOME/.cargo/bin/mdbook || cargo install --vers "^0.4" mdbook)
|
||||||
|
- name: Install mdbook plugins
|
||||||
|
run: |
|
||||||
|
cargo install --vers "^0.2.0" mdbook-variables && cargo install \
|
||||||
|
--vers "^1.8.0" mdbook-admonish && cargo install --vers \
|
||||||
|
"^0.1.2" mdbook-last-changed && cargo install --vers "^0.1.2" \
|
||||||
|
mdbook-theme && cargo install --vers "^0.7.7" mdbook-linkcheck && \
|
||||||
|
cargo install --vers "^0.5.0" mdbook-cmdrun
|
||||||
|
- name: Clean website
|
||||||
|
run: cd documentation/docs && mdbook clean
|
||||||
|
- name: Build website
|
||||||
|
run: cd documentation/docs && mdbook build
|
||||||
|
- name: Deploy branch master to dev
|
||||||
|
continue-on-error: true
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CD_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/docs/book/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CD_WWW_REMOTE_HOST_DEV }}
|
||||||
|
REMOTE_USER: ${{ secrets.CD_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CD_WWW_REMOTE_TARGET }}/
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Deploy branch master to prod
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CD_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/docs/book/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CD_WWW_REMOTE_HOST_PROD }}
|
||||||
|
REMOTE_USER: ${{ secrets.CD_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CD_WWW_REMOTE_TARGET }}/
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Matrix - Node Install
|
||||||
|
run: npm install
|
||||||
|
working-directory: .github/workflows/support-files
|
||||||
|
- name: Matrix - Send Notification
|
||||||
|
env:
|
||||||
|
NYM_NOTIFICATION_KIND: cd-docs
|
||||||
|
NYM_PROJECT_NAME: "Docs CD"
|
||||||
|
NYM_CI_WWW_BASE: "${{ secrets.NYM_CD_WWW_BASE }}"
|
||||||
|
NYM_CI_WWW_LOCATION: "${{ env.GITHUB_REF_SLUG }}"
|
||||||
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_DOCS }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
uses: docker://keybaseio/client:stable-node
|
||||||
|
with:
|
||||||
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,61 @@
|
|||||||
|
name: check-merge-conflicts
|
||||||
|
|
||||||
|
# Check that the latest release branch merges into master and develop without
|
||||||
|
# any conflicts that git is not able to resolve
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
schedule:
|
||||||
|
- cron: '5 6 * * *'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
get_release:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
output1: ${{ steps.step2.outputs.latest_release }}
|
||||||
|
steps:
|
||||||
|
- name: Check out repository code
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: Set output variable to latest release branch
|
||||||
|
id: step2
|
||||||
|
run: echo "latest_release=$(git branch -r | grep -E 'release/v[0-9]+\.[0-9]+\.[0-9]+$' | sort -V | tail -n 1)" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
|
check-merge-release-into-master:
|
||||||
|
name: Check that the release branch merges into master
|
||||||
|
needs: get_release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repo
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: Setup git user
|
||||||
|
run: |
|
||||||
|
git config --global user.name "ci"
|
||||||
|
git config --global user.email "ci@localhost"
|
||||||
|
- name: Check merge release branch into master
|
||||||
|
run: |
|
||||||
|
./.github/workflows/support-files/git-merge-check.sh origin/master $branch1
|
||||||
|
env:
|
||||||
|
branch1: ${{needs.get_release.outputs.output1}}
|
||||||
|
|
||||||
|
check-merge-release-into-develop:
|
||||||
|
name: Check that the release branch merges into develop
|
||||||
|
needs: get_release
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repo
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
- name: Setup git user
|
||||||
|
run: |
|
||||||
|
git config --global user.name "ci"
|
||||||
|
git config --global user.email "ci@localhost"
|
||||||
|
- name: Check merge release branch into develop
|
||||||
|
run: |
|
||||||
|
./.github/workflows/support-files/git-merge-check.sh origin/develop $branch1
|
||||||
|
env:
|
||||||
|
branch1: ${{needs.get_release.outputs.output1}}
|
||||||
@@ -0,0 +1,56 @@
|
|||||||
|
name: Run config checks on all binaries
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
release:
|
||||||
|
types: [created]
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'clients/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'gateway/**'
|
||||||
|
- 'integrations/**'
|
||||||
|
- 'mixnode/**'
|
||||||
|
- 'sdk/rust/nym-sdk/**'
|
||||||
|
- 'service-providers/**'
|
||||||
|
|
||||||
|
env:
|
||||||
|
NETWORK: mainnet
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
publish-nym:
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
platform: [custom-runner-linux]
|
||||||
|
|
||||||
|
runs-on: ${{ matrix.platform }}
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
run: sudo apt-get update && sudo apt-get -y install jq vim libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
|
- name: Branch name
|
||||||
|
run: echo running on branch ${GITHUB_REF##*/}
|
||||||
|
|
||||||
|
- name: Run tests against binaries
|
||||||
|
run: ./build_and_run.sh ${{ github.head_ref || github.ref_name }}
|
||||||
|
working-directory: tests/
|
||||||
|
|
||||||
|
|
||||||
@@ -0,0 +1,66 @@
|
|||||||
|
name: CI dev-portal
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches-ignore: master
|
||||||
|
paths:
|
||||||
|
- 'documentation/dev-portal/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Install rsync
|
||||||
|
run: sudo apt-get install rsync
|
||||||
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: "16"
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
- name: Install mdbook
|
||||||
|
run: (test -x $HOME/.cargo/bin/mdbook || cargo install --vers "^0.4" mdbook)
|
||||||
|
- name: Install mdbook plugins
|
||||||
|
run: |
|
||||||
|
cargo install --vers "^0.2.0" mdbook-variables && cargo install \
|
||||||
|
--vers "^1.8.0" mdbook-admonish && cargo install --vers \
|
||||||
|
"^0.1.2" mdbook-last-changed && cargo install --vers "^0.1.2" mdbook-theme \
|
||||||
|
&& cargo install --vers "^0.7.7" mdbook-linkcheck
|
||||||
|
- name: Clean website
|
||||||
|
run: cd documentation/dev-portal && mdbook clean
|
||||||
|
- name: Build website
|
||||||
|
run: cd documentation/dev-portal && mdbook build
|
||||||
|
- name: Deploy branch to CI www
|
||||||
|
continue-on-error: true
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CI_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/dev-portal/book/html/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CI_WWW_REMOTE_HOST }}
|
||||||
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/dev-portal-${{ env.GITHUB_REF_SLUG }}
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Matrix - Node Install
|
||||||
|
run: npm install
|
||||||
|
working-directory: .github/workflows/support-files
|
||||||
|
- name: Matrix - Send Notification
|
||||||
|
env:
|
||||||
|
NYM_NOTIFICATION_KIND: ci-dev
|
||||||
|
NYM_PROJECT_NAME: "Dev portal CI"
|
||||||
|
NYM_CI_WWW_BASE: "${{ secrets.NYM_CI_WWW_BASE }}"
|
||||||
|
NYM_CI_WWW_LOCATION: "dev-portal-${{ env.GITHUB_REF_SLUG }}"
|
||||||
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_DEVP }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
uses: docker://keybaseio/client:stable-node
|
||||||
|
with:
|
||||||
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,72 @@
|
|||||||
|
name: CI docs
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches-ignore: master
|
||||||
|
paths:
|
||||||
|
- 'documentation/docs/**'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- name: Install rsync
|
||||||
|
run: sudo apt-get install rsync
|
||||||
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: "16"
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
- name: Build all binaries
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --release --all
|
||||||
|
- name: Install mdbook
|
||||||
|
run: (test -x $HOME/.cargo/bin/mdbook || cargo install --vers "^0.4" mdbook)
|
||||||
|
- name: Install mdbook plugins
|
||||||
|
run: |
|
||||||
|
cargo install --vers "^0.2.0" mdbook-variables && cargo install \
|
||||||
|
--vers "^1.8.0" mdbook-admonish && cargo install --vers \
|
||||||
|
"^0.1.2" mdbook-last-changed && cargo install --vers "^0.1.2" \
|
||||||
|
mdbook-theme && cargo install --vers "^0.7.7" mdbook-linkcheck && \
|
||||||
|
cargo install --vers "^0.5.0" mdbook-cmdrun
|
||||||
|
- name: Clean website
|
||||||
|
run: cd documentation/docs && mdbook clean
|
||||||
|
- name: Build website
|
||||||
|
run: cd documentation/docs && mdbook build
|
||||||
|
- name: Deploy branch to CI www
|
||||||
|
continue-on-error: true
|
||||||
|
uses: easingthemes/ssh-deploy@main
|
||||||
|
env:
|
||||||
|
SSH_PRIVATE_KEY: ${{ secrets.CI_WWW_SSH_PRIVATE_KEY }}
|
||||||
|
ARGS: "-rltgoDzvO --delete"
|
||||||
|
SOURCE: "documentation/docs/book/"
|
||||||
|
REMOTE_HOST: ${{ secrets.CI_WWW_REMOTE_HOST }}
|
||||||
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/docs-${{ env.GITHUB_REF_SLUG }}
|
||||||
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
|
- name: Matrix - Node Install
|
||||||
|
run: npm install
|
||||||
|
working-directory: .github/workflows/support-files
|
||||||
|
- name: Matrix - Send Notification
|
||||||
|
env:
|
||||||
|
NYM_NOTIFICATION_KIND: ci-docs
|
||||||
|
NYM_PROJECT_NAME: "Docs CI"
|
||||||
|
NYM_CI_WWW_BASE: "${{ secrets.NYM_CI_WWW_BASE }}"
|
||||||
|
NYM_CI_WWW_LOCATION: "docs-${{ env.GITHUB_REF_SLUG }}"
|
||||||
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_DOCS }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
uses: docker://keybaseio/client:stable-node
|
||||||
|
with:
|
||||||
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,138 @@
|
|||||||
|
name: Nym Connect - Android APK Build
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- "release/nc-android-v[0-9].[0-9].[0-9]*"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
name: Build APK
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
env:
|
||||||
|
ANDROID_HOME: ${{ github.workspace }}/android-sdk
|
||||||
|
NDK_VERSION: 25.1.8937393
|
||||||
|
NDK_HOME: ${{ github.workspace }}/android-sdk/ndk/25.1.8937393
|
||||||
|
SDK_PLATFORM_VERSION: android-33
|
||||||
|
SDK_BUILDTOOLS_VERSION: 33.0.1
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
# https://next--tauri.netlify.app/next/guides/getting-started/prerequisites/linux/#1-system-dependencies
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get -y install \
|
||||||
|
build-essential \
|
||||||
|
unzip \
|
||||||
|
curl \
|
||||||
|
wget \
|
||||||
|
libssl-dev \
|
||||||
|
squashfs-tools \
|
||||||
|
librsvg2-dev
|
||||||
|
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install Java
|
||||||
|
uses: actions/setup-java@v3
|
||||||
|
with:
|
||||||
|
distribution: "temurin"
|
||||||
|
java-version: "17"
|
||||||
|
|
||||||
|
- name: Install Android SDK manager
|
||||||
|
# https://developer.android.com/studio/command-line/sdkmanager
|
||||||
|
run: |
|
||||||
|
curl -sS https://dl.google.com/android/repository/commandlinetools-linux-9477386_latest.zip -o cmdline-tools.zip
|
||||||
|
unzip cmdline-tools.zip
|
||||||
|
mkdir -p $ANDROID_HOME/cmdline-tools/latest
|
||||||
|
mv cmdline-tools/* $ANDROID_HOME/cmdline-tools/latest
|
||||||
|
rm -rf cmdline-tools
|
||||||
|
|
||||||
|
- name: Install Android S/NDK
|
||||||
|
run: |
|
||||||
|
echo y | $ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager --licenses
|
||||||
|
echo y | $ANDROID_HOME/cmdline-tools/latest/bin/sdkmanager \
|
||||||
|
"platforms;$SDK_PLATFORM_VERSION" \
|
||||||
|
"platform-tools" \
|
||||||
|
"ndk;$NDK_VERSION" \
|
||||||
|
"build-tools;$SDK_BUILDTOOLS_VERSION"
|
||||||
|
|
||||||
|
- name: Install Rust toolchain
|
||||||
|
uses: dtolnay/rust-toolchain@stable
|
||||||
|
|
||||||
|
# TODO this step takes a considerable amount of time
|
||||||
|
# We could avoid to compile from source tauri-cli and use instead
|
||||||
|
# pre-compiled binary provided by the node package `@tauri-apps/cli`
|
||||||
|
# But when using the later the build fails for some reason
|
||||||
|
# so keep installing and using tauri-cli
|
||||||
|
- name: Install tauri cli
|
||||||
|
run: cargo install tauri-cli --version "^2.0.0-alpha.2"
|
||||||
|
|
||||||
|
- name: Install rust android targets
|
||||||
|
run: |
|
||||||
|
rustup target add aarch64-linux-android \
|
||||||
|
armv7-linux-androideabi \
|
||||||
|
i686-linux-android \
|
||||||
|
x86_64-linux-android
|
||||||
|
|
||||||
|
- name: Setup Nodejs
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 18
|
||||||
|
|
||||||
|
- name: Install yarn
|
||||||
|
run: |
|
||||||
|
npm i -g yarn
|
||||||
|
yarn --version
|
||||||
|
|
||||||
|
- name: Build frontend code
|
||||||
|
run: |
|
||||||
|
yarn install --frozen-lockfile
|
||||||
|
yarn build
|
||||||
|
yarn workspace @nym/nym-connect-mobile webpack:prod
|
||||||
|
|
||||||
|
- name: Build APK
|
||||||
|
working-directory: nym-connect/mobile
|
||||||
|
env:
|
||||||
|
# NODE_TAURI_CLI=${{ github.workspace }}/nym-connect/mobile/node_modules/.bin/tauri
|
||||||
|
ANDROID_SDK_ROOT: ${{ env.ANDROID_HOME }}
|
||||||
|
WRY_ANDROID_PACKAGE: net.nymtech.nym_connect
|
||||||
|
WRY_ANDROID_LIBRARY: nym_connect
|
||||||
|
# TODO build with release profile (--release), it will requires
|
||||||
|
# to sign the APK. For now build with debug profile to avoid that
|
||||||
|
# TODO build using `yarn tauri`, provide NODE_TAURI_CLI, see TODO notes above
|
||||||
|
run: cargo tauri android build --debug --apk --split-per-abi -t aarch64
|
||||||
|
|
||||||
|
# TODO add the version number to APK name
|
||||||
|
- name: Rename APK artifact
|
||||||
|
run: |
|
||||||
|
mkdir apk/
|
||||||
|
mv nym-connect/mobile/src-tauri/gen/android/nym_connect/app/build/outputs/apk/arm64/debug/app-arm64-debug.apk \
|
||||||
|
apk/nym-connect-arm64-debug.apk
|
||||||
|
mv nym-connect/mobile/src-tauri/gen/android/nym_connect/app/build/outputs/apk/x86_64/debug/app-x86_64-debug.apk \
|
||||||
|
apk/nym-connect-x86_64-debug.apk
|
||||||
|
|
||||||
|
- name: Upload APK artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: nc-apk-debug
|
||||||
|
path: |
|
||||||
|
apk/nym-connect-arm64-debug.apk
|
||||||
|
apk/nym-connect-x86_64-debug.apk
|
||||||
|
|
||||||
|
# publish:
|
||||||
|
# name: Publish APK
|
||||||
|
# needs: build
|
||||||
|
# runs-on: ubuntu-latest
|
||||||
|
# steps:
|
||||||
|
# - name: Checkout
|
||||||
|
# uses: actions/checkout@v3
|
||||||
|
# - name: Download binary artifact
|
||||||
|
# uses: actions/download-artifact@v3
|
||||||
|
# with:
|
||||||
|
# name: nc-apk-debug
|
||||||
|
# path: apk
|
||||||
|
# # TODO add a step to upload the APK somewhere
|
||||||
|
# - name: Publish
|
||||||
|
# uses: ???
|
||||||
@@ -1,13 +1,13 @@
|
|||||||
name: CI for nym-connect
|
name: CI for nym-connect - Desktop
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
paths:
|
paths:
|
||||||
- 'nym-connect/**'
|
- 'nym-connect/desktop/**'
|
||||||
|
|
||||||
defaults:
|
defaults:
|
||||||
run:
|
run:
|
||||||
working-directory: nym-connect
|
working-directory: nym-connect/desktop
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
@@ -16,6 +16,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- name: Install rsync
|
- name: Install rsync
|
||||||
run: sudo apt-get install rsync
|
run: sudo apt-get install rsync
|
||||||
|
continue-on-error: true
|
||||||
- uses: rlespinasse/github-slug-action@v3.x
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
@@ -33,15 +34,15 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
SSH_PRIVATE_KEY: ${{ secrets.CI_WWW_SSH_PRIVATE_KEY }}
|
SSH_PRIVATE_KEY: ${{ secrets.CI_WWW_SSH_PRIVATE_KEY }}
|
||||||
ARGS: "-rltgoDzvO --delete"
|
ARGS: "-rltgoDzvO --delete"
|
||||||
SOURCE: "nym-connect/storybook-static/"
|
SOURCE: "nym-connect/desktop/storybook-static/"
|
||||||
REMOTE_HOST: ${{ secrets.CI_WWW_REMOTE_HOST }}
|
REMOTE_HOST: ${{ secrets.CI_WWW_REMOTE_HOST }}
|
||||||
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/nym-connect-${{ env.GITHUB_REF_SLUG }}
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/nym-connect-${{ env.GITHUB_REF_SLUG }}
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
- name: Keybase - Node Install
|
- name: Matrix - Node Install
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: nym-connect
|
NYM_NOTIFICATION_KIND: nym-connect
|
||||||
NYM_PROJECT_NAME: "nym-connect"
|
NYM_PROJECT_NAME: "nym-connect"
|
||||||
@@ -49,11 +50,12 @@ jobs:
|
|||||||
NYM_CI_WWW_LOCATION: "nym-connect-${{ env.GITHUB_REF_SLUG }}"
|
NYM_CI_WWW_LOCATION: "nym-connect-${{ env.GITHUB_REF_SLUG }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-nym-connect"
|
|
||||||
IS_SUCCESS: "${{ job.status == 'success' }}"
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,75 @@
|
|||||||
|
name: Nym Connect - desktop (Rust)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- "nym-connect/desktop/src-tauri/**"
|
||||||
|
- "nym-connect/desktop/src-tauri/Cargo.toml"
|
||||||
|
- "clients/client-core/**"
|
||||||
|
- "clients/socks5/**"
|
||||||
|
- "common/**"
|
||||||
|
- "gateway/gateway-requests/**"
|
||||||
|
- "contracts/vesting/**"
|
||||||
|
- "nym-api/nym-api-requests/**"
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- "nym-connect/desktop/src-tauri/**"
|
||||||
|
- "nym-connect/desktop/src-tauri/Cargo.toml"
|
||||||
|
- "clients/client-core/**"
|
||||||
|
- "clients/socks5/**"
|
||||||
|
- "common/**"
|
||||||
|
- "gateway/gateway-requests/**"
|
||||||
|
- "contracts/vesting/**"
|
||||||
|
- "nym-api/nym-api-requests/**"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: [self-hosted, custom-linux]
|
||||||
|
env:
|
||||||
|
RUSTC_WRAPPER: /home/ubuntu/.cargo/bin/sccache
|
||||||
|
steps:
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev squashfs-tools libayatana-appindicator3-dev
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Check out repository code
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Install rust toolchain
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
profile: minimal
|
||||||
|
toolchain: stable
|
||||||
|
override: true
|
||||||
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Build all binaries
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --manifest-path nym-connect/desktop/Cargo.toml --workspace
|
||||||
|
|
||||||
|
- name: Run all tests
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: test
|
||||||
|
args: --manifest-path nym-connect/desktop/Cargo.toml --workspace
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: fmt
|
||||||
|
args: --manifest-path nym-connect/desktop/Cargo.toml --all -- --check
|
||||||
|
|
||||||
|
- uses: actions-rs/clippy-check@v1
|
||||||
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
|
with:
|
||||||
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
args: --manifest-path nym-connect/desktop/Cargo.toml --workspace --all-features
|
||||||
|
|
||||||
|
- name: Run clippy
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: clippy
|
||||||
|
args: --manifest-path nym-connect/desktop/Cargo.toml --workspace --all-features -- -D warnings
|
||||||
@@ -0,0 +1,72 @@
|
|||||||
|
name: Nym Connect - mobile (Rust)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- "nym-connect/mobile/src-tauri/**"
|
||||||
|
- "nym-connect/mobile/src-tauri/Cargo.toml"
|
||||||
|
- "!nym-connect/mobile/src-tauri/gen/**"
|
||||||
|
- "clients/client-core/**"
|
||||||
|
- "clients/socks5/**"
|
||||||
|
- "common/**"
|
||||||
|
- "gateway/gateway-requests/**"
|
||||||
|
- "contracts/vesting/**"
|
||||||
|
- "nym-api/nym-api-requests/**"
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- "nym-connect/mobile/src-tauri/**"
|
||||||
|
- "nym-connect/mobile/src-tauri/Cargo.toml"
|
||||||
|
- "!nym-connect/mobile/src-tauri/gen/**"
|
||||||
|
- "clients/client-core/**"
|
||||||
|
- "clients/socks5/**"
|
||||||
|
- "common/**"
|
||||||
|
- "gateway/gateway-requests/**"
|
||||||
|
- "contracts/vesting/**"
|
||||||
|
- "nym-api/nym-api-requests/**"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
#runs-on: [self-hosted, custom-linux]
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
#env:
|
||||||
|
#RUSTC_WRAPPER: /home/ubuntu/.cargo/bin/sccache
|
||||||
|
#defaults:
|
||||||
|
#run:
|
||||||
|
#working-directory: nym-connect/mobile/src-tauri/
|
||||||
|
steps:
|
||||||
|
- name: Install Dependencies (Linux)
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get -y install \
|
||||||
|
libwebkit2gtk-4.1-dev \
|
||||||
|
build-essential \
|
||||||
|
curl \
|
||||||
|
wget \
|
||||||
|
libssl-dev \
|
||||||
|
libgtk-3-dev \
|
||||||
|
squashfs-tools \
|
||||||
|
libayatana-appindicator3-dev \
|
||||||
|
librsvg2-dev \
|
||||||
|
libsoup-3.0-dev \
|
||||||
|
libjavascriptcoregtk-4.1-dev
|
||||||
|
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install Rust toolchain
|
||||||
|
uses: dtolnay/rust-toolchain@master
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
components: clippy, rustfmt
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
run: cargo fmt --manifest-path nym-connect/mobile/src-tauri/Cargo.toml -- --check
|
||||||
|
|
||||||
|
- name: Build all binaries
|
||||||
|
run: cargo build --manifest-path nym-connect/mobile/src-tauri/Cargo.toml
|
||||||
|
|
||||||
|
- name: Run all tests
|
||||||
|
run: cargo test --manifest-path nym-connect/mobile/src-tauri/Cargo.toml
|
||||||
|
|
||||||
|
- name: Clippy
|
||||||
|
run: cargo clippy --manifest-path nym-connect/mobile/src-tauri/Cargo.toml --all-targets -- -D warnings
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
name: Nym Connect (rust)
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
paths-ignore:
|
|
||||||
- 'explorer/**'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: [ self-hosted, custom-linux ]
|
|
||||||
env:
|
|
||||||
RUSTC_WRAPPER: /home/ubuntu/.cargo/bin/sccache
|
|
||||||
steps:
|
|
||||||
- name: Install Dependencies (Linux)
|
|
||||||
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev squashfs-tools libayatana-appindicator3-dev
|
|
||||||
|
|
||||||
- name: Check out repository code
|
|
||||||
uses: actions/checkout@v2
|
|
||||||
|
|
||||||
- name: Install rust toolchain
|
|
||||||
uses: actions-rs/toolchain@v1
|
|
||||||
with:
|
|
||||||
profile: minimal
|
|
||||||
toolchain: stable
|
|
||||||
override: true
|
|
||||||
components: rustfmt, clippy
|
|
||||||
|
|
||||||
- name: Build all binaries
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --manifest-path nym-connect/Cargo.toml --workspace
|
|
||||||
|
|
||||||
- name: Run all tests
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --manifest-path nym-connect/Cargo.toml --workspace
|
|
||||||
|
|
||||||
- name: Check formatting
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: fmt
|
|
||||||
args: --manifest-path nym-connect/Cargo.toml --all -- --check
|
|
||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
|
||||||
name: Clippy checks
|
|
||||||
with:
|
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
args: --manifest-path nym-connect/Cargo.toml --workspace --all-features
|
|
||||||
|
|
||||||
- name: Run clippy
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: clippy
|
|
||||||
args: --manifest-path nym-connect/Cargo.toml --workspace --all-features -- -D warnings
|
|
||||||
@@ -6,17 +6,11 @@ on:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
runs-on: ubuntu-20.04
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-contracts-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
|
runs-on: [self-hosted, custom-runner-linux]
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-contracts-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-contracts-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-contracts-...')
|
|
||||||
|
|
||||||
- name: Install Rust stable
|
- name: Install Rust stable
|
||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
with:
|
with:
|
||||||
@@ -25,6 +19,9 @@ jobs:
|
|||||||
override: true
|
override: true
|
||||||
components: rustfmt, clippy
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Install wasm-opt
|
||||||
|
run: cargo install --version 0.112.0 wasm-opt
|
||||||
|
|
||||||
- name: Build release contracts
|
- name: Build release contracts
|
||||||
run: make wasm
|
run: make wasm
|
||||||
|
|
||||||
|
|||||||
@@ -2,11 +2,13 @@ name: Contracts
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'contracts/**'
|
||||||
|
- 'common/**'
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- 'explorer/**'
|
- 'contracts/**'
|
||||||
|
- 'common/**'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
matrix_prep:
|
matrix_prep:
|
||||||
@@ -28,6 +30,7 @@ jobs:
|
|||||||
continue-on-error: ${{ matrix.rust == 'nightly' }}
|
continue-on-error: ${{ matrix.rust == 'nightly' }}
|
||||||
needs: matrix_prep
|
needs: matrix_prep
|
||||||
strategy:
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
matrix: ${{fromJson(needs.matrix_prep.outputs.matrix)}}
|
matrix: ${{fromJson(needs.matrix_prep.outputs.matrix)}}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
@@ -61,4 +64,4 @@ jobs:
|
|||||||
if: ${{ matrix.rust != 'nightly' }}
|
if: ${{ matrix.rust != 'nightly' }}
|
||||||
with:
|
with:
|
||||||
command: clippy
|
command: clippy
|
||||||
args: --manifest-path contracts/Cargo.toml --workspace -- -D warnings
|
args: --manifest-path contracts/Cargo.toml --workspace --all-targets -- -D warnings
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
name: Greetings
|
||||||
|
|
||||||
|
on: [pull_request_target, issues]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
greeting:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/first-interaction@v1
|
||||||
|
with:
|
||||||
|
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
issue-message: 'Thank you for raising this issue'
|
||||||
|
pr-message: 'Thank you for making this first PR'
|
||||||
@@ -1,56 +0,0 @@
|
|||||||
name: CI for Network Explorer API
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
release:
|
|
||||||
types: [created]
|
|
||||||
|
|
||||||
env:
|
|
||||||
NETWORK: mainnet
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
publish-nym:
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
platform: [ubuntu-20.04]
|
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Install Dependencies (Linux)
|
|
||||||
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-explorer-api-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-explorer-api-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-explorer-api-...')
|
|
||||||
|
|
||||||
- name: Install Rust stable
|
|
||||||
uses: actions-rs/toolchain@v1
|
|
||||||
with:
|
|
||||||
toolchain: stable
|
|
||||||
|
|
||||||
- name: Build all explorer-api
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --manifest-path explorer-api/Cargo.toml --workspace --release
|
|
||||||
|
|
||||||
- name: Upload Artifact
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: my-artifact
|
|
||||||
path: |
|
|
||||||
target/release/explorer-api
|
|
||||||
retention-days: 30
|
|
||||||
|
|
||||||
- name: Upload to release based on tag name
|
|
||||||
uses: softprops/action-gh-release@v1
|
|
||||||
if: github.event_name == 'release'
|
|
||||||
with:
|
|
||||||
files: |
|
|
||||||
target/release/explorer-api
|
|
||||||
@@ -17,6 +17,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- name: Install rsync
|
- name: Install rsync
|
||||||
run: sudo apt-get install rsync
|
run: sudo apt-get install rsync
|
||||||
|
continue-on-error: true
|
||||||
- uses: rlespinasse/github-slug-action@v3.x
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
@@ -56,10 +57,10 @@ jobs:
|
|||||||
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/ne-sb-${{ env.GITHUB_REF_SLUG }}
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/ne-sb-${{ env.GITHUB_REF_SLUG }}
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
- name: Keybase - Node Install
|
- name: Matrix - Node Install
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: network-explorer
|
NYM_NOTIFICATION_KIND: network-explorer
|
||||||
NYM_PROJECT_NAME: "Network Explorer"
|
NYM_PROJECT_NAME: "Network Explorer"
|
||||||
@@ -68,11 +69,12 @@ jobs:
|
|||||||
NYM_CI_WWW_LOCATION_STORYBOOK: "ne-sb-${{ env.GITHUB_REF_SLUG }}"
|
NYM_CI_WWW_LOCATION_STORYBOOK: "ne-sb-${{ env.GITHUB_REF_SLUG }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-network-explorer"
|
|
||||||
IS_SUCCESS: "${{ job.status == 'success' }}"
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ jobs:
|
|||||||
matrix: ${{ steps.set-matrix.outputs.matrix }}
|
matrix: ${{ steps.set-matrix.outputs.matrix }}
|
||||||
steps:
|
steps:
|
||||||
# creates the matrix strategy from nightly_build_matrix_includes.json
|
# creates the matrix strategy from nightly_build_matrix_includes.json
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v3
|
||||||
- id: set-matrix
|
- id: set-matrix
|
||||||
uses: JoshuaTheMiller/conditional-build-matrix@main
|
uses: JoshuaTheMiller/conditional-build-matrix@main
|
||||||
with:
|
with:
|
||||||
@@ -25,10 +25,11 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
if: matrix.os == 'ubuntu-20.04'
|
if: matrix.os == 'ubuntu-20.04'
|
||||||
|
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Install rust toolchain
|
- name: Install rust toolchain
|
||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
@@ -38,15 +39,33 @@ jobs:
|
|||||||
override: true
|
override: true
|
||||||
components: rustfmt, clippy
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: fmt
|
||||||
|
args: --all -- --check
|
||||||
|
|
||||||
- name: Build all binaries
|
- name: Build all binaries
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: build
|
command: build
|
||||||
args: --workspace
|
args: --workspace
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
|
with:
|
||||||
|
command: clean
|
||||||
|
|
||||||
|
- name: Build all examples
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --examples
|
||||||
|
|
||||||
|
- name: Reclaim some disk space
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
@@ -56,9 +75,9 @@ jobs:
|
|||||||
command: test
|
command: test
|
||||||
args: --workspace
|
args: --workspace
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
@@ -67,25 +86,20 @@ jobs:
|
|||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: test
|
command: test
|
||||||
args: --workspace --all-features -- --ignored
|
args: --workspace -- --ignored
|
||||||
|
|
||||||
- name: Check formatting
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
command: fmt
|
|
||||||
args: --all -- --check
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
- uses: actions-rs/clippy-check@v1
|
||||||
name: Clippy checks
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
args: --all-features
|
args: --workspace
|
||||||
|
|
||||||
- name: Run clippy
|
- name: Run clippy
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -100,38 +114,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
# COCONUT stuff
|
|
||||||
- name: Build all binaries with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run all tests with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run clippy with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.rust != 'nightly' }}
|
|
||||||
with:
|
|
||||||
command: clippy
|
|
||||||
args: --workspace --all-targets --features=coconut -- -D warnings
|
|
||||||
|
|
||||||
# nym-wallet (the rust part)
|
# nym-wallet (the rust part)
|
||||||
- name: Build nym-wallet rust code
|
- name: Build nym-wallet rust code
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -160,17 +142,22 @@ jobs:
|
|||||||
|
|
||||||
notification:
|
notification:
|
||||||
needs: build
|
needs: build
|
||||||
runs-on: ubuntu-20.04
|
runs-on: custom-runner-linux
|
||||||
steps:
|
steps:
|
||||||
- name: Collect jobs status
|
- name: Collect jobs status
|
||||||
uses: technote-space/workflow-conclusion-action@v2
|
uses: technote-space/workflow-conclusion-action@v2
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v3
|
||||||
- name: Keybase - Node Install
|
- name: install npm
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Matrix - Node Install
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: nightly
|
NYM_NOTIFICATION_KIND: nightly
|
||||||
@@ -178,11 +165,12 @@ jobs:
|
|||||||
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-nightly"
|
|
||||||
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_NIGHTLY }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ jobs:
|
|||||||
run: git fetch --all
|
run: git fetch --all
|
||||||
- name: Set output variable to latest release branch
|
- name: Set output variable to latest release branch
|
||||||
id: step2
|
id: step2
|
||||||
run: echo "latest_release=$(git branch -r | grep -E 'release/v[0-9]+\.[0-9]+\.[0-9]+' | tail -n 1 | sed 's/ origin\///')" >> $GITHUB_OUTPUT
|
run: echo "latest_release=$(git branch -r | grep -E 'release/v[0-9]+\.[0-9]+\.[0-9]+$' | sort -V | tail -n 1 | sed 's/ origin\///')" >> $GITHUB_OUTPUT
|
||||||
build:
|
build:
|
||||||
needs: [get_release,matrix_prep]
|
needs: [get_release,matrix_prep]
|
||||||
strategy:
|
strategy:
|
||||||
@@ -38,6 +38,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
if: matrix.os == 'ubuntu-20.04'
|
if: matrix.os == 'ubuntu-20.04'
|
||||||
|
|
||||||
- name: Check out latest release branch
|
- name: Check out latest release branch
|
||||||
@@ -53,15 +54,33 @@ jobs:
|
|||||||
override: true
|
override: true
|
||||||
components: rustfmt, clippy
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: fmt
|
||||||
|
args: --all -- --check
|
||||||
|
|
||||||
- name: Build all binaries
|
- name: Build all binaries
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: build
|
command: build
|
||||||
args: --workspace
|
args: --workspace
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
|
with:
|
||||||
|
command: clean
|
||||||
|
|
||||||
|
- name: Build all examples
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --examples
|
||||||
|
|
||||||
|
- name: Reclaim some disk space
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
@@ -71,9 +90,9 @@ jobs:
|
|||||||
command: test
|
command: test
|
||||||
args: --workspace
|
args: --workspace
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
@@ -82,25 +101,20 @@ jobs:
|
|||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: test
|
command: test
|
||||||
args: --workspace --all-features -- --ignored
|
args: --workspace -- --ignored
|
||||||
|
|
||||||
- name: Check formatting
|
- name: Reclaim some disk space
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
command: fmt
|
|
||||||
args: --all -- --check
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
- uses: actions-rs/clippy-check@v1
|
||||||
name: Clippy checks
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
args: --all-features
|
args: --workspace
|
||||||
|
|
||||||
- name: Run clippy
|
- name: Run clippy
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -115,38 +129,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
# COCONUT stuff
|
|
||||||
- name: Build all binaries with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run all tests with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run clippy with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.rust != 'nightly' }}
|
|
||||||
with:
|
|
||||||
command: clippy
|
|
||||||
args: --workspace --all-targets --features=coconut -- -D warnings
|
|
||||||
|
|
||||||
# nym-wallet (the rust part)
|
# nym-wallet (the rust part)
|
||||||
- name: Build nym-wallet rust code
|
- name: Build nym-wallet rust code
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -175,29 +157,35 @@ jobs:
|
|||||||
|
|
||||||
notification:
|
notification:
|
||||||
needs: [build,get_release]
|
needs: [build,get_release]
|
||||||
runs-on: ubuntu-20.04
|
runs-on: custom-runner-linux
|
||||||
steps:
|
steps:
|
||||||
- name: Collect jobs status
|
- name: Collect jobs status
|
||||||
uses: technote-space/workflow-conclusion-action@v2
|
uses: technote-space/workflow-conclusion-action@v2
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
- name: Keybase - Node Install
|
- name: install npm
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Matrix - Node Install
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: nightly
|
NYM_NOTIFICATION_KIND: nightly
|
||||||
NYM_PROJECT_NAME: "Nym nightly build on latest release"
|
NYM_PROJECT_NAME: "Nym nightly build on latest release"
|
||||||
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "https://github.com/nymtech/nym/tree/${{needs.get_release.outputs.output1}}"
|
GIT_BRANCH_NAME: "${{needs.get_release.outputs.output1}}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-nightly-release"
|
|
||||||
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_NIGHTLY }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -28,7 +28,7 @@ jobs:
|
|||||||
run: git fetch --all
|
run: git fetch --all
|
||||||
- name: Set output variable to latest release branch
|
- name: Set output variable to latest release branch
|
||||||
id: step2
|
id: step2
|
||||||
run: echo "latest_release=$(git branch -r | grep -E 'release/v[0-9]+\.[0-9]+\.[0-9]+' | tail -n 2 | head -n 1 | sed 's/ origin\///')" >> $GITHUB_OUTPUT
|
run: echo "latest_release=$(git branch -r | grep -E 'release/v[0-9]+\.[0-9]+\.[0-9]+$' | sort -V | tail -n 2 | head -n 1 | sed 's/ origin\///')" >> $GITHUB_OUTPUT
|
||||||
build:
|
build:
|
||||||
needs: [get_release,matrix_prep]
|
needs: [get_release,matrix_prep]
|
||||||
strategy:
|
strategy:
|
||||||
@@ -38,6 +38,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
if: matrix.os == 'ubuntu-20.04'
|
if: matrix.os == 'ubuntu-20.04'
|
||||||
|
|
||||||
- name: Check out latest release branch
|
- name: Check out latest release branch
|
||||||
@@ -53,6 +54,12 @@ jobs:
|
|||||||
override: true
|
override: true
|
||||||
components: rustfmt, clippy
|
components: rustfmt, clippy
|
||||||
|
|
||||||
|
- name: Check formatting
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: fmt
|
||||||
|
args: --all -- --check
|
||||||
|
|
||||||
- name: Build all binaries
|
- name: Build all binaries
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
@@ -65,6 +72,18 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
|
- name: Build all examples
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
with:
|
||||||
|
command: build
|
||||||
|
args: --workspace --examples
|
||||||
|
|
||||||
|
- name: Reclaim some disk space (because Windows is being annoying)
|
||||||
|
uses: actions-rs/cargo@v1
|
||||||
|
if: ${{ matrix.os == 'windows-latest' }}
|
||||||
|
with:
|
||||||
|
command: clean
|
||||||
|
|
||||||
- name: Run all tests
|
- name: Run all tests
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
@@ -73,7 +92,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space (because Windows is being annoying)
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
if: ${{ matrix.os == 'windows-latest' || matrix.os == 'ubuntu-20.04' }}
|
||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
@@ -82,13 +101,7 @@ jobs:
|
|||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: test
|
command: test
|
||||||
args: --workspace --all-features -- --ignored
|
args: --workspace -- --ignored
|
||||||
|
|
||||||
- name: Check formatting
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: fmt
|
|
||||||
args: --all -- --check
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
- name: Reclaim some disk space (because Windows is being annoying)
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -98,9 +111,10 @@ jobs:
|
|||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
- uses: actions-rs/clippy-check@v1
|
||||||
name: Clippy checks
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
args: --all-features
|
args: --workspace
|
||||||
|
|
||||||
- name: Run clippy
|
- name: Run clippy
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -115,38 +129,6 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
command: clean
|
command: clean
|
||||||
|
|
||||||
# COCONUT stuff
|
|
||||||
- name: Build all binaries with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run all tests with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --workspace --features=coconut
|
|
||||||
|
|
||||||
- name: Reclaim some disk space (because Windows is being annoying)
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.os == 'windows-latest' }}
|
|
||||||
with:
|
|
||||||
command: clean
|
|
||||||
|
|
||||||
- name: Run clippy with coconut enabled
|
|
||||||
uses: actions-rs/cargo@v1
|
|
||||||
if: ${{ matrix.rust != 'nightly' }}
|
|
||||||
with:
|
|
||||||
command: clippy
|
|
||||||
args: --workspace --all-targets --features=coconut -- -D warnings
|
|
||||||
|
|
||||||
# nym-wallet (the rust part)
|
# nym-wallet (the rust part)
|
||||||
- name: Build nym-wallet rust code
|
- name: Build nym-wallet rust code
|
||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
@@ -175,29 +157,35 @@ jobs:
|
|||||||
|
|
||||||
notification:
|
notification:
|
||||||
needs: [build,get_release]
|
needs: [build,get_release]
|
||||||
runs-on: ubuntu-20.04
|
runs-on: custom-runner-linux
|
||||||
steps:
|
steps:
|
||||||
- name: Collect jobs status
|
- name: Collect jobs status
|
||||||
uses: technote-space/workflow-conclusion-action@v2
|
uses: technote-space/workflow-conclusion-action@v2
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
- name: Keybase - Node Install
|
- name: install npm
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Matrix - Node Install
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
if: env.WORKFLOW_CONCLUSION == 'failure'
|
if: env.WORKFLOW_CONCLUSION == 'failure'
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: nightly
|
NYM_NOTIFICATION_KIND: nightly
|
||||||
NYM_PROJECT_NAME: "Nym nightly build on latest release"
|
NYM_PROJECT_NAME: "Nym nightly build on latest release"
|
||||||
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "https://github.com/nymtech/nym/tree/${{needs.get_release.outputs.output1}}"
|
GIT_BRANCH_NAME: "${{needs.get_release.outputs.output1}}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-nightly-release"
|
|
||||||
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
IS_SUCCESS: "${{ env.WORKFLOW_CONCLUSION == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM_NIGHTLY }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -1,50 +0,0 @@
|
|||||||
name: Publish Nym CLI binaries
|
|
||||||
|
|
||||||
on:
|
|
||||||
workflow_dispatch:
|
|
||||||
release:
|
|
||||||
types: [created]
|
|
||||||
|
|
||||||
env:
|
|
||||||
NETWORK: mainnet
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
publish-nym-cli:
|
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
platform: [ubuntu-20.04, windows-latest, macos-latest]
|
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-cli-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-cli-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-cli-...')
|
|
||||||
|
|
||||||
- name: Install Rust stable
|
|
||||||
uses: actions-rs/toolchain@v1
|
|
||||||
with:
|
|
||||||
toolchain: stable
|
|
||||||
|
|
||||||
- name: Build binary
|
|
||||||
run: make build-nym-cli
|
|
||||||
|
|
||||||
- name: Upload Artifact
|
|
||||||
uses: actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: nym-cli-${{ matrix.platform }}
|
|
||||||
path: |
|
|
||||||
target/release/nym-cli*
|
|
||||||
retention-days: 30
|
|
||||||
|
|
||||||
- name: Upload to release based on tag name
|
|
||||||
uses: softprops/action-gh-release@v1
|
|
||||||
if: github.event_name == 'release'
|
|
||||||
with:
|
|
||||||
files: |
|
|
||||||
target/release/nym-cli
|
|
||||||
@@ -1,4 +1,4 @@
|
|||||||
name: Publish Nym Connect (MacOS)
|
name: Publish Nym Connect - desktop (MacOS)
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
release:
|
release:
|
||||||
@@ -6,10 +6,11 @@ on:
|
|||||||
|
|
||||||
defaults:
|
defaults:
|
||||||
run:
|
run:
|
||||||
working-directory: nym-connect
|
working-directory: nym-connect/desktop
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-connect-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@@ -19,13 +20,6 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-connect-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-connect-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-connect-...')
|
|
||||||
|
|
||||||
- name: Node v16
|
- name: Node v16
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
@@ -79,7 +73,7 @@ jobs:
|
|||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: nym-connect_1.0.0_x64.dmg
|
name: nym-connect_1.0.0_x64.dmg
|
||||||
path: nym-connect/target/release/bundle/dmg/nym-connect_1.0.0_x64.dmg
|
path: nym-connect/desktop/target/release/bundle/dmg/nym-connect_1.0.0_x64.dmg
|
||||||
retention-days: 30
|
retention-days: 30
|
||||||
|
|
||||||
- name: Clean up keychain
|
- name: Clean up keychain
|
||||||
@@ -92,5 +86,5 @@ jobs:
|
|||||||
if: github.event_name == 'release'
|
if: github.event_name == 'release'
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
nym-connect/target/release/bundle/dmg/*.dmg
|
nym-connect/desktop/target/release/bundle/dmg/*.dmg
|
||||||
nym-connect/target/release/bundle/macos/*.app.tar.gz*
|
nym-connect/desktop/target/release/bundle/macos/*.app.tar.gz*
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
name: Publish Nym Connect (Ubuntu)
|
name: Publish Nym Connect - desktop (Ubuntu)
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
release:
|
release:
|
||||||
@@ -6,14 +6,15 @@ on:
|
|||||||
|
|
||||||
defaults:
|
defaults:
|
||||||
run:
|
run:
|
||||||
working-directory: nym-connect
|
working-directory: nym-connect/desktop
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-connect-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
platform: [ubuntu-20.04]
|
platform: [custom-runner-linux]
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
runs-on: ${{ matrix.platform }}
|
||||||
steps:
|
steps:
|
||||||
@@ -23,17 +24,13 @@ jobs:
|
|||||||
run: >
|
run: >
|
||||||
sudo apt-get update &&
|
sudo apt-get update &&
|
||||||
sudo apt-get install -y webkit2gtk-4.0 libayatana-appindicator3-dev
|
sudo apt-get install -y webkit2gtk-4.0 libayatana-appindicator3-dev
|
||||||
- name: Check the release tag starts with `nym-connect-`
|
continue-on-error: true
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-connect-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-connect-...')
|
|
||||||
|
|
||||||
- name: Node v16
|
- name: Node v16
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: 16
|
node-version: 16
|
||||||
|
|
||||||
- name: Install Rust stable
|
- name: Install Rust stable
|
||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
with:
|
with:
|
||||||
@@ -56,7 +53,7 @@ jobs:
|
|||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: nym-connect.AppImage.tar.gz
|
name: nym-connect.AppImage.tar.gz
|
||||||
path: nym-connect/target/release/bundle/appimage/nym-connect_1.0.0_amd64.AppImage
|
path: nym-connect/desktop/target/release/bundle/appimage/nym-connect_1.0.0_amd64.AppImage
|
||||||
retention-days: 30
|
retention-days: 30
|
||||||
|
|
||||||
- name: Upload to release based on tag name
|
- name: Upload to release based on tag name
|
||||||
@@ -64,5 +61,5 @@ jobs:
|
|||||||
if: github.event_name == 'release'
|
if: github.event_name == 'release'
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
nym-connect/target/release/bundle/appimage/*.AppImage
|
nym-connect/desktop/target/release/bundle/appimage/*.AppImage
|
||||||
nym-connect/target/release/bundle/appimage/*.AppImage.tar.gz*
|
nym-connect/desktop/target/release/bundle/appimage/*.AppImage.tar.gz*
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
name: Publish Nym Connect (Windows 10)
|
name: Publish Nym Connect - desktop (Windows 10)
|
||||||
on:
|
on:
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
release:
|
release:
|
||||||
@@ -6,10 +6,11 @@ on:
|
|||||||
|
|
||||||
defaults:
|
defaults:
|
||||||
run:
|
run:
|
||||||
working-directory: nym-connect
|
working-directory: nym-connect/desktop
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-connect-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@@ -27,13 +28,6 @@ jobs:
|
|||||||
|
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-connect-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-connect-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-connect-...')
|
|
||||||
|
|
||||||
- name: Import signing certificate
|
- name: Import signing certificate
|
||||||
env:
|
env:
|
||||||
WINDOWS_CERTIFICATE: ${{ secrets.WINDOWS_CERTIFICATE }}
|
WINDOWS_CERTIFICATE: ${{ secrets.WINDOWS_CERTIFICATE }}
|
||||||
@@ -62,7 +56,7 @@ jobs:
|
|||||||
encodedString: ${{ secrets.WALLET_ADMIN_ADDRESS }}
|
encodedString: ${{ secrets.WALLET_ADMIN_ADDRESS }}
|
||||||
|
|
||||||
- name: Install app dependencies
|
- name: Install app dependencies
|
||||||
run: yarn
|
run: yarn --network-timeout 100000
|
||||||
|
|
||||||
- name: Build and sign it
|
- name: Build and sign it
|
||||||
env:
|
env:
|
||||||
@@ -78,7 +72,7 @@ jobs:
|
|||||||
uses: actions/upload-artifact@v3
|
uses: actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: nym-connect_1.0.0_x64_en-US.msi
|
name: nym-connect_1.0.0_x64_en-US.msi
|
||||||
path: nym-connect/target/release/bundle/msi/nym-connect_1.0.0_x64_en-US.msi
|
path: nym-connect/desktop/target/release/bundle/msi/nym-connect_1.0.0_x64_en-US.msi
|
||||||
retention-days: 30
|
retention-days: 30
|
||||||
|
|
||||||
- name: Upload to release based on tag name
|
- name: Upload to release based on tag name
|
||||||
@@ -86,5 +80,5 @@ jobs:
|
|||||||
if: github.event_name == 'release'
|
if: github.event_name == 'release'
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
nym-connect/target/release/bundle/msi/*.msi
|
nym-connect/desktop/target/release/bundle/msi/*.msi
|
||||||
nym-connect/target/release/bundle/msi/*.msi.zip*
|
nym-connect/desktop/target/release/bundle/msi/*.msi.zip*
|
||||||
|
|||||||
@@ -16,10 +16,11 @@ env:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-nym:
|
publish-nym:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-binaries-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
platform: [ubuntu-20.04]
|
platform: [custom-runner-linux]
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
runs-on: ${{ matrix.platform }}
|
||||||
steps:
|
steps:
|
||||||
@@ -27,13 +28,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev libudev-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
- name: Check the release tag starts with `nym-binaries-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-binaries-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-binaries-...')
|
|
||||||
|
|
||||||
- name: Sets env vars for tokio if set in manual dispatch inputs
|
- name: Sets env vars for tokio if set in manual dispatch inputs
|
||||||
run: |
|
run: |
|
||||||
@@ -56,11 +51,12 @@ jobs:
|
|||||||
with:
|
with:
|
||||||
name: my-artifact
|
name: my-artifact
|
||||||
path: |
|
path: |
|
||||||
|
target/release/explorer-api
|
||||||
target/release/nym-client
|
target/release/nym-client
|
||||||
target/release/nym-gateway
|
target/release/nym-gateway
|
||||||
target/release/nym-mixnode
|
target/release/nym-mixnode
|
||||||
target/release/nym-socks5-client
|
target/release/nym-socks5-client
|
||||||
target/release/nym-validator-api
|
target/release/nym-api
|
||||||
target/release/nym-network-requester
|
target/release/nym-network-requester
|
||||||
target/release/nym-network-statistics
|
target/release/nym-network-statistics
|
||||||
target/release/nym-cli
|
target/release/nym-cli
|
||||||
@@ -71,11 +67,12 @@ jobs:
|
|||||||
if: github.event_name == 'release'
|
if: github.event_name == 'release'
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
|
target/release/explorer-api
|
||||||
target/release/nym-client
|
target/release/nym-client
|
||||||
target/release/nym-gateway
|
target/release/nym-gateway
|
||||||
target/release/nym-mixnode
|
target/release/nym-mixnode
|
||||||
target/release/nym-socks5-client
|
target/release/nym-socks5-client
|
||||||
target/release/nym-validator-api
|
target/release/nym-api
|
||||||
target/release/nym-network-requester
|
target/release/nym-network-requester
|
||||||
target/release/nym-network-statistics
|
target/release/nym-network-statistics
|
||||||
target/release/nym-cli
|
target/release/nym-cli
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ defaults:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-wallet-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@@ -19,13 +20,6 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-wallet-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-wallet-') == false && github.event_name != 'workflow_dispatch'
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-wallet-...')
|
|
||||||
|
|
||||||
- name: Node v16
|
- name: Node v16
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
|
|||||||
@@ -9,10 +9,11 @@ defaults:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-wallet-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
platform: [ubuntu-20.04]
|
platform: [custom-runner-linux]
|
||||||
|
|
||||||
runs-on: ${{ matrix.platform }}
|
runs-on: ${{ matrix.platform }}
|
||||||
steps:
|
steps:
|
||||||
@@ -22,17 +23,13 @@ jobs:
|
|||||||
run: >
|
run: >
|
||||||
sudo apt-get update &&
|
sudo apt-get update &&
|
||||||
sudo apt-get install -y webkit2gtk-4.0
|
sudo apt-get install -y webkit2gtk-4.0
|
||||||
- name: Check the release tag starts with `nym-wallet-`
|
continue-on-error: true
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-wallet-') == false
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-wallet-...')
|
|
||||||
|
|
||||||
- name: Node v16
|
- name: Node v16
|
||||||
uses: actions/setup-node@v3
|
uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
node-version: 16
|
node-version: 16
|
||||||
|
|
||||||
- name: Install Rust stable
|
- name: Install Rust stable
|
||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
with:
|
with:
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
name: Publish Nym Wallet (Windows 10)
|
name: Publish Nym Wallet (Windows 10)
|
||||||
on:
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
release:
|
release:
|
||||||
types: [created]
|
types: [created]
|
||||||
|
|
||||||
@@ -9,6 +10,7 @@ defaults:
|
|||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
publish-tauri:
|
publish-tauri:
|
||||||
|
if: ${{ (startsWith(github.ref, 'refs/tags/nym-wallet-') && github.event_name == 'release') || github.event_name == 'workflow_dispatch' }}
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@@ -26,13 +28,6 @@ jobs:
|
|||||||
|
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
- name: Check the release tag starts with `nym-wallet-`
|
|
||||||
if: startsWith(github.ref, 'refs/tags/nym-wallet-') == false
|
|
||||||
uses: actions/github-script@v3
|
|
||||||
with:
|
|
||||||
script: |
|
|
||||||
core.setFailed('Release tag did not start with nym-wallet-...')
|
|
||||||
|
|
||||||
- name: Import signing certificate
|
- name: Import signing certificate
|
||||||
env:
|
env:
|
||||||
WINDOWS_CERTIFICATE: ${{ secrets.WINDOWS_CERTIFICATE }}
|
WINDOWS_CERTIFICATE: ${{ secrets.WINDOWS_CERTIFICATE }}
|
||||||
@@ -61,7 +56,7 @@ jobs:
|
|||||||
encodedString: ${{ secrets.WALLET_ADMIN_ADDRESS }}
|
encodedString: ${{ secrets.WALLET_ADMIN_ADDRESS }}
|
||||||
|
|
||||||
- name: Install app dependencies
|
- name: Install app dependencies
|
||||||
run: yarn
|
run: yarn --network-timeout 100000
|
||||||
|
|
||||||
- name: Build and sign it
|
- name: Build and sign it
|
||||||
env:
|
env:
|
||||||
@@ -73,8 +68,16 @@ jobs:
|
|||||||
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }}
|
TAURI_KEY_PASSWORD: ${{ secrets.TAURI_KEY_PASSWORD }}
|
||||||
run: yarn build
|
run: yarn build
|
||||||
|
|
||||||
|
- name: Upload Artifact
|
||||||
|
uses: actions/upload-artifact@v3
|
||||||
|
with:
|
||||||
|
name: nym-wallet_1.0.0_x64_en-US.msi
|
||||||
|
path: nym-wallet/target/release/bundle/msi/nym-wallet_1.*.msi
|
||||||
|
retention-days: 30
|
||||||
|
|
||||||
- name: Upload to release based on tag name
|
- name: Upload to release based on tag name
|
||||||
uses: softprops/action-gh-release@v1
|
uses: softprops/action-gh-release@v1
|
||||||
|
if: github.event_name == 'release'
|
||||||
with:
|
with:
|
||||||
files: |
|
files: |
|
||||||
nym-wallet/target/release/bundle/msi/*.msi
|
nym-wallet/target/release/bundle/msi/*.msi
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- name: Install rsync
|
- name: Install rsync
|
||||||
run: sudo apt-get install rsync
|
run: sudo apt-get install rsync
|
||||||
|
continue-on-error: true
|
||||||
- uses: rlespinasse/github-slug-action@v3.x
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
with:
|
with:
|
||||||
@@ -34,10 +35,10 @@ jobs:
|
|||||||
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
REMOTE_USER: ${{ secrets.CI_WWW_REMOTE_USER }}
|
||||||
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/wallet-${{ env.GITHUB_REF_SLUG }}
|
TARGET: ${{ secrets.CI_WWW_REMOTE_TARGET }}/wallet-${{ env.GITHUB_REF_SLUG }}
|
||||||
EXCLUDE: "/dist/, /node_modules/"
|
EXCLUDE: "/dist/, /node_modules/"
|
||||||
- name: Keybase - Node Install
|
- name: Matrix - Node Install
|
||||||
run: npm install
|
run: npm install
|
||||||
working-directory: .github/workflows/support-files
|
working-directory: .github/workflows/support-files
|
||||||
- name: Keybase - Send Notification
|
- name: Matrix - Send Notification
|
||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: nym-wallet
|
NYM_NOTIFICATION_KIND: nym-wallet
|
||||||
NYM_PROJECT_NAME: "nym-wallet"
|
NYM_PROJECT_NAME: "nym-wallet"
|
||||||
@@ -45,11 +46,12 @@ jobs:
|
|||||||
NYM_CI_WWW_LOCATION: "wallet-${{ env.GITHUB_REF_SLUG }}"
|
NYM_CI_WWW_LOCATION: "wallet-${{ env.GITHUB_REF_SLUG }}"
|
||||||
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
|
||||||
KEYBASE_NYM_CHANNEL: "ci-nym-wallet"
|
|
||||||
IS_SUCCESS: "${{ job.status == 'success' }}"
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
args: .github/workflows/support-files/notifications/entry_point.sh
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
|
|||||||
@@ -26,6 +26,7 @@ jobs:
|
|||||||
libappindicator3-dev
|
libappindicator3-dev
|
||||||
webkit2gtk-driver
|
webkit2gtk-driver
|
||||||
xvfb
|
xvfb
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
- name: Install minimal stable
|
- name: Install minimal stable
|
||||||
uses: actions-rs/toolchain@v1
|
uses: actions-rs/toolchain@v1
|
||||||
|
|||||||
@@ -0,0 +1,36 @@
|
|||||||
|
name: CI for Nym API Tests
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- "nym-api/**"
|
||||||
|
|
||||||
|
defaults:
|
||||||
|
run:
|
||||||
|
working-directory: nym-api/tests
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
name: nym-api tests
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
|
||||||
|
- name: Install npm
|
||||||
|
run: npm install
|
||||||
|
|
||||||
|
- name: Node v18
|
||||||
|
uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 18.1.0
|
||||||
|
|
||||||
|
- name: Install yarn
|
||||||
|
run: yarn install
|
||||||
|
|
||||||
|
- name: Run yarn
|
||||||
|
run: yarn
|
||||||
|
|
||||||
|
- name: Run tests
|
||||||
|
run: yarn test:qa
|
||||||
|
working-directory: nym-api/tests
|
||||||
@@ -1,6 +1,9 @@
|
|||||||
KEYBASE_NYM_CHANNEL=
|
MATRIX_SERVER=
|
||||||
KEYBASE_NYMBOT_USERNAME=
|
MATRIX_ROOM=
|
||||||
KEYBASE_NYMBOT_PAPERKEY=
|
MATRIX_ROOM_OF_SHAME=
|
||||||
|
MATRIX_USER_ID=
|
||||||
|
MATRIX_TOKEN=
|
||||||
|
MATRIX_DEVICE_ID=
|
||||||
|
|
||||||
NYM_NOTIFICATION_KIND=nightly
|
NYM_NOTIFICATION_KIND=nightly
|
||||||
NYM_PROJECT_NAME=Nightly Build
|
NYM_PROJECT_NAME=Nightly Build
|
||||||
@@ -32,4 +35,4 @@ NYM_CI_WWW_BASE=example.com
|
|||||||
# Nightly builds
|
# Nightly builds
|
||||||
WORKFLOW_CONCLUSION=success
|
WORKFLOW_CONCLUSION=success
|
||||||
|
|
||||||
SHOW_DEBUG=true
|
SHOW_DEBUG=true
|
||||||
|
|||||||
@@ -2,4 +2,6 @@ node_modules
|
|||||||
.idea
|
.idea
|
||||||
|
|
||||||
# don't commit the lock file to avoid cross-platform issues
|
# don't commit the lock file to avoid cross-platform issues
|
||||||
package-lock.json
|
package-lock.json
|
||||||
|
|
||||||
|
scratch
|
||||||
@@ -4,7 +4,7 @@ This is a collection of scripts and files to support GitHub Actions.
|
|||||||
|
|
||||||
## Sending Notifications
|
## Sending Notifications
|
||||||
|
|
||||||
These scripts send CI notifications to Keybase by creating messages from templates and env vars passed from GitHub Actions.
|
These scripts send CI notifications to Matrix by creating messages from templates and env vars passed from GitHub Actions.
|
||||||
|
|
||||||
### Adding notifications to a GitHub Action
|
### Adding notifications to a GitHub Action
|
||||||
|
|
||||||
@@ -19,10 +19,11 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
NYM_NOTIFICATION_KIND: "my-component"
|
NYM_NOTIFICATION_KIND: "my-component"
|
||||||
GIT_BRANCH: "${GITHUB_REF##*/}"
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
KEYBASE_NYMBOT_USERNAME: "${{ secrets.KEYBASE_NYMBOT_USERNAME }}"
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
KEYBASE_NYMBOT_PAPERKEY: "${{ secrets.KEYBASE_NYMBOT_PAPERKEY }}"
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
KEYBASE_NYMBOT_TEAM: "${{ secrets.KEYBASE_NYMBOT_TEAM }}"
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
KEYBASE_NYM_CHANNEL: "ci-network-explorer"
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
IS_SUCCESS: "${{ job.status == 'success' }}"
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
uses: docker://keybaseio/client:stable-node
|
uses: docker://keybaseio/client:stable-node
|
||||||
with:
|
with:
|
||||||
@@ -34,8 +35,8 @@ Notifications are run by adding the snippet above to a GitHub Action, and:
|
|||||||
1. Installing node packages needed at run time
|
1. Installing node packages needed at run time
|
||||||
2. Set the env vars as required:
|
2. Set the env vars as required:
|
||||||
- `NYM_NOTIFICATION_KIND` matches the directory in `.github/workflows/support-files/${NYM_NOTIFICATION_KIND}` to provide the templates and extra scripting in `index.js`
|
- `NYM_NOTIFICATION_KIND` matches the directory in `.github/workflows/support-files/${NYM_NOTIFICATION_KIND}` to provide the templates and extra scripting in `index.js`
|
||||||
- Keybase credentials, channel and other env vars for the status of the build and repo
|
- Matrix credentials, room and other env vars for the status of the build and repo
|
||||||
3. Replacing the default entry point shell script on the `keybaseio/client:stable-node` docker image to run `.github/workflows/support-files/notifications/entry_point.sh`
|
3. Replacing the default entry point shell script on the `keybaseio/client:stable-node` docker image to run `.github/workflows/support-files/notifications/entry_point.sh`
|
||||||
|
|
||||||
### Running locally
|
### Running locally
|
||||||
|
|
||||||
@@ -43,7 +44,7 @@ You will need:
|
|||||||
- Node 16 LTS
|
- Node 16 LTS
|
||||||
- npm
|
- npm
|
||||||
|
|
||||||
Copy `.github/workflows/support-files/.env.example` to `.github/workflows/support-files/.env` and valid Keybase credentials.
|
Copy `.github/workflows/support-files/.env.example` to `.github/workflows/support-files/.env` and valid Matrix credentials.
|
||||||
|
|
||||||
Then run `npm install` to get dependencies.
|
Then run `npm install` to get dependencies.
|
||||||
|
|
||||||
@@ -55,4 +56,4 @@ npm install
|
|||||||
cp .env.example .env
|
cp .env.example .env
|
||||||
vi .env
|
vi .env
|
||||||
npm run dev
|
npm run dev
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -0,0 +1,29 @@
|
|||||||
|
const Handlebars = require('handlebars');
|
||||||
|
const fs = require('fs');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
async function addToContextAndValidate(context) {
|
||||||
|
if (!context.env.NYM_CI_WWW_LOCATION) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_LOCATION is set');
|
||||||
|
}
|
||||||
|
if (!context.env.NYM_CI_WWW_BASE) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_BASE is set');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getMessageBody(context) {
|
||||||
|
const source = fs
|
||||||
|
.readFileSync(
|
||||||
|
context.env.IS_SUCCESS === 'true'
|
||||||
|
? path.resolve(__dirname, 'templates', 'success')
|
||||||
|
: path.resolve(__dirname, 'templates', 'failure'),
|
||||||
|
)
|
||||||
|
.toString();
|
||||||
|
const template = Handlebars.compile(source);
|
||||||
|
return template(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
addToContextAndValidate,
|
||||||
|
getMessageBody,
|
||||||
|
};
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_BASE }}/developers/
|
||||||
|
>
|
||||||
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
const Handlebars = require('handlebars');
|
||||||
|
const fs = require('fs');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
async function addToContextAndValidate(context) {
|
||||||
|
if (!context.env.NYM_CI_WWW_LOCATION) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_LOCATION is set');
|
||||||
|
}
|
||||||
|
if (!context.env.NYM_CI_WWW_BASE) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_BASE is set');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getMessageBody(context) {
|
||||||
|
const source = fs
|
||||||
|
.readFileSync(
|
||||||
|
context.env.IS_SUCCESS === 'true'
|
||||||
|
? path.resolve(__dirname, 'templates', 'success')
|
||||||
|
: path.resolve(__dirname, 'templates', 'failure'),
|
||||||
|
)
|
||||||
|
.toString();
|
||||||
|
const template = Handlebars.compile(source);
|
||||||
|
return template(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
addToContextAndValidate,
|
||||||
|
getMessageBody,
|
||||||
|
};
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
> 🔴 **FAILURE** :cry:
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
|
||||||
|
Commit message:
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_BASE }}/docs/
|
||||||
|
>
|
||||||
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
const Handlebars = require('handlebars');
|
||||||
|
const fs = require('fs');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
async function addToContextAndValidate(context) {
|
||||||
|
if (!context.env.NYM_CI_WWW_LOCATION) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_LOCATION is set');
|
||||||
|
}
|
||||||
|
if (!context.env.NYM_CI_WWW_BASE) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_BASE is set');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getMessageBody(context) {
|
||||||
|
const source = fs
|
||||||
|
.readFileSync(
|
||||||
|
context.env.IS_SUCCESS === 'true'
|
||||||
|
? path.resolve(__dirname, 'templates', 'success')
|
||||||
|
: path.resolve(__dirname, 'templates', 'failure'),
|
||||||
|
)
|
||||||
|
.toString();
|
||||||
|
const template = Handlebars.compile(source);
|
||||||
|
return template(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
addToContextAndValidate,
|
||||||
|
getMessageBody,
|
||||||
|
};
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
||||||
|
>
|
||||||
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,29 @@
|
|||||||
|
const Handlebars = require('handlebars');
|
||||||
|
const fs = require('fs');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
async function addToContextAndValidate(context) {
|
||||||
|
if (!context.env.NYM_CI_WWW_LOCATION) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_LOCATION is set');
|
||||||
|
}
|
||||||
|
if (!context.env.NYM_CI_WWW_BASE) {
|
||||||
|
throw new Error('Please ensure the env var NYM_CI_WWW_BASE is set');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function getMessageBody(context) {
|
||||||
|
const source = fs
|
||||||
|
.readFileSync(
|
||||||
|
context.env.IS_SUCCESS === 'true'
|
||||||
|
? path.resolve(__dirname, 'templates', 'success')
|
||||||
|
: path.resolve(__dirname, 'templates', 'failure'),
|
||||||
|
)
|
||||||
|
.toString();
|
||||||
|
const template = Handlebars.compile(source);
|
||||||
|
return template(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
addToContextAndValidate,
|
||||||
|
getMessageBody,
|
||||||
|
};
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
||||||
|
>
|
||||||
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
|
|
||||||
|
```
|
||||||
|
{{ env.GIT_COMMIT_MESSAGE }}
|
||||||
|
```
|
||||||
+62
@@ -0,0 +1,62 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
#
|
||||||
|
# Basic usage:
|
||||||
|
# ./git-merge-check origin/develop origin/release/v1.1.9
|
||||||
|
#
|
||||||
|
|
||||||
|
set -x
|
||||||
|
|
||||||
|
set -o nounset
|
||||||
|
set -o pipefail
|
||||||
|
|
||||||
|
# Start from branch ...
|
||||||
|
branch1=$1
|
||||||
|
|
||||||
|
# ... and try to merge in
|
||||||
|
branch2=$2
|
||||||
|
|
||||||
|
echo "Checking if $branch2 merges without conflicts into $branch1..."
|
||||||
|
|
||||||
|
git checkout -q $branch1 || exit 1
|
||||||
|
|
||||||
|
# There are two options here as far as I see on what we should check for. Either
|
||||||
|
#
|
||||||
|
# (A) check for CONFLICT in any file except whitelist (such as .lock files)
|
||||||
|
# (B) check for "Automatic merge failed"
|
||||||
|
#
|
||||||
|
# Both of these options have drawbacks.
|
||||||
|
#
|
||||||
|
# The first (A) has the problem in that maybe we don't want to fail if the
|
||||||
|
# changes can be automatically merged (duh), but at least we are not pestered
|
||||||
|
# about constant lock file changes.
|
||||||
|
# The second (B) has the problem that it's difficult to filter out automatic
|
||||||
|
# merge fails for files we don't care about (.lock files).
|
||||||
|
#
|
||||||
|
# The ideal solution would be to check for automatic merge fails for files
|
||||||
|
# except those on a whitelist (e.g. lock files).
|
||||||
|
|
||||||
|
# For now I choose to use (B) here, because I hope it might be less noisy
|
||||||
|
|
||||||
|
# Alternative A
|
||||||
|
#output=$(git merge --no-commit --no-ff $branch2 | grep -v .lock)
|
||||||
|
#merge_failed=$(echo $output | grep -v "CONFLICT")
|
||||||
|
#return_code=$?
|
||||||
|
|
||||||
|
# Alternative B
|
||||||
|
output=$(git merge --no-commit --no-ff $branch2)
|
||||||
|
merge_failed=$(echo $output | grep -v "Automatic merge failed")
|
||||||
|
return_code=$?
|
||||||
|
|
||||||
|
# Restore
|
||||||
|
|
||||||
|
git merge --abort
|
||||||
|
git checkout -q -
|
||||||
|
|
||||||
|
if [ $return_code -eq 0 ]; then
|
||||||
|
echo "Merge check success"
|
||||||
|
else
|
||||||
|
echo "Merge check failed"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit $return_code
|
||||||
@@ -1,9 +1,14 @@
|
|||||||
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> 🔴 **FAILURE** :cry:
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message:
|
Commit message:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,10 +1,16 @@
|
|||||||
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View output:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
||||||
|
>
|
||||||
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION_STORYBOOK }}.{{ env.NYM_CI_WWW_BASE }}
|
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION_STORYBOOK }}.{{ env.NYM_CI_WWW_BASE }}
|
||||||
|
>
|
||||||
> ✅ **SUCCESS**
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -151,7 +151,7 @@ async function getMessageBody(context) {
|
|||||||
return `${icon} ${job.conclusion}: ${job.name} - ${job.html_url}`;
|
return `${icon} ${job.conclusion}: ${job.name} - ${job.html_url}`;
|
||||||
})
|
})
|
||||||
// and join with newlines for display in the template
|
// and join with newlines for display in the template
|
||||||
.join('\n');
|
.join('\n\n');
|
||||||
|
|
||||||
return template({ ...context, jobResults });
|
return template({ ...context, jobResults });
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,15 @@
|
|||||||
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> 🔴 **FAILURE** :cry:
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
> `when` {{ timestamp }}
|
> `when` {{ timestamp }}
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
{{ jobResults }}
|
{{ jobResults }}
|
||||||
|
|||||||
@@ -1,9 +1,15 @@
|
|||||||
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> ✅ **SUCCESS**
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
> `when` {{ timestamp }}
|
> `when` {{ timestamp }}
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
{{ jobResults }}
|
{{ jobResults }}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
require('dotenv').config();
|
require('dotenv').config();
|
||||||
|
|
||||||
const Bot = require('keybase-bot');
|
const { sendMatrixMessage } = require('./send_message_to_matrix');
|
||||||
|
|
||||||
let context = {
|
let context = {
|
||||||
kinds: ['nym-wallet', 'ts-packages', 'network-explorer', 'nightly', 'nym-connect','security'],
|
kinds: ['nym-wallet', 'ts-packages', 'network-explorer', 'nightly', 'nym-connect','security','ci-docs','cd-docs','ci-dev','cd-dev'],
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -23,20 +23,27 @@ function validateContext() {
|
|||||||
'Please set env var NYM_PROJECT_NAME with the project name for displaying in notification messages',
|
'Please set env var NYM_PROJECT_NAME with the project name for displaying in notification messages',
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
if (!context.env.KEYBASE_NYM_CHANNEL) {
|
if (context.env.MATRIX_ROOM) {
|
||||||
throw new Error(
|
if (!context.env.MATRIX_SERVER) {
|
||||||
'Please set env var KEYBASE_NYM_CHANNEL with the channel name for the notification message',
|
throw new Error(
|
||||||
);
|
'Matrix server is not defined. Please set env var MATRIX_SERVER',
|
||||||
}
|
);
|
||||||
if (!context.env.KEYBASE_NYMBOT_USERNAME) {
|
}
|
||||||
throw new Error(
|
if (!context.env.MATRIX_USER_ID) {
|
||||||
'Username is not defined. Please set env var KEYBASE_NYMBOT_USERNAME',
|
throw new Error(
|
||||||
);
|
'Matrix user id is not defined. Please set env var MATRIX_USER_ID',
|
||||||
}
|
);
|
||||||
if (!context.env.KEYBASE_NYMBOT_PAPERKEY) {
|
}
|
||||||
throw new Error(
|
if (!context.env.MATRIX_TOKEN) {
|
||||||
'Paperkey is not defined. Please set env var KEYBASE_NYMBOT_PAPERKEY',
|
throw new Error(
|
||||||
);
|
'Matrix token is not defined. Please set env var MATRIX_TOKEN',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (!context.env.MATRIX_DEVICE_ID) {
|
||||||
|
throw new Error(
|
||||||
|
'Matrix device id is not defined. Please set env var MATRIX_DEVICE_ID',
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -61,12 +68,6 @@ function createTemplateContext() {
|
|||||||
|
|
||||||
context.kind = context.env.NYM_NOTIFICATION_KIND;
|
context.kind = context.env.NYM_NOTIFICATION_KIND;
|
||||||
|
|
||||||
context.keybase = {
|
|
||||||
channel: context.env.KEYBASE_NYM_CHANNEL,
|
|
||||||
username: context.env.KEYBASE_NYMBOT_USERNAME,
|
|
||||||
paperkey: context.env.KEYBASE_NYMBOT_PAPERKEY,
|
|
||||||
};
|
|
||||||
|
|
||||||
if (!context.env.GIT_BRANCH_NAME) {
|
if (!context.env.GIT_BRANCH_NAME) {
|
||||||
context.env.GIT_BRANCH_NAME = context.env.GITHUB_REF.split('/')
|
context.env.GIT_BRANCH_NAME = context.env.GITHUB_REF.split('/')
|
||||||
.slice(2)
|
.slice(2)
|
||||||
@@ -76,40 +77,6 @@ function createTemplateContext() {
|
|||||||
context.status = process.env.IS_SUCCESS === 'true' ? 'success' : 'failure';
|
context.status = process.env.IS_SUCCESS === 'true' ? 'success' : 'failure';
|
||||||
}
|
}
|
||||||
|
|
||||||
async function sendKeybaseMessage(messageBody) {
|
|
||||||
const bot = new Bot();
|
|
||||||
try {
|
|
||||||
console.log(
|
|
||||||
`Initialising keybase with user "${
|
|
||||||
context.keybase.username
|
|
||||||
}" and key: "${'*'.repeat(context.keybase.paperkey.length)}"...`,
|
|
||||||
);
|
|
||||||
await bot.init(context.keybase.username, context.keybase.paperkey, {
|
|
||||||
verbose: false,
|
|
||||||
});
|
|
||||||
|
|
||||||
const channel = {
|
|
||||||
name: context.env.KEYBASE_NYMBOT_TEAM || 'nymtech_bot',
|
|
||||||
membersType: 'team',
|
|
||||||
topicName: context.keybase.channel,
|
|
||||||
topic_type: 'CHAT',
|
|
||||||
};
|
|
||||||
const message = {
|
|
||||||
body: messageBody,
|
|
||||||
};
|
|
||||||
|
|
||||||
console.log(`Sending to ${channel.name}#${channel.topicName}...`);
|
|
||||||
await bot.chat.send(channel, message);
|
|
||||||
|
|
||||||
console.log('Message sent!');
|
|
||||||
} catch (error) {
|
|
||||||
console.error(error);
|
|
||||||
process.exitCode = -1;
|
|
||||||
} finally {
|
|
||||||
await bot.deinit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Uses the `kind` set in the context to process the context and generate a notification message
|
* Uses the `kind` set in the context to process the context and generate a notification message
|
||||||
* @returns {Promise<string>} A string notification message body
|
* @returns {Promise<string>} A string notification message body
|
||||||
@@ -146,7 +113,13 @@ async function main() {
|
|||||||
console.log(messageBody);
|
console.log(messageBody);
|
||||||
console.log('-----------------------------------------');
|
console.log('-----------------------------------------');
|
||||||
}
|
}
|
||||||
await sendKeybaseMessage(messageBody);
|
if(context.env.MATRIX_ROOM) {
|
||||||
|
await sendMatrixMessage(context, messageBody, context.env.MATRIX_ROOM)
|
||||||
|
}
|
||||||
|
if(context.env.MATRIX_ROOM_OF_SHAME && context.env.IS_SUCCESS !== 'true') {
|
||||||
|
// when a job fails
|
||||||
|
await sendMatrixMessage(context, messageBody, context.env.MATRIX_ROOM_OF_SHAME)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// call main function and let NodeJS handle the promise
|
// call main function and let NodeJS handle the promise
|
||||||
|
|||||||
@@ -0,0 +1,67 @@
|
|||||||
|
const sdk = require('matrix-js-sdk');
|
||||||
|
global.Olm = require('olm');
|
||||||
|
const { LocalStorage } = require('node-localstorage');
|
||||||
|
const localStorage = new LocalStorage('./scratch');
|
||||||
|
const {
|
||||||
|
LocalStorageCryptoStore,
|
||||||
|
} = require('matrix-js-sdk/lib/crypto/store/localStorage-crypto-store');
|
||||||
|
var showdown = require('showdown');
|
||||||
|
|
||||||
|
// hide all matrix client output
|
||||||
|
console.error = (error) => console.log('❌ error: ', error);
|
||||||
|
process.stderr.write = () => {};
|
||||||
|
process.stdout.write = () => {};
|
||||||
|
|
||||||
|
|
||||||
|
function createClient(context, room, message) {
|
||||||
|
const server = context.env.MATRIX_SERVER;
|
||||||
|
const token = context.env.MATRIX_TOKEN;
|
||||||
|
const deviceId = context.env.MATRIX_DEVICE_ID;
|
||||||
|
const userId = context.env.MATRIX_USER_ID;
|
||||||
|
|
||||||
|
const client = sdk.createClient({
|
||||||
|
baseUrl: server,
|
||||||
|
accessToken: token,
|
||||||
|
userId,
|
||||||
|
deviceId,
|
||||||
|
sessionStore: new sdk.WebStorageSessionStore(localStorage),
|
||||||
|
cryptoStore: new LocalStorageCryptoStore(localStorage),
|
||||||
|
});
|
||||||
|
|
||||||
|
client.on('sync', async function(state, prevState, res) {
|
||||||
|
if (state !== 'PREPARED') return;
|
||||||
|
client.setGlobalErrorOnUnknownDevices(false);
|
||||||
|
try {
|
||||||
|
await client.joinRoom(room);
|
||||||
|
await client.sendEvent(
|
||||||
|
room,
|
||||||
|
'm.room.message',
|
||||||
|
{
|
||||||
|
msgtype: 'm.text',
|
||||||
|
format: 'org.matrix.custom.html',
|
||||||
|
body: message,
|
||||||
|
formatted_body: message,
|
||||||
|
},
|
||||||
|
'',
|
||||||
|
);
|
||||||
|
} catch (error) {
|
||||||
|
console.error('Job failed: ' + error.message);
|
||||||
|
}
|
||||||
|
client.stopClient();
|
||||||
|
process.exit(0);
|
||||||
|
});
|
||||||
|
|
||||||
|
return client;
|
||||||
|
}
|
||||||
|
|
||||||
|
async function sendMatrixMessage(contextArg, messageAsMarkdown, roomId) {
|
||||||
|
const converter = new showdown.Converter();
|
||||||
|
const messageAsHtml = converter.makeHtml(messageAsMarkdown);
|
||||||
|
const client = createClient(contextArg, roomId, messageAsHtml);
|
||||||
|
await client.initCrypto();
|
||||||
|
await client.startClient({ initialSyncLimit: 1 });
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
sendMatrixMessage,
|
||||||
|
};
|
||||||
@@ -1,9 +1,14 @@
|
|||||||
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> 🔴 **FAILURE** :cry:
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message:
|
Commit message:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,9 +1,14 @@
|
|||||||
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View storybook:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
> :rocket: {{ env.NYM_PROJECT_NAME }} ➡️➡️➡️➡️➡️ **View storybook:** https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}/
|
||||||
|
>
|
||||||
> ✅ **SUCCESS**
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,9 +1,14 @@
|
|||||||
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> 🔴 **FAILURE** :cry:
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message:
|
Commit message:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,13 +1,18 @@
|
|||||||
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> ✅ **SUCCESS**
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
> ➡️➡️➡️➡️➡️ **View output:**
|
> ➡️➡️➡️➡️➡️ **View output:**
|
||||||
|
>
|
||||||
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}
|
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "send-keybase-message",
|
"name": "send-matrix-message",
|
||||||
"description": "Sends a notification message with the keybase package that fails when piped into the keybase CLI",
|
"description": "Sends a notification message with the matrix sdk",
|
||||||
"version": "1.0.0",
|
"version": "1.0.0",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
@@ -10,10 +10,18 @@
|
|||||||
"dependencies": {
|
"dependencies": {
|
||||||
"dotenv": "^16.0.0",
|
"dotenv": "^16.0.0",
|
||||||
"handlebars": "^4.7.7",
|
"handlebars": "^4.7.7",
|
||||||
"keybase-bot": "^3.6.1",
|
"matrix-js-sdk": "^9.3.0",
|
||||||
"octokit": "^1.7.1"
|
"node-localstorage": "^2.1.6",
|
||||||
|
"octokit": "^1.7.1",
|
||||||
|
"olm": "https://packages.matrix.org/npm/olm/olm-3.2.1.tgz",
|
||||||
|
"remark-emoji": "^2.2.0",
|
||||||
|
"remark-html": "^13.0.2",
|
||||||
|
"remark-parse": "^9.0.0",
|
||||||
|
"showdown": "^2.1.0",
|
||||||
|
"to-vfile": "^6.1.0",
|
||||||
|
"unified": "^9.2.2"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"prettier": "2.3.2"
|
"prettier": "^2.8.7"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,14 @@
|
|||||||
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥🟥
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> 🔴 **FAILURE** :cry:
|
> 🔴 **FAILURE** :cry:
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message:
|
Commit message:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -1,14 +1,20 @@
|
|||||||
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩🟩
|
||||||
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
> :rocket: {{ env.NYM_PROJECT_NAME }}
|
||||||
|
>
|
||||||
> ✅ **SUCCESS**
|
> ✅ **SUCCESS**
|
||||||
|
>
|
||||||
> ➡️➡️➡️➡️➡️ **View output:**
|
> ➡️➡️➡️➡️➡️ **View output:**
|
||||||
|
>
|
||||||
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}
|
> `storybook`: https://{{ env.NYM_CI_WWW_LOCATION }}.{{ env.NYM_CI_WWW_BASE }}
|
||||||
|
>
|
||||||
> `example`: https://{{ env.NYM_CI_WWW_LOCATION }}-example.{{ env.NYM_CI_WWW_BASE }}
|
> `example`: https://{{ env.NYM_CI_WWW_LOCATION }}-example.{{ env.NYM_CI_WWW_BASE }}
|
||||||
|
>
|
||||||
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
> `branch` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/tree/{{ env.GIT_BRANCH_NAME }}
|
||||||
|
>
|
||||||
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
> `commit` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/commit/{{ env.GITHUB_SHA }}
|
||||||
|
>
|
||||||
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
> `build ` {{ env.GITHUB_SERVER_URL }}/{{ env.GITHUB_REPOSITORY }}/actions/runs/{{ env.GITHUB_RUN_ID }}
|
||||||
|
>
|
||||||
|
|
||||||
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
Commit message by `{{ env.GITHUB_ACTOR }}` at {{ timestamp }}:
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -0,0 +1,46 @@
|
|||||||
|
name: tag-and-release
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
nym_binaries_version:
|
||||||
|
description: 'Version of the nym-binaries tag'
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
nym_wallet_version:
|
||||||
|
description: 'Version of the nym-wallet tag'
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
nym_connect_version:
|
||||||
|
description: 'Version of the nym-connect tag'
|
||||||
|
required: false
|
||||||
|
type: string
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
tag-components:
|
||||||
|
uses: nymtech/reusable-workflows/.github/workflows/tag-components.yml@master
|
||||||
|
with:
|
||||||
|
nym_binaries_version: ${{ input.nym_binaries_version }}
|
||||||
|
nym_wallet_version: ${{ input.nym_wallet_version }}
|
||||||
|
nym_connect_version: ${{ input.nym_connect_version }}
|
||||||
|
|
||||||
|
create-nym-binaries-release:
|
||||||
|
if: ${{ input.nym_binaries_version }}
|
||||||
|
uses: nymtech/reusable-workflows/.github/workflows/create-binaries-release.yml@master
|
||||||
|
with:
|
||||||
|
version: ${{ input.nym_binaries_version }}
|
||||||
|
needs: ["tag-components"]
|
||||||
|
|
||||||
|
create-nym-wallet-release:
|
||||||
|
if: ${{ input.nym_wallet_version }}
|
||||||
|
uses: nymtech/reusable-workflows/.github/workflows/create-wallet-release.yml@master
|
||||||
|
with:
|
||||||
|
version: ${{ input.nym_wallet_version }}
|
||||||
|
needs: ["tag-components"]
|
||||||
|
|
||||||
|
create-nym-connect-release:
|
||||||
|
if: ${{ input.nym_connect_version }}
|
||||||
|
uses: nymtech/reusable-workflows/.github/workflows/create-connect-release.yml@master
|
||||||
|
with:
|
||||||
|
version: ${{ input.nym_connect_version }}
|
||||||
|
needs: ["tag-components"]
|
||||||
@@ -0,0 +1,64 @@
|
|||||||
|
name: CI for linting Typescript
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
paths:
|
||||||
|
- 'ts-packages/**'
|
||||||
|
- 'sdk/typescript/**'
|
||||||
|
- 'nym-connect/desktop/src/**'
|
||||||
|
- 'nym-connect/desktop/package.json'
|
||||||
|
- 'nym-connect/mobile/src/**'
|
||||||
|
- 'nym-connect/mobile/package.json'
|
||||||
|
- 'nym-wallet/src/**'
|
||||||
|
- 'nym-wallet/package.json'
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'ts-packages/**'
|
||||||
|
- 'sdk/typescript/**'
|
||||||
|
- 'nym-connect/desktop/src/**'
|
||||||
|
- 'nym-connect/desktop/package.json'
|
||||||
|
- 'nym-connect/mobile/src/**'
|
||||||
|
- 'nym-connect/mobile/package.json'
|
||||||
|
- 'nym-wallet/src/**'
|
||||||
|
- 'nym-wallet/package.json'
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
runs-on: custom-runner-linux
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- name: Install rsync
|
||||||
|
run: sudo apt-get install rsync
|
||||||
|
continue-on-error: true
|
||||||
|
- uses: rlespinasse/github-slug-action@v3.x
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version: 16
|
||||||
|
- name: Setup yarn
|
||||||
|
run: npm install -g yarn
|
||||||
|
- name: Install
|
||||||
|
run: yarn
|
||||||
|
- name: Build packages
|
||||||
|
run: yarn build
|
||||||
|
- name: Lint
|
||||||
|
run: yarn lint && yarn tsc
|
||||||
|
- name: Matrix - Node Install
|
||||||
|
run: npm install
|
||||||
|
working-directory: .github/workflows/support-files
|
||||||
|
- name: Matrix - Send Notification
|
||||||
|
env:
|
||||||
|
NYM_NOTIFICATION_KIND: ts-packages
|
||||||
|
NYM_PROJECT_NAME: "ts-packages"
|
||||||
|
NYM_CI_WWW_BASE: "${{ secrets.NYM_CI_WWW_BASE }}"
|
||||||
|
NYM_CI_WWW_LOCATION: "ts-${{ env.GITHUB_REF_SLUG }}"
|
||||||
|
GIT_COMMIT_MESSAGE: "${{ github.event.head_commit.message }}"
|
||||||
|
GIT_BRANCH: "${GITHUB_REF##*/}"
|
||||||
|
IS_SUCCESS: "${{ job.status == 'success' }}"
|
||||||
|
MATRIX_SERVER: "${{ secrets.MATRIX_SERVER }}"
|
||||||
|
MATRIX_ROOM: "${{ secrets.MATRIX_ROOM }}"
|
||||||
|
MATRIX_USER_ID: "${{ secrets.MATRIX_USER_ID }}"
|
||||||
|
MATRIX_TOKEN: "${{ secrets.MATRIX_TOKEN }}"
|
||||||
|
MATRIX_DEVICE_ID: "${{ secrets.MATRIX_DEVICE_ID }}"
|
||||||
|
uses: docker://keybaseio/client:stable-node
|
||||||
|
with:
|
||||||
|
args: .github/workflows/support-files/notifications/entry_point.sh
|
||||||
@@ -0,0 +1,95 @@
|
|||||||
|
name: update-versions-and-changelog
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
inputs:
|
||||||
|
release_version:
|
||||||
|
description: "Release version, usually the milestone title"
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
milestone_id:
|
||||||
|
description: "Milestone ID, check the URL when you're on the specific milestone page"
|
||||||
|
required: true
|
||||||
|
type: string
|
||||||
|
|
||||||
|
env:
|
||||||
|
CI_BOT_AUTHOR: "Nym bot"
|
||||||
|
CI_BOT_EMAIL: "nym-bot@users.noreply.github.com"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
update-versions:
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
steps:
|
||||||
|
- name: checkout-source
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
ref: "release/${{ inputs.release_version }}"
|
||||||
|
path: "nym"
|
||||||
|
|
||||||
|
- name: checkout-ci-tools-repo
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
repository: "nymtech/ci-tools"
|
||||||
|
ref: "master"
|
||||||
|
path: "ci-tools"
|
||||||
|
token: "${{ secrets.ACCESS_TOKEN_PRIVATE_REPOS }}"
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
|
- name: install-version-bumper
|
||||||
|
run: "cargo install --path ."
|
||||||
|
working-directory: "ci-tools/version-bumper"
|
||||||
|
|
||||||
|
- name: run-version-bumper
|
||||||
|
run: "version-bumper bump binaries --nym-repo-directory nym"
|
||||||
|
|
||||||
|
- name: push-changes-to-branch
|
||||||
|
run: |
|
||||||
|
git config --global user.name "${{ env.CI_BOT_AUTHOR }}"
|
||||||
|
git config --global user.email "${{ env.CI_BOT_EMAIL }}"
|
||||||
|
git checkout -b release/${{ inputs.release_version }}-preparation
|
||||||
|
git commit -am "chore: version bump in preparation for release"
|
||||||
|
git push -u origin release/${{ inputs.release_version }}-preparation
|
||||||
|
working-directory: "nym"
|
||||||
|
|
||||||
|
update-changelog:
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
needs: [update-versions]
|
||||||
|
steps:
|
||||||
|
- name: checkout-source
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
ref: "release/${{ inputs.release_version }}"
|
||||||
|
path: "nym"
|
||||||
|
|
||||||
|
- name: checkout-ci-tools-repo
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
with:
|
||||||
|
repository: "nymtech/ci-tools"
|
||||||
|
ref: "master"
|
||||||
|
path: "ci-tools"
|
||||||
|
token: "${{ secrets.ACCESS_TOKEN_PRIVATE_REPOS }}"
|
||||||
|
|
||||||
|
- name: Install Rust stable
|
||||||
|
uses: actions-rs/toolchain@v1
|
||||||
|
with:
|
||||||
|
toolchain: stable
|
||||||
|
|
||||||
|
- name: install-changelog-updater
|
||||||
|
run: "cargo install --path ."
|
||||||
|
working-directory: "ci-tools/changelog-updater"
|
||||||
|
|
||||||
|
- name: run-changelog-updater
|
||||||
|
run: "changelog-updater mix ${{ inputs.milestone_id }} release/${{ inputs.release_version }}"
|
||||||
|
|
||||||
|
- name: push-changes-to-branch
|
||||||
|
run: |
|
||||||
|
git config --global user.name "${{ env.CI_BOT_AUTHOR }}"
|
||||||
|
git config --global user.email "${{ env.CI_BOT_EMAIL }}"
|
||||||
|
git checkout release/${{ inputs.release_version }}-preparation
|
||||||
|
git commit -am "chore: update changelog preparation for release"
|
||||||
|
git push
|
||||||
|
working-directory: "nym"
|
||||||
@@ -2,11 +2,17 @@ name: Nym Wallet (rust)
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'nym-wallet/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/vesting/**'
|
||||||
|
- 'nym-api/nym-api-requests/**'
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'nym-wallet/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/vesting/**'
|
||||||
|
- 'nym-api/nym-api-requests/**'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
@@ -16,6 +22,7 @@ jobs:
|
|||||||
steps:
|
steps:
|
||||||
- name: Install Dependencies (Linux)
|
- name: Install Dependencies (Linux)
|
||||||
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev squashfs-tools
|
run: sudo apt-get update && sudo apt-get -y install libwebkit2gtk-4.0-dev build-essential curl wget libssl-dev libgtk-3-dev squashfs-tools
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
- name: Check out repository code
|
- name: Check out repository code
|
||||||
uses: actions/checkout@v2
|
uses: actions/checkout@v2
|
||||||
@@ -48,6 +55,7 @@ jobs:
|
|||||||
|
|
||||||
- uses: actions-rs/clippy-check@v1
|
- uses: actions-rs/clippy-check@v1
|
||||||
name: Clippy checks
|
name: Clippy checks
|
||||||
|
continue-on-error: true
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.GITHUB_TOKEN }}
|
token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
args: --manifest-path nym-wallet/Cargo.toml --workspace --all-features
|
args: --manifest-path nym-wallet/Cargo.toml --workspace --all-features
|
||||||
@@ -56,4 +64,4 @@ jobs:
|
|||||||
uses: actions-rs/cargo@v1
|
uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: clippy
|
command: clippy
|
||||||
args: --manifest-path nym-wallet/Cargo.toml --workspace --all-features -- -D warnings
|
args: --manifest-path nym-wallet/Cargo.toml --workspace --all-features --all-targets -- -D warnings
|
||||||
|
|||||||
@@ -2,8 +2,13 @@ name: Wasm Client
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
paths:
|
||||||
- 'explorer/**'
|
- 'clients/webassembly/**'
|
||||||
|
- 'clients/client-core/**'
|
||||||
|
- 'common/**'
|
||||||
|
- 'contracts/**'
|
||||||
|
- 'gateway/gateway-requests/**'
|
||||||
|
- 'nym-api/nym-api-requests/**'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
wasm:
|
wasm:
|
||||||
@@ -24,16 +29,6 @@ jobs:
|
|||||||
command: build
|
command: build
|
||||||
args: --manifest-path clients/webassembly/Cargo.toml --target wasm32-unknown-unknown
|
args: --manifest-path clients/webassembly/Cargo.toml --target wasm32-unknown-unknown
|
||||||
|
|
||||||
- uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: build
|
|
||||||
args: --manifest-path clients/webassembly/Cargo.toml --target wasm32-unknown-unknown --features=coconut
|
|
||||||
|
|
||||||
- uses: actions-rs/cargo@v1
|
|
||||||
with:
|
|
||||||
command: test
|
|
||||||
args: --manifest-path clients/webassembly/Cargo.toml
|
|
||||||
|
|
||||||
- uses: actions-rs/cargo@v1
|
- uses: actions-rs/cargo@v1
|
||||||
with:
|
with:
|
||||||
command: fmt
|
command: fmt
|
||||||
|
|||||||
+5
-1
@@ -37,4 +37,8 @@ validator-config
|
|||||||
*.patch
|
*.patch
|
||||||
validator-api-config.toml
|
validator-api-config.toml
|
||||||
dist
|
dist
|
||||||
storybook-static
|
storybook-static
|
||||||
|
envs/qwerty.env
|
||||||
|
.parcel-cache
|
||||||
|
**/.DS_Store
|
||||||
|
cpu-cycles/libcpucycles/build
|
||||||
@@ -1,6 +1,8 @@
|
|||||||
{
|
{
|
||||||
"mainnet":[{
|
"mainnet": [
|
||||||
"nymd_url":"https://rpc.nyx.nodes.guru/",
|
{
|
||||||
"api_url":"https://api.nyx.nodes.guru/"
|
"nyxd_url": "https://rpc.nyx.nodes.guru/",
|
||||||
}]
|
"api_url": "https://api.nyx.nodes.guru/"
|
||||||
}
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
+306
-34
@@ -2,13 +2,291 @@
|
|||||||
|
|
||||||
Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
## [Unreleased]
|
||||||
|
|
||||||
|
- nym-network-statistics properly handles signals ([#3209])
|
||||||
|
- add socks5 support for Rust SDK ([#3226], [#3255])
|
||||||
|
- add coconut bandwidth credential support for Rust SDK ([#3273])
|
||||||
|
|
||||||
|
[#3209]: https://github.com/nymtech/nym/issues/3209
|
||||||
|
[#3226]: https://github.com/nymtech/nym/pull/3226
|
||||||
|
[#3255]: https://github.com/nymtech/nym/pull/3255
|
||||||
|
[#3273]: https://github.com/nymtech/nym/pull/3273
|
||||||
|
|
||||||
|
## [v1.1.15] (2023-04-18)
|
||||||
|
|
||||||
|
- Fix verloc being stuck waiting for shutdown signal ([#3250])
|
||||||
|
- Introduce `--output json` flag to `sign` command to allow to more easily capture the output ([#3249])
|
||||||
|
- Explorer - Dont fetch Service Provider list on Testnet ([#3245])
|
||||||
|
- When determining active set, rather than weighting the nodes by just the `stake`, use `stake * performance` ([#3234])
|
||||||
|
- Introduce dual packet sizes to our clients (as in use two packet sizes at the same time depending on message size) ([#3189])
|
||||||
|
- Experiment with offline signing in our validator client ([#3174])
|
||||||
|
- Modify network requester binary to reload `allowed.list` periodically to pull in any changes made upstream without having to restart the service ([#3149])
|
||||||
|
- Standardise all `--output json` on binary inits, we pass the output json at different points for different binaries. ([#3080])
|
||||||
|
- Service provider directory contract: initial version ([#2759])
|
||||||
|
- Fix issue where network-requester run failed on fresh init due to missing allow file ([#3316])
|
||||||
|
|
||||||
|
[#3250]: https://github.com/nymtech/nym/issues/3250
|
||||||
|
[#3249]: https://github.com/nymtech/nym/issues/3249
|
||||||
|
[#3245]: https://github.com/nymtech/nym/issues/3245
|
||||||
|
[#3234]: https://github.com/nymtech/nym/issues/3234
|
||||||
|
[#3189]: https://github.com/nymtech/nym/issues/3189
|
||||||
|
[#3174]: https://github.com/nymtech/nym/issues/3174
|
||||||
|
[#3149]: https://github.com/nymtech/nym/issues/3149
|
||||||
|
[#3080]: https://github.com/nymtech/nym/issues/3080
|
||||||
|
[#2759]: https://github.com/nymtech/nym/issues/2759
|
||||||
|
[#3316]: https://github.com/nymtech/nym/pull/3316
|
||||||
|
|
||||||
|
## [v1.1.14] (2023-04-04)
|
||||||
|
|
||||||
|
- Investigate cause of qwerty validator being in invalid rewarding state ([#3224])
|
||||||
|
- Fix NR config due to changes in #3199 ([#3223])
|
||||||
|
- [Issue] Mixnodes and gateway do not close connections properly ([#3187])
|
||||||
|
- disable sign-ext when using wasm-opt + update wasm-opt ([#3203])
|
||||||
|
- chore: tidy up client `Debug` config section ([#3199])
|
||||||
|
|
||||||
|
[#3224]: https://github.com/nymtech/nym/issues/3224
|
||||||
|
[#3223]: https://github.com/nymtech/nym/issues/3223
|
||||||
|
[#3187]: https://github.com/nymtech/nym/issues/3187
|
||||||
|
[#3203]: https://github.com/nymtech/nym/pull/3203
|
||||||
|
[#3199]: https://github.com/nymtech/nym/pull/3199
|
||||||
|
>>>>>>> master
|
||||||
|
|
||||||
|
## [v1.1.13] (2023-03-15)
|
||||||
|
|
||||||
|
- NE - instead of throwing a "Mixnode/Gateway not found" error for blacklisted nodes due to bad performance, show their history but tag them as "Having poor performance" ([#2979])
|
||||||
|
- NE - Upgrade Sandbox and make below changes: ([#2332])
|
||||||
|
- Explorer - Updates ([#3168])
|
||||||
|
- Website v2 - deploy infrastructure for strapi and CI ([#2213])
|
||||||
|
- add blockstream green to sp list ([#3180])
|
||||||
|
- mock-nym-api: fix .storybook lint error ([#3178])
|
||||||
|
- Validating new interval config parameters to prevent division by zero ([#3153])
|
||||||
|
|
||||||
|
[#2979]: https://github.com/nymtech/nym/issues/2979
|
||||||
|
[#2332]: https://github.com/nymtech/nym/issues/2332
|
||||||
|
[#3168]: https://github.com/nymtech/nym/issues/3168
|
||||||
|
[#2213]: https://github.com/nymtech/nym/issues/2213
|
||||||
|
[#3180]: https://github.com/nymtech/nym/pull/3180
|
||||||
|
[#3178]: https://github.com/nymtech/nym/pull/3178
|
||||||
|
[#3153]: https://github.com/nymtech/nym/pull/3153
|
||||||
|
|
||||||
|
## [v1.1.12] (2023-03-07)
|
||||||
|
|
||||||
|
- Fix generated docs for mixnet and vesting contract on docs.rs ([#3093])
|
||||||
|
- Introduce a way of injecting topology into the client ([#3044])
|
||||||
|
- Update mixnet TypeScript client methods #1 ([#2783])
|
||||||
|
- Update tooltips for routing and average score ([#3133])
|
||||||
|
- update selected service provider description style ([#3128])
|
||||||
|
|
||||||
|
[#3093]: https://github.com/nymtech/nym/issues/3093
|
||||||
|
[#3044]: https://github.com/nymtech/nym/issues/3044
|
||||||
|
[#2783]: https://github.com/nymtech/nym/issues/2783
|
||||||
|
[#3133]: https://github.com/nymtech/nym/pull/3133
|
||||||
|
[#3128]: https://github.com/nymtech/nym/pull/3128
|
||||||
|
|
||||||
|
## [v1.1.11] (2023-02-28)
|
||||||
|
|
||||||
|
- Fix empty dealer set loop ([#3105])
|
||||||
|
- The nym-api db.sqlite is broken when trying to run against it it in `enabled-credentials-mode true` there is an ordering issue with migrations when using the credential binary to purchase bandwidth ([#3100])
|
||||||
|
- Feature/latency based gateway selection ([#3081])
|
||||||
|
- Fix the credential binary to handle transactions to sleep when in non-inProgress epochs ([#3057])
|
||||||
|
- Publish mixnet contract to crates.io ([#1919])
|
||||||
|
- Publish vesting contract to crates.io ([#1920])
|
||||||
|
- Feature/update checker to use master ([#3097])
|
||||||
|
- Feature/improve binary checks ([#3094])
|
||||||
|
|
||||||
|
[#3105]: https://github.com/nymtech/nym/issues/3105
|
||||||
|
[#3100]: https://github.com/nymtech/nym/issues/3100
|
||||||
|
[#3081]: https://github.com/nymtech/nym/pull/3081
|
||||||
|
[#3057]: https://github.com/nymtech/nym/issues/3057
|
||||||
|
[#1919]: https://github.com/nymtech/nym/issues/1919
|
||||||
|
[#1920]: https://github.com/nymtech/nym/issues/1920
|
||||||
|
[#3097]: https://github.com/nymtech/nym/pull/3097
|
||||||
|
[#3094]: https://github.com/nymtech/nym/pull/3094
|
||||||
|
|
||||||
|
## [v1.1.10] (2023-02-21)
|
||||||
|
|
||||||
|
- Verloc listener causing mixnode unexpected shutdown ([#3038])
|
||||||
|
- rust-sdk - update API following implementation experience with the network-requester ([#3001])
|
||||||
|
- Prevent coconut deposits in incompatible states ([#2991])
|
||||||
|
- Support unavailable signer within threshold ([#2987])
|
||||||
|
- Implement DKG re-sharing ([#2935])
|
||||||
|
- contracts: add nym prefix to mixnet and vesting contract packages ([#2855])
|
||||||
|
- Introduce common interface for all service providers to allow obtaining information such as whether they're online, what binary version they're running, etc. ([#2758])
|
||||||
|
- Add client functionality to nym-network-requester ([#1900])
|
||||||
|
- nym-api: uptime rework ([#3053])
|
||||||
|
- ci: update typescript-lint.yml ([#3035])
|
||||||
|
- contracts: add nym prefix to mixnet and vesting contract packages ([#2855])
|
||||||
|
|
||||||
|
[#3038]: https://github.com/nymtech/nym/issues/3038
|
||||||
|
[#3001]: https://github.com/nymtech/nym/issues/3001
|
||||||
|
[#2991]: https://github.com/nymtech/nym/issues/2991
|
||||||
|
[#2987]: https://github.com/nymtech/nym/issues/2987
|
||||||
|
[#2935]: https://github.com/nymtech/nym/issues/2935
|
||||||
|
[#2855]: https://github.com/nymtech/nym/pull/2855
|
||||||
|
[#2758]: https://github.com/nymtech/nym/issues/2758
|
||||||
|
[#1900]: https://github.com/nymtech/nym/issues/1900
|
||||||
|
[#3053]: https://github.com/nymtech/nym/pull/3053
|
||||||
|
[#3035]: https://github.com/nymtech/nym/pull/3035
|
||||||
|
[#2855]: https://github.com/nymtech/nym/pull/2855
|
||||||
|
|
||||||
|
## [v1.1.9] (2023-02-07)
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- Remove Coconut feature flag ([#2793])
|
||||||
|
- Separate `nym-api` endpoints with values of "total-supply" and "circulating-supply" in `nym` ([#2964])
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- native-client: is now capable of listening for requests on sockets different than `127.0.0.1` ([#2912]). This can be specified via `--host` flag during `init` or `run`. Alternatively a custom `host` can be set in `config.toml` file under `socket` section.
|
||||||
|
- mixnode, gateway: fix unexpected shutdown on corrupted connection ([#2963])
|
||||||
|
|
||||||
|
[#2793]: https://github.com/nymtech/nym/issues/2793
|
||||||
|
[#2912]: https://github.com/nymtech/nym/issues/2912
|
||||||
|
[#2964]: https://github.com/nymtech/nym/issues/2964
|
||||||
|
[#2963]: https://github.com/nymtech/nym/issues/3017
|
||||||
|
|
||||||
|
## [v1.1.8] (2023-01-31)
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- Rust SDK - Support SURBS (anonymous send + storage) ([#2754])
|
||||||
|
- dkg rerun from scratch and dkg-specific epochs ([#2810])
|
||||||
|
- Rename `'initial_supply'` field to `'total_supply'` in the circulating supply endpoint ([#2931])
|
||||||
|
- Circulating supply api endpoint (read the note inside before testing/deploying) ([#1902])
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- nym-api: an `--id` flag is now always explicitly required ([#2873])
|
||||||
|
|
||||||
|
[#2754]: https://github.com/nymtech/nym/issues/2754
|
||||||
|
[#2810]: https://github.com/nymtech/nym/issues/2810
|
||||||
|
[#2931]: https://github.com/nymtech/nym/issues/2931
|
||||||
|
[#1902]: https://github.com/nymtech/nym/issues/1902
|
||||||
|
[#2873]: https://github.com/nymtech/nym/issues/2873
|
||||||
|
|
||||||
|
|
||||||
|
## [v1.1.7] (2023-01-24)
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- Gateways now shut down gracefully ([#2019]).
|
||||||
|
- Rust SDK - Initial version for nym-client ([#2669]).
|
||||||
|
- Introduce vesting contract query for addresses of all vesting accounts (required for the circulating supply calculation) ([#2778]).
|
||||||
|
- Add threshold value to the contract storage ([#1893])
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- Refactor vesting account storage (and in particular, ACCOUNTS saving) ([#2795]).
|
||||||
|
- Move from manual advancing DKG state to an automatic process ([#2670]).
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- Gateways now shut down gracefully ([#2019]).
|
||||||
|
|
||||||
|
[#2019]: https://github.com/nymtech/nym/issues/2019
|
||||||
|
[#2669]: https://github.com/nymtech/nym/issues/2669
|
||||||
|
[#2795]: https://github.com/nymtech/nym/issues/2795
|
||||||
|
[#2778]: https://github.com/nymtech/nym/issues/2778
|
||||||
|
[#2670]: https://github.com/nymtech/nym/issues/2670
|
||||||
|
[#1893]: https://github.com/nymtech/nym/issues/1893
|
||||||
|
|
||||||
|
## [v1.1.6] (2023-01-17)
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- nym-sdk: added initial version of a Rust client sdk
|
||||||
|
- nym-api: added `/circulating-supply` endpoint ([#2814])
|
||||||
|
- nym-api: add endpoint listing detailed gateway info by @octol in https://github.com/nymtech/nym/pull/2833
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- streamline override_config functions -> there's a lot of duplicate if statements everywhere ([#2774])
|
||||||
|
- clean-up nym-api startup arguments/flags to use clap 3 and its macro-derived arguments ([#2772])
|
||||||
|
- renamed all references to validator_api to nym_api
|
||||||
|
- renamed all references to nymd to nyxd ([#2696])
|
||||||
|
- all-binaries: standarised argument names (note: old names should still be accepted) ([#2762]
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- nym-api: should now correctly use `rewarding.enabled` config flag ([#2753])
|
||||||
|
|
||||||
|
[#2696]: https://github.com/nymtech/nym/pull/2696
|
||||||
|
[#2753]: https://github.com/nymtech/nym/pull/2753
|
||||||
|
[#2762]: https://github.com/nymtech/nym/pull/2762
|
||||||
|
[#2814]: https://github.com/nymtech/nym/pull/2814
|
||||||
|
[#2772]: https://github.com/nymtech/nym/pull/2772
|
||||||
|
[#2774]: https://github.com/nymtech/nym/pull/2774
|
||||||
|
|
||||||
|
## [v1.1.5] (2023-01-10)
|
||||||
|
|
||||||
|
### Added
|
||||||
|
|
||||||
|
- socks5: send status message for service ready, and network-requester error response in https://github.com/nymtech/nym/pull/2715
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- all-binaries: improved error logging in https://github.com/nymtech/nym/pull/2686
|
||||||
|
- native client: bring shutdown logic up to the same level as socks5-client in https://github.com/nymtech/nym/pull/2695
|
||||||
|
- nym-api, coconut-dkg contract: automatic, time-based dkg epoch state advancement in https://github.com/nymtech/nym/pull/2670
|
||||||
|
- DKG resharing unit test by @neacsu in https://github.com/nymtech/nym/pull/2668
|
||||||
|
- Renaming validator-api to nym-api by @futurechimp in https://github.com/nymtech/nym/pull/1863
|
||||||
|
- Modify wasm specific make targets by @neacsu in https://github.com/nymtech/nym/pull/2693
|
||||||
|
- client: create websocket handler builder by @octol in https://github.com/nymtech/nym/pull/2700
|
||||||
|
- Outfox and Lion by @durch in https://github.com/nymtech/nym/pull/2730
|
||||||
|
- Feature/multi surb transmission lanes by @jstuczyn in https://github.com/nymtech/nym/pull/2723
|
||||||
|
|
||||||
|
## [v1.1.4] (2022-12-20)
|
||||||
|
|
||||||
|
This release adds multiple Single Use Reply Blocks (SURBs) to allow arbitrarily-sized anonymized replies.
|
||||||
|
At the moment this is turned off by default, but available for use by application developers.
|
||||||
|
We will need to wait for network-requesters to upgrade to this new release, after which multi-SURB anonymization will become the default setting for the SOCKS proxy clients.
|
||||||
|
|
||||||
|
The release also include some additional work for distributed key generation in the Coconut signing authority nodes.
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- Feature/dkg contract threshold by @neacsu in https://github.com/nymtech/nym/pull/1885
|
||||||
|
- Multi-surbs by @jstuczyn in https://github.com/nymtech/nym/pull/2667
|
||||||
|
- Fix multi-surb backwards compatibility in pre 1.1.4 client config files by @jstuczyn in https://github.com/nymtech/nym/pull/2703
|
||||||
|
- fix: ignore corrupted surb storage and instead create fresh one by @jstuczyn in https://github.com/nymtech/nym/pull/2711
|
||||||
|
- socks5: rework waiting in inbound.rs by @octol in https://github.com/nymtech/nym/pull/1880
|
||||||
|
|
||||||
|
## [v1.1.3] (2022-12-13)
|
||||||
|
|
||||||
|
### Changed
|
||||||
|
|
||||||
|
- validator-api: can recover from shutdown during DKG process ([#1872])
|
||||||
|
- clients: deduplicate gateway initialization, part of work towards a rust-sdk
|
||||||
|
- clients: keep all transmission lanes going at all times by making priority probabilistic
|
||||||
|
- clients: ability to use multi-reply SURBs to send arbitrarily long messages fully anonymously whilst requesting additional reply blocks whenever they're about to run out ([#1796], [#1801], [#1804], [#1835], [#1858], [#1883]))
|
||||||
|
|
||||||
|
### Fixed
|
||||||
|
|
||||||
|
- network-requester: fix bug where websocket connection disconnect resulted in success error code
|
||||||
|
- clients: fix a few panics handling the gateway-client
|
||||||
|
- mixnode, gateway, validator-api: Use mainnet values as defaults for URLs and mixnet contract ([#1884])
|
||||||
|
- socks5: fixed bug where connections sometimes where closed too early
|
||||||
|
- clients: improve message logging when received message fails to get reconstructed ([#1803])
|
||||||
|
|
||||||
|
[#1796]: https://github.com/nymtech/nym/pull/1796
|
||||||
|
[#1801]: https://github.com/nymtech/nym/pull/1801
|
||||||
|
[#1803]: https://github.com/nymtech/nym/pull/1803
|
||||||
|
[#1804]: https://github.com/nymtech/nym/pull/1804
|
||||||
|
[#1835]: https://github.com/nymtech/nym/pull/1835
|
||||||
|
[#1858]: https://github.com/nymtech/nym/pull/1858
|
||||||
|
[#1872]: https://github.com/nymtech/nym/pull/1872
|
||||||
|
[#1883]: https://github.com/nymtech/nym/pull/1883
|
||||||
|
[#1884]: https://github.com/nymtech/nym/pull/1884
|
||||||
|
|
||||||
## [v1.1.2]
|
## [v1.1.2]
|
||||||
|
|
||||||
### Changed
|
### Changed
|
||||||
|
|
||||||
- gateway: Renamed flag from `enabled/disabled_credentials_mode` to `only-coconut-credentials`
|
- gateway: Renamed flag from `enabled/disabled_credentials_mode` to `only-coconut-credentials`
|
||||||
- "Family" feature for node families + layers
|
- "Family" feature for node families + layers
|
||||||
- Initial coconut functionality including credentials and distributed key generation
|
- Initial coconut functionality including credentials and distributed key generation
|
||||||
|
|
||||||
## [v1.1.1](https://github.com/nymtech/nym/tree/v1.1.1) (2022-11-29)
|
## [v1.1.1](https://github.com/nymtech/nym/tree/v1.1.1) (2022-11-29)
|
||||||
|
|
||||||
@@ -44,7 +322,6 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
[#1786]: https://github.com/nymtech/nym/pull/1786
|
[#1786]: https://github.com/nymtech/nym/pull/1786
|
||||||
[#1805]: https://github.com/nymtech/nym/pull/1805
|
[#1805]: https://github.com/nymtech/nym/pull/1805
|
||||||
|
|
||||||
|
|
||||||
## [v1.1.0](https://github.com/nymtech/nym/tree/v1.1.0) (2022-11-09)
|
## [v1.1.0](https://github.com/nymtech/nym/tree/v1.1.0) (2022-11-09)
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
@@ -56,7 +333,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- native-client/socks5-client/wasm-client: `use_extended_packet_size` Debug config option to make the client use 'ExtendedPacketSize' for its traffic (32kB as opposed to 2kB in 1.0.2) ([#1671])
|
- native-client/socks5-client/wasm-client: `use_extended_packet_size` Debug config option to make the client use 'ExtendedPacketSize' for its traffic (32kB as opposed to 2kB in 1.0.2) ([#1671])
|
||||||
- network-requester: added additional Blockstream Green wallet endpoint to `example.allowed.list` ([#1611])
|
- network-requester: added additional Blockstream Green wallet endpoint to `example.allowed.list` ([#1611])
|
||||||
- validator-api: add `interval_operating_cost` and `profit_margin_percent` to compute reward estimation endpoint
|
- validator-api: add `interval_operating_cost` and `profit_margin_percent` to compute reward estimation endpoint
|
||||||
- validator-client: added `query_contract_smart` and `query_contract_raw` on `NymdClient` ([#1558])
|
- validator-client: added `query_contract_smart` and `query_contract_raw` on `NyxdClient` ([#1558])
|
||||||
- wasm-client: uses updated wasm-compatible `client-core` so that it's now capable of packet retransmission, cover traffic and poisson delay (among other things!) ([#1673])
|
- wasm-client: uses updated wasm-compatible `client-core` so that it's now capable of packet retransmission, cover traffic and poisson delay (among other things!) ([#1673])
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
@@ -71,7 +348,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- gateway-client: will attempt to read now as many as 8 websocket messages at once, assuming they're already available on the socket ([#1669])
|
- gateway-client: will attempt to read now as many as 8 websocket messages at once, assuming they're already available on the socket ([#1669])
|
||||||
- moved `Percent` struct to `contracts-common`, change affects explorer-api
|
- moved `Percent` struct to `contracts-common`, change affects explorer-api
|
||||||
- socks5 client: graceful shutdown should fix error on disconnect in nym-connect ([#1591])
|
- socks5 client: graceful shutdown should fix error on disconnect in nym-connect ([#1591])
|
||||||
- validator-api: changed error serialization on `inclusion_probability`, `stake-saturation` and `reward-estimation` endpoints to provide more accurate information ([#1681])
|
- validator-api: changed error serialization on `inclusion_probability`, `stake-saturation` and `reward-estimation` endpoints to provide more accurate information ([#1681])
|
||||||
- validator-client: made `fee` argument optional for `execute` and `execute_multiple` ([#1541])
|
- validator-client: made `fee` argument optional for `execute` and `execute_multiple` ([#1541])
|
||||||
- wasm-client: fixed build errors on MacOS and changed example JS code to use mainnet ([#1585])
|
- wasm-client: fixed build errors on MacOS and changed example JS code to use mainnet ([#1585])
|
||||||
- validator-api: changes to internal SQL schema due to the mixnet contract revamp ([#1472])
|
- validator-api: changes to internal SQL schema due to the mixnet contract revamp ([#1472])
|
||||||
@@ -99,7 +376,6 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
[#1724]: https://github.com/nymtech/nym/pull/1724
|
[#1724]: https://github.com/nymtech/nym/pull/1724
|
||||||
[#1725]: https://github.com/nymtech/nym/pull/1725
|
[#1725]: https://github.com/nymtech/nym/pull/1725
|
||||||
|
|
||||||
|
|
||||||
## [nym-binaries-1.0.2](https://github.com/nymtech/nym/tree/nym-binaries-1.0.2)
|
## [nym-binaries-1.0.2](https://github.com/nymtech/nym/tree/nym-binaries-1.0.2)
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
@@ -152,9 +428,8 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- All binaries and cosmwasm blobs are configured at runtime now; binaries are configured using environment variables or .env files and contracts keep the configuration parameters in storage ([#1463])
|
- All binaries and cosmwasm blobs are configured at runtime now; binaries are configured using environment variables or .env files and contracts keep the configuration parameters in storage ([#1463])
|
||||||
- gateway, network-statistics: include gateway id in the sent statistical data ([#1478])
|
- gateway, network-statistics: include gateway id in the sent statistical data ([#1478])
|
||||||
- network explorer: tweak how active set probability is shown ([#1503])
|
- network explorer: tweak how active set probability is shown ([#1503])
|
||||||
- validator-api: rewarder set update fails without panicking on possible nymd queries ([#1520])
|
- validator-api: rewarder set update fails without panicking on possible nyxd queries ([#1520])
|
||||||
- network-requester, socks5 client (nym-connect): send and receive respectively a message error to be displayed about filter check failure ([#1576])
|
- network-requester, socks5 client (nym-connect): send and receive respectively a message error to be displayed about filter check failure ([#1576])
|
||||||
|
|
||||||
|
|
||||||
[#1249]: https://github.com/nymtech/nym/pull/1249
|
[#1249]: https://github.com/nymtech/nym/pull/1249
|
||||||
[#1256]: https://github.com/nymtech/nym/pull/1256
|
[#1256]: https://github.com/nymtech/nym/pull/1256
|
||||||
@@ -248,9 +523,9 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Bump minimist from 1.2.5 to 1.2.6 in /clients/tauri-client [\#1163](https://github.com/nymtech/nym/pull/1163) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump minimist from 1.2.5 to 1.2.6 in /clients/tauri-client [\#1163](https://github.com/nymtech/nym/pull/1163) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Bump minimist from 1.2.5 to 1.2.6 in /clients/webassembly/js-example [\#1162](https://github.com/nymtech/nym/pull/1162) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump minimist from 1.2.5 to 1.2.6 in /clients/webassembly/js-example [\#1162](https://github.com/nymtech/nym/pull/1162) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Bump minimist from 1.2.5 to 1.2.6 in /clients/native/examples/js-examples/websocket [\#1160](https://github.com/nymtech/nym/pull/1160) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump minimist from 1.2.5 to 1.2.6 in /clients/native/examples/js-examples/websocket [\#1160](https://github.com/nymtech/nym/pull/1160) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Bump minimist from 1.2.5 to 1.2.6 in /docker/typescript\_client/upload\_contract [\#1159](https://github.com/nymtech/nym/pull/1159) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump minimist from 1.2.5 to 1.2.6 in /docker/typescript_client/upload_contract [\#1159](https://github.com/nymtech/nym/pull/1159) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Feature/vesting full [\#1158](https://github.com/nymtech/nym/pull/1158) ([fmtabbara](https://github.com/fmtabbara))
|
- Feature/vesting full [\#1158](https://github.com/nymtech/nym/pull/1158) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- get\_current\_epoch tauri [\#1156](https://github.com/nymtech/nym/pull/1156) ([durch](https://github.com/durch))
|
- get_current_epoch tauri [\#1156](https://github.com/nymtech/nym/pull/1156) ([durch](https://github.com/durch))
|
||||||
- Cleanup [\#1155](https://github.com/nymtech/nym/pull/1155) ([durch](https://github.com/durch))
|
- Cleanup [\#1155](https://github.com/nymtech/nym/pull/1155) ([durch](https://github.com/durch))
|
||||||
- Feature flag reward payments [\#1154](https://github.com/nymtech/nym/pull/1154) ([durch](https://github.com/durch))
|
- Feature flag reward payments [\#1154](https://github.com/nymtech/nym/pull/1154) ([durch](https://github.com/durch))
|
||||||
- Add Query endpoints for calculating rewards [\#1152](https://github.com/nymtech/nym/pull/1152) ([durch](https://github.com/durch))
|
- Add Query endpoints for calculating rewards [\#1152](https://github.com/nymtech/nym/pull/1152) ([durch](https://github.com/durch))
|
||||||
@@ -259,7 +534,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- wallet: use Urls rather than Strings for validator urls [\#1148](https://github.com/nymtech/nym/pull/1148) ([octol](https://github.com/octol))
|
- wallet: use Urls rather than Strings for validator urls [\#1148](https://github.com/nymtech/nym/pull/1148) ([octol](https://github.com/octol))
|
||||||
- Change accumulated reward to Option, migrate delegations [\#1147](https://github.com/nymtech/nym/pull/1147) ([durch](https://github.com/durch))
|
- Change accumulated reward to Option, migrate delegations [\#1147](https://github.com/nymtech/nym/pull/1147) ([durch](https://github.com/durch))
|
||||||
- wallet: fetch validators url remotely if available [\#1146](https://github.com/nymtech/nym/pull/1146) ([octol](https://github.com/octol))
|
- wallet: fetch validators url remotely if available [\#1146](https://github.com/nymtech/nym/pull/1146) ([octol](https://github.com/octol))
|
||||||
- Fix delegated\_free calculation [\#1145](https://github.com/nymtech/nym/pull/1145) ([durch](https://github.com/durch))
|
- Fix delegated_free calculation [\#1145](https://github.com/nymtech/nym/pull/1145) ([durch](https://github.com/durch))
|
||||||
- Update Nym wallet dependencies to use `ts-packages` [\#1144](https://github.com/nymtech/nym/pull/1144) ([mmsinclair](https://github.com/mmsinclair))
|
- Update Nym wallet dependencies to use `ts-packages` [\#1144](https://github.com/nymtech/nym/pull/1144) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- wallet: try validators one by one if available [\#1143](https://github.com/nymtech/nym/pull/1143) ([octol](https://github.com/octol))
|
- wallet: try validators one by one if available [\#1143](https://github.com/nymtech/nym/pull/1143) ([octol](https://github.com/octol))
|
||||||
- Update Network Explorer Packages and add mix node identity key copy [\#1142](https://github.com/nymtech/nym/pull/1142) ([mmsinclair](https://github.com/mmsinclair))
|
- Update Network Explorer Packages and add mix node identity key copy [\#1142](https://github.com/nymtech/nym/pull/1142) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
@@ -299,14 +574,13 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- feature/pedersen-commitments [\#1048](https://github.com/nymtech/nym/pull/1048) ([danielementary](https://github.com/danielementary))
|
- feature/pedersen-commitments [\#1048](https://github.com/nymtech/nym/pull/1048) ([danielementary](https://github.com/danielementary))
|
||||||
- Feature/reuse init owner [\#970](https://github.com/nymtech/nym/pull/970) ([neacsu](https://github.com/neacsu))
|
- Feature/reuse init owner [\#970](https://github.com/nymtech/nym/pull/970) ([neacsu](https://github.com/neacsu))
|
||||||
|
|
||||||
|
|
||||||
## [v0.12.1](https://github.com/nymtech/nym/tree/v0.12.1) (2021-12-23)
|
## [v0.12.1](https://github.com/nymtech/nym/tree/v0.12.1) (2021-12-23)
|
||||||
|
|
||||||
[Full Changelog](https://github.com/nymtech/nym/compare/v0.12.0...v0.12.1)
|
[Full Changelog](https://github.com/nymtech/nym/compare/v0.12.0...v0.12.1)
|
||||||
|
|
||||||
**Implemented enhancements:**
|
**Implemented enhancements:**
|
||||||
|
|
||||||
- Add version check to binaries [\#967](https://github.com/nymtech/nym/issues/967)
|
- Add version check to binaries [\#967](https://github.com/nymtech/nym/issues/967)
|
||||||
|
|
||||||
**Fixed bugs:**
|
**Fixed bugs:**
|
||||||
|
|
||||||
@@ -336,7 +610,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Bugfix/remove mixnode bonding overwrite [\#917](https://github.com/nymtech/nym/pull/917) ([jstuczyn](https://github.com/jstuczyn))
|
- Bugfix/remove mixnode bonding overwrite [\#917](https://github.com/nymtech/nym/pull/917) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Fixes crash condition in validator API when calculating last day uptime [\#909](https://github.com/nymtech/nym/pull/909) ([jstuczyn](https://github.com/jstuczyn))
|
- Fixes crash condition in validator API when calculating last day uptime [\#909](https://github.com/nymtech/nym/pull/909) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Bugfix/monitor initial values wait [\#907](https://github.com/nymtech/nym/pull/907) ([jstuczyn](https://github.com/jstuczyn))
|
- Bugfix/monitor initial values wait [\#907](https://github.com/nymtech/nym/pull/907) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Bug fix: Network Explorer: Add freegeoip API key and split out tasks for country distributions [\#806](https://github.com/nymtech/nym/pull/806) ([mmsinclair](https://github.com/mmsinclair))
|
- Bug fix: Network Explorer: Add freegeoip API key and split out tasks for country distributions [\#806](https://github.com/nymtech/nym/pull/806) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- Explorer API: port test now split out address resolution and add units tests [\#755](https://github.com/nymtech/nym/pull/755) ([mmsinclair](https://github.com/mmsinclair))
|
- Explorer API: port test now split out address resolution and add units tests [\#755](https://github.com/nymtech/nym/pull/755) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
|
|
||||||
**Closed issues:**
|
**Closed issues:**
|
||||||
@@ -351,7 +625,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- help!!! [\#712](https://github.com/nymtech/nym/issues/712)
|
- help!!! [\#712](https://github.com/nymtech/nym/issues/712)
|
||||||
- UX feature request: show all delegated nodes in wallet [\#711](https://github.com/nymtech/nym/issues/711)
|
- UX feature request: show all delegated nodes in wallet [\#711](https://github.com/nymtech/nym/issues/711)
|
||||||
- UX feature request: add current balance on wallet pages [\#710](https://github.com/nymtech/nym/issues/710)
|
- UX feature request: add current balance on wallet pages [\#710](https://github.com/nymtech/nym/issues/710)
|
||||||
- got sign issue from bot [\#709](https://github.com/nymtech/nym/issues/709)
|
- got sign issue from bot [\#709](https://github.com/nymtech/nym/issues/709)
|
||||||
- As a wallet user, I would like to be able to log out of the wallet [\#706](https://github.com/nymtech/nym/issues/706)
|
- As a wallet user, I would like to be able to log out of the wallet [\#706](https://github.com/nymtech/nym/issues/706)
|
||||||
- As a wallet user, I would like to have a "receive" page where I can see my own wallet address [\#705](https://github.com/nymtech/nym/issues/705)
|
- As a wallet user, I would like to have a "receive" page where I can see my own wallet address [\#705](https://github.com/nymtech/nym/issues/705)
|
||||||
- Update native client/socks client/mixnode/gateway `upgrade` command [\#689](https://github.com/nymtech/nym/issues/689)
|
- Update native client/socks client/mixnode/gateway `upgrade` command [\#689](https://github.com/nymtech/nym/issues/689)
|
||||||
@@ -361,7 +635,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- nym-socks5-client crash after opening Keybase team "Browse all channels" [\#494](https://github.com/nymtech/nym/issues/494)
|
- nym-socks5-client crash after opening Keybase team "Browse all channels" [\#494](https://github.com/nymtech/nym/issues/494)
|
||||||
- Mixed Content problem [\#400](https://github.com/nymtech/nym/issues/400)
|
- Mixed Content problem [\#400](https://github.com/nymtech/nym/issues/400)
|
||||||
- Gateway disk quota [\#137](https://github.com/nymtech/nym/issues/137)
|
- Gateway disk quota [\#137](https://github.com/nymtech/nym/issues/137)
|
||||||
- Simplify message encapsulation with regards to topology [\#127](https://github.com/nymtech/nym/issues/127)
|
- Simplify message encapsulation with regards to topology [\#127](https://github.com/nymtech/nym/issues/127)
|
||||||
- Create constants for cli argument names [\#115](https://github.com/nymtech/nym/issues/115)
|
- Create constants for cli argument names [\#115](https://github.com/nymtech/nym/issues/115)
|
||||||
- Using Blake3 as a hash function [\#103](https://github.com/nymtech/nym/issues/103)
|
- Using Blake3 as a hash function [\#103](https://github.com/nymtech/nym/issues/103)
|
||||||
- Validator should decide which layer a node is in [\#86](https://github.com/nymtech/nym/issues/86)
|
- Validator should decide which layer a node is in [\#86](https://github.com/nymtech/nym/issues/86)
|
||||||
@@ -417,10 +691,10 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Feature/pre cosmrs updates [\#935](https://github.com/nymtech/nym/pull/935) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/pre cosmrs updates [\#935](https://github.com/nymtech/nym/pull/935) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Feature/client on behalf [\#934](https://github.com/nymtech/nym/pull/934) ([neacsu](https://github.com/neacsu))
|
- Feature/client on behalf [\#934](https://github.com/nymtech/nym/pull/934) ([neacsu](https://github.com/neacsu))
|
||||||
- Webpack wallet prod configuration [\#933](https://github.com/nymtech/nym/pull/933) ([tommyv1987](https://github.com/tommyv1987))
|
- Webpack wallet prod configuration [\#933](https://github.com/nymtech/nym/pull/933) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Adding tx\_hash to wallet response [\#932](https://github.com/nymtech/nym/pull/932) ([futurechimp](https://github.com/futurechimp))
|
- Adding tx_hash to wallet response [\#932](https://github.com/nymtech/nym/pull/932) ([futurechimp](https://github.com/futurechimp))
|
||||||
- Release/1.0.0 pre1 [\#931](https://github.com/nymtech/nym/pull/931) ([durch](https://github.com/durch))
|
- Release/1.0.0 pre1 [\#931](https://github.com/nymtech/nym/pull/931) ([durch](https://github.com/durch))
|
||||||
- Feature/identity verification [\#930](https://github.com/nymtech/nym/pull/930) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/identity verification [\#930](https://github.com/nymtech/nym/pull/930) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Move cleaned up smart contracts to main code repo [\#929](https://github.com/nymtech/nym/pull/929) ([mfahampshire](https://github.com/mfahampshire))
|
- Move cleaned up smart contracts to main code repo [\#929](https://github.com/nymtech/nym/pull/929) ([mfahampshire](https://github.com/mfahampshire))
|
||||||
- Feature/mixnet contract further adjustments [\#928](https://github.com/nymtech/nym/pull/928) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/mixnet contract further adjustments [\#928](https://github.com/nymtech/nym/pull/928) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- typo copy change for nodemap [\#926](https://github.com/nymtech/nym/pull/926) ([Aid19801](https://github.com/Aid19801))
|
- typo copy change for nodemap [\#926](https://github.com/nymtech/nym/pull/926) ([Aid19801](https://github.com/Aid19801))
|
||||||
- Feature/UI enhancements for Desktop Wallet [\#925](https://github.com/nymtech/nym/pull/925) ([fmtabbara](https://github.com/fmtabbara))
|
- Feature/UI enhancements for Desktop Wallet [\#925](https://github.com/nymtech/nym/pull/925) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
@@ -433,7 +707,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Feature/faucet page react [\#911](https://github.com/nymtech/nym/pull/911) ([fmtabbara](https://github.com/fmtabbara))
|
- Feature/faucet page react [\#911](https://github.com/nymtech/nym/pull/911) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Feature/mixnet contract refactor [\#910](https://github.com/nymtech/nym/pull/910) ([futurechimp](https://github.com/futurechimp))
|
- Feature/mixnet contract refactor [\#910](https://github.com/nymtech/nym/pull/910) ([futurechimp](https://github.com/futurechimp))
|
||||||
- Update README.md [\#905](https://github.com/nymtech/nym/pull/905) ([tommyv1987](https://github.com/tommyv1987))
|
- Update README.md [\#905](https://github.com/nymtech/nym/pull/905) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- BUG: Bond cell denom [\#904](https://github.com/nymtech/nym/pull/904) ([Aid19801](https://github.com/Aid19801))
|
- BUG: Bond cell denom [\#904](https://github.com/nymtech/nym/pull/904) ([Aid19801](https://github.com/Aid19801))
|
||||||
- Explorer UI tests missing data-testid [\#903](https://github.com/nymtech/nym/pull/903) ([tommyv1987](https://github.com/tommyv1987))
|
- Explorer UI tests missing data-testid [\#903](https://github.com/nymtech/nym/pull/903) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Fix up Nym-Wallet README.md [\#899](https://github.com/nymtech/nym/pull/899) ([tommyv1987](https://github.com/tommyv1987))
|
- Fix up Nym-Wallet README.md [\#899](https://github.com/nymtech/nym/pull/899) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Feature/batch delegator rewarding [\#898](https://github.com/nymtech/nym/pull/898) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/batch delegator rewarding [\#898](https://github.com/nymtech/nym/pull/898) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
@@ -451,7 +725,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Reverted gateway registration handshake to its 0.11.0 version [\#882](https://github.com/nymtech/nym/pull/882) ([jstuczyn](https://github.com/jstuczyn))
|
- Reverted gateway registration handshake to its 0.11.0 version [\#882](https://github.com/nymtech/nym/pull/882) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Network Explorer [\#881](https://github.com/nymtech/nym/pull/881) ([mmsinclair](https://github.com/mmsinclair))
|
- Network Explorer [\#881](https://github.com/nymtech/nym/pull/881) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- Feature/rewarding interval updates [\#880](https://github.com/nymtech/nym/pull/880) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/rewarding interval updates [\#880](https://github.com/nymtech/nym/pull/880) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Put client\_address and id in the correct order [\#875](https://github.com/nymtech/nym/pull/875) ([neacsu](https://github.com/neacsu))
|
- Put client_address and id in the correct order [\#875](https://github.com/nymtech/nym/pull/875) ([neacsu](https://github.com/neacsu))
|
||||||
- remove gateway selection on delegation and undelegation pages [\#873](https://github.com/nymtech/nym/pull/873) ([fmtabbara](https://github.com/fmtabbara))
|
- remove gateway selection on delegation and undelegation pages [\#873](https://github.com/nymtech/nym/pull/873) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Set MSRV on all binaries to 1.56 [\#872](https://github.com/nymtech/nym/pull/872) ([jstuczyn](https://github.com/jstuczyn))
|
- Set MSRV on all binaries to 1.56 [\#872](https://github.com/nymtech/nym/pull/872) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- add native window items \(copy/paste\) via tauri [\#871](https://github.com/nymtech/nym/pull/871) ([fmtabbara](https://github.com/fmtabbara))
|
- add native window items \(copy/paste\) via tauri [\#871](https://github.com/nymtech/nym/pull/871) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
@@ -467,7 +741,7 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Overflow checks in release [\#846](https://github.com/nymtech/nym/pull/846) ([jstuczyn](https://github.com/jstuczyn))
|
- Overflow checks in release [\#846](https://github.com/nymtech/nym/pull/846) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- fix delegate success overflow [\#842](https://github.com/nymtech/nym/pull/842) ([fmtabbara](https://github.com/fmtabbara))
|
- fix delegate success overflow [\#842](https://github.com/nymtech/nym/pull/842) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Feature NYM wallet webdriverio test [\#841](https://github.com/nymtech/nym/pull/841) ([tommyv1987](https://github.com/tommyv1987))
|
- Feature NYM wallet webdriverio test [\#841](https://github.com/nymtech/nym/pull/841) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Update nym\_wallet.yml [\#840](https://github.com/nymtech/nym/pull/840) ([tommyv1987](https://github.com/tommyv1987))
|
- Update nym_wallet.yml [\#840](https://github.com/nymtech/nym/pull/840) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Feature/vouchers [\#837](https://github.com/nymtech/nym/pull/837) ([aniampio](https://github.com/aniampio))
|
- Feature/vouchers [\#837](https://github.com/nymtech/nym/pull/837) ([aniampio](https://github.com/aniampio))
|
||||||
- Apply readable ids to elements on Nym Wallet [\#836](https://github.com/nymtech/nym/pull/836) ([tommyv1987](https://github.com/tommyv1987))
|
- Apply readable ids to elements on Nym Wallet [\#836](https://github.com/nymtech/nym/pull/836) ([tommyv1987](https://github.com/tommyv1987))
|
||||||
- Feature/removal of monitor good nodes [\#833](https://github.com/nymtech/nym/pull/833) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/removal of monitor good nodes [\#833](https://github.com/nymtech/nym/pull/833) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
@@ -491,8 +765,8 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Created getters for AccountData [\#787](https://github.com/nymtech/nym/pull/787) ([jstuczyn](https://github.com/jstuczyn))
|
- Created getters for AccountData [\#787](https://github.com/nymtech/nym/pull/787) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Feature/migrate hidden delegations [\#786](https://github.com/nymtech/nym/pull/786) ([neacsu](https://github.com/neacsu))
|
- Feature/migrate hidden delegations [\#786](https://github.com/nymtech/nym/pull/786) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/persistent gateway storage [\#784](https://github.com/nymtech/nym/pull/784) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/persistent gateway storage [\#784](https://github.com/nymtech/nym/pull/784) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Replaced unwrap\_or\_else with unwrap\_or\_default [\#780](https://github.com/nymtech/nym/pull/780) ([jstuczyn](https://github.com/jstuczyn))
|
- Replaced unwrap_or_else with unwrap_or_default [\#780](https://github.com/nymtech/nym/pull/780) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Add block\_height method to Delegation [\#778](https://github.com/nymtech/nym/pull/778) ([durch](https://github.com/durch))
|
- Add block_height method to Delegation [\#778](https://github.com/nymtech/nym/pull/778) ([durch](https://github.com/durch))
|
||||||
- Make fee helpers public [\#777](https://github.com/nymtech/nym/pull/777) ([durch](https://github.com/durch))
|
- Make fee helpers public [\#777](https://github.com/nymtech/nym/pull/777) ([durch](https://github.com/durch))
|
||||||
- re-enable bonding [\#776](https://github.com/nymtech/nym/pull/776) ([fmtabbara](https://github.com/fmtabbara))
|
- re-enable bonding [\#776](https://github.com/nymtech/nym/pull/776) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Explorer-api: add API resource to show the delegations for each mix node [\#774](https://github.com/nymtech/nym/pull/774) ([mmsinclair](https://github.com/mmsinclair))
|
- Explorer-api: add API resource to show the delegations for each mix node [\#774](https://github.com/nymtech/nym/pull/774) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
@@ -501,14 +775,14 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Adding deps for building the Tauri wallet under Ubuntu [\#770](https://github.com/nymtech/nym/pull/770) ([futurechimp](https://github.com/futurechimp))
|
- Adding deps for building the Tauri wallet under Ubuntu [\#770](https://github.com/nymtech/nym/pull/770) ([futurechimp](https://github.com/futurechimp))
|
||||||
- remove alert [\#767](https://github.com/nymtech/nym/pull/767) ([fmtabbara](https://github.com/fmtabbara))
|
- remove alert [\#767](https://github.com/nymtech/nym/pull/767) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Feature/consumable bandwidth [\#766](https://github.com/nymtech/nym/pull/766) ([neacsu](https://github.com/neacsu))
|
- Feature/consumable bandwidth [\#766](https://github.com/nymtech/nym/pull/766) ([neacsu](https://github.com/neacsu))
|
||||||
- Update coconut-rs and use hash\_to\_scalar from there [\#765](https://github.com/nymtech/nym/pull/765) ([neacsu](https://github.com/neacsu))
|
- Update coconut-rs and use hash_to_scalar from there [\#765](https://github.com/nymtech/nym/pull/765) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/active sets [\#764](https://github.com/nymtech/nym/pull/764) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/active sets [\#764](https://github.com/nymtech/nym/pull/764) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- add app alert banner [\#762](https://github.com/nymtech/nym/pull/762) ([fmtabbara](https://github.com/fmtabbara))
|
- add app alert banner [\#762](https://github.com/nymtech/nym/pull/762) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Updated cosmos-sdk [\#761](https://github.com/nymtech/nym/pull/761) ([jstuczyn](https://github.com/jstuczyn))
|
- Updated cosmos-sdk [\#761](https://github.com/nymtech/nym/pull/761) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Feature/bond blockstamp [\#760](https://github.com/nymtech/nym/pull/760) ([neacsu](https://github.com/neacsu))
|
- Feature/bond blockstamp [\#760](https://github.com/nymtech/nym/pull/760) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/revert migration code [\#759](https://github.com/nymtech/nym/pull/759) ([neacsu](https://github.com/neacsu))
|
- Feature/revert migration code [\#759](https://github.com/nymtech/nym/pull/759) ([neacsu](https://github.com/neacsu))
|
||||||
- Bump next from 11.1.0 to 11.1.1 in /wallet-web [\#758](https://github.com/nymtech/nym/pull/758) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump next from 11.1.0 to 11.1.1 in /wallet-web [\#758](https://github.com/nymtech/nym/pull/758) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Add block\_height in the Delegation structure as well [\#757](https://github.com/nymtech/nym/pull/757) ([neacsu](https://github.com/neacsu))
|
- Add block_height in the Delegation structure as well [\#757](https://github.com/nymtech/nym/pull/757) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/add blockstamp [\#756](https://github.com/nymtech/nym/pull/756) ([neacsu](https://github.com/neacsu))
|
- Feature/add blockstamp [\#756](https://github.com/nymtech/nym/pull/756) ([neacsu](https://github.com/neacsu))
|
||||||
- NetworkMonitorBuilder - starting the monitor after rocket has launched [\#754](https://github.com/nymtech/nym/pull/754) ([jstuczyn](https://github.com/jstuczyn))
|
- NetworkMonitorBuilder - starting the monitor after rocket has launched [\#754](https://github.com/nymtech/nym/pull/754) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Enabled validators api argument [\#753](https://github.com/nymtech/nym/pull/753) ([jstuczyn](https://github.com/jstuczyn))
|
- Enabled validators api argument [\#753](https://github.com/nymtech/nym/pull/753) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
@@ -520,21 +794,21 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Feature/more reliable uptime calculation [\#747](https://github.com/nymtech/nym/pull/747) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/more reliable uptime calculation [\#747](https://github.com/nymtech/nym/pull/747) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Update template toml key [\#746](https://github.com/nymtech/nym/pull/746) ([neacsu](https://github.com/neacsu))
|
- Update template toml key [\#746](https://github.com/nymtech/nym/pull/746) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/cred after handshake [\#745](https://github.com/nymtech/nym/pull/745) ([neacsu](https://github.com/neacsu))
|
- Feature/cred after handshake [\#745](https://github.com/nymtech/nym/pull/745) ([neacsu](https://github.com/neacsu))
|
||||||
- Reinstate the POST method blind\_sign [\#744](https://github.com/nymtech/nym/pull/744) ([neacsu](https://github.com/neacsu))
|
- Reinstate the POST method blind_sign [\#744](https://github.com/nymtech/nym/pull/744) ([neacsu](https://github.com/neacsu))
|
||||||
- explorer-api: add pending field to port check response [\#742](https://github.com/nymtech/nym/pull/742) ([mmsinclair](https://github.com/mmsinclair))
|
- explorer-api: add pending field to port check response [\#742](https://github.com/nymtech/nym/pull/742) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- Feature/use delegation rates [\#741](https://github.com/nymtech/nym/pull/741) ([neacsu](https://github.com/neacsu))
|
- Feature/use delegation rates [\#741](https://github.com/nymtech/nym/pull/741) ([neacsu](https://github.com/neacsu))
|
||||||
- Feature/copy to clipboard [\#740](https://github.com/nymtech/nym/pull/740) ([fmtabbara](https://github.com/fmtabbara))
|
- Feature/copy to clipboard [\#740](https://github.com/nymtech/nym/pull/740) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Feature/update wallet with stake rates [\#739](https://github.com/nymtech/nym/pull/739) ([neacsu](https://github.com/neacsu))
|
- Feature/update wallet with stake rates [\#739](https://github.com/nymtech/nym/pull/739) ([neacsu](https://github.com/neacsu))
|
||||||
- Add stake reward rates and bump version of client [\#738](https://github.com/nymtech/nym/pull/738) ([neacsu](https://github.com/neacsu))
|
- Add stake reward rates and bump version of client [\#738](https://github.com/nymtech/nym/pull/738) ([neacsu](https://github.com/neacsu))
|
||||||
- Bump next from 10.1.3 to 11.1.0 in /wallet-web [\#737](https://github.com/nymtech/nym/pull/737) ([dependabot[bot]](https://github.com/apps/dependabot))
|
- Bump next from 10.1.3 to 11.1.0 in /wallet-web [\#737](https://github.com/nymtech/nym/pull/737) ([dependabot[bot]](https://github.com/apps/dependabot))
|
||||||
- Feature/nymd client integration [\#736](https://github.com/nymtech/nym/pull/736) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/nyxd client integration [\#736](https://github.com/nymtech/nym/pull/736) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Bug/fix parking lot on wasm [\#735](https://github.com/nymtech/nym/pull/735) ([neacsu](https://github.com/neacsu))
|
- Bug/fix parking lot on wasm [\#735](https://github.com/nymtech/nym/pull/735) ([neacsu](https://github.com/neacsu))
|
||||||
- Explorer API: add new HTTP resource to decorate mix nodes with geoip locations [\#734](https://github.com/nymtech/nym/pull/734) ([mmsinclair](https://github.com/mmsinclair))
|
- Explorer API: add new HTTP resource to decorate mix nodes with geoip locations [\#734](https://github.com/nymtech/nym/pull/734) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- Feature/completing nymd client api [\#732](https://github.com/nymtech/nym/pull/732) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/completing nyxd client api [\#732](https://github.com/nymtech/nym/pull/732) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Explorer API - add port check and node description/stats proxy [\#731](https://github.com/nymtech/nym/pull/731) ([mmsinclair](https://github.com/mmsinclair))
|
- Explorer API - add port check and node description/stats proxy [\#731](https://github.com/nymtech/nym/pull/731) ([mmsinclair](https://github.com/mmsinclair))
|
||||||
- Feature/nymd client fee handling [\#730](https://github.com/nymtech/nym/pull/730) ([jstuczyn](https://github.com/jstuczyn))
|
- Feature/nyxd client fee handling [\#730](https://github.com/nymtech/nym/pull/730) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Update DelegationCheck.tsx [\#725](https://github.com/nymtech/nym/pull/725) ([jessgess](https://github.com/jessgess))
|
- Update DelegationCheck.tsx [\#725](https://github.com/nymtech/nym/pull/725) ([jessgess](https://github.com/jessgess))
|
||||||
- Rust nymd/cosmwasm client [\#724](https://github.com/nymtech/nym/pull/724) ([jstuczyn](https://github.com/jstuczyn))
|
- Rust nyxd/cosmwasm client [\#724](https://github.com/nymtech/nym/pull/724) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Removed wasm feature bypassing cyclic dependencies [\#723](https://github.com/nymtech/nym/pull/723) ([jstuczyn](https://github.com/jstuczyn))
|
- Removed wasm feature bypassing cyclic dependencies [\#723](https://github.com/nymtech/nym/pull/723) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Updated used sphinx dependency to the most recent revision [\#722](https://github.com/nymtech/nym/pull/722) ([jstuczyn](https://github.com/jstuczyn))
|
- Updated used sphinx dependency to the most recent revision [\#722](https://github.com/nymtech/nym/pull/722) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- update state management and validation [\#721](https://github.com/nymtech/nym/pull/721) ([fmtabbara](https://github.com/fmtabbara))
|
- update state management and validation [\#721](https://github.com/nymtech/nym/pull/721) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
@@ -553,10 +827,8 @@ Post 1.0.0 release, the changelog format is based on [Keep a Changelog](https://
|
|||||||
- Bond and delegation alerts [\#698](https://github.com/nymtech/nym/pull/698) ([fmtabbara](https://github.com/fmtabbara))
|
- Bond and delegation alerts [\#698](https://github.com/nymtech/nym/pull/698) ([fmtabbara](https://github.com/fmtabbara))
|
||||||
- Bugfix/network monitor version check [\#697](https://github.com/nymtech/nym/pull/697) ([jstuczyn](https://github.com/jstuczyn))
|
- Bugfix/network monitor version check [\#697](https://github.com/nymtech/nym/pull/697) ([jstuczyn](https://github.com/jstuczyn))
|
||||||
- Feature/other containers [\#692](https://github.com/nymtech/nym/pull/692) ([neacsu](https://github.com/neacsu))
|
- Feature/other containers [\#692](https://github.com/nymtech/nym/pull/692) ([neacsu](https://github.com/neacsu))
|
||||||
- Using validator API instead of nymd [\#690](https://github.com/nymtech/nym/pull/690) ([futurechimp](https://github.com/futurechimp))
|
- Using validator API instead of nyxd [\#690](https://github.com/nymtech/nym/pull/690) ([futurechimp](https://github.com/futurechimp))
|
||||||
- Hang coconut issuance off the validator-api [\#679](https://github.com/nymtech/nym/pull/679) ([durch](https://github.com/durch))
|
- Hang coconut issuance off the validator-api [\#679](https://github.com/nymtech/nym/pull/679) ([durch](https://github.com/durch))
|
||||||
- Update hmac and blake3 [\#673](https://github.com/nymtech/nym/pull/673) ([durch](https://github.com/durch))
|
- Update hmac and blake3 [\#673](https://github.com/nymtech/nym/pull/673) ([durch](https://github.com/durch))
|
||||||
|
|
||||||
|
\* _This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)_
|
||||||
|
|
||||||
\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)*
|
|
||||||
|
|||||||
Generated
+2618
-2081
File diff suppressed because it is too large
Load Diff
+49
-10
@@ -17,33 +17,35 @@ opt-level = 3
|
|||||||
|
|
||||||
resolver = "2"
|
resolver = "2"
|
||||||
members = [
|
members = [
|
||||||
"clients/client-core",
|
|
||||||
"clients/credential",
|
"clients/credential",
|
||||||
"clients/native",
|
"clients/native",
|
||||||
"clients/native/websocket-requests",
|
"clients/native/websocket-requests",
|
||||||
"clients/socks5",
|
"clients/socks5",
|
||||||
"common/bandwidth-claim-contract",
|
"common/async-file-watcher",
|
||||||
|
"common/bandwidth-controller",
|
||||||
|
"common/bin-common",
|
||||||
|
"common/client-core",
|
||||||
"common/client-libs/gateway-client",
|
"common/client-libs/gateway-client",
|
||||||
"common/client-libs/mixnet-client",
|
"common/client-libs/mixnet-client",
|
||||||
"common/client-libs/validator-client",
|
"common/client-libs/validator-client",
|
||||||
"common/client-connections",
|
|
||||||
"common/coconut-interface",
|
"common/coconut-interface",
|
||||||
"common/commands",
|
"common/commands",
|
||||||
"common/config",
|
"common/config",
|
||||||
"common/cosmwasm-smart-contracts/coconut-bandwidth-contract",
|
"common/cosmwasm-smart-contracts/coconut-bandwidth-contract",
|
||||||
"common/cosmwasm-smart-contracts/coconut-dkg",
|
"common/cosmwasm-smart-contracts/coconut-dkg",
|
||||||
"common/cosmwasm-smart-contracts/contracts-common",
|
"common/cosmwasm-smart-contracts/contracts-common",
|
||||||
|
"common/cosmwasm-smart-contracts/group-contract",
|
||||||
"common/cosmwasm-smart-contracts/mixnet-contract",
|
"common/cosmwasm-smart-contracts/mixnet-contract",
|
||||||
"common/cosmwasm-smart-contracts/multisig-contract",
|
"common/cosmwasm-smart-contracts/multisig-contract",
|
||||||
|
"common/cosmwasm-smart-contracts/service-provider-directory",
|
||||||
"common/cosmwasm-smart-contracts/vesting-contract",
|
"common/cosmwasm-smart-contracts/vesting-contract",
|
||||||
"common/credential-storage",
|
"common/credential-storage",
|
||||||
"common/credentials",
|
"common/credentials",
|
||||||
"common/crypto",
|
"common/crypto",
|
||||||
"common/crypto/dkg",
|
"common/dkg",
|
||||||
"common/execute",
|
"common/execute",
|
||||||
"common/inclusion-probability",
|
"common/inclusion-probability",
|
||||||
"common/ledger",
|
"common/ledger",
|
||||||
"common/logging",
|
|
||||||
"common/mixnode-common",
|
"common/mixnode-common",
|
||||||
"common/network-defaults",
|
"common/network-defaults",
|
||||||
"common/nonexhaustive-delayqueue",
|
"common/nonexhaustive-delayqueue",
|
||||||
@@ -59,6 +61,7 @@ members = [
|
|||||||
"common/nymsphinx/params",
|
"common/nymsphinx/params",
|
||||||
"common/nymsphinx/types",
|
"common/nymsphinx/types",
|
||||||
"common/pemstore",
|
"common/pemstore",
|
||||||
|
"common/socks5-client-core",
|
||||||
"common/socks5/proxy-helpers",
|
"common/socks5/proxy-helpers",
|
||||||
"common/socks5/requests",
|
"common/socks5/requests",
|
||||||
"common/statistics",
|
"common/statistics",
|
||||||
@@ -66,16 +69,18 @@ members = [
|
|||||||
"common/topology",
|
"common/topology",
|
||||||
"common/types",
|
"common/types",
|
||||||
"common/wasm-utils",
|
"common/wasm-utils",
|
||||||
"common/completions",
|
|
||||||
"explorer-api",
|
"explorer-api",
|
||||||
"gateway",
|
"gateway",
|
||||||
"gateway/gateway-requests",
|
"gateway/gateway-requests",
|
||||||
"integrations/bity",
|
"integrations/bity",
|
||||||
"mixnode",
|
"mixnode",
|
||||||
|
"sdk/rust/nym-sdk",
|
||||||
|
"service-providers/common",
|
||||||
"service-providers/network-requester",
|
"service-providers/network-requester",
|
||||||
"service-providers/network-statistics",
|
"service-providers/network-statistics",
|
||||||
"validator-api",
|
"nym-api",
|
||||||
"validator-api/validator-api-requests",
|
"nym-api/nym-api-requests",
|
||||||
|
"nym-outfox",
|
||||||
"tools/nym-cli",
|
"tools/nym-cli",
|
||||||
"tools/ts-rs-cli"
|
"tools/ts-rs-cli"
|
||||||
]
|
]
|
||||||
@@ -87,8 +92,42 @@ default-members = [
|
|||||||
"service-providers/network-requester",
|
"service-providers/network-requester",
|
||||||
"service-providers/network-statistics",
|
"service-providers/network-statistics",
|
||||||
"mixnode",
|
"mixnode",
|
||||||
"validator-api",
|
"nym-api",
|
||||||
"explorer-api",
|
"explorer-api",
|
||||||
]
|
]
|
||||||
|
|
||||||
exclude = ["explorer", "contracts", "clients/webassembly", "nym-wallet", "nym-connect"]
|
exclude = ["explorer", "contracts", "clients/webassembly", "nym-wallet", "nym-connect/mobile/src-tauri", "nym-connect/desktop", "cpu-cycles"]
|
||||||
|
|
||||||
|
[workspace.package]
|
||||||
|
authors = ["Nym Technologies SA"]
|
||||||
|
repository = "https://github.com/nymtech/nym"
|
||||||
|
homepage = "https://nymtech.net"
|
||||||
|
documentation = "https://nymtech.net"
|
||||||
|
edition = "2021"
|
||||||
|
license = "Apache-2.0"
|
||||||
|
|
||||||
|
[workspace.dependencies]
|
||||||
|
async-trait = "0.1.64"
|
||||||
|
bip39 = { version = "2.0.0", features = ["zeroize"] }
|
||||||
|
cfg-if = "1.0.0"
|
||||||
|
cosmwasm-derive = "=1.0.0"
|
||||||
|
cosmwasm-schema = "=1.0.0"
|
||||||
|
cosmwasm-std = "=1.0.0"
|
||||||
|
cosmwasm-storage = "=1.0.0"
|
||||||
|
cw-utils = "=0.13.4"
|
||||||
|
cw-storage-plus = "=0.13.4"
|
||||||
|
cw2 = { version = "=0.13.4" }
|
||||||
|
cw3 = { version = "=0.13.4" }
|
||||||
|
cw3-fixed-multisig = { version = "=0.13.4" }
|
||||||
|
cw4 = { version = "=0.13.4" }
|
||||||
|
dotenvy = "0.15.6"
|
||||||
|
lazy_static = "1.4.0"
|
||||||
|
log = "0.4"
|
||||||
|
once_cell = "1.7.2"
|
||||||
|
rand = "0.8.5"
|
||||||
|
serde = "1.0.152"
|
||||||
|
serde_json = "1.0.91"
|
||||||
|
tap = "1.0.1"
|
||||||
|
thiserror = "1.0.38"
|
||||||
|
tokio = "1.24.1"
|
||||||
|
url = "2.2"
|
||||||
|
|||||||
@@ -1,127 +1,122 @@
|
|||||||
|
# Default target
|
||||||
|
all: test
|
||||||
|
|
||||||
test: clippy-all cargo-test wasm fmt
|
test: clippy-all cargo-test wasm fmt
|
||||||
|
|
||||||
test-all: test cargo-test-expensive
|
test-all: test cargo-test-expensive
|
||||||
|
|
||||||
no-clippy: build cargo-test wasm fmt
|
no-clippy: build cargo-test wasm fmt
|
||||||
|
|
||||||
happy: fmt clippy-happy test
|
happy: fmt clippy-happy test
|
||||||
clippy-all: clippy-main clippy-coconut clippy-all-contracts clippy-all-wallet clippy-all-connect clippy-all-wasm-client
|
|
||||||
clippy-happy: clippy-happy-main clippy-happy-contracts clippy-happy-wallet clippy-happy-connect
|
|
||||||
cargo-test: test-main test-contracts test-wallet test-connect test-coconut test-wasm-client
|
|
||||||
cargo-test-expensive: test-main-expensive test-contracts-expensive test-wallet-expensive test-connect-expensive test-coconut-expensive
|
|
||||||
build: build-contracts build-wallet build-main build-connect build-wasm-client
|
|
||||||
fmt: fmt-main fmt-contracts fmt-wallet fmt-connect fmt-wasm-client
|
|
||||||
|
|
||||||
clippy-happy-main:
|
# Building release binaries is a little manual as we can't just build --release
|
||||||
cargo clippy
|
# on all workspaces.
|
||||||
|
build-release: build-release-main wasm
|
||||||
|
|
||||||
clippy-happy-contracts:
|
# -----------------------------------------------------------------------------
|
||||||
cargo clippy --manifest-path contracts/Cargo.toml --target wasm32-unknown-unknown
|
# Define targets for a given workspace
|
||||||
|
# $(1): name
|
||||||
|
# $(2): path to workspace
|
||||||
|
# $(3): extra arguments to cargo
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
define add_cargo_workspace
|
||||||
|
|
||||||
clippy-happy-wallet:
|
clippy-happy-$(1):
|
||||||
cargo clippy --manifest-path nym-wallet/Cargo.toml
|
cargo clippy --manifest-path $(2)/Cargo.toml $(3)
|
||||||
|
|
||||||
clippy-happy-connect:
|
clippy-$(1):
|
||||||
cargo clippy --manifest-path nym-connect/Cargo.toml
|
cargo clippy --manifest-path $(2)/Cargo.toml --workspace $(3) -- -D warnings
|
||||||
|
|
||||||
clippy-main:
|
clippy-examples-$(1):
|
||||||
cargo clippy --workspace -- -D warnings
|
cargo clippy --manifest-path $(2)/Cargo.toml --workspace --examples -- -D warnings
|
||||||
|
|
||||||
clippy-coconut:
|
check-$(1):
|
||||||
cargo clippy --workspace --features coconut -- -D warnings
|
cargo check --manifest-path $(2)/Cargo.toml --workspace $(3)
|
||||||
|
|
||||||
clippy-wasm:
|
test-$(1):
|
||||||
cargo clippy --workspace --features wasm -- -D warnings
|
cargo test --manifest-path $(2)/Cargo.toml --workspace
|
||||||
|
|
||||||
|
test-expensive-$(1):
|
||||||
|
cargo test --manifest-path $(2)/Cargo.toml --workspace -- --ignored
|
||||||
|
|
||||||
clippy-all-contracts:
|
build-$(1):
|
||||||
cargo clippy --workspace --manifest-path contracts/Cargo.toml --all-features --target wasm32-unknown-unknown -- -D warnings
|
cargo build --manifest-path $(2)/Cargo.toml --workspace $(3)
|
||||||
|
|
||||||
clippy-all-wallet:
|
build-examples-$(1):
|
||||||
cargo clippy --workspace --manifest-path nym-wallet/Cargo.toml --all-features -- -D warnings
|
cargo build --manifest-path $(2)/Cargo.toml --workspace --examples
|
||||||
|
|
||||||
clippy-all-connect:
|
build-release-$(1):
|
||||||
cargo clippy --workspace --manifest-path nym-connect/Cargo.toml --all-features -- -D warnings
|
cargo build --manifest-path $(2)/Cargo.toml --workspace --release $(3)
|
||||||
|
|
||||||
clippy-all-wasm-client:
|
fmt-$(1):
|
||||||
cargo clippy --workspace --manifest-path clients/webassembly/Cargo.toml --all-features --target wasm32-unknown-unknown -- -D warnings
|
cargo fmt --manifest-path $(2)/Cargo.toml --all
|
||||||
|
|
||||||
test-main:
|
clippy-happy: clippy-happy-$(1)
|
||||||
cargo test --workspace
|
clippy-all: clippy-$(1) clippy-examples-$(1)
|
||||||
|
check: check-$(1)
|
||||||
|
cargo-test: test-$(1)
|
||||||
|
cargo-test-expensive: test-expensive-$(1)
|
||||||
|
build: build-$(1) build-$(1)-examples
|
||||||
|
build-release-all: build-release-$(1)
|
||||||
|
fmt: fmt-$(1)
|
||||||
|
|
||||||
test-coconut:
|
endef
|
||||||
cargo test --workspace --features coconut
|
|
||||||
|
|
||||||
test-wasm:
|
# -----------------------------------------------------------------------------
|
||||||
cargo test --workspace --features wasm
|
# Rust workspaces
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# Generate targets for the various cargo workspaces
|
||||||
|
|
||||||
test-main-expensive:
|
$(eval $(call add_cargo_workspace,main,.))
|
||||||
cargo test --workspace -- --ignored
|
$(eval $(call add_cargo_workspace,contracts,contracts,--target wasm32-unknown-unknown))
|
||||||
|
$(eval $(call add_cargo_workspace,wasm-client,clients/webassembly,--target wasm32-unknown-unknown))
|
||||||
|
$(eval $(call add_cargo_workspace,wallet,nym-wallet,))
|
||||||
|
$(eval $(call add_cargo_workspace,connect,nym-connect/desktop))
|
||||||
|
ifdef NYM_MOBILE
|
||||||
|
$(eval $(call add_cargo_workspace,connect-mobile,nym-connect/mobile/src-tauri))
|
||||||
|
endif
|
||||||
|
|
||||||
test-coconut-expensive:
|
# -----------------------------------------------------------------------------
|
||||||
cargo test --workspace --features coconut -- --ignored
|
# Convenience targets for crates that are already part of the main workspace
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
test-contracts:
|
|
||||||
cargo test --manifest-path contracts/Cargo.toml --all-features
|
|
||||||
|
|
||||||
test-contracts-expensive:
|
|
||||||
cargo test --manifest-path contracts/Cargo.toml --all-features -- --ignored
|
|
||||||
|
|
||||||
test-wallet:
|
|
||||||
cargo test --manifest-path nym-wallet/Cargo.toml --all-features
|
|
||||||
|
|
||||||
test-wallet-expensive:
|
|
||||||
cargo test --manifest-path nym-wallet/Cargo.toml --all-features -- --ignored
|
|
||||||
|
|
||||||
test-wasm-client:
|
|
||||||
cargo test --workspace --manifest-path clients/webassembly/Cargo.toml --all-features
|
|
||||||
|
|
||||||
test-connect:
|
|
||||||
cargo test --manifest-path nym-connect/Cargo.toml --all-features
|
|
||||||
|
|
||||||
test-connect-expensive:
|
|
||||||
cargo test --manifest-path nym-connect/Cargo.toml --all-features -- --ignored
|
|
||||||
|
|
||||||
build-main:
|
|
||||||
cargo build --workspace
|
|
||||||
|
|
||||||
build-contracts:
|
|
||||||
cargo build --manifest-path contracts/Cargo.toml --workspace
|
|
||||||
|
|
||||||
build-wallet:
|
|
||||||
cargo build --manifest-path nym-wallet/Cargo.toml --workspace
|
|
||||||
|
|
||||||
build-connect:
|
|
||||||
cargo build --manifest-path nym-connect/Cargo.toml --workspace
|
|
||||||
|
|
||||||
build-explorer-api:
|
build-explorer-api:
|
||||||
cargo build --manifest-path explorer-api/Cargo.toml --workspace
|
cargo build -p explorer-api
|
||||||
|
|
||||||
build-wasm-client:
|
|
||||||
cargo build --manifest-path clients/webassembly/Cargo.toml --workspace --target wasm32-unknown-unknown
|
|
||||||
|
|
||||||
build-nym-cli:
|
build-nym-cli:
|
||||||
cargo build --release --manifest-path tools/nym-cli/Cargo.toml
|
cargo build -p nym-cli --release
|
||||||
|
|
||||||
fmt-main:
|
# -----------------------------------------------------------------------------
|
||||||
cargo fmt --all
|
# Build contracts ready for deploy
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
|
||||||
fmt-contracts:
|
CONTRACTS_OUT_DIR=contracts/target/wasm32-unknown-unknown/release
|
||||||
cargo fmt --manifest-path contracts/Cargo.toml --all
|
VESTING_CONTRACT=$(CONTRACTS_OUT_DIR)/vesting_contract.wasm
|
||||||
|
MIXNET_CONTRACT=$(CONTRACTS_OUT_DIR)/mixnet_contract.wasm
|
||||||
|
SERVICE_PROVIDER_DIRECTORY_CONTRACT=$(CONTRACTS_OUT_DIR)/nym_service_provider_directory.wasm
|
||||||
|
|
||||||
fmt-wallet:
|
wasm: wasm-build wasm-opt
|
||||||
cargo fmt --manifest-path nym-wallet/Cargo.toml --all
|
|
||||||
|
|
||||||
fmt-connect:
|
wasm-build:
|
||||||
cargo fmt --manifest-path nym-connect/Cargo.toml --all
|
|
||||||
|
|
||||||
fmt-wasm-client:
|
|
||||||
cargo fmt --manifest-path clients/webassembly/Cargo.toml --all
|
|
||||||
|
|
||||||
wasm:
|
|
||||||
RUSTFLAGS='-C link-arg=-s' cargo build --manifest-path contracts/Cargo.toml --release --target wasm32-unknown-unknown
|
RUSTFLAGS='-C link-arg=-s' cargo build --manifest-path contracts/Cargo.toml --release --target wasm32-unknown-unknown
|
||||||
|
|
||||||
|
wasm-opt:
|
||||||
|
wasm-opt --disable-sign-ext -Os $(VESTING_CONTRACT) -o $(VESTING_CONTRACT)
|
||||||
|
wasm-opt --disable-sign-ext -Os $(MIXNET_CONTRACT) -o $(MIXNET_CONTRACT)
|
||||||
|
wasm-opt --disable-sign-ext -Os $(SERVICE_PROVIDER_DIRECTORY_CONTRACT) -o $(SERVICE_PROVIDER_DIRECTORY_CONTRACT)
|
||||||
|
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
# Misc
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# NOTE: this seems deprecated an not needed anymore?
|
||||||
mixnet-opt: wasm
|
mixnet-opt: wasm
|
||||||
cd contracts/mixnet && make opt
|
cd contracts/mixnet && make opt
|
||||||
|
|
||||||
generate-typescript:
|
generate-typescript:
|
||||||
cd tools/ts-rs-cli && cargo run && cd ../..
|
cd tools/ts-rs-cli && cargo run && cd ../..
|
||||||
yarn types:lint:fix
|
yarn types:lint:fix
|
||||||
|
|
||||||
|
run-api-tests:
|
||||||
|
cd nym-api/tests/functional_test && yarn test:qa
|
||||||
|
|||||||
@@ -16,12 +16,12 @@ The platform is composed of multiple Rust crates. Top-level executable binary cr
|
|||||||
* nym-wallet - a desktop wallet implemented using the [Tauri](https://tauri.studio/en/docs/about/intro) framework.
|
* nym-wallet - a desktop wallet implemented using the [Tauri](https://tauri.studio/en/docs/about/intro) framework.
|
||||||
|
|
||||||
[](https://opensource.org/licenses/Apache-2.0)
|
[](https://opensource.org/licenses/Apache-2.0)
|
||||||
[](https://github.com/nymtech/nym/actions?query=branch%3Adevelop)
|
[](https://github.com/nymtech/nym/actions?query=branch%3Adevelop)
|
||||||
|
|
||||||
|
|
||||||
### Building
|
### Building
|
||||||
|
|
||||||
Platform build instructions are available on [our docs site](https://nymtech.net/docs/stable/run-nym-nodes/build-nym).
|
Platform build instructions are available on [our docs site](https://nymtech.net/docs/binaries/building-nym.html).
|
||||||
Wallet build instructions are also available on [our docs site](https://nymtech.net/docs/stable/nym-apps/wallet#for-developers).
|
Wallet build instructions are also available on [our docs site](https://nymtech.net/docs/stable/nym-apps/wallet#for-developers).
|
||||||
|
|
||||||
### Developing
|
### Developing
|
||||||
|
|||||||
+3
-3
@@ -3,8 +3,8 @@ Critical bug or security issue 💥
|
|||||||
If you're here because you're trying to figure out how to notify us of a security issue, go to Discord, and alert the core engineers:
|
If you're here because you're trying to figure out how to notify us of a security issue, go to Discord, and alert the core engineers:
|
||||||
|
|
||||||
Dave Hrycyszyn futurechimp#5430
|
Dave Hrycyszyn futurechimp#5430
|
||||||
Drazen Urch drazen#4873
|
|
||||||
Jedrzej Stuczynski "Jedrzej | Nym#5666"
|
Jedrzej Stuczynski "Jedrzej | Nym#5666"
|
||||||
|
Fran Arbanas | franarbanas#0995
|
||||||
|
Mark Sinclair | marknym#8088
|
||||||
|
|
||||||
|
Please avoid opening public issues on GitHub that contain information about a potential security vulnerability as this makes it difficult to reduce the impact and harm of valid security issues.
|
||||||
Please avoid opening public issues on GitHub that contain information about a potential security vulnerability as this makes it difficult to reduce the impact and harm of valid security issues.
|
|
||||||
|
|||||||
@@ -1,61 +0,0 @@
|
|||||||
[package]
|
|
||||||
name = "client-core"
|
|
||||||
version = "1.1.2"
|
|
||||||
authors = ["Dave Hrycyszyn <futurechimp@users.noreply.github.com>"]
|
|
||||||
edition = "2021"
|
|
||||||
|
|
||||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
|
||||||
|
|
||||||
[dependencies]
|
|
||||||
dirs = "4.0"
|
|
||||||
futures = "0.3"
|
|
||||||
humantime-serde = "1.0"
|
|
||||||
log = "0.4"
|
|
||||||
rand = { version = "0.7.3", features = ["wasm-bindgen"] }
|
|
||||||
serde = { version = "1.0", features = ["derive"] }
|
|
||||||
sled = { version = "0.34", optional = true }
|
|
||||||
tap = "1.0.1"
|
|
||||||
thiserror = "1.0.34"
|
|
||||||
url = { version ="2.2", features = ["serde"] }
|
|
||||||
|
|
||||||
# internal
|
|
||||||
config = { path = "../../common/config" }
|
|
||||||
client-connections = { path = "../../common/client-connections" }
|
|
||||||
crypto = { path = "../../common/crypto" }
|
|
||||||
gateway-client = { path = "../../common/client-libs/gateway-client" }
|
|
||||||
#gateway-client = { path = "../../common/client-libs/gateway-client", default-features = false, features = ["wasm", "coconut"] }
|
|
||||||
gateway-requests = { path = "../../gateway/gateway-requests" }
|
|
||||||
nonexhaustive-delayqueue = { path = "../../common/nonexhaustive-delayqueue" }
|
|
||||||
nymsphinx = { path = "../../common/nymsphinx" }
|
|
||||||
pemstore = { path = "../../common/pemstore" }
|
|
||||||
topology = { path = "../../common/topology" }
|
|
||||||
validator-client = { path = "../../common/client-libs/validator-client", default-features = false }
|
|
||||||
|
|
||||||
tokio = { version = "1.21.2", features = ["time", "macros"]}
|
|
||||||
|
|
||||||
[target."cfg(target_arch = \"wasm32\")".dependencies.wasm-bindgen-futures]
|
|
||||||
version = "0.4"
|
|
||||||
|
|
||||||
[target."cfg(target_arch = \"wasm32\")".dependencies.wasm-bindgen]
|
|
||||||
version = "0.2.83"
|
|
||||||
|
|
||||||
[target."cfg(target_arch = \"wasm32\")".dependencies.wasm-timer]
|
|
||||||
git = "https://github.com/mmsinclair/wasm-timer"
|
|
||||||
rev = "b9d1a54ad514c2f230a026afe0dde341e98cd7b6"
|
|
||||||
|
|
||||||
[target."cfg(target_arch = \"wasm32\")".dependencies.gloo-timers]
|
|
||||||
version = "0.2.4"
|
|
||||||
features = ["futures"]
|
|
||||||
|
|
||||||
[target."cfg(not(target_arch = \"wasm32\"))".dependencies.task]
|
|
||||||
path = "../../common/task"
|
|
||||||
|
|
||||||
[dev-dependencies]
|
|
||||||
tempfile = "3.1.0"
|
|
||||||
|
|
||||||
[features]
|
|
||||||
default = ["reply-surb"]
|
|
||||||
wasm = ["gateway-client/wasm"]
|
|
||||||
coconut = ["gateway-client/coconut", "gateway-requests/coconut"]
|
|
||||||
reply-surb = ["sled"]
|
|
||||||
|
|
||||||
@@ -1,40 +0,0 @@
|
|||||||
use client_connections::TransmissionLane;
|
|
||||||
use nymsphinx::addressing::clients::Recipient;
|
|
||||||
use nymsphinx::anonymous_replies::ReplySurb;
|
|
||||||
|
|
||||||
pub type InputMessageSender = tokio::sync::mpsc::Sender<InputMessage>;
|
|
||||||
pub type InputMessageReceiver = tokio::sync::mpsc::Receiver<InputMessage>;
|
|
||||||
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub enum InputMessage {
|
|
||||||
Fresh {
|
|
||||||
recipient: Recipient,
|
|
||||||
data: Vec<u8>,
|
|
||||||
with_reply_surb: bool,
|
|
||||||
lane: TransmissionLane,
|
|
||||||
},
|
|
||||||
Reply {
|
|
||||||
reply_surb: ReplySurb,
|
|
||||||
data: Vec<u8>,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
impl InputMessage {
|
|
||||||
pub fn new_fresh(
|
|
||||||
recipient: Recipient,
|
|
||||||
data: Vec<u8>,
|
|
||||||
with_reply_surb: bool,
|
|
||||||
lane: TransmissionLane,
|
|
||||||
) -> Self {
|
|
||||||
InputMessage::Fresh {
|
|
||||||
recipient,
|
|
||||||
data,
|
|
||||||
with_reply_surb,
|
|
||||||
lane,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn new_reply(reply_surb: ReplySurb, data: Vec<u8>) -> Self {
|
|
||||||
InputMessage::Reply { reply_surb, data }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
pub mod cover_traffic_stream;
|
|
||||||
pub mod inbound_messages;
|
|
||||||
pub mod key_manager;
|
|
||||||
pub mod mix_traffic;
|
|
||||||
pub mod real_messages_control;
|
|
||||||
pub mod received_buffer;
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
pub mod reply_key_storage;
|
|
||||||
pub mod topology_control;
|
|
||||||
-232
@@ -1,232 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use super::action_controller::{Action, ActionSender};
|
|
||||||
use super::PendingAcknowledgement;
|
|
||||||
use crate::client::{
|
|
||||||
inbound_messages::{InputMessage, InputMessageReceiver},
|
|
||||||
real_messages_control::real_traffic_stream::{BatchRealMessageSender, RealMessage},
|
|
||||||
topology_control::TopologyAccessor,
|
|
||||||
};
|
|
||||||
use client_connections::TransmissionLane;
|
|
||||||
use log::*;
|
|
||||||
use nymsphinx::anonymous_replies::ReplySurb;
|
|
||||||
use nymsphinx::preparer::MessagePreparer;
|
|
||||||
use nymsphinx::{acknowledgements::AckKey, addressing::clients::Recipient};
|
|
||||||
use rand::{CryptoRng, Rng};
|
|
||||||
use std::sync::Arc;
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use crate::client::reply_key_storage::ReplyKeyStorage;
|
|
||||||
|
|
||||||
/// Module responsible for dealing with the received messages: splitting them, creating acknowledgements,
|
|
||||||
/// putting everything into sphinx packets, etc.
|
|
||||||
/// It also makes an initial sending attempt for said messages.
|
|
||||||
pub(super) struct InputMessageListener<R>
|
|
||||||
where
|
|
||||||
R: CryptoRng + Rng,
|
|
||||||
{
|
|
||||||
ack_key: Arc<AckKey>,
|
|
||||||
ack_recipient: Recipient,
|
|
||||||
input_receiver: InputMessageReceiver,
|
|
||||||
message_preparer: MessagePreparer<R>,
|
|
||||||
action_sender: ActionSender,
|
|
||||||
real_message_sender: BatchRealMessageSender,
|
|
||||||
topology_access: TopologyAccessor,
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage: ReplyKeyStorage,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<R> InputMessageListener<R>
|
|
||||||
where
|
|
||||||
R: CryptoRng + Rng,
|
|
||||||
{
|
|
||||||
// at this point I'm not entirely sure how to deal with this warning without
|
|
||||||
// some considerable refactoring
|
|
||||||
#[allow(clippy::too_many_arguments)]
|
|
||||||
pub(super) fn new(
|
|
||||||
ack_key: Arc<AckKey>,
|
|
||||||
ack_recipient: Recipient,
|
|
||||||
input_receiver: InputMessageReceiver,
|
|
||||||
message_preparer: MessagePreparer<R>,
|
|
||||||
action_sender: ActionSender,
|
|
||||||
real_message_sender: BatchRealMessageSender,
|
|
||||||
topology_access: TopologyAccessor,
|
|
||||||
#[cfg(feature = "reply-surb")] reply_key_storage: ReplyKeyStorage,
|
|
||||||
) -> Self {
|
|
||||||
InputMessageListener {
|
|
||||||
ack_key,
|
|
||||||
ack_recipient,
|
|
||||||
input_receiver,
|
|
||||||
message_preparer,
|
|
||||||
action_sender,
|
|
||||||
real_message_sender,
|
|
||||||
topology_access,
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// we require topology for replies to generate surb_acks
|
|
||||||
async fn handle_reply(&mut self, reply_surb: ReplySurb, data: Vec<u8>) -> Option<RealMessage> {
|
|
||||||
let topology_permit = self.topology_access.get_read_permit().await;
|
|
||||||
let topology = match topology_permit.try_get_valid_topology_ref(&self.ack_recipient, None) {
|
|
||||||
Some(topology_ref) => topology_ref,
|
|
||||||
None => {
|
|
||||||
warn!("Could not process the message - the network topology is invalid");
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
match self
|
|
||||||
.message_preparer
|
|
||||||
.prepare_reply_for_use(data, reply_surb, topology, &self.ack_key)
|
|
||||||
.await
|
|
||||||
{
|
|
||||||
Ok((mix_packet, reply_id)) => {
|
|
||||||
// TODO: later probably write pending ack here
|
|
||||||
// and deal with them....
|
|
||||||
// ... somehow
|
|
||||||
Some(RealMessage::new(mix_packet, reply_id))
|
|
||||||
}
|
|
||||||
Err(err) => {
|
|
||||||
// TODO: should we have some mechanism to indicate to the user that the `reply_surb`
|
|
||||||
// could be reused since technically it wasn't used up here?
|
|
||||||
warn!("failed to deal with received reply surb - {:?}", err);
|
|
||||||
None
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn handle_fresh_message(
|
|
||||||
&mut self,
|
|
||||||
recipient: Recipient,
|
|
||||||
content: Vec<u8>,
|
|
||||||
with_reply_surb: bool,
|
|
||||||
) -> Option<Vec<RealMessage>> {
|
|
||||||
log::trace!("handling msg size: {}", content.len());
|
|
||||||
let topology_permit = self.topology_access.get_read_permit().await;
|
|
||||||
let topology = match topology_permit
|
|
||||||
.try_get_valid_topology_ref(&self.ack_recipient, Some(&recipient))
|
|
||||||
{
|
|
||||||
Some(topology_ref) => topology_ref,
|
|
||||||
None => {
|
|
||||||
warn!("Could not process the message - the network topology is invalid");
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// split the message, attach optional reply surb
|
|
||||||
let (split_message, reply_key) = self
|
|
||||||
.message_preparer
|
|
||||||
.prepare_and_split_message(content, with_reply_surb, topology)
|
|
||||||
.expect("somehow the topology was invalid after all!");
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
if let Some(reply_key) = reply_key {
|
|
||||||
self.reply_key_storage
|
|
||||||
.insert_encryption_key(reply_key)
|
|
||||||
.expect("Failed to insert surb reply key to the store!")
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(feature = "reply-surb"))]
|
|
||||||
let _reply_key = reply_key;
|
|
||||||
|
|
||||||
// encrypt chunks, put them inside sphinx packets and generate acks
|
|
||||||
let mut pending_acks = Vec::with_capacity(split_message.len());
|
|
||||||
let mut real_messages = Vec::with_capacity(split_message.len());
|
|
||||||
for message_chunk in split_message {
|
|
||||||
// we need to clone it because we need to keep it in memory in case we had to retransmit
|
|
||||||
// it. And then we'd need to recreate entire ACK again.
|
|
||||||
let chunk_clone = message_chunk.clone();
|
|
||||||
let prepared_fragment = self
|
|
||||||
.message_preparer
|
|
||||||
.prepare_chunk_for_sending(chunk_clone, topology, &self.ack_key, &recipient)
|
|
||||||
.unwrap();
|
|
||||||
|
|
||||||
real_messages.push(RealMessage::new(
|
|
||||||
prepared_fragment.mix_packet,
|
|
||||||
message_chunk.fragment_identifier(),
|
|
||||||
));
|
|
||||||
|
|
||||||
pending_acks.push(PendingAcknowledgement::new(
|
|
||||||
message_chunk,
|
|
||||||
prepared_fragment.total_delay,
|
|
||||||
recipient,
|
|
||||||
));
|
|
||||||
}
|
|
||||||
|
|
||||||
// tells the controller to put this into the hashmap
|
|
||||||
self.action_sender
|
|
||||||
.unbounded_send(Action::new_insert(pending_acks))
|
|
||||||
.unwrap();
|
|
||||||
|
|
||||||
Some(real_messages)
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn on_input_message(&mut self, msg: InputMessage) {
|
|
||||||
let (real_messages, lane) = match msg {
|
|
||||||
InputMessage::Fresh {
|
|
||||||
recipient,
|
|
||||||
data,
|
|
||||||
with_reply_surb,
|
|
||||||
lane,
|
|
||||||
} => (
|
|
||||||
self.handle_fresh_message(recipient, data, with_reply_surb)
|
|
||||||
.await,
|
|
||||||
lane,
|
|
||||||
),
|
|
||||||
InputMessage::Reply { reply_surb, data } => (
|
|
||||||
self.handle_reply(reply_surb, data)
|
|
||||||
.await
|
|
||||||
.map(|message| vec![message]),
|
|
||||||
TransmissionLane::Reply,
|
|
||||||
),
|
|
||||||
};
|
|
||||||
|
|
||||||
// there's no point in trying to send nothing
|
|
||||||
if let Some(real_messages) = real_messages {
|
|
||||||
// tells real message sender (with the poisson timer) to send this to the mix network
|
|
||||||
self.real_message_sender
|
|
||||||
.send((real_messages, lane))
|
|
||||||
.await
|
|
||||||
.expect("BatchRealMessageReceiver has stopped receiving!");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
pub(super) async fn run_with_shutdown(&mut self, mut shutdown: task::ShutdownListener) {
|
|
||||||
use std::time::Duration;
|
|
||||||
|
|
||||||
debug!("Started InputMessageListener with graceful shutdown support");
|
|
||||||
|
|
||||||
while !shutdown.is_shutdown() {
|
|
||||||
tokio::select! {
|
|
||||||
input_msg = self.input_receiver.recv() => match input_msg {
|
|
||||||
Some(input_msg) => {
|
|
||||||
self.on_input_message(input_msg).await;
|
|
||||||
},
|
|
||||||
None => {
|
|
||||||
log::trace!("InputMessageListener: Stopping since channel closed");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
_ = shutdown.recv() => {
|
|
||||||
log::trace!("InputMessageListener: Received shutdown");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tokio::time::timeout(Duration::from_secs(5), shutdown.recv())
|
|
||||||
.await
|
|
||||||
.expect("Task stopped without shutdown called");
|
|
||||||
log::debug!("InputMessageListener: Exiting");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
pub(super) async fn run(&mut self) {
|
|
||||||
debug!("Started InputMessageListener without graceful shutdown support");
|
|
||||||
while let Some(input_msg) = self.input_receiver.recv().await {
|
|
||||||
self.on_input_message(input_msg).await;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,202 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
// INPUT: InputMessage from user
|
|
||||||
// INPUT2: Acks from mix
|
|
||||||
// OUTPUT: MixMessage to mix traffic
|
|
||||||
|
|
||||||
use self::{
|
|
||||||
acknowledgement_control::AcknowledgementController, real_traffic_stream::OutQueueControl,
|
|
||||||
};
|
|
||||||
use crate::{
|
|
||||||
client::{
|
|
||||||
inbound_messages::InputMessageReceiver, mix_traffic::BatchMixMessageSender,
|
|
||||||
real_messages_control::acknowledgement_control::AcknowledgementControllerConnectors,
|
|
||||||
topology_control::TopologyAccessor,
|
|
||||||
},
|
|
||||||
spawn_future,
|
|
||||||
};
|
|
||||||
use client_connections::{ConnectionCommandReceiver, LaneQueueLengths};
|
|
||||||
use futures::channel::mpsc;
|
|
||||||
use gateway_client::AcknowledgementReceiver;
|
|
||||||
use log::*;
|
|
||||||
use nymsphinx::acknowledgements::AckKey;
|
|
||||||
use nymsphinx::addressing::clients::Recipient;
|
|
||||||
use nymsphinx::params::PacketSize;
|
|
||||||
use rand::{rngs::OsRng, CryptoRng, Rng};
|
|
||||||
use std::sync::Arc;
|
|
||||||
use std::time::Duration;
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use crate::client::reply_key_storage::ReplyKeyStorage;
|
|
||||||
|
|
||||||
mod acknowledgement_control;
|
|
||||||
mod real_traffic_stream;
|
|
||||||
|
|
||||||
// TODO: ack_key and self_recipient shouldn't really be part of this config
|
|
||||||
pub struct Config {
|
|
||||||
/// Key used to decrypt contents of received SURBAcks
|
|
||||||
ack_key: Arc<AckKey>,
|
|
||||||
|
|
||||||
/// Given ack timeout in the form a * BASE_DELAY + b, it specifies the additive part `b`
|
|
||||||
ack_wait_addition: Duration,
|
|
||||||
|
|
||||||
/// Given ack timeout in the form a * BASE_DELAY + b, it specifies the multiplier `a`
|
|
||||||
ack_wait_multiplier: f64,
|
|
||||||
|
|
||||||
/// Address of `this` client.
|
|
||||||
self_recipient: Recipient,
|
|
||||||
|
|
||||||
/// Average delay between sending subsequent packets from this client.
|
|
||||||
average_message_sending_delay: Duration,
|
|
||||||
|
|
||||||
/// Average delay a data packet is going to get delayed at a single mixnode.
|
|
||||||
average_packet_delay_duration: Duration,
|
|
||||||
|
|
||||||
/// Average delay an acknowledgement packet is going to get delayed at a single mixnode.
|
|
||||||
average_ack_delay_duration: Duration,
|
|
||||||
|
|
||||||
/// Controls whether the main packet stream constantly produces packets according to the predefined
|
|
||||||
/// poisson distribution.
|
|
||||||
disable_main_poisson_packet_distribution: bool,
|
|
||||||
|
|
||||||
/// Predefined packet size used for the encapsulated messages.
|
|
||||||
packet_size: PacketSize,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Config {
|
|
||||||
// TODO: change the config into a builder
|
|
||||||
#[allow(clippy::too_many_arguments)]
|
|
||||||
pub fn new(
|
|
||||||
ack_key: Arc<AckKey>,
|
|
||||||
ack_wait_multiplier: f64,
|
|
||||||
ack_wait_addition: Duration,
|
|
||||||
average_ack_delay_duration: Duration,
|
|
||||||
average_message_sending_delay: Duration,
|
|
||||||
average_packet_delay_duration: Duration,
|
|
||||||
disable_main_poisson_packet_distribution: bool,
|
|
||||||
self_recipient: Recipient,
|
|
||||||
) -> Self {
|
|
||||||
Config {
|
|
||||||
ack_key,
|
|
||||||
ack_wait_addition,
|
|
||||||
ack_wait_multiplier,
|
|
||||||
self_recipient,
|
|
||||||
average_message_sending_delay,
|
|
||||||
average_packet_delay_duration,
|
|
||||||
average_ack_delay_duration,
|
|
||||||
disable_main_poisson_packet_distribution,
|
|
||||||
packet_size: Default::default(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_custom_packet_size(&mut self, packet_size: PacketSize) {
|
|
||||||
self.packet_size = packet_size;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct RealMessagesController<R>
|
|
||||||
where
|
|
||||||
R: CryptoRng + Rng,
|
|
||||||
{
|
|
||||||
out_queue_control: OutQueueControl<R>,
|
|
||||||
ack_control: AcknowledgementController<R>,
|
|
||||||
}
|
|
||||||
|
|
||||||
// obviously when we finally make shared rng that is on 'higher' level, this should become
|
|
||||||
// generic `R`
|
|
||||||
impl RealMessagesController<OsRng> {
|
|
||||||
#[allow(clippy::too_many_arguments)]
|
|
||||||
pub fn new(
|
|
||||||
config: Config,
|
|
||||||
ack_receiver: AcknowledgementReceiver,
|
|
||||||
input_receiver: InputMessageReceiver,
|
|
||||||
mix_sender: BatchMixMessageSender,
|
|
||||||
topology_access: TopologyAccessor,
|
|
||||||
#[cfg(feature = "reply-surb")] reply_key_storage: ReplyKeyStorage,
|
|
||||||
lane_queue_lengths: LaneQueueLengths,
|
|
||||||
client_connection_rx: ConnectionCommandReceiver,
|
|
||||||
) -> Self {
|
|
||||||
let rng = OsRng;
|
|
||||||
|
|
||||||
let (real_message_sender, real_message_receiver) = tokio::sync::mpsc::channel(1);
|
|
||||||
let (sent_notifier_tx, sent_notifier_rx) = mpsc::unbounded();
|
|
||||||
|
|
||||||
let ack_controller_connectors = AcknowledgementControllerConnectors::new(
|
|
||||||
real_message_sender,
|
|
||||||
input_receiver,
|
|
||||||
sent_notifier_rx,
|
|
||||||
ack_receiver,
|
|
||||||
);
|
|
||||||
|
|
||||||
let ack_control_config = acknowledgement_control::Config::new(
|
|
||||||
config.ack_wait_addition,
|
|
||||||
config.ack_wait_multiplier,
|
|
||||||
config.average_ack_delay_duration,
|
|
||||||
config.average_packet_delay_duration,
|
|
||||||
)
|
|
||||||
.with_custom_packet_size(config.packet_size);
|
|
||||||
|
|
||||||
let ack_control = AcknowledgementController::new(
|
|
||||||
ack_control_config,
|
|
||||||
rng,
|
|
||||||
topology_access.clone(),
|
|
||||||
Arc::clone(&config.ack_key),
|
|
||||||
config.self_recipient,
|
|
||||||
ack_controller_connectors,
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage,
|
|
||||||
);
|
|
||||||
|
|
||||||
let out_queue_config = real_traffic_stream::Config::new(
|
|
||||||
config.average_ack_delay_duration,
|
|
||||||
config.average_packet_delay_duration,
|
|
||||||
config.average_message_sending_delay,
|
|
||||||
config.disable_main_poisson_packet_distribution,
|
|
||||||
)
|
|
||||||
.with_custom_cover_packet_size(config.packet_size);
|
|
||||||
|
|
||||||
let out_queue_control = OutQueueControl::new(
|
|
||||||
out_queue_config,
|
|
||||||
Arc::clone(&config.ack_key),
|
|
||||||
sent_notifier_tx,
|
|
||||||
mix_sender,
|
|
||||||
real_message_receiver,
|
|
||||||
rng,
|
|
||||||
config.self_recipient,
|
|
||||||
topology_access,
|
|
||||||
lane_queue_lengths,
|
|
||||||
client_connection_rx,
|
|
||||||
);
|
|
||||||
|
|
||||||
RealMessagesController {
|
|
||||||
out_queue_control,
|
|
||||||
ack_control,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
pub fn start_with_shutdown(self, shutdown: task::ShutdownListener) {
|
|
||||||
let mut out_queue_control = self.out_queue_control;
|
|
||||||
let ack_control = self.ack_control;
|
|
||||||
|
|
||||||
let shutdown_handle = shutdown.clone();
|
|
||||||
spawn_future(async move {
|
|
||||||
out_queue_control.run_with_shutdown(shutdown_handle).await;
|
|
||||||
debug!("The out queue controller has finished execution!");
|
|
||||||
});
|
|
||||||
ack_control.start_with_shutdown(shutdown);
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
pub fn start(self) {
|
|
||||||
let mut out_queue_control = self.out_queue_control;
|
|
||||||
let ack_control = self.ack_control;
|
|
||||||
|
|
||||||
spawn_future(async move {
|
|
||||||
out_queue_control.run().await;
|
|
||||||
debug!("The out queue controller has finished execution!");
|
|
||||||
});
|
|
||||||
ack_control.start();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,468 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use crate::spawn_future;
|
|
||||||
use crypto::asymmetric::encryption;
|
|
||||||
use futures::channel::mpsc;
|
|
||||||
use futures::lock::Mutex;
|
|
||||||
use futures::StreamExt;
|
|
||||||
use gateway_client::MixnetMessageReceiver;
|
|
||||||
use log::*;
|
|
||||||
use nymsphinx::receiver::{MessageReceiver, MessageRecoveryError, ReconstructedMessage};
|
|
||||||
use std::collections::HashSet;
|
|
||||||
use std::sync::Arc;
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use crate::client::reply_key_storage::ReplyKeyStorage;
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use crypto::{symmetric::stream_cipher, Digest};
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use nymsphinx::anonymous_replies::{encryption_key::EncryptionKeyDigest, SurbEncryptionKey};
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
use nymsphinx::params::{ReplySurbEncryptionAlgorithm, ReplySurbKeyDigestAlgorithm};
|
|
||||||
|
|
||||||
// Buffer Requests to say "hey, send any reconstructed messages to this channel"
|
|
||||||
// or to say "hey, I'm going offline, don't send anything more to me. Just buffer them instead"
|
|
||||||
pub type ReceivedBufferRequestSender = mpsc::UnboundedSender<ReceivedBufferMessage>;
|
|
||||||
pub type ReceivedBufferRequestReceiver = mpsc::UnboundedReceiver<ReceivedBufferMessage>;
|
|
||||||
|
|
||||||
// The channel set for the above
|
|
||||||
pub type ReconstructedMessagesSender = mpsc::UnboundedSender<Vec<ReconstructedMessage>>;
|
|
||||||
pub type ReconstructedMessagesReceiver = mpsc::UnboundedReceiver<Vec<ReconstructedMessage>>;
|
|
||||||
|
|
||||||
struct ReceivedMessagesBufferInner {
|
|
||||||
messages: Vec<ReconstructedMessage>,
|
|
||||||
local_encryption_keypair: Arc<encryption::KeyPair>,
|
|
||||||
|
|
||||||
// TODO: looking how it 'looks' here, perhaps `MessageReceiver` should be renamed to something
|
|
||||||
// else instead.
|
|
||||||
message_receiver: MessageReceiver,
|
|
||||||
message_sender: Option<ReconstructedMessagesSender>,
|
|
||||||
|
|
||||||
// TODO: this will get cleared upon re-running the client
|
|
||||||
// but perhaps it should be changed to include timestamps of when the message was reconstructed
|
|
||||||
// and every now and then remove ids older than X
|
|
||||||
recently_reconstructed: HashSet<i32>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ReceivedMessagesBufferInner {
|
|
||||||
fn process_received_fragment(&mut self, raw_fragment: Vec<u8>) -> Option<ReconstructedMessage> {
|
|
||||||
let fragment_data = match self
|
|
||||||
.message_receiver
|
|
||||||
.recover_plaintext(self.local_encryption_keypair.private_key(), raw_fragment)
|
|
||||||
{
|
|
||||||
Err(e) => {
|
|
||||||
warn!("failed to recover fragment data: {:?}. The whole underlying message might be corrupted and unrecoverable!", e);
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
Ok(frag_data) => frag_data,
|
|
||||||
};
|
|
||||||
|
|
||||||
if nymsphinx::cover::is_cover(&fragment_data) {
|
|
||||||
trace!("The message was a loop cover message! Skipping it");
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
|
|
||||||
let fragment = match self.message_receiver.recover_fragment(&fragment_data) {
|
|
||||||
Err(e) => {
|
|
||||||
warn!("failed to recover fragment from raw data: {:?}. The whole underlying message might be corrupted and unrecoverable!", e);
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
Ok(frag) => frag,
|
|
||||||
};
|
|
||||||
|
|
||||||
if self.recently_reconstructed.contains(&fragment.id()) {
|
|
||||||
debug!("Received a chunk of already re-assembled message ({:?})! It probably got here because the ack got lost", fragment.id());
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
|
|
||||||
// if we returned an error the underlying message is malformed in some way
|
|
||||||
match self.message_receiver.insert_new_fragment(fragment) {
|
|
||||||
Err(err) => match err {
|
|
||||||
MessageRecoveryError::MalformedReconstructedMessage(message_sets) => {
|
|
||||||
// TODO: should we really insert reconstructed sets? could this be abused for some attack?
|
|
||||||
for set_id in message_sets {
|
|
||||||
if !self.recently_reconstructed.insert(set_id) {
|
|
||||||
// or perhaps we should even panic at this point?
|
|
||||||
error!("Reconstructed another message containing already used set id!")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
None
|
|
||||||
}
|
|
||||||
_ => unreachable!(
|
|
||||||
"no other error kind should have been returned here! If so, it's a bug!"
|
|
||||||
),
|
|
||||||
},
|
|
||||||
Ok(reconstruction_result) => match reconstruction_result {
|
|
||||||
Some((reconstructed_message, used_sets)) => {
|
|
||||||
for set_id in used_sets {
|
|
||||||
if !self.recently_reconstructed.insert(set_id) {
|
|
||||||
// or perhaps we should even panic at this point?
|
|
||||||
error!("Reconstructed another message containing already used set id!")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Some(reconstructed_message)
|
|
||||||
}
|
|
||||||
None => None,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
|
||||||
// Note: you should NEVER create more than a single instance of this using 'new()'.
|
|
||||||
// You should always use .clone() to create additional instances
|
|
||||||
struct ReceivedMessagesBuffer {
|
|
||||||
inner: Arc<Mutex<ReceivedMessagesBufferInner>>,
|
|
||||||
|
|
||||||
/// Storage containing keys to all [`ReplySURB`]s ever sent out that we did not receive back.
|
|
||||||
// There's no need to put it behind a Mutex since it's already properly concurrent
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage: ReplyKeyStorage,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ReceivedMessagesBuffer {
|
|
||||||
fn new(
|
|
||||||
local_encryption_keypair: Arc<encryption::KeyPair>,
|
|
||||||
#[cfg(feature = "reply-surb")] reply_key_storage: ReplyKeyStorage,
|
|
||||||
) -> Self {
|
|
||||||
ReceivedMessagesBuffer {
|
|
||||||
inner: Arc::new(Mutex::new(ReceivedMessagesBufferInner {
|
|
||||||
messages: Vec::new(),
|
|
||||||
local_encryption_keypair,
|
|
||||||
message_receiver: MessageReceiver::new(),
|
|
||||||
message_sender: None,
|
|
||||||
recently_reconstructed: HashSet::new(),
|
|
||||||
})),
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn disconnect_sender(&mut self) {
|
|
||||||
let mut guard = self.inner.lock().await;
|
|
||||||
if guard.message_sender.is_none() {
|
|
||||||
// in theory we could just ignore it, but that situation should have never happened
|
|
||||||
// in the first place, so this way we at least know we have an important bug to fix
|
|
||||||
panic!("trying to disconnect non-existent sender!")
|
|
||||||
}
|
|
||||||
guard.message_sender = None;
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn connect_sender(&mut self, sender: ReconstructedMessagesSender) {
|
|
||||||
let mut guard = self.inner.lock().await;
|
|
||||||
if guard.message_sender.is_some() {
|
|
||||||
// in theory we could just ignore it, but that situation should have never happened
|
|
||||||
// in the first place, so this way we at least know we have an important bug to fix
|
|
||||||
panic!("trying overwrite an existing sender!")
|
|
||||||
}
|
|
||||||
|
|
||||||
// while we're at it, also empty the buffer if we happened to receive anything while
|
|
||||||
// no sender was connected
|
|
||||||
let stored_messages = std::mem::take(&mut guard.messages);
|
|
||||||
if !stored_messages.is_empty() {
|
|
||||||
if let Err(err) = sender.unbounded_send(stored_messages) {
|
|
||||||
error!(
|
|
||||||
"The sender channel we just received is already invalidated - {:?}",
|
|
||||||
err
|
|
||||||
);
|
|
||||||
// put the values back to the buffer
|
|
||||||
// the returned error has two fields: err: SendError and val: T,
|
|
||||||
// where val is the value that was failed to get sent;
|
|
||||||
// it's returned by the `into_inner` call
|
|
||||||
guard.messages = err.into_inner();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
guard.message_sender = Some(sender);
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn add_reconstructed_messages(&mut self, msgs: Vec<ReconstructedMessage>) {
|
|
||||||
debug!("Adding {:?} new messages to the buffer!", msgs.len());
|
|
||||||
trace!("Adding new messages to the buffer! {:?}", msgs);
|
|
||||||
self.inner.lock().await.messages.extend(msgs)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
fn process_received_reply(
|
|
||||||
reply_ciphertext: &[u8],
|
|
||||||
reply_key: SurbEncryptionKey,
|
|
||||||
) -> Option<ReconstructedMessage> {
|
|
||||||
let zero_iv = stream_cipher::zero_iv::<ReplySurbEncryptionAlgorithm>();
|
|
||||||
|
|
||||||
let mut reply_msg = stream_cipher::decrypt::<ReplySurbEncryptionAlgorithm>(
|
|
||||||
reply_key.inner(),
|
|
||||||
&zero_iv,
|
|
||||||
reply_ciphertext,
|
|
||||||
);
|
|
||||||
if let Err(err) = MessageReceiver::remove_padding(&mut reply_msg) {
|
|
||||||
warn!("Received reply had malformed padding! - {:?}", err);
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
// TODO: perhaps having to say it doesn't have a surb an indication the type should be changed?
|
|
||||||
Some(ReconstructedMessage {
|
|
||||||
message: reply_msg,
|
|
||||||
reply_surb: None,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn handle_new_received(&mut self, msgs: Vec<Vec<u8>>) {
|
|
||||||
trace!(
|
|
||||||
"Processing {:?} new message that might get added to the buffer!",
|
|
||||||
msgs.len()
|
|
||||||
);
|
|
||||||
|
|
||||||
let mut completed_messages = Vec::new();
|
|
||||||
let mut inner_guard = self.inner.lock().await;
|
|
||||||
|
|
||||||
// first check if this is a reply or a chunked message
|
|
||||||
// TODO: verify with @AP if this way of doing it is safe or whether it could
|
|
||||||
// cause some attacks due to, I don't know, stupid edge case collisions?
|
|
||||||
// Update: this DOES introduce a possible leakage: https://github.com/nymtech/nym/issues/296
|
|
||||||
for msg in msgs {
|
|
||||||
// TODO:
|
|
||||||
// 1. make it nicer
|
|
||||||
// 2. make it not feature-locked
|
|
||||||
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
{
|
|
||||||
let reply_surb_digest_size = ReplySurbKeyDigestAlgorithm::output_size();
|
|
||||||
|
|
||||||
let possible_key_digest =
|
|
||||||
EncryptionKeyDigest::clone_from_slice(&msg[..reply_surb_digest_size]);
|
|
||||||
|
|
||||||
// check first `HasherOutputSize` bytes if they correspond to known encryption key
|
|
||||||
// if yes - this is a reply message
|
|
||||||
|
|
||||||
// TODO: this might be a bottleneck - since the keys are stored on disk we, presumably,
|
|
||||||
// are doing a disk operation every single received fragment
|
|
||||||
if let Some(reply_encryption_key) = self
|
|
||||||
.reply_key_storage
|
|
||||||
.get_and_remove_encryption_key(possible_key_digest)
|
|
||||||
.expect("storage operation failed!")
|
|
||||||
{
|
|
||||||
if let Some(completed_message) = Self::process_received_reply(
|
|
||||||
&msg[reply_surb_digest_size..],
|
|
||||||
reply_encryption_key,
|
|
||||||
) {
|
|
||||||
completed_messages.push(completed_message)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// otherwise - it's a 'normal' message
|
|
||||||
if let Some(completed_message) = inner_guard.process_received_fragment(msg) {
|
|
||||||
completed_messages.push(completed_message)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(feature = "reply-surb"))]
|
|
||||||
if let Some(completed_message) = inner_guard.process_received_fragment(msg) {
|
|
||||||
completed_messages.push(completed_message)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if !completed_messages.is_empty() {
|
|
||||||
if let Some(sender) = &inner_guard.message_sender {
|
|
||||||
trace!("Sending reconstructed messages to announced sender");
|
|
||||||
if let Err(err) = sender.unbounded_send(completed_messages) {
|
|
||||||
warn!("The reconstructed message receiver went offline without explicit notification (relevant error: - {:?})", err);
|
|
||||||
// make sure to drop the lock to not deadlock
|
|
||||||
// (it is required by `add_reconstructed_messages`)
|
|
||||||
inner_guard.message_sender = None;
|
|
||||||
drop(inner_guard);
|
|
||||||
self.add_reconstructed_messages(err.into_inner()).await;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// make sure to drop the lock to not deadlock
|
|
||||||
// (it is required by `add_reconstructed_messages`)
|
|
||||||
drop(inner_guard);
|
|
||||||
trace!("No sender available - buffering reconstructed messages");
|
|
||||||
self.add_reconstructed_messages(completed_messages).await;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub enum ReceivedBufferMessage {
|
|
||||||
// Signals a websocket connection (or a native implementation) was established and we should stop buffering messages,
|
|
||||||
// and instead send them directly to the received channel
|
|
||||||
ReceiverAnnounce(ReconstructedMessagesSender),
|
|
||||||
|
|
||||||
// Explicit signal that Receiver connection will no longer accept messages
|
|
||||||
ReceiverDisconnect,
|
|
||||||
}
|
|
||||||
|
|
||||||
struct RequestReceiver {
|
|
||||||
received_buffer: ReceivedMessagesBuffer,
|
|
||||||
query_receiver: ReceivedBufferRequestReceiver,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl RequestReceiver {
|
|
||||||
fn new(
|
|
||||||
received_buffer: ReceivedMessagesBuffer,
|
|
||||||
query_receiver: ReceivedBufferRequestReceiver,
|
|
||||||
) -> Self {
|
|
||||||
RequestReceiver {
|
|
||||||
received_buffer,
|
|
||||||
query_receiver,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn handle_message(&mut self, message: ReceivedBufferMessage) {
|
|
||||||
match message {
|
|
||||||
ReceivedBufferMessage::ReceiverAnnounce(sender) => {
|
|
||||||
self.received_buffer.connect_sender(sender).await;
|
|
||||||
}
|
|
||||||
ReceivedBufferMessage::ReceiverDisconnect => {
|
|
||||||
self.received_buffer.disconnect_sender().await
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
async fn run_with_shutdown(&mut self, mut shutdown: task::ShutdownListener) {
|
|
||||||
use std::time::Duration;
|
|
||||||
|
|
||||||
debug!("Started RequestReceiver with graceful shutdown support");
|
|
||||||
while !shutdown.is_shutdown() {
|
|
||||||
tokio::select! {
|
|
||||||
biased;
|
|
||||||
_ = shutdown.recv() => {
|
|
||||||
log::trace!("RequestReceiver: Received shutdown");
|
|
||||||
}
|
|
||||||
request = self.query_receiver.next() => {
|
|
||||||
match request {
|
|
||||||
Some(message) => self.handle_message(message).await,
|
|
||||||
None => {
|
|
||||||
log::trace!("RequestReceiver: Stopping since channel closed");
|
|
||||||
break;
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tokio::time::timeout(Duration::from_secs(5), shutdown.recv())
|
|
||||||
.await
|
|
||||||
.expect("Task stopped without shutdown called");
|
|
||||||
log::debug!("RequestReceiver: Exiting");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
async fn run(&mut self) {
|
|
||||||
debug!("Started RequestReceiver without graceful shutdown support");
|
|
||||||
|
|
||||||
while let Some(message) = self.query_receiver.next().await {
|
|
||||||
self.handle_message(message).await
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct FragmentedMessageReceiver {
|
|
||||||
received_buffer: ReceivedMessagesBuffer,
|
|
||||||
mixnet_packet_receiver: MixnetMessageReceiver,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl FragmentedMessageReceiver {
|
|
||||||
fn new(
|
|
||||||
received_buffer: ReceivedMessagesBuffer,
|
|
||||||
mixnet_packet_receiver: MixnetMessageReceiver,
|
|
||||||
) -> Self {
|
|
||||||
FragmentedMessageReceiver {
|
|
||||||
received_buffer,
|
|
||||||
mixnet_packet_receiver,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
async fn run_with_shutdown(&mut self, mut shutdown: task::ShutdownListener) {
|
|
||||||
use std::time::Duration;
|
|
||||||
|
|
||||||
debug!("Started FragmentedMessageReceiver with graceful shutdown support");
|
|
||||||
while !shutdown.is_shutdown() {
|
|
||||||
tokio::select! {
|
|
||||||
new_messages = self.mixnet_packet_receiver.next() => match new_messages {
|
|
||||||
Some(new_messages) => {
|
|
||||||
self.received_buffer.handle_new_received(new_messages).await;
|
|
||||||
}
|
|
||||||
None => {
|
|
||||||
log::trace!("FragmentedMessageReceiver: Stopping since channel closed");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
_ = shutdown.recv() => {
|
|
||||||
log::trace!("FragmentedMessageReceiver: Received shutdown");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tokio::time::timeout(Duration::from_secs(5), shutdown.recv())
|
|
||||||
.await
|
|
||||||
.expect("Task stopped without shutdown called");
|
|
||||||
log::debug!("FragmentedMessageReceiver: Exiting");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
async fn run(&mut self) {
|
|
||||||
debug!("Started FragmentedMessageReceiver without graceful shutdown support");
|
|
||||||
|
|
||||||
while let Some(new_messages) = self.mixnet_packet_receiver.next().await {
|
|
||||||
self.received_buffer.handle_new_received(new_messages).await;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct ReceivedMessagesBufferController {
|
|
||||||
fragmented_message_receiver: FragmentedMessageReceiver,
|
|
||||||
request_receiver: RequestReceiver,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ReceivedMessagesBufferController {
|
|
||||||
pub fn new(
|
|
||||||
local_encryption_keypair: Arc<encryption::KeyPair>,
|
|
||||||
query_receiver: ReceivedBufferRequestReceiver,
|
|
||||||
mixnet_packet_receiver: MixnetMessageReceiver,
|
|
||||||
#[cfg(feature = "reply-surb")] reply_key_storage: ReplyKeyStorage,
|
|
||||||
) -> Self {
|
|
||||||
let received_buffer = ReceivedMessagesBuffer::new(
|
|
||||||
local_encryption_keypair,
|
|
||||||
#[cfg(feature = "reply-surb")]
|
|
||||||
reply_key_storage,
|
|
||||||
);
|
|
||||||
|
|
||||||
ReceivedMessagesBufferController {
|
|
||||||
fragmented_message_receiver: FragmentedMessageReceiver::new(
|
|
||||||
received_buffer.clone(),
|
|
||||||
mixnet_packet_receiver,
|
|
||||||
),
|
|
||||||
request_receiver: RequestReceiver::new(received_buffer, query_receiver),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
pub fn start_with_shutdown(self, shutdown: task::ShutdownListener) {
|
|
||||||
let mut fragmented_message_receiver = self.fragmented_message_receiver;
|
|
||||||
let mut request_receiver = self.request_receiver;
|
|
||||||
|
|
||||||
let shutdown_handle = shutdown.clone();
|
|
||||||
spawn_future(async move {
|
|
||||||
fragmented_message_receiver
|
|
||||||
.run_with_shutdown(shutdown_handle)
|
|
||||||
.await;
|
|
||||||
});
|
|
||||||
spawn_future(async move {
|
|
||||||
request_receiver.run_with_shutdown(shutdown).await;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
pub fn start(self) {
|
|
||||||
let mut fragmented_message_receiver = self.fragmented_message_receiver;
|
|
||||||
let mut request_receiver = self.request_receiver;
|
|
||||||
spawn_future(async move {
|
|
||||||
fragmented_message_receiver.run().await;
|
|
||||||
});
|
|
||||||
spawn_future(async move {
|
|
||||||
request_receiver.run().await;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,97 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use crypto::generic_array::typenum::Unsigned;
|
|
||||||
use log::*;
|
|
||||||
use nymsphinx::anonymous_replies::{
|
|
||||||
encryption_key::EncryptionKeyDigest, SurbEncryptionKey, SurbEncryptionKeySize,
|
|
||||||
};
|
|
||||||
use std::path::Path;
|
|
||||||
|
|
||||||
#[derive(Debug, thiserror::Error)]
|
|
||||||
pub enum ReplyKeyStorageError {
|
|
||||||
#[error("DB Read Error: {0}")]
|
|
||||||
DbReadError(sled::Error),
|
|
||||||
#[error("DB Write Error: {0}")]
|
|
||||||
DbWriteError(sled::Error),
|
|
||||||
#[error("DB Open Error: {0}")]
|
|
||||||
DbOpenError(sled::Error),
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Permanent storage for keys in all sent [`ReplySURB`]
|
|
||||||
///
|
|
||||||
/// Each sent out [`ReplySURB`] has a new key associated with it that is going to be used for
|
|
||||||
/// payload encryption. In order to -decrypt whatever reply we receive, we need to know which
|
|
||||||
/// key to use for that purpose. We do it based on received `H(t)` which has to be included
|
|
||||||
/// with each reply.
|
|
||||||
/// Moreover, there is no restriction when the [`ReplySURB`] might get used so we need to
|
|
||||||
/// have a permanent storage for all the keys that we might ever see in the future.
|
|
||||||
#[derive(Debug, Clone)]
|
|
||||||
pub struct ReplyKeyStorage {
|
|
||||||
db: sled::Db,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl ReplyKeyStorage {
|
|
||||||
pub fn load<P: AsRef<Path>>(path: P) -> Result<Self, ReplyKeyStorageError> {
|
|
||||||
let db = match sled::open(path) {
|
|
||||||
Err(e) => return Err(ReplyKeyStorageError::DbOpenError(e)),
|
|
||||||
Ok(db) => db,
|
|
||||||
};
|
|
||||||
|
|
||||||
Ok(ReplyKeyStorage { db })
|
|
||||||
}
|
|
||||||
|
|
||||||
fn read_encryption_key(&self, raw_key: sled::IVec) -> SurbEncryptionKey {
|
|
||||||
let key_bytes_ref = raw_key.as_ref();
|
|
||||||
// if this fails it means we have some database corruption and we
|
|
||||||
// absolutely can't continue
|
|
||||||
|
|
||||||
if key_bytes_ref.len() != SurbEncryptionKeySize::USIZE {
|
|
||||||
error!("REPLY KEY STORAGE DATA CORRUPTION - ENCRYPTION KEY HAS INVALID LENGTH");
|
|
||||||
panic!("REPLY KEY STORAGE DATA CORRUPTION - ENCRYPTION KEY HAS INVALID LENGTH");
|
|
||||||
}
|
|
||||||
|
|
||||||
// this can only fail if the bytes have invalid length but we already asserted it
|
|
||||||
SurbEncryptionKey::try_from_bytes(key_bytes_ref).unwrap()
|
|
||||||
}
|
|
||||||
|
|
||||||
// TOOD: perhaps we could also store some part of original message here too?
|
|
||||||
pub fn insert_encryption_key(
|
|
||||||
&mut self,
|
|
||||||
encryption_key: SurbEncryptionKey,
|
|
||||||
) -> Result<(), ReplyKeyStorageError> {
|
|
||||||
let digest = encryption_key.compute_digest();
|
|
||||||
|
|
||||||
let insertion_result = match self.db.insert(digest, encryption_key.to_bytes()) {
|
|
||||||
Err(e) => Err(ReplyKeyStorageError::DbWriteError(e)),
|
|
||||||
Ok(existing_key) => {
|
|
||||||
if existing_key.is_some() {
|
|
||||||
panic!("HASH COLLISION DETECTED")
|
|
||||||
};
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// TODO: perhaps we could implement some batching mechanism to avoid frequent flushes?
|
|
||||||
self.db.flush().unwrap();
|
|
||||||
insertion_result
|
|
||||||
}
|
|
||||||
|
|
||||||
// Once we use key once, we do not expect to use it again
|
|
||||||
pub fn get_and_remove_encryption_key(
|
|
||||||
&self,
|
|
||||||
key_digest: EncryptionKeyDigest,
|
|
||||||
) -> Result<Option<SurbEncryptionKey>, ReplyKeyStorageError> {
|
|
||||||
let removal_result = match self.db.remove(key_digest) {
|
|
||||||
Err(e) => Err(ReplyKeyStorageError::DbReadError(e)),
|
|
||||||
Ok(existing_key) => {
|
|
||||||
Ok(existing_key.map(|existing_key| self.read_encryption_key(existing_key)))
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// TODO: not sure how to feel about flushing it every single time here...
|
|
||||||
// same with insertion
|
|
||||||
self.db.flush().unwrap();
|
|
||||||
removal_result
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,329 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use crate::spawn_future;
|
|
||||||
use log::*;
|
|
||||||
use nymsphinx::addressing::clients::Recipient;
|
|
||||||
use nymsphinx::params::DEFAULT_NUM_MIX_HOPS;
|
|
||||||
use rand::seq::SliceRandom;
|
|
||||||
use rand::thread_rng;
|
|
||||||
use std::ops::Deref;
|
|
||||||
use std::sync::Arc;
|
|
||||||
use std::time;
|
|
||||||
use std::time::Duration;
|
|
||||||
use tokio::sync::{RwLock, RwLockReadGuard};
|
|
||||||
use topology::{nym_topology_from_detailed, NymTopology};
|
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
// I'm extremely curious why compiler NEVER complained about lack of Debug here before
|
|
||||||
#[derive(Debug)]
|
|
||||||
pub struct TopologyAccessorInner(Option<NymTopology>);
|
|
||||||
|
|
||||||
impl AsRef<Option<NymTopology>> for TopologyAccessorInner {
|
|
||||||
fn as_ref(&self) -> &Option<NymTopology> {
|
|
||||||
&self.0
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl TopologyAccessorInner {
|
|
||||||
fn new() -> Self {
|
|
||||||
TopologyAccessorInner(None)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn update(&mut self, new: Option<NymTopology>) {
|
|
||||||
self.0 = new;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct TopologyReadPermit<'a> {
|
|
||||||
permit: RwLockReadGuard<'a, TopologyAccessorInner>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> Deref for TopologyReadPermit<'a> {
|
|
||||||
type Target = TopologyAccessorInner;
|
|
||||||
|
|
||||||
fn deref(&self) -> &Self::Target {
|
|
||||||
&self.permit
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> TopologyReadPermit<'a> {
|
|
||||||
/// Using provided topology read permit, tries to get an immutable reference to the underlying
|
|
||||||
/// topology. For obvious reasons the lifetime of the topology reference is bound to the permit.
|
|
||||||
pub(super) fn try_get_valid_topology_ref(
|
|
||||||
&'a self,
|
|
||||||
ack_recipient: &Recipient,
|
|
||||||
packet_recipient: Option<&Recipient>,
|
|
||||||
) -> Option<&'a NymTopology> {
|
|
||||||
// Note: implicit deref with Deref for TopologyReadPermit is happening here
|
|
||||||
let topology_ref_option = self.permit.as_ref();
|
|
||||||
topology_ref_option.as_ref().filter(|topology_ref| {
|
|
||||||
!(!topology_ref.can_construct_path_through(DEFAULT_NUM_MIX_HOPS)
|
|
||||||
|| !topology_ref.gateway_exists(ack_recipient.gateway())
|
|
||||||
|| if let Some(packet_recipient) = packet_recipient {
|
|
||||||
!topology_ref.gateway_exists(packet_recipient.gateway())
|
|
||||||
} else {
|
|
||||||
false
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'a> From<RwLockReadGuard<'a, TopologyAccessorInner>> for TopologyReadPermit<'a> {
|
|
||||||
fn from(read_permit: RwLockReadGuard<'a, TopologyAccessorInner>) -> Self {
|
|
||||||
TopologyReadPermit {
|
|
||||||
permit: read_permit,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
|
||||||
pub struct TopologyAccessor {
|
|
||||||
// `RwLock` *seems to* be the better approach for this as write access is only requested every
|
|
||||||
// few seconds, while reads are needed every single packet generated.
|
|
||||||
// However, proper benchmarks will be needed to determine if `RwLock` is indeed a better
|
|
||||||
// approach than a `Mutex`
|
|
||||||
inner: Arc<RwLock<TopologyAccessorInner>>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl TopologyAccessor {
|
|
||||||
pub fn new() -> Self {
|
|
||||||
TopologyAccessor {
|
|
||||||
inner: Arc::new(RwLock::new(TopologyAccessorInner::new())),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn get_read_permit(&self) -> TopologyReadPermit<'_> {
|
|
||||||
self.inner.read().await.into()
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn update_global_topology(&self, new_topology: Option<NymTopology>) {
|
|
||||||
self.inner.write().await.update(new_topology);
|
|
||||||
}
|
|
||||||
|
|
||||||
// only used by the client at startup to get a slightly more reasonable error message
|
|
||||||
// (currently displays as unused because health checker is disabled due to required changes)
|
|
||||||
pub async fn is_routable(&self) -> bool {
|
|
||||||
match &self.inner.read().await.0 {
|
|
||||||
None => false,
|
|
||||||
Some(ref topology) => topology.can_construct_path_through(DEFAULT_NUM_MIX_HOPS),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Default for TopologyAccessor {
|
|
||||||
fn default() -> Self {
|
|
||||||
TopologyAccessor::new()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct TopologyRefresherConfig {
|
|
||||||
validator_api_urls: Vec<Url>,
|
|
||||||
refresh_rate: time::Duration,
|
|
||||||
client_version: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl TopologyRefresherConfig {
|
|
||||||
pub fn new(
|
|
||||||
validator_api_urls: Vec<Url>,
|
|
||||||
refresh_rate: time::Duration,
|
|
||||||
client_version: String,
|
|
||||||
) -> Self {
|
|
||||||
TopologyRefresherConfig {
|
|
||||||
validator_api_urls,
|
|
||||||
refresh_rate,
|
|
||||||
client_version,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub struct TopologyRefresher {
|
|
||||||
validator_client: validator_client::client::ApiClient,
|
|
||||||
client_version: String,
|
|
||||||
|
|
||||||
validator_api_urls: Vec<Url>,
|
|
||||||
topology_accessor: TopologyAccessor,
|
|
||||||
refresh_rate: Duration,
|
|
||||||
|
|
||||||
currently_used_api: usize,
|
|
||||||
was_latest_valid: bool,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl TopologyRefresher {
|
|
||||||
pub fn new(mut cfg: TopologyRefresherConfig, topology_accessor: TopologyAccessor) -> Self {
|
|
||||||
cfg.validator_api_urls.shuffle(&mut thread_rng());
|
|
||||||
|
|
||||||
TopologyRefresher {
|
|
||||||
validator_client: validator_client::client::ApiClient::new(
|
|
||||||
cfg.validator_api_urls[0].clone(),
|
|
||||||
),
|
|
||||||
client_version: cfg.client_version,
|
|
||||||
validator_api_urls: cfg.validator_api_urls,
|
|
||||||
topology_accessor,
|
|
||||||
refresh_rate: cfg.refresh_rate,
|
|
||||||
currently_used_api: 0,
|
|
||||||
was_latest_valid: true,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn use_next_validator_api(&mut self) {
|
|
||||||
if self.validator_api_urls.len() == 1 {
|
|
||||||
warn!("There's only a single validator API available - it won't be possible to use a different one");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
self.currently_used_api = (self.currently_used_api + 1) % self.validator_api_urls.len();
|
|
||||||
self.validator_client
|
|
||||||
.change_validator_api(self.validator_api_urls[self.currently_used_api].clone())
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Verifies whether nodes a reasonably distributed among all mix layers.
|
|
||||||
///
|
|
||||||
/// In ideal world we would have 33% nodes on layer 1, 33% on layer 2 and 33% on layer 3.
|
|
||||||
/// However, this is a rather unrealistic expectation, instead we check whether there exists
|
|
||||||
/// a layer with more than 66% of nodes or with fewer than 15% and if so, we trigger a failure.
|
|
||||||
///
|
|
||||||
/// # Arguments
|
|
||||||
///
|
|
||||||
/// * `topology`: active topology constructed from validator api data
|
|
||||||
fn check_layer_distribution(&self, active_topology: &NymTopology) -> bool {
|
|
||||||
let mixes = active_topology.mixes();
|
|
||||||
let mixnodes_count = active_topology.num_mixnodes();
|
|
||||||
|
|
||||||
if active_topology.gateways().is_empty() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// trivial check to see if have at least a single node on each layer (regardless of active set size)
|
|
||||||
if mixes.get(&1).is_none() || mixes.get(&2).is_none() || mixes.get(&3).is_none() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
let upper_bound = (mixnodes_count as f32 * 0.66) as usize;
|
|
||||||
let lower_bound = (mixnodes_count as f32 * 0.15) as usize;
|
|
||||||
|
|
||||||
let layer1 = mixes.get(&1).unwrap().len();
|
|
||||||
let layer2 = mixes.get(&2).unwrap().len();
|
|
||||||
let layer3 = mixes.get(&3).unwrap().len();
|
|
||||||
|
|
||||||
if layer1 < lower_bound || layer1 > upper_bound {
|
|
||||||
warn!(
|
|
||||||
"nodes: {}, layer1: {}, layer2: {}, layer3: {}",
|
|
||||||
mixnodes_count, layer1, layer2, layer3
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if layer2 < lower_bound || layer2 > upper_bound {
|
|
||||||
warn!(
|
|
||||||
"nodes: {}, layer1: {}, layer2: {}, layer3: {}",
|
|
||||||
mixnodes_count, layer1, layer2, layer3
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if layer3 < lower_bound || layer3 > upper_bound {
|
|
||||||
warn!(
|
|
||||||
"nodes: {}, layer1: {}, layer2: {}, layer3: {}",
|
|
||||||
mixnodes_count, layer1, layer2, layer3
|
|
||||||
);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
true
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn get_current_compatible_topology(&self) -> Option<NymTopology> {
|
|
||||||
// TODO: optimization for the future:
|
|
||||||
// only refresh mixnodes on timer and refresh gateways only when
|
|
||||||
// we have to send to a new, unknown, gateway
|
|
||||||
|
|
||||||
let mixnodes = match self.validator_client.get_cached_active_mixnodes().await {
|
|
||||||
Err(err) => {
|
|
||||||
error!("failed to get network mixnodes - {}", err);
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
Ok(mixes) => mixes,
|
|
||||||
};
|
|
||||||
|
|
||||||
let gateways = match self.validator_client.get_cached_gateways().await {
|
|
||||||
Err(err) => {
|
|
||||||
error!("failed to get network gateways - {}", err);
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
Ok(gateways) => gateways,
|
|
||||||
};
|
|
||||||
|
|
||||||
let topology = nym_topology_from_detailed(mixnodes, gateways)
|
|
||||||
.filter_system_version(&self.client_version);
|
|
||||||
|
|
||||||
if !self.check_layer_distribution(&topology) {
|
|
||||||
warn!("The current filtered active topology has extremely skewed layer distribution. It cannot be used.");
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
Some(topology)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn refresh(&mut self) {
|
|
||||||
trace!("Refreshing the topology");
|
|
||||||
let new_topology = self.get_current_compatible_topology().await;
|
|
||||||
|
|
||||||
if new_topology.is_none() {
|
|
||||||
self.use_next_validator_api();
|
|
||||||
}
|
|
||||||
|
|
||||||
if new_topology.is_none() && self.was_latest_valid {
|
|
||||||
// if we failed to grab this topology, but the one before it was alright, let's assume
|
|
||||||
// validator had a tiny hiccup and use the old data
|
|
||||||
warn!("we're going to keep on using the old topology for this iteration");
|
|
||||||
self.was_latest_valid = false;
|
|
||||||
return;
|
|
||||||
} else if new_topology.is_some() {
|
|
||||||
self.was_latest_valid = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
self.topology_accessor
|
|
||||||
.update_global_topology(new_topology)
|
|
||||||
.await;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn is_topology_routable(&self) -> bool {
|
|
||||||
self.topology_accessor.is_routable().await
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
pub fn start_with_shutdown(mut self, mut shutdown: task::ShutdownListener) {
|
|
||||||
spawn_future(async move {
|
|
||||||
debug!("Started TopologyRefresher with graceful shutdown support");
|
|
||||||
|
|
||||||
while !shutdown.is_shutdown() {
|
|
||||||
tokio::select! {
|
|
||||||
_ = tokio::time::sleep(self.refresh_rate) => {
|
|
||||||
self.refresh().await;
|
|
||||||
},
|
|
||||||
_ = shutdown.recv() => {
|
|
||||||
log::trace!("TopologyRefresher: Received shutdown");
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
tokio::time::timeout(Duration::from_secs(5), shutdown.recv())
|
|
||||||
.await
|
|
||||||
.expect("Task stopped without shutdown called");
|
|
||||||
log::debug!("TopologyRefresher: Exiting");
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
pub fn start(mut self) {
|
|
||||||
use futures::StreamExt;
|
|
||||||
|
|
||||||
spawn_future(async move {
|
|
||||||
let mut interval =
|
|
||||||
gloo_timers::future::IntervalStream::new(self.refresh_rate.as_millis() as u32);
|
|
||||||
while let Some(_) = interval.next().await {
|
|
||||||
self.refresh().await;
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,526 +0,0 @@
|
|||||||
// Copyright 2021 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use config::{NymConfig, DB_FILE_NAME};
|
|
||||||
use nymsphinx::params::PacketSize;
|
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
use std::marker::PhantomData;
|
|
||||||
use std::path::PathBuf;
|
|
||||||
use std::time::Duration;
|
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
#[cfg(target_arch = "wasm32")]
|
|
||||||
use wasm_bindgen::prelude::*;
|
|
||||||
|
|
||||||
pub mod persistence;
|
|
||||||
|
|
||||||
pub const MISSING_VALUE: &str = "MISSING VALUE";
|
|
||||||
|
|
||||||
// 'DEBUG'
|
|
||||||
const DEFAULT_ACK_WAIT_MULTIPLIER: f64 = 1.5;
|
|
||||||
|
|
||||||
const DEFAULT_ACK_WAIT_ADDITION: Duration = Duration::from_millis(1_500);
|
|
||||||
const DEFAULT_LOOP_COVER_STREAM_AVERAGE_DELAY: Duration = Duration::from_millis(200);
|
|
||||||
const DEFAULT_MESSAGE_STREAM_AVERAGE_DELAY: Duration = Duration::from_millis(20);
|
|
||||||
const DEFAULT_AVERAGE_PACKET_DELAY: Duration = Duration::from_millis(50);
|
|
||||||
const DEFAULT_TOPOLOGY_REFRESH_RATE: Duration = Duration::from_secs(5 * 60); // every 5min
|
|
||||||
const DEFAULT_TOPOLOGY_RESOLUTION_TIMEOUT: Duration = Duration::from_millis(5_000);
|
|
||||||
// Set this to a high value for now, so that we don't risk sporadic timeouts that might cause
|
|
||||||
// bought bandwidth tokens to not have time to be spent; Once we remove the gateway from the
|
|
||||||
// bandwidth bridging protocol, we can come back to a smaller timeout value
|
|
||||||
const DEFAULT_GATEWAY_RESPONSE_TIMEOUT: Duration = Duration::from_secs(5 * 60);
|
|
||||||
|
|
||||||
pub fn missing_string_value() -> String {
|
|
||||||
MISSING_VALUE.to_string()
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, PartialEq, Serialize)]
|
|
||||||
#[serde(deny_unknown_fields)]
|
|
||||||
pub struct Config<T> {
|
|
||||||
client: Client<T>,
|
|
||||||
|
|
||||||
#[serde(default)]
|
|
||||||
logging: Logging,
|
|
||||||
#[serde(default)]
|
|
||||||
debug: Debug,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: NymConfig> Config<T> {
|
|
||||||
pub fn new<S: Into<String>>(id: S) -> Self {
|
|
||||||
let mut cfg = Config::default();
|
|
||||||
cfg.with_id(id);
|
|
||||||
cfg
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn with_id<S: Into<String>>(&mut self, id: S) {
|
|
||||||
let id = id.into();
|
|
||||||
|
|
||||||
// identity key setting
|
|
||||||
if self.client.private_identity_key_file.as_os_str().is_empty() {
|
|
||||||
self.client.private_identity_key_file =
|
|
||||||
self::Client::<T>::default_private_identity_key_file(&id);
|
|
||||||
}
|
|
||||||
if self.client.public_identity_key_file.as_os_str().is_empty() {
|
|
||||||
self.client.public_identity_key_file =
|
|
||||||
self::Client::<T>::default_public_identity_key_file(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
// encryption key setting
|
|
||||||
if self
|
|
||||||
.client
|
|
||||||
.private_encryption_key_file
|
|
||||||
.as_os_str()
|
|
||||||
.is_empty()
|
|
||||||
{
|
|
||||||
self.client.private_encryption_key_file =
|
|
||||||
self::Client::<T>::default_private_encryption_key_file(&id);
|
|
||||||
}
|
|
||||||
if self
|
|
||||||
.client
|
|
||||||
.public_encryption_key_file
|
|
||||||
.as_os_str()
|
|
||||||
.is_empty()
|
|
||||||
{
|
|
||||||
self.client.public_encryption_key_file =
|
|
||||||
self::Client::<T>::default_public_encryption_key_file(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
// shared gateway key setting
|
|
||||||
if self.client.gateway_shared_key_file.as_os_str().is_empty() {
|
|
||||||
self.client.gateway_shared_key_file =
|
|
||||||
self::Client::<T>::default_gateway_shared_key_file(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
// ack key setting
|
|
||||||
if self.client.ack_key_file.as_os_str().is_empty() {
|
|
||||||
self.client.ack_key_file = self::Client::<T>::default_ack_key_file(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
if self
|
|
||||||
.client
|
|
||||||
.reply_encryption_key_store_path
|
|
||||||
.as_os_str()
|
|
||||||
.is_empty()
|
|
||||||
{
|
|
||||||
self.client.reply_encryption_key_store_path =
|
|
||||||
self::Client::<T>::default_reply_encryption_key_store_path(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
if self.client.database_path.as_os_str().is_empty() {
|
|
||||||
self.client.database_path = self::Client::<T>::default_database_path(&id);
|
|
||||||
}
|
|
||||||
|
|
||||||
self.client.id = id;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn with_disabled_credentials(&mut self, disabled_credentials_mode: bool) {
|
|
||||||
self.client.disabled_credentials_mode = disabled_credentials_mode;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn with_gateway_endpoint(&mut self, gateway_endpoint: GatewayEndpoint) {
|
|
||||||
self.client.gateway_endpoint = gateway_endpoint;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn with_gateway_id<S: Into<String>>(&mut self, id: S) {
|
|
||||||
self.client.gateway_endpoint.gateway_id = id.into();
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_custom_validators(&mut self, validator_urls: Vec<Url>) {
|
|
||||||
self.client.validator_urls = validator_urls;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_custom_validator_apis(&mut self, validator_api_urls: Vec<Url>) {
|
|
||||||
self.client.validator_api_urls = validator_api_urls;
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_high_default_traffic_volume(&mut self) {
|
|
||||||
self.debug.average_packet_delay = Duration::from_millis(10);
|
|
||||||
self.debug.loop_cover_traffic_average_delay = Duration::from_millis(2_000_000); // basically don't really send cover messages
|
|
||||||
self.debug.message_sending_average_delay = Duration::from_millis(4); // 250 "real" messages / s
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn set_custom_version(&mut self, version: &str) {
|
|
||||||
self.client.version = version.to_string();
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_id(&self) -> String {
|
|
||||||
self.client.id.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_disabled_credentials_mode(&self) -> bool {
|
|
||||||
self.client.disabled_credentials_mode
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_nym_root_directory(&self) -> PathBuf {
|
|
||||||
self.client.nym_root_directory.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_private_identity_key_file(&self) -> PathBuf {
|
|
||||||
self.client.private_identity_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_public_identity_key_file(&self) -> PathBuf {
|
|
||||||
self.client.public_identity_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_private_encryption_key_file(&self) -> PathBuf {
|
|
||||||
self.client.private_encryption_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_public_encryption_key_file(&self) -> PathBuf {
|
|
||||||
self.client.public_encryption_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_shared_key_file(&self) -> PathBuf {
|
|
||||||
self.client.gateway_shared_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_reply_encryption_key_store_path(&self) -> PathBuf {
|
|
||||||
self.client.reply_encryption_key_store_path.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_ack_key_file(&self) -> PathBuf {
|
|
||||||
self.client.ack_key_file.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_validator_endpoints(&self) -> Vec<Url> {
|
|
||||||
self.client.validator_urls.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_validator_api_endpoints(&self) -> Vec<Url> {
|
|
||||||
self.client.validator_api_urls.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_id(&self) -> String {
|
|
||||||
self.client.gateway_endpoint.gateway_id.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_owner(&self) -> String {
|
|
||||||
self.client.gateway_endpoint.gateway_owner.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_listener(&self) -> String {
|
|
||||||
self.client.gateway_endpoint.gateway_listener.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_endpoint(&self) -> &GatewayEndpoint {
|
|
||||||
&self.client.gateway_endpoint
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_database_path(&self) -> PathBuf {
|
|
||||||
self.client.database_path.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Debug getters
|
|
||||||
pub fn get_average_packet_delay(&self) -> Duration {
|
|
||||||
self.debug.average_packet_delay
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_average_ack_delay(&self) -> Duration {
|
|
||||||
self.debug.average_ack_delay
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_ack_wait_multiplier(&self) -> f64 {
|
|
||||||
self.debug.ack_wait_multiplier
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_ack_wait_addition(&self) -> Duration {
|
|
||||||
self.debug.ack_wait_addition
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_loop_cover_traffic_average_delay(&self) -> Duration {
|
|
||||||
self.debug.loop_cover_traffic_average_delay
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_message_sending_average_delay(&self) -> Duration {
|
|
||||||
self.debug.message_sending_average_delay
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_gateway_response_timeout(&self) -> Duration {
|
|
||||||
self.debug.gateway_response_timeout
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_topology_refresh_rate(&self) -> Duration {
|
|
||||||
self.debug.topology_refresh_rate
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_topology_resolution_timeout(&self) -> Duration {
|
|
||||||
self.debug.topology_resolution_timeout
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_disabled_loop_cover_traffic_stream(&self) -> bool {
|
|
||||||
self.debug.disable_loop_cover_traffic_stream
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_disabled_main_poisson_packet_distribution(&self) -> bool {
|
|
||||||
self.debug.disable_main_poisson_packet_distribution
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_use_extended_packet_size(&self) -> Option<ExtendedPacketSize> {
|
|
||||||
self.debug.use_extended_packet_size.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn get_version(&self) -> &str {
|
|
||||||
&self.client.version
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: NymConfig> Default for Config<T> {
|
|
||||||
fn default() -> Self {
|
|
||||||
Config {
|
|
||||||
client: Client::<T>::default(),
|
|
||||||
logging: Default::default(),
|
|
||||||
debug: Default::default(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, Default, Deserialize, PartialEq, Eq, Serialize)]
|
|
||||||
#[cfg_attr(target_arch = "wasm32", wasm_bindgen(getter_with_clone))]
|
|
||||||
pub struct GatewayEndpoint {
|
|
||||||
/// gateway_id specifies ID of the gateway to which the client should send messages.
|
|
||||||
/// If initially omitted, a random gateway will be chosen from the available topology.
|
|
||||||
pub gateway_id: String,
|
|
||||||
|
|
||||||
/// Address of the gateway owner to which the client should send messages.
|
|
||||||
pub gateway_owner: String,
|
|
||||||
|
|
||||||
/// Address of the gateway listener to which all client requests should be sent.
|
|
||||||
pub gateway_listener: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<topology::gateway::Node> for GatewayEndpoint {
|
|
||||||
fn from(node: topology::gateway::Node) -> GatewayEndpoint {
|
|
||||||
let gateway_listener = node.clients_address();
|
|
||||||
GatewayEndpoint {
|
|
||||||
gateway_id: node.identity_key.to_base58_string(),
|
|
||||||
gateway_owner: node.owner,
|
|
||||||
gateway_listener,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, PartialEq, Eq, Serialize)]
|
|
||||||
pub struct Client<T> {
|
|
||||||
/// Version of the client for which this configuration was created.
|
|
||||||
#[serde(default = "missing_string_value")]
|
|
||||||
version: String,
|
|
||||||
|
|
||||||
/// ID specifies the human readable ID of this particular client.
|
|
||||||
id: String,
|
|
||||||
|
|
||||||
/// Indicates whether this client is running in a disabled credentials mode, thus attempting
|
|
||||||
/// to claim bandwidth without presenting bandwidth credentials.
|
|
||||||
#[serde(default)]
|
|
||||||
disabled_credentials_mode: bool,
|
|
||||||
|
|
||||||
/// Addresses to nymd validators via which the client can communicate with the chain.
|
|
||||||
#[serde(default)]
|
|
||||||
validator_urls: Vec<Url>,
|
|
||||||
|
|
||||||
/// Addresses to APIs running on validator from which the client gets the view of the network.
|
|
||||||
validator_api_urls: Vec<Url>,
|
|
||||||
|
|
||||||
/// Path to file containing private identity key.
|
|
||||||
private_identity_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Path to file containing public identity key.
|
|
||||||
public_identity_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Path to file containing private encryption key.
|
|
||||||
private_encryption_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Path to file containing public encryption key.
|
|
||||||
public_encryption_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Path to file containing shared key derived with the specified gateway that is used
|
|
||||||
/// for all communication with it.
|
|
||||||
gateway_shared_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Path to file containing key used for encrypting and decrypting the content of an
|
|
||||||
/// acknowledgement so that nobody besides the client knows which packet it refers to.
|
|
||||||
ack_key_file: PathBuf,
|
|
||||||
|
|
||||||
/// Full path to file containing reply encryption keys of all reply-SURBs we have ever
|
|
||||||
/// sent but not received back.
|
|
||||||
reply_encryption_key_store_path: PathBuf,
|
|
||||||
|
|
||||||
/// Information regarding how the client should send data to gateway.
|
|
||||||
gateway_endpoint: GatewayEndpoint,
|
|
||||||
|
|
||||||
/// Path to the database containing bandwidth credentials of this client.
|
|
||||||
database_path: PathBuf,
|
|
||||||
|
|
||||||
/// nym_home_directory specifies absolute path to the home nym Clients directory.
|
|
||||||
/// It is expected to use default value and hence .toml file should not redefine this field.
|
|
||||||
nym_root_directory: PathBuf,
|
|
||||||
|
|
||||||
#[serde(skip)]
|
|
||||||
super_struct: PhantomData<T>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: NymConfig> Default for Client<T> {
|
|
||||||
fn default() -> Self {
|
|
||||||
// there must be explicit checks for whether id is not empty later
|
|
||||||
Client {
|
|
||||||
version: env!("CARGO_PKG_VERSION").to_string(),
|
|
||||||
id: "".to_string(),
|
|
||||||
disabled_credentials_mode: true,
|
|
||||||
validator_urls: vec![],
|
|
||||||
validator_api_urls: vec![],
|
|
||||||
private_identity_key_file: Default::default(),
|
|
||||||
public_identity_key_file: Default::default(),
|
|
||||||
private_encryption_key_file: Default::default(),
|
|
||||||
public_encryption_key_file: Default::default(),
|
|
||||||
gateway_shared_key_file: Default::default(),
|
|
||||||
ack_key_file: Default::default(),
|
|
||||||
reply_encryption_key_store_path: Default::default(),
|
|
||||||
gateway_endpoint: Default::default(),
|
|
||||||
database_path: Default::default(),
|
|
||||||
nym_root_directory: T::default_root_directory(),
|
|
||||||
super_struct: Default::default(),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<T: NymConfig> Client<T> {
|
|
||||||
fn default_private_identity_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("private_identity.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_public_identity_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("public_identity.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_private_encryption_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("private_encryption.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_public_encryption_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("public_encryption.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_gateway_shared_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("gateway_shared.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_ack_key_file(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("ack_key.pem")
|
|
||||||
}
|
|
||||||
|
|
||||||
fn default_reply_encryption_key_store_path(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join("reply_key_store")
|
|
||||||
}
|
|
||||||
fn default_database_path(id: &str) -> PathBuf {
|
|
||||||
T::default_data_directory(Some(id)).join(DB_FILE_NAME)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Debug, Default, Deserialize, PartialEq, Eq, Serialize)]
|
|
||||||
#[serde(deny_unknown_fields)]
|
|
||||||
pub struct Logging {}
|
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, PartialEq, Serialize)]
|
|
||||||
#[serde(default, deny_unknown_fields)]
|
|
||||||
pub struct Debug {
|
|
||||||
/// The parameter of Poisson distribution determining how long, on average,
|
|
||||||
/// sent packet is going to be delayed at any given mix node.
|
|
||||||
/// So for a packet going through three mix nodes, on average, it will take three times this value
|
|
||||||
/// until the packet reaches its destination.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub average_packet_delay: Duration,
|
|
||||||
|
|
||||||
/// The parameter of Poisson distribution determining how long, on average,
|
|
||||||
/// sent acknowledgement is going to be delayed at any given mix node.
|
|
||||||
/// So for an ack going through three mix nodes, on average, it will take three times this value
|
|
||||||
/// until the packet reaches its destination.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub average_ack_delay: Duration,
|
|
||||||
|
|
||||||
/// Value multiplied with the expected round trip time of an acknowledgement packet before
|
|
||||||
/// it is assumed it was lost and retransmission of the data packet happens.
|
|
||||||
/// In an ideal network with 0 latency, this value would have been 1.
|
|
||||||
pub ack_wait_multiplier: f64,
|
|
||||||
|
|
||||||
/// Value added to the expected round trip time of an acknowledgement packet before
|
|
||||||
/// it is assumed it was lost and retransmission of the data packet happens.
|
|
||||||
/// In an ideal network with 0 latency, this value would have been 0.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub ack_wait_addition: Duration,
|
|
||||||
|
|
||||||
/// The parameter of Poisson distribution determining how long, on average,
|
|
||||||
/// it is going to take for another loop cover traffic message to be sent.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub loop_cover_traffic_average_delay: Duration,
|
|
||||||
|
|
||||||
/// The parameter of Poisson distribution determining how long, on average,
|
|
||||||
/// it is going to take another 'real traffic stream' message to be sent.
|
|
||||||
/// If no real packets are available and cover traffic is enabled,
|
|
||||||
/// a loop cover message is sent instead in order to preserve the rate.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub message_sending_average_delay: Duration,
|
|
||||||
|
|
||||||
/// How long we're willing to wait for a response to a message sent to the gateway,
|
|
||||||
/// before giving up on it.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub gateway_response_timeout: Duration,
|
|
||||||
|
|
||||||
/// The uniform delay every which clients are querying the directory server
|
|
||||||
/// to try to obtain a compatible network topology to send sphinx packets through.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub topology_refresh_rate: Duration,
|
|
||||||
|
|
||||||
/// During topology refresh, test packets are sent through every single possible network
|
|
||||||
/// path. This timeout determines waiting period until it is decided that the packet
|
|
||||||
/// did not reach its destination.
|
|
||||||
#[serde(with = "humantime_serde")]
|
|
||||||
pub topology_resolution_timeout: Duration,
|
|
||||||
|
|
||||||
/// Controls whether the dedicated loop cover traffic stream should be enabled.
|
|
||||||
/// (and sending packets, on average, every [Self::loop_cover_traffic_average_delay])
|
|
||||||
pub disable_loop_cover_traffic_stream: bool,
|
|
||||||
|
|
||||||
/// Controls whether the main packet stream constantly produces packets according to the predefined
|
|
||||||
/// poisson distribution.
|
|
||||||
pub disable_main_poisson_packet_distribution: bool,
|
|
||||||
|
|
||||||
/// Controls whether the sent sphinx packet use a NON-DEFAULT bigger size.
|
|
||||||
pub use_extended_packet_size: Option<ExtendedPacketSize>,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize, PartialEq, Eq)]
|
|
||||||
#[serde(rename_all = "lowercase")]
|
|
||||||
pub enum ExtendedPacketSize {
|
|
||||||
Extended8,
|
|
||||||
Extended16,
|
|
||||||
Extended32,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl Default for Debug {
|
|
||||||
fn default() -> Self {
|
|
||||||
Debug {
|
|
||||||
average_packet_delay: DEFAULT_AVERAGE_PACKET_DELAY,
|
|
||||||
average_ack_delay: DEFAULT_AVERAGE_PACKET_DELAY,
|
|
||||||
ack_wait_multiplier: DEFAULT_ACK_WAIT_MULTIPLIER,
|
|
||||||
ack_wait_addition: DEFAULT_ACK_WAIT_ADDITION,
|
|
||||||
loop_cover_traffic_average_delay: DEFAULT_LOOP_COVER_STREAM_AVERAGE_DELAY,
|
|
||||||
message_sending_average_delay: DEFAULT_MESSAGE_STREAM_AVERAGE_DELAY,
|
|
||||||
gateway_response_timeout: DEFAULT_GATEWAY_RESPONSE_TIMEOUT,
|
|
||||||
topology_refresh_rate: DEFAULT_TOPOLOGY_REFRESH_RATE,
|
|
||||||
topology_resolution_timeout: DEFAULT_TOPOLOGY_RESOLUTION_TIMEOUT,
|
|
||||||
disable_loop_cover_traffic_stream: false,
|
|
||||||
disable_main_poisson_packet_distribution: false,
|
|
||||||
use_extended_packet_size: None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<ExtendedPacketSize> for PacketSize {
|
|
||||||
fn from(size: ExtendedPacketSize) -> PacketSize {
|
|
||||||
match size {
|
|
||||||
ExtendedPacketSize::Extended8 => PacketSize::ExtendedPacket8,
|
|
||||||
ExtendedPacketSize::Extended16 => PacketSize::ExtendedPacket16,
|
|
||||||
ExtendedPacketSize::Extended32 => PacketSize::ExtendedPacket32,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,32 +0,0 @@
|
|||||||
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
use crypto::asymmetric::identity::Ed25519RecoveryError;
|
|
||||||
use gateway_client::error::GatewayClientError;
|
|
||||||
use validator_client::ValidatorClientError;
|
|
||||||
|
|
||||||
#[derive(thiserror::Error, Debug)]
|
|
||||||
pub enum ClientCoreError {
|
|
||||||
#[error("I/O error: {0}")]
|
|
||||||
IoError(#[from] std::io::Error),
|
|
||||||
#[error("Gateway client error: {0}")]
|
|
||||||
GatewayClientError(#[from] GatewayClientError),
|
|
||||||
#[error("Ed25519 error: {0}")]
|
|
||||||
Ed25519RecoveryError(#[from] Ed25519RecoveryError),
|
|
||||||
#[error("Validator client error: {0}")]
|
|
||||||
ValidatorClientError(#[from] ValidatorClientError),
|
|
||||||
|
|
||||||
#[error("No gateway with id: {0}")]
|
|
||||||
NoGatewayWithId(String),
|
|
||||||
#[error("No gateways on network")]
|
|
||||||
NoGatewaysOnNetwork,
|
|
||||||
#[error("List of validator apis is empty")]
|
|
||||||
ListOfValidatorApisIsEmpty,
|
|
||||||
#[error("Could not load existing gateway configuration: {0}")]
|
|
||||||
CouldNotLoadExistingGatewayConfiguration(std::io::Error),
|
|
||||||
#[error("The current network topology seem to be insufficient to route any packets through")]
|
|
||||||
InsufficientNetworkTopology,
|
|
||||||
|
|
||||||
#[error("Unexpected exit")]
|
|
||||||
UnexpectedExit,
|
|
||||||
}
|
|
||||||
@@ -1,149 +0,0 @@
|
|||||||
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
|
||||||
|
|
||||||
//! Collection of initialization steps used by client implementations
|
|
||||||
|
|
||||||
use std::{sync::Arc, time::Duration};
|
|
||||||
|
|
||||||
use config::NymConfig;
|
|
||||||
use crypto::asymmetric::{encryption, identity};
|
|
||||||
use gateway_client::GatewayClient;
|
|
||||||
use gateway_requests::registration::handshake::SharedKeys;
|
|
||||||
use nymsphinx::addressing::clients::Recipient;
|
|
||||||
use nymsphinx::addressing::nodes::NodeIdentity;
|
|
||||||
use rand::rngs::OsRng;
|
|
||||||
use rand::seq::SliceRandom;
|
|
||||||
use rand::thread_rng;
|
|
||||||
use tap::TapFallible;
|
|
||||||
use topology::{filter::VersionFilterable, gateway};
|
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
use crate::{
|
|
||||||
client::key_manager::KeyManager,
|
|
||||||
config::{persistence::key_pathfinder::ClientKeyPathfinder, Config},
|
|
||||||
error::ClientCoreError,
|
|
||||||
};
|
|
||||||
|
|
||||||
pub async fn query_gateway_details(
|
|
||||||
validator_servers: Vec<Url>,
|
|
||||||
chosen_gateway_id: Option<&str>,
|
|
||||||
) -> Result<gateway::Node, ClientCoreError> {
|
|
||||||
let validator_api = validator_servers
|
|
||||||
.choose(&mut thread_rng())
|
|
||||||
.ok_or(ClientCoreError::ListOfValidatorApisIsEmpty)?;
|
|
||||||
let validator_client = validator_client::client::ApiClient::new(validator_api.clone());
|
|
||||||
|
|
||||||
log::trace!("Fetching list of gateways from: {}", validator_api);
|
|
||||||
let gateways = validator_client.get_cached_gateways().await?;
|
|
||||||
let valid_gateways = gateways
|
|
||||||
.into_iter()
|
|
||||||
.filter_map(|gateway| gateway.try_into().ok())
|
|
||||||
.collect::<Vec<gateway::Node>>();
|
|
||||||
|
|
||||||
let filtered_gateways = valid_gateways.filter_by_version(env!("CARGO_PKG_VERSION"));
|
|
||||||
|
|
||||||
// if we have chosen particular gateway - use it, otherwise choose a random one.
|
|
||||||
// (remember that in active topology all gateways have at least 100 reputation so should
|
|
||||||
// be working correctly)
|
|
||||||
if let Some(gateway_id) = chosen_gateway_id {
|
|
||||||
filtered_gateways
|
|
||||||
.iter()
|
|
||||||
.find(|gateway| gateway.identity_key.to_base58_string() == gateway_id)
|
|
||||||
.ok_or_else(|| ClientCoreError::NoGatewayWithId(gateway_id.to_string()))
|
|
||||||
.cloned()
|
|
||||||
} else {
|
|
||||||
filtered_gateways
|
|
||||||
.choose(&mut rand::thread_rng())
|
|
||||||
.ok_or(ClientCoreError::NoGatewaysOnNetwork)
|
|
||||||
.cloned()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn register_with_gateway_and_store_keys<T>(
|
|
||||||
gateway_details: gateway::Node,
|
|
||||||
config: &Config<T>,
|
|
||||||
) -> Result<(), ClientCoreError>
|
|
||||||
where
|
|
||||||
T: NymConfig,
|
|
||||||
{
|
|
||||||
let mut rng = OsRng;
|
|
||||||
let mut key_manager = KeyManager::new(&mut rng);
|
|
||||||
|
|
||||||
let shared_keys =
|
|
||||||
register_with_gateway(&gateway_details, key_manager.identity_keypair()).await?;
|
|
||||||
key_manager.insert_gateway_shared_key(shared_keys);
|
|
||||||
|
|
||||||
let pathfinder = ClientKeyPathfinder::new_from_config(config);
|
|
||||||
Ok(key_manager
|
|
||||||
.store_keys(&pathfinder)
|
|
||||||
.tap_err(|err| log::error!("Failed to generate keys: {err}"))?)
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn register_with_gateway(
|
|
||||||
gateway: &gateway::Node,
|
|
||||||
our_identity: Arc<identity::KeyPair>,
|
|
||||||
) -> Result<Arc<SharedKeys>, ClientCoreError> {
|
|
||||||
let timeout = Duration::from_millis(1500);
|
|
||||||
let mut gateway_client = GatewayClient::new_init(
|
|
||||||
gateway.clients_address(),
|
|
||||||
gateway.identity_key,
|
|
||||||
gateway.owner.clone(),
|
|
||||||
our_identity.clone(),
|
|
||||||
timeout,
|
|
||||||
#[cfg(not(target_arch = "wasm32"))]
|
|
||||||
None,
|
|
||||||
);
|
|
||||||
gateway_client
|
|
||||||
.establish_connection()
|
|
||||||
.await
|
|
||||||
.tap_err(|_| log::warn!("Failed to establish connection with gateway!"))?;
|
|
||||||
let shared_keys = gateway_client
|
|
||||||
.perform_initial_authentication()
|
|
||||||
.await
|
|
||||||
.tap_err(|_| log::warn!("Failed to register with the gateway!"))?;
|
|
||||||
Ok(shared_keys)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn show_address<T>(config: &Config<T>) -> Result<(), ClientCoreError>
|
|
||||||
where
|
|
||||||
T: config::NymConfig,
|
|
||||||
{
|
|
||||||
fn load_identity_keys(
|
|
||||||
pathfinder: &ClientKeyPathfinder,
|
|
||||||
) -> Result<identity::KeyPair, ClientCoreError> {
|
|
||||||
let identity_keypair: identity::KeyPair =
|
|
||||||
pemstore::load_keypair(&pemstore::KeyPairPath::new(
|
|
||||||
pathfinder.private_identity_key().to_owned(),
|
|
||||||
pathfinder.public_identity_key().to_owned(),
|
|
||||||
))
|
|
||||||
.tap_err(|_| log::error!("Failed to read stored identity key files"))?;
|
|
||||||
Ok(identity_keypair)
|
|
||||||
}
|
|
||||||
|
|
||||||
fn load_sphinx_keys(
|
|
||||||
pathfinder: &ClientKeyPathfinder,
|
|
||||||
) -> Result<encryption::KeyPair, ClientCoreError> {
|
|
||||||
let sphinx_keypair: encryption::KeyPair =
|
|
||||||
pemstore::load_keypair(&pemstore::KeyPairPath::new(
|
|
||||||
pathfinder.private_encryption_key().to_owned(),
|
|
||||||
pathfinder.public_encryption_key().to_owned(),
|
|
||||||
))
|
|
||||||
.tap_err(|_| log::error!("Failed to read stored sphinx key files"))?;
|
|
||||||
Ok(sphinx_keypair)
|
|
||||||
}
|
|
||||||
|
|
||||||
let pathfinder = ClientKeyPathfinder::new_from_config(config);
|
|
||||||
let identity_keypair = load_identity_keys(&pathfinder)?;
|
|
||||||
let sphinx_keypair = load_sphinx_keys(&pathfinder)?;
|
|
||||||
|
|
||||||
let client_recipient = Recipient::new(
|
|
||||||
*identity_keypair.public_key(),
|
|
||||||
*sphinx_keypair.public_key(),
|
|
||||||
// TODO: below only works under assumption that gateway address == gateway id
|
|
||||||
// (which currently is true)
|
|
||||||
NodeIdentity::from_base58_string(config.get_gateway_id())?,
|
|
||||||
);
|
|
||||||
|
|
||||||
println!("\nThe address of this client is: {}", client_recipient);
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
@@ -1,29 +1,23 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "credential"
|
name = "nym-credential-client"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
|
|
||||||
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html
|
||||||
|
|
||||||
[dependencies]
|
[dependencies]
|
||||||
bip39 = "1.0.1"
|
clap = { version = "4.0", features = ["cargo", "derive"] }
|
||||||
cfg-if = "0.1"
|
log = "0.4"
|
||||||
clap = { version = "3.2", features = ["cargo", "derive"] }
|
serde = { workspace = true, features = ["derive"] }
|
||||||
rand = "0.7.3"
|
|
||||||
serde = { version = "1.0", features = ["derive"] }
|
|
||||||
thiserror = "1.0"
|
thiserror = "1.0"
|
||||||
url = "2.2"
|
tokio = { version = "1.24.1", features = ["rt-multi-thread", "net", "signal", "macros"] } # async runtime
|
||||||
tokio = { version = "1.21.2", features = ["rt-multi-thread", "net", "signal", "macros"] } # async runtime
|
|
||||||
|
|
||||||
coconut-interface = { path = "../../common/coconut-interface" }
|
nym-bandwidth-controller = { path = "../../common/bandwidth-controller" }
|
||||||
config = { path = "../../common/config" }
|
nym-config = { path = "../../common/config" }
|
||||||
completions = { path = "../../common/completions" }
|
nym-credentials = { path = "../../common/credentials" }
|
||||||
credentials = { path = "../../common/credentials" }
|
nym-credential-storage = { path = "../../common/credential-storage" }
|
||||||
credential-storage = { path = "../../common/credential-storage" }
|
nym-bin-common = { path = "../../common/bin-common"}
|
||||||
crypto = { path = "../../common/crypto", features = ["rand", "asymmetric", "symmetric", "aes", "hashing"] }
|
nym-network-defaults = { path = "../../common/network-defaults" }
|
||||||
network-defaults = { path = "../../common/network-defaults" }
|
nym-pemstore = { path = "../../common/pemstore" }
|
||||||
pemstore = { path = "../../common/pemstore" }
|
nym-validator-client = { path = "../../common/client-libs/validator-client", features = ["nyxd-client"] }
|
||||||
validator-client = { path = "../../common/client-libs/validator-client", features = ["nymd-client"] }
|
|
||||||
|
|
||||||
[features]
|
|
||||||
coconut = ["credentials/coconut"]
|
|
||||||
|
|||||||
@@ -0,0 +1,32 @@
|
|||||||
|
<!--
|
||||||
|
Copyright 2023 - Nym Technologies SA <contact@nymtech.net>
|
||||||
|
SPDX-License-Identifier: Apache-2.0
|
||||||
|
-->
|
||||||
|
|
||||||
|
## Credential binary
|
||||||
|
|
||||||
|
The credential binary is used to acquire coconut bandwidth credentials in exchange for nym tokens. Those credentials are stored in the client's `data` directory, so that they can be used as the client sees fit.
|
||||||
|
|
||||||
|
### Warning
|
||||||
|
|
||||||
|
The credential binary is still experimental software. The infrastructure for using it is not yet deployed to mainnet and it's still in the process of being deployed to sandbox.
|
||||||
|
|
||||||
|
### Building
|
||||||
|
|
||||||
|
From the project's root directory, run:
|
||||||
|
```
|
||||||
|
cargo build -p credential
|
||||||
|
```
|
||||||
|
which generates the `credential` binary in `target/debug/credential`.
|
||||||
|
|
||||||
|
|
||||||
|
### Running
|
||||||
|
|
||||||
|
For example, you can get a credential worth 3 nym (3000000 unym) in a socks5 client that was already initialized like so:
|
||||||
|
|
||||||
|
```
|
||||||
|
./target/debug/credential --config-env-file envs/sandbox.env --client-home-directory ~/.nym/socks5-clients/cred_client --nyxd-url https://sandbox-validator1.nymtech.net --mnemonic $MNEMONIC --recovery-dir /tmp/recovery --amount 3000000
|
||||||
|
```
|
||||||
|
|
||||||
|
More information regarding how to run the binary can be found by running it with the `--help` argument.
|
||||||
|
|
||||||
@@ -3,30 +3,30 @@
|
|||||||
|
|
||||||
use crate::error::Result;
|
use crate::error::Result;
|
||||||
use bip39::Mnemonic;
|
use bip39::Mnemonic;
|
||||||
use network_defaults::{NymNetworkDetails, VOUCHER_INFO};
|
use nym_network_defaults::{NymNetworkDetails, VOUCHER_INFO};
|
||||||
|
use nym_validator_client::nyxd;
|
||||||
|
use nym_validator_client::nyxd::traits::CoconutBandwidthSigningClient;
|
||||||
|
use nym_validator_client::nyxd::{Coin, DirectSigningNyxdClient, Fee, NyxdClient};
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
use url::Url;
|
use url::Url;
|
||||||
use validator_client::nymd;
|
|
||||||
use validator_client::nymd::traits::CoconutBandwidthSigningClient;
|
|
||||||
use validator_client::nymd::{Coin, Fee, NymdClient, SigningNymdClient};
|
|
||||||
|
|
||||||
pub(crate) struct Client {
|
pub(crate) struct Client {
|
||||||
nymd_client: NymdClient<SigningNymdClient>,
|
nyxd_client: NyxdClient<DirectSigningNyxdClient>,
|
||||||
mix_denom_base: String,
|
mix_denom_base: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Client {
|
impl Client {
|
||||||
pub fn new(nymd_url: &str, mnemonic: &str) -> Self {
|
pub fn new(nyxd_url: &str, mnemonic: &str) -> Self {
|
||||||
let nymd_url = Url::from_str(nymd_url).unwrap();
|
let nyxd_url = Url::from_str(nyxd_url).unwrap();
|
||||||
let mnemonic = Mnemonic::from_str(mnemonic).unwrap();
|
let mnemonic = Mnemonic::from_str(mnemonic).unwrap();
|
||||||
let network_details = NymNetworkDetails::new_from_env();
|
let network_details = NymNetworkDetails::new_from_env();
|
||||||
let config = nymd::Config::try_from_nym_network_details(&network_details)
|
let config = nyxd::Config::try_from_nym_network_details(&network_details)
|
||||||
.expect("failed to construct valid validator client config with the provided network");
|
.expect("failed to construct valid validator client config with the provided network");
|
||||||
let nymd_client =
|
let nyxd_client =
|
||||||
NymdClient::connect_with_mnemonic(config, nymd_url.as_ref(), mnemonic, None).unwrap();
|
NyxdClient::connect_with_mnemonic(config, nyxd_url.as_ref(), mnemonic, None).unwrap();
|
||||||
|
|
||||||
Client {
|
Client {
|
||||||
nymd_client,
|
nyxd_client,
|
||||||
mix_denom_base: network_details.chain_details.mix_denom.base,
|
mix_denom_base: network_details.chain_details.mix_denom.base,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -40,7 +40,7 @@ impl Client {
|
|||||||
) -> Result<String> {
|
) -> Result<String> {
|
||||||
let amount = Coin::new(amount as u128, self.mix_denom_base.clone());
|
let amount = Coin::new(amount as u128, self.mix_denom_base.clone());
|
||||||
Ok(self
|
Ok(self
|
||||||
.nymd_client
|
.nyxd_client
|
||||||
.deposit(
|
.deposit(
|
||||||
amount,
|
amount,
|
||||||
String::from(VOUCHER_INFO),
|
String::from(VOUCHER_INFO),
|
||||||
|
|||||||
@@ -1,28 +1,19 @@
|
|||||||
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
use clap::{Args, Subcommand};
|
use clap::{ArgGroup, Args, Subcommand};
|
||||||
use completions::ArgShell;
|
use log::*;
|
||||||
use rand::rngs::OsRng;
|
use nym_bandwidth_controller::acquire::state::State;
|
||||||
use std::str::FromStr;
|
use nym_bin_common::completions::ArgShell;
|
||||||
|
use nym_credential_storage::persistent_storage::PersistentStorage;
|
||||||
|
use nym_validator_client::nyxd::traits::DkgQueryClient;
|
||||||
|
|
||||||
use coconut_interface::{Base58, Parameters};
|
use crate::error::Result;
|
||||||
use credential_storage::storage::Storage;
|
use crate::recovery_storage::RecoveryStorage;
|
||||||
use credential_storage::PersistentStorage;
|
|
||||||
use credentials::coconut::bandwidth::{BandwidthVoucher, TOTAL_ATTRIBUTES};
|
|
||||||
use credentials::coconut::utils::obtain_aggregate_signature;
|
|
||||||
use crypto::asymmetric::{encryption, identity};
|
|
||||||
use network_defaults::{NymNetworkDetails, VOUCHER_INFO};
|
|
||||||
use validator_client::nymd::tx::Hash;
|
|
||||||
use validator_client::{CoconutApiClient, Config};
|
|
||||||
|
|
||||||
use crate::client::Client;
|
|
||||||
use crate::error::{CredentialClientError, Result};
|
|
||||||
use crate::state::{KeyPair, State};
|
|
||||||
|
|
||||||
#[derive(Subcommand)]
|
#[derive(Subcommand)]
|
||||||
pub(crate) enum Command {
|
pub(crate) enum Command {
|
||||||
/// Run the binary
|
/// Run the binary to obtain a credential
|
||||||
Run(Run),
|
Run(Run),
|
||||||
|
|
||||||
/// Generate shell completions
|
/// Generate shell completions
|
||||||
@@ -33,80 +24,59 @@ pub(crate) enum Command {
|
|||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Args)]
|
#[derive(Args)]
|
||||||
|
#[clap(group(
|
||||||
|
ArgGroup::new("recov")
|
||||||
|
.required(true)
|
||||||
|
.args(&["amount", "recovery_mode"]),
|
||||||
|
))]
|
||||||
pub(crate) struct Run {
|
pub(crate) struct Run {
|
||||||
/// Home directory of the client that is supposed to use the credential.
|
/// Home directory of the client that is supposed to use the credential.
|
||||||
#[clap(long)]
|
#[clap(long)]
|
||||||
pub(crate) client_home_directory: std::path::PathBuf,
|
pub(crate) client_home_directory: std::path::PathBuf,
|
||||||
|
|
||||||
/// The nymd URL that should be used
|
|
||||||
#[clap(long)]
|
|
||||||
pub(crate) nymd_url: String,
|
|
||||||
|
|
||||||
/// A mnemonic for the account that buys the credential
|
/// A mnemonic for the account that buys the credential
|
||||||
#[clap(long)]
|
#[clap(long)]
|
||||||
pub(crate) mnemonic: String,
|
pub(crate) mnemonic: String,
|
||||||
|
|
||||||
/// The amount of utokens the credential will hold
|
/// The amount of utokens the credential will hold. If recovery mode is enabled, this value
|
||||||
#[clap(long)]
|
/// is not needed
|
||||||
|
#[clap(long, default_value = "0")]
|
||||||
pub(crate) amount: u64,
|
pub(crate) amount: u64,
|
||||||
|
|
||||||
|
/// Path to a directory used to store recovery files for unconsumed deposits
|
||||||
|
#[clap(long)]
|
||||||
|
pub(crate) recovery_dir: std::path::PathBuf,
|
||||||
|
|
||||||
|
/// Recovery mode, when enabled, tries to recover any deposit data dumped in recovery_dir
|
||||||
|
#[clap(long)]
|
||||||
|
pub(crate) recovery_mode: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn deposit(nymd_url: &str, mnemonic: &str, amount: u64) -> Result<State> {
|
pub(crate) async fn recover_credentials<C: DkgQueryClient + Send + Sync>(
|
||||||
let mut rng = OsRng;
|
client: &C,
|
||||||
let signing_keypair = KeyPair::from(identity::KeyPair::new(&mut rng));
|
recovery_storage: &RecoveryStorage,
|
||||||
let encryption_keypair = KeyPair::from(encryption::KeyPair::new(&mut rng));
|
shared_storage: &PersistentStorage,
|
||||||
|
) -> Result<()> {
|
||||||
let client = Client::new(nymd_url, mnemonic);
|
for voucher in recovery_storage.unconsumed_vouchers()? {
|
||||||
let tx_hash = client
|
let state = State::new(voucher);
|
||||||
.deposit(
|
if let Err(e) =
|
||||||
amount,
|
nym_bandwidth_controller::acquire::get_credential(&state, client, shared_storage).await
|
||||||
signing_keypair.public_key.clone(),
|
{
|
||||||
encryption_keypair.public_key.clone(),
|
error!(
|
||||||
None,
|
"Could not recover deposit {} due to {:?}, try again later",
|
||||||
)
|
state.voucher.tx_hash(),
|
||||||
.await?;
|
e
|
||||||
|
)
|
||||||
let state = State {
|
} else {
|
||||||
amount,
|
info!(
|
||||||
tx_hash,
|
"Converted deposit {} to a credential, removing recovery data for it",
|
||||||
signing_keypair,
|
state.voucher.tx_hash()
|
||||||
encryption_keypair,
|
);
|
||||||
};
|
if let Err(e) = recovery_storage.remove_voucher(state.voucher.tx_hash().to_string()) {
|
||||||
|
warn!("Could not remove recovery data - {:?}", e);
|
||||||
Ok(state)
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
pub(crate) async fn get_credential(state: &State, shared_storage: PersistentStorage) -> Result<()> {
|
|
||||||
let network_details = NymNetworkDetails::new_from_env();
|
|
||||||
let config = Config::try_from_nym_network_details(&network_details)?;
|
|
||||||
let client = validator_client::Client::new_query(config)?;
|
|
||||||
let coconut_api_clients = CoconutApiClient::all_coconut_api_clients(&client).await?;
|
|
||||||
|
|
||||||
let params = Parameters::new(TOTAL_ATTRIBUTES).unwrap();
|
|
||||||
let bandwidth_credential_attributes = BandwidthVoucher::new(
|
|
||||||
¶ms,
|
|
||||||
state.amount.to_string(),
|
|
||||||
VOUCHER_INFO.to_string(),
|
|
||||||
Hash::from_str(&state.tx_hash).map_err(|_| CredentialClientError::InvalidTxHash)?,
|
|
||||||
identity::PrivateKey::from_base58_string(&state.signing_keypair.private_key)?,
|
|
||||||
encryption::PrivateKey::from_base58_string(&state.encryption_keypair.private_key)?,
|
|
||||||
);
|
|
||||||
|
|
||||||
let signature = obtain_aggregate_signature(
|
|
||||||
¶ms,
|
|
||||||
&bandwidth_credential_attributes,
|
|
||||||
&coconut_api_clients,
|
|
||||||
)
|
|
||||||
.await?;
|
|
||||||
shared_storage
|
|
||||||
.insert_coconut_credential(
|
|
||||||
state.amount.to_string(),
|
|
||||||
VOUCHER_INFO.to_string(),
|
|
||||||
bandwidth_credential_attributes.get_private_attributes()[0].to_bs58(),
|
|
||||||
bandwidth_credential_attributes.get_private_attributes()[1].to_bs58(),
|
|
||||||
signature.to_bs58(),
|
|
||||||
)
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,21 +1,26 @@
|
|||||||
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
use std::time::SystemTimeError;
|
||||||
use thiserror::Error;
|
use thiserror::Error;
|
||||||
|
|
||||||
use credential_storage::error::StorageError;
|
use nym_credential_storage::error::StorageError;
|
||||||
use credentials::error::Error as CredentialError;
|
use nym_credentials::error::Error as CredentialError;
|
||||||
use crypto::asymmetric::encryption::KeyRecoveryError;
|
use nym_validator_client::nyxd::error::NyxdError;
|
||||||
use crypto::asymmetric::identity::Ed25519RecoveryError;
|
use nym_validator_client::ValidatorClientError;
|
||||||
use validator_client::nymd::error::NymdError;
|
|
||||||
use validator_client::ValidatorClientError;
|
|
||||||
|
|
||||||
pub type Result<T> = std::result::Result<T, CredentialClientError>;
|
pub type Result<T> = std::result::Result<T, CredentialClientError>;
|
||||||
|
|
||||||
#[derive(Error, Debug)]
|
#[derive(Error, Debug)]
|
||||||
pub enum CredentialClientError {
|
pub enum CredentialClientError {
|
||||||
#[error("Nymd error: {0}")]
|
#[error("IO error: {0}")]
|
||||||
Nymd(#[from] NymdError),
|
IOError(#[from] std::io::Error),
|
||||||
|
|
||||||
|
#[error("Bandwidth controller error: {0}")]
|
||||||
|
BandwidthControllerError(#[from] nym_bandwidth_controller::error::BandwidthControllerError),
|
||||||
|
|
||||||
|
#[error("Nyxd error: {0}")]
|
||||||
|
Nyxd(#[from] NyxdError),
|
||||||
|
|
||||||
#[error("Validator client error: {0}")]
|
#[error("Validator client error: {0}")]
|
||||||
ValidatorClientError(#[from] ValidatorClientError),
|
ValidatorClientError(#[from] ValidatorClientError),
|
||||||
@@ -23,15 +28,9 @@ pub enum CredentialClientError {
|
|||||||
#[error("Credential error: {0}")]
|
#[error("Credential error: {0}")]
|
||||||
Credential(#[from] CredentialError),
|
Credential(#[from] CredentialError),
|
||||||
|
|
||||||
#[error("The tx hash provided is not valid")]
|
|
||||||
InvalidTxHash,
|
|
||||||
|
|
||||||
#[error("Could not parse Ed25519 data")]
|
|
||||||
Ed25519ParseError(#[from] Ed25519RecoveryError),
|
|
||||||
|
|
||||||
#[error("Could not parse X25519 data")]
|
|
||||||
X25519ParseError(#[from] KeyRecoveryError),
|
|
||||||
|
|
||||||
#[error("Could not use shared storage")]
|
#[error("Could not use shared storage")]
|
||||||
SharedStorageError(#[from] StorageError),
|
SharedStorageError(#[from] StorageError),
|
||||||
|
|
||||||
|
#[error("Could not get system time")]
|
||||||
|
SysTimeError(#[from] SystemTimeError),
|
||||||
}
|
}
|
||||||
|
|||||||
+112
-42
@@ -1,56 +1,126 @@
|
|||||||
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
// Copyright 2022 - Nym Technologies SA <contact@nymtech.net>
|
||||||
// SPDX-License-Identifier: Apache-2.0
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
cfg_if::cfg_if! {
|
mod commands;
|
||||||
if #[cfg(feature = "coconut")] {
|
mod error;
|
||||||
|
mod recovery_storage;
|
||||||
|
|
||||||
mod client;
|
use commands::*;
|
||||||
mod commands;
|
use error::Result;
|
||||||
mod error;
|
use log::*;
|
||||||
mod state;
|
use nym_bin_common::completions::fig_generate;
|
||||||
|
use nym_config::{CRED_DB_FILE_NAME, DATA_DIR};
|
||||||
|
use nym_network_defaults::{setup_env, NymNetworkDetails};
|
||||||
|
use std::process::exit;
|
||||||
|
use std::time::{Duration, SystemTime};
|
||||||
|
|
||||||
use error::Result;
|
use clap::{CommandFactory, Parser};
|
||||||
use network_defaults::setup_env;
|
use nym_bin_common::logging::setup_logging;
|
||||||
use completions::fig_generate;
|
use nym_validator_client::nyxd::traits::DkgQueryClient;
|
||||||
use commands::*;
|
use nym_validator_client::nyxd::{Coin, CosmWasmClient};
|
||||||
use config::{DATA_DIR, DB_FILE_NAME};
|
use nym_validator_client::Config;
|
||||||
|
|
||||||
use clap::{CommandFactory, Parser};
|
const SAFETY_BUFFER_SECS: u64 = 60; // 1 minute
|
||||||
|
|
||||||
#[derive(Parser)]
|
#[derive(Parser)]
|
||||||
#[clap(author = "Nymtech", version, about)]
|
#[clap(author = "Nymtech", version, about)]
|
||||||
struct Cli {
|
struct Cli {
|
||||||
/// Path pointing to an env file that configures the client.
|
/// Path pointing to an env file that configures the client.
|
||||||
#[clap(short, long)]
|
#[clap(short, long)]
|
||||||
pub(crate) config_env_file: Option<std::path::PathBuf>,
|
pub(crate) config_env_file: Option<std::path::PathBuf>,
|
||||||
|
|
||||||
#[clap(subcommand)]
|
#[clap(subcommand)]
|
||||||
pub(crate) command: Command,
|
pub(crate) command: Command,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::main]
|
async fn block_until_coconut_is_available<C: CosmWasmClient + Send + Sync>(
|
||||||
async fn main() -> Result<()> {
|
client: &nym_validator_client::Client<C>,
|
||||||
let args = Cli::parse();
|
) -> Result<()> {
|
||||||
setup_env(args.config_env_file.clone());
|
loop {
|
||||||
let bin_name = "nym-credential-client";
|
let epoch = client.nyxd.get_current_epoch().await?;
|
||||||
|
let current_timestamp_secs = SystemTime::now()
|
||||||
match args.command {
|
.duration_since(SystemTime::UNIX_EPOCH)?
|
||||||
Command::Run(r) => {
|
.as_secs();
|
||||||
let db_path = r.client_home_directory.join(DATA_DIR).join(DB_FILE_NAME);
|
if epoch.state.is_final() {
|
||||||
let shared_storage = credential_storage::initialise_storage(db_path).await;
|
if current_timestamp_secs + SAFETY_BUFFER_SECS >= epoch.finish_timestamp.seconds() {
|
||||||
|
info!("In the next {} minute(s), a transition will take place in the coconut system. Deposits should be halted in this time for safety reasons.", SAFETY_BUFFER_SECS / 60);
|
||||||
let state = deposit(&r.nymd_url, &r.mnemonic, r.amount).await?;
|
exit(0);
|
||||||
get_credential(&state, shared_storage).await?;
|
|
||||||
}
|
|
||||||
Command::Completions(c) => c.generate(&mut crate::Cli::into_app(), bin_name),
|
|
||||||
Command::GenerateFigSpec => fig_generate(&mut crate::Cli::into_app(), bin_name)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
break;
|
||||||
}
|
} else {
|
||||||
} else {
|
// Use 1 additional second to not start the next iteration immediately and spam get_current_epoch queries
|
||||||
fn main() {
|
let secs_until_final = epoch
|
||||||
println!("Crate only designed for coconut feature");
|
.final_timestamp_secs()
|
||||||
|
.saturating_sub(current_timestamp_secs)
|
||||||
|
+ 1;
|
||||||
|
info!("Approximately {} seconds until coconut is available. Sleeping until then. You can safely kill the process at any moment.", secs_until_final);
|
||||||
|
std::thread::sleep(Duration::from_secs(secs_until_final));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
#[tokio::main]
|
||||||
|
async fn main() -> Result<()> {
|
||||||
|
let args = Cli::parse();
|
||||||
|
setup_logging();
|
||||||
|
setup_env(args.config_env_file.as_ref());
|
||||||
|
let bin_name = "nym-credential-client";
|
||||||
|
|
||||||
|
match args.command {
|
||||||
|
Command::Run(r) => {
|
||||||
|
let db_path = r
|
||||||
|
.client_home_directory
|
||||||
|
.join(DATA_DIR)
|
||||||
|
.join(CRED_DB_FILE_NAME);
|
||||||
|
let shared_storage =
|
||||||
|
nym_credential_storage::initialise_persistent_storage(db_path).await;
|
||||||
|
let recovery_storage = recovery_storage::RecoveryStorage::new(r.recovery_dir)?;
|
||||||
|
|
||||||
|
let network_details = NymNetworkDetails::new_from_env();
|
||||||
|
let config = Config::try_from_nym_network_details(&network_details).expect(
|
||||||
|
"failed to construct valid validator client config with the provided network",
|
||||||
|
);
|
||||||
|
let amount = Coin::new(
|
||||||
|
r.amount as u128,
|
||||||
|
network_details.chain_details.mix_denom.base,
|
||||||
|
);
|
||||||
|
let client =
|
||||||
|
nym_validator_client::Client::new_signing(config, r.mnemonic.parse().unwrap())?;
|
||||||
|
|
||||||
|
block_until_coconut_is_available(&client).await?;
|
||||||
|
info!("Starting depositing funds, don't kill the process");
|
||||||
|
|
||||||
|
if !r.recovery_mode {
|
||||||
|
let state =
|
||||||
|
nym_bandwidth_controller::acquire::deposit(&client.nyxd, amount).await?;
|
||||||
|
if nym_bandwidth_controller::acquire::get_credential(
|
||||||
|
&state,
|
||||||
|
&client,
|
||||||
|
&shared_storage,
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.is_err()
|
||||||
|
{
|
||||||
|
warn!("Failed to obtain credential. Dumping recovery data.",);
|
||||||
|
match recovery_storage.insert_voucher(&state.voucher) {
|
||||||
|
Ok(file_path) => {
|
||||||
|
warn!("Dumped recovery data to {:?}. Try using recovery mode to convert it to a credential", file_path);
|
||||||
|
}
|
||||||
|
Err(e) => {
|
||||||
|
error!("Could not dump recovery data to file system due to {:?}, the deposit will be lost!", e)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
recover_credentials(&client.nyxd, &recovery_storage, &shared_storage).await?;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Command::Completions(c) => c.generate(&mut Cli::command(), bin_name),
|
||||||
|
Command::GenerateFigSpec => fig_generate(&mut Cli::command(), bin_name),
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,56 @@
|
|||||||
|
// Copyright 2023 - Nym Technologies SA <contact@nymtech.net>
|
||||||
|
// SPDX-License-Identifier: Apache-2.0
|
||||||
|
|
||||||
|
use nym_credentials::coconut::bandwidth::BandwidthVoucher;
|
||||||
|
use std::fs::{create_dir_all, read_dir, File};
|
||||||
|
use std::io::{Read, Write};
|
||||||
|
use std::path::PathBuf;
|
||||||
|
|
||||||
|
pub struct RecoveryStorage {
|
||||||
|
recovery_dir: PathBuf,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl RecoveryStorage {
|
||||||
|
pub fn new(recovery_dir: PathBuf) -> std::io::Result<Self> {
|
||||||
|
create_dir_all(&recovery_dir)?;
|
||||||
|
Ok(Self { recovery_dir })
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn unconsumed_vouchers(&self) -> std::io::Result<impl Iterator<Item = BandwidthVoucher>> {
|
||||||
|
Ok(read_dir(&self.recovery_dir)?
|
||||||
|
.filter_map(|entry| entry.ok())
|
||||||
|
.filter_map(|entry| {
|
||||||
|
let path = entry.path();
|
||||||
|
if path.is_file() {
|
||||||
|
Some(path)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.filter_map(|path| File::open(path).ok())
|
||||||
|
.filter_map(|mut f| {
|
||||||
|
let mut buff = Vec::new();
|
||||||
|
if f.read_to_end(&mut buff).is_ok() {
|
||||||
|
Some(buff)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.filter_map(|buff| BandwidthVoucher::try_from_bytes(&buff).ok()))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn insert_voucher(&self, voucher: &BandwidthVoucher) -> std::io::Result<PathBuf> {
|
||||||
|
let file_name = voucher.tx_hash().to_string();
|
||||||
|
let file_path = self.recovery_dir.join(file_name);
|
||||||
|
let mut file = File::create(&file_path)?;
|
||||||
|
let buff = voucher.to_bytes();
|
||||||
|
file.write_all(&buff)?;
|
||||||
|
|
||||||
|
Ok(file_path)
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn remove_voucher(&self, file_name: String) -> std::io::Result<()> {
|
||||||
|
let file_path = self.recovery_dir.join(file_name);
|
||||||
|
std::fs::remove_file(file_path)
|
||||||
|
}
|
||||||
|
}
|
||||||
+24
-33
@@ -1,6 +1,6 @@
|
|||||||
[package]
|
[package]
|
||||||
name = "nym-client"
|
name = "nym-client"
|
||||||
version = "1.1.2"
|
version = "1.1.15"
|
||||||
authors = ["Dave Hrycyszyn <futurechimp@users.noreply.github.com>", "Jędrzej Stuczyński <andrew@nymtech.net>"]
|
authors = ["Dave Hrycyszyn <futurechimp@users.noreply.github.com>", "Jędrzej Stuczyński <andrew@nymtech.net>"]
|
||||||
description = "Implementation of the Nym Client"
|
description = "Implementation of the Nym Client"
|
||||||
edition = "2021"
|
edition = "2021"
|
||||||
@@ -20,44 +20,35 @@ futures = "0.3" # bunch of futures stuff, however, now that I think about it, it
|
|||||||
# and the single instance of abortable we have should really be refactored anyway
|
# and the single instance of abortable we have should really be refactored anyway
|
||||||
url = "2.2"
|
url = "2.2"
|
||||||
|
|
||||||
clap = { version = "3.2", features = ["cargo", "derive"] }
|
clap = { version = "4.0", features = ["cargo", "derive"] }
|
||||||
dirs = "4.0"
|
dirs = "4.0"
|
||||||
log = "0.4" # self explanatory
|
lazy_static = "1.4.0"
|
||||||
|
log = { workspace = true } # self explanatory
|
||||||
pretty_env_logger = "0.4" # for formatting log messages
|
pretty_env_logger = "0.4" # for formatting log messages
|
||||||
rand = { version = "0.7.3", features = ["wasm-bindgen"] } # rng-related traits + some rng implementation to use
|
rand = { version = "0.7.3", features = ["wasm-bindgen"] } # rng-related traits + some rng implementation to use
|
||||||
serde = { version = "1.0.104", features = ["derive"] } # for config serialization/deserialization
|
serde = { workspace = true, features = ["derive"] } # for config serialization/deserialization
|
||||||
sled = "0.34" # for storage of replySURB decryption keys
|
serde_json = { workspace = true }
|
||||||
thiserror = "1.0.34"
|
thiserror = "1.0.34"
|
||||||
tokio = { version = "1.21.2", features = ["rt-multi-thread", "net", "signal"] } # async runtime
|
tap = "1.0.1"
|
||||||
|
tokio = { version = "1.24.1", features = ["rt-multi-thread", "net", "signal"] } # async runtime
|
||||||
tokio-tungstenite = "0.14" # websocket
|
tokio-tungstenite = "0.14" # websocket
|
||||||
|
|
||||||
## internal
|
## internal
|
||||||
client-core = { path = "../client-core" }
|
nym-bandwidth-controller = { path = "../../common/bandwidth-controller" }
|
||||||
client-connections = { path = "../../common/client-connections" }
|
nym-bin-common = { path = "../../common/bin-common", features = ["output_format"] }
|
||||||
coconut-interface = { path = "../../common/coconut-interface", optional = true }
|
nym-client-core = { path = "../../common/client-core", features = ["fs-surb-storage"] }
|
||||||
config = { path = "../../common/config" }
|
nym-coconut-interface = { path = "../../common/coconut-interface" }
|
||||||
completions = { path = "../../common/completions" }
|
nym-config = { path = "../../common/config" }
|
||||||
credential-storage = { path = "../../common/credential-storage" }
|
nym-credential-storage = { path = "../../common/credential-storage" }
|
||||||
credentials = { path = "../../common/credentials", optional = true }
|
nym-credentials = { path = "../../common/credentials" }
|
||||||
crypto = { path = "../../common/crypto" }
|
nym-crypto = { path = "../../common/crypto" }
|
||||||
logging = { path = "../../common/logging"}
|
nym-gateway-requests = { path = "../../gateway/gateway-requests" }
|
||||||
gateway-client = { path = "../../common/client-libs/gateway-client" }
|
nym-network-defaults = { path = "../../common/network-defaults" }
|
||||||
gateway-requests = { path = "../../gateway/gateway-requests" }
|
nym-sphinx = { path = "../../common/nymsphinx" }
|
||||||
network-defaults = { path = "../../common/network-defaults" }
|
nym-pemstore = { path = "../../common/pemstore" }
|
||||||
nymsphinx = { path = "../../common/nymsphinx" }
|
nym-task = { path = "../../common/task" }
|
||||||
pemstore = { path = "../../common/pemstore" }
|
nym-topology = { path = "../../common/topology" }
|
||||||
task = { path = "../../common/task" }
|
nym-validator-client = { path = "../../common/client-libs/validator-client", features = ["nyxd-client"] }
|
||||||
topology = { path = "../../common/topology" }
|
nym-client-websocket-requests = { path = "websocket-requests" }
|
||||||
validator-client = { path = "../../common/client-libs/validator-client", features = ["nymd-client"] }
|
|
||||||
version-checker = { path = "../../common/version-checker" }
|
|
||||||
websocket-requests = { path = "websocket-requests" }
|
|
||||||
tap = "1.0.1"
|
|
||||||
|
|
||||||
[features]
|
|
||||||
coconut = ["coconut-interface", "credentials", "credentials/coconut", "gateway-requests/coconut", "gateway-client/coconut", "client-core/coconut"]
|
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
serde_json = "1.0" # for the "textsend" example
|
|
||||||
|
|
||||||
[build-dependencies]
|
|
||||||
vergen = { version = "5", default-features = false, features = ["build", "git", "rustc", "cargo"] }
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user