2021-02-10 15:45:20 +09:00
|
|
|
# coding: utf-8
|
|
|
|
from __future__ import unicode_literals
|
|
|
|
|
|
|
|
import threading
|
|
|
|
|
|
|
|
from .common import FileDownloader
|
|
|
|
from ..downloader import _get_real_downloader
|
|
|
|
from ..extractor.niconico import NiconicoIE
|
|
|
|
from ..compat import compat_urllib_request
|
|
|
|
|
|
|
|
|
|
|
|
class NiconicoDmcFD(FileDownloader):
|
|
|
|
""" Downloading niconico douga from DMC with heartbeat """
|
|
|
|
|
|
|
|
FD_NAME = 'niconico_dmc'
|
|
|
|
|
|
|
|
def real_download(self, filename, info_dict):
|
|
|
|
self.to_screen('[%s] Downloading from DMC' % self.FD_NAME)
|
|
|
|
|
|
|
|
ie = NiconicoIE(self.ydl)
|
|
|
|
info_dict, heartbeat_info_dict = ie._get_heartbeat_info(info_dict)
|
|
|
|
|
|
|
|
fd = _get_real_downloader(info_dict, params=self.params)(self.ydl, self.params)
|
|
|
|
|
|
|
|
success = download_complete = False
|
|
|
|
timer = [None]
|
|
|
|
heartbeat_lock = threading.Lock()
|
|
|
|
heartbeat_url = heartbeat_info_dict['url']
|
2021-04-05 13:11:21 +05:30
|
|
|
heartbeat_data = heartbeat_info_dict['data'].encode()
|
2021-02-10 15:45:20 +09:00
|
|
|
heartbeat_interval = heartbeat_info_dict.get('interval', 30)
|
|
|
|
|
|
|
|
def heartbeat():
|
|
|
|
try:
|
2021-04-05 13:11:21 +05:30
|
|
|
compat_urllib_request.urlopen(url=heartbeat_url, data=heartbeat_data)
|
2021-02-10 15:45:20 +09:00
|
|
|
except Exception:
|
|
|
|
self.to_screen('[%s] Heartbeat failed' % self.FD_NAME)
|
|
|
|
|
|
|
|
with heartbeat_lock:
|
|
|
|
if not download_complete:
|
|
|
|
timer[0] = threading.Timer(heartbeat_interval, heartbeat)
|
|
|
|
timer[0].start()
|
|
|
|
|
2021-04-05 13:11:21 +05:30
|
|
|
heartbeat_info_dict['ping']()
|
|
|
|
self.to_screen('[%s] Heartbeat with %d second interval ...' % (self.FD_NAME, heartbeat_interval))
|
2021-02-10 15:45:20 +09:00
|
|
|
try:
|
|
|
|
heartbeat()
|
2021-04-05 13:11:21 +05:30
|
|
|
if type(fd).__name__ == 'HlsFD':
|
|
|
|
info_dict.update(ie._extract_m3u8_formats(info_dict['url'], info_dict['id'])[0])
|
2021-02-10 15:45:20 +09:00
|
|
|
success = fd.real_download(filename, info_dict)
|
|
|
|
finally:
|
|
|
|
if heartbeat_lock:
|
|
|
|
with heartbeat_lock:
|
|
|
|
timer[0].cancel()
|
|
|
|
download_complete = True
|
|
|
|
return success
|