diff options
author | Anton Luka Šijanec <anton@sijanec.eu> | 2023-01-08 23:48:11 +0100 |
---|---|---|
committer | Anton Luka Šijanec <anton@sijanec.eu> | 2023-01-08 23:48:11 +0100 |
commit | 9b3caf1f841cf451ba162bcaf83a96ba0c834a78 (patch) | |
tree | 1ea5adf151c03064c58f9e44fc72e8f87bfba16c /utils/info.c | |
parent | idea for metadl via tcp for outgoing connections implemented, not tested, compiles (diff) | |
download | travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar.gz travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar.bz2 travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar.lz travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar.xz travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.tar.zst travnik-9b3caf1f841cf451ba162bcaf83a96ba0c834a78.zip |
Diffstat (limited to 'utils/info.c')
-rw-r--r-- | utils/info.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/utils/info.c b/utils/info.c new file mode 100644 index 0000000..6f082dc --- /dev/null +++ b/utils/info.c @@ -0,0 +1,33 @@ +#include <error.h> +#include <sys/time.h> +#include <poll.h> +#define TORRENT_USERDATA struct dht * dht; +#define DHT_USERDATA struct pollfd ** pollfds; size_t * pollfds_size; nfds_t * nfds; +#include <dht.c> +#define S0(x) (x ? x : "") +int we_have_disconnected = 0; +#define DISCONNECTION_MIXIN_BOTTOM we_have_disconnected++; +#include <tcp.c> +int main (int argc, char ** argv) { + if (argc != 1+3) + error_at_line(1, 0, __FILE__, __LINE__, "%s infohash ipv6 port", S0(argv[0])); + struct dht * dht = dht_init(NULL); + nfds_t nfds = 0; + size_t pollfds_size = 1; + struct pollfd * pollfds = malloc(sizeof *pollfds); + dht->nfds = &nfds; + dht->pollfds_size = &pollfds_size; + dht->pollfds = &pollfds; + dht->connection = connection; + dht->verbosity |= incoming_dht | outgoing_dht | expected | debug; + dht->torrents = torrent_init(); + hex2bin(dht->torrents->hash, argv[1], 20); + dht->torrents->type = info; + dht->torrents->peers = peer_init(); + inet_pton(AF_INET6, argv[2], dht->torrents->peers->addr.sin6_addr.s6_addr); + dht->torrents->peers->addr.sin6_port = htons(atoi(argv[3])); + periodic(dht); + while (!we_have_disconnected && poll(*dht->pollfds, *dht->nfds, -1) != -1) + tcp_work(dht); + dht_free(dht); +} |