mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-25 03:31:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # coding: utf-8
 | |
| from __future__ import unicode_literals
 | |
| 
 | |
| import threading
 | |
| 
 | |
| from .common import FileDownloader
 | |
| from ..downloader import get_suitable_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_suitable_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']
 | |
|         heartbeat_data = heartbeat_info_dict['data'].encode()
 | |
|         heartbeat_interval = heartbeat_info_dict.get('interval', 30)
 | |
| 
 | |
|         def heartbeat():
 | |
|             try:
 | |
|                 compat_urllib_request.urlopen(url=heartbeat_url, data=heartbeat_data)
 | |
|             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()
 | |
| 
 | |
|         heartbeat_info_dict['ping']()
 | |
|         self.to_screen('[%s] Heartbeat with %d second interval ...' % (self.FD_NAME, heartbeat_interval))
 | |
|         try:
 | |
|             heartbeat()
 | |
|             if type(fd).__name__ == 'HlsFD':
 | |
|                 info_dict.update(ie._extract_m3u8_formats(info_dict['url'], info_dict['id'])[0])
 | |
|             success = fd.real_download(filename, info_dict)
 | |
|         finally:
 | |
|             if heartbeat_lock:
 | |
|                 with heartbeat_lock:
 | |
|                     timer[0].cancel()
 | |
|                     download_complete = True
 | |
|             return success
 | 
