diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2014-05-19 23:23:08 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2014-05-19 23:23:08 +0200 |
commit | 1055b951f37e4424f8c759f8cca4677e4fd8f02f (patch) | |
tree | 834962cc24af75bebc47ccf739af69ece8148d54 /sys/src/cmd | |
parent | c994152a90f479a5f3165590f72b749017b6af3e (diff) |
ip/torrent: fix usage, add -A option to set user-agent
trackers do like the new default Mozilla/5.0 (compatible)
user agent. so force useragent to hjdicks and give option
to override it in case trackers get even more clever in
the future.
Diffstat (limited to 'sys/src/cmd')
-rw-r--r-- | sys/src/cmd/ip/torrent.c | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/sys/src/cmd/ip/torrent.c b/sys/src/cmd/ip/torrent.c index 36e437f21..d84ea4fb2 100644 --- a/sys/src/cmd/ip/torrent.c +++ b/sys/src/cmd/ip/torrent.c @@ -54,6 +54,7 @@ int killgroup = -1; int port = 6881; char *deftrack = "http://exodus.desync.com/announce"; char *mntweb = "/mnt/web"; +char *useragent = "hjdicks"; uchar infohash[20]; uchar peerid[20]; int blocksize; @@ -726,6 +727,10 @@ hopen(char *url, ...) close(ctlfd); return -1; } + if(useragent != nil && useragent[0] != '\0'){ + n = snprint(buf, sizeof buf, "useragent %s", useragent); + write(ctlfd, buf, n); + } snprint(buf, sizeof buf, "%s/%d/body", mntweb, conn); if((fd = open(buf, OREAD)) < 0) goto ErrOut; @@ -1157,7 +1162,7 @@ void usage(void) { fprint(2, "usage: %s [ -vsdpc ] [ -m mtpt ] [ -t tracker-url ] " - "[ -w webseed-url ] [ file ]\n", argv0); + "[ -w webseed-url ] [ -i peerid ] [ -A useragent ] [ file ]\n", argv0); exits("usage"); } @@ -1217,6 +1222,9 @@ main(int argc, char *argv[]) case 'i': strncpy((char*)peerid, EARGF(usage()), sizeof(peerid)); break; + case 'A': + useragent = EARGF(usage()); + break; default: usage(); } ARGEND; |