gallery.accords-library.com/server/szurubooru/func/net.py

55 lines
1.8 KiB
Python
Raw Normal View History

import logging
2016-05-05 11:23:15 +00:00
import urllib.request
import os
from tempfile import NamedTemporaryFile
from szurubooru import config, errors
from szurubooru.func import mime, util
from youtube_dl import YoutubeDL
from youtube_dl.utils import YoutubeDLError
2016-05-05 11:23:15 +00:00
logger = logging.getLogger(__name__)
def download(url: str, use_video_downloader: bool = False) -> bytes:
2016-08-14 08:45:00 +00:00
assert url
2016-05-05 11:23:15 +00:00
request = urllib.request.Request(url)
if config.config['user_agent']:
request.add_header('User-Agent', config.config['user_agent'])
2016-05-05 11:23:15 +00:00
request.add_header('Referer', url)
2016-09-25 12:52:47 +00:00
try:
with urllib.request.urlopen(request) as handle:
content = handle.read()
2016-09-26 20:51:00 +00:00
except Exception as ex:
raise errors.ProcessingError('Error downloading %s (%s)' % (url, ex))
if (use_video_downloader and
mime.get_mime_type(content) == 'application/octet-stream'):
return _youtube_dl_wrapper(url)
return content
def _youtube_dl_wrapper(url: str) -> bytes:
outpath = os.path.join(
config.config['data_dir'],
'temporary-uploads',
'youtubedl-' + util.get_sha1(url)[0:8] + '.dat')
options = {
'ignoreerrors': False,
'format': 'best[ext=webm]/best[ext=mp4]/best[ext=flv]',
'logger': logger,
'max_filesize': config.config['max_dl_filesize'],
'max_downloads': 1,
'outtmpl': outpath,
}
try:
with YoutubeDL(options) as ydl:
ydl.extract_info(url, download=True)
with open(outpath, 'rb') as f:
return f.read()
except YoutubeDLError as ex:
raise errors.ThirdPartyError(
'Error downloading video %s (%s)' % (url, ex))
2020-06-05 14:02:18 +00:00
except FileNotFoundError:
raise errors.ThirdPartyError(
'Error downloading video %s (file could not be saved)' % (url))