1
0
mirror of https://github.com/spaam/svtplay-dl.git synced 2024-11-24 20:25:41 +01:00
svtplay-dl/lib/svtplay_dl/fetcher/http.py

55 lines
1.6 KiB
Python
Raw Normal View History

2013-03-02 21:26:28 +01:00
# ex:ts=4:sw=4:sts=4:et
# -*- tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*-
from __future__ import absolute_import
2013-02-12 19:15:11 +01:00
import sys
import time
from svtplay_dl.output import progress, output # FIXME use progressbar() instead
from svtplay_dl.log import log
from svtplay_dl.utils.urllib import urlopen, Request, HTTPError
2014-04-21 16:50:24 +02:00
from svtplay_dl.fetcher import VideoRetriever
2013-02-12 19:15:11 +01:00
2014-04-21 16:50:24 +02:00
class HTTP(VideoRetriever):
def name(self):
return "http"
2014-04-21 16:50:24 +02:00
def download(self):
""" Get the stream from HTTP """
request = Request(self.url)
request.add_header('User-Agent', 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-GB; rv:1.9.0.3) Gecko/2008092417 Firefox/3.0.3')
try:
response = urlopen(request)
except HTTPError as e:
log.error("Something wrong with that url")
log.error("Error code: %s", e.code)
sys.exit(5)
try:
total_size = response.info()['Content-Length']
except KeyError:
total_size = 0
total_size = int(total_size)
bytes_so_far = 0
file_d = output(self.options, self.url, "mp4")
2014-08-21 22:10:16 +02:00
if hasattr(file_d, "read") is False:
return
2013-02-12 19:15:11 +01:00
2014-04-21 16:50:24 +02:00
lastprogress = 0
while 1:
chunk = response.read(8192)
bytes_so_far += len(chunk)
2013-02-12 19:15:11 +01:00
2014-04-21 16:50:24 +02:00
if not chunk:
break
2013-02-12 19:15:11 +01:00
2014-04-21 16:50:24 +02:00
file_d.write(chunk)
if self.options.output != "-":
now = time.time()
if lastprogress + 1 < now:
lastprogress = now
progress(bytes_so_far, total_size)
2013-02-12 19:15:11 +01:00
2014-04-21 16:50:24 +02:00
if self.options.output != "-":
file_d.close()
2013-02-12 19:15:11 +01:00