From: Ramakrishnan Muthukrishnan Date: Tue, 17 Feb 2015 11:05:00 +0000 (+0530) Subject: Handle the `left' parameter for the tracker request. X-Git-Url: https://git.rkrishnan.org/pf/content/en/seg/biz//%22%22.?a=commitdiff_plain;h=1f707b2dc36f4b5d9c083c57de71906663f1c313;p=functorrent.git Handle the `left' parameter for the tracker request. Tracker initial request includes a parameter called `left' to indicate the size of the file left to be downloaded. When we contact the tracker initially, we haven't downloaded anything yet. So, the left parameter should be the length parameter. For now, we handle only single file torrent files, so we just pick the length param from Metainfo and shove it in into the tracker http request. --- diff --git a/src/Main.hs b/src/Main.hs index b0f594a..482b433 100644 --- a/src/Main.hs +++ b/src/Main.hs @@ -8,6 +8,7 @@ import qualified Metainfo as MInfo import qualified Tracker as T import qualified Text.ParserCombinators.Parsec as Parsec import qualified Peer as P +import qualified Data.Map as M import Data.Functor printError :: Parsec.ParseError -> IO () @@ -35,7 +36,8 @@ main = do Right d -> case MInfo.mkMetaInfo d of Nothing -> putStrLn "parse error" Just m -> do - body <- BC.pack <$> T.connect (MInfo.announce m) (T.prepareRequest d genPeerId) + let length = MInfo.lengthInBytes (MInfo.info m) + body <- BC.pack <$> T.connect (MInfo.announce m) (T.prepareRequest d genPeerId length) print (P.getPeers (P.getPeerResponse body)) Left e -> printError e putStrLn "done" diff --git a/src/Tracker.hs b/src/Tracker.hs index 52dccdd..68cf28c 100644 --- a/src/Tracker.hs +++ b/src/Tracker.hs @@ -38,17 +38,18 @@ infoHash m = let info = m M.! Benc.Bstr (BC.pack "info") peerHash :: String -> BC.ByteString peerHash = B16.encode . SHA1.hash . BC.pack -prepareRequest :: Benc.BVal -> String -> String -prepareRequest (Benc.Bdict d) peer_id = let p = [("info_hash", urlEncode (infoHash d)), - ("peer_id", urlEncode (peerHash peer_id)), - ("port", "6881"), - ("uploaded", "0"), - ("downloaded", "0"), - ("left", "0"), - ("compact", "1"), - ("event", "started")] - in - List.intercalate "&" [f ++ "=" ++ s | (f,s) <- p] +prepareRequest :: Benc.BVal -> String -> Integer -> String +prepareRequest (Benc.Bdict d) peer_id length = + let p = [("info_hash", urlEncode (infoHash d)), + ("peer_id", urlEncode (peerHash peer_id)), + ("port", "6881"), + ("uploaded", "0"), + ("downloaded", "0"), + ("left", show length), + ("compact", "1"), + ("event", "started")] + in + List.intercalate "&" [f ++ "=" ++ s | (f,s) <- p] connect :: Url -> String -> IO String connect baseurl qstr = let url = baseurl ++ "?" ++ qstr