diff options
author | Philipp Hagemeister <[email protected]> | 2014-05-12 21:56:10 +0200 |
---|---|---|
committer | Philipp Hagemeister <[email protected]> | 2014-05-12 21:58:23 +0200 |
commit | c1bce22f23811bf54420dd39e23cce3acc545016 (patch) | |
tree | add34b0cdc4ae00ca9359333f94c7274d4fbe2a0 /youtube_dl | |
parent | e3abbbe3018cf3213a84a4b366392edb730faccc (diff) | |
download | youtube-dl-c1bce22f23811bf54420dd39e23cce3acc545016.tar.gz youtube-dl-c1bce22f23811bf54420dd39e23cce3acc545016.zip |
[extractor/common] Protect against long video IDs and URLs
Diffstat (limited to 'youtube_dl')
-rw-r--r-- | youtube_dl/extractor/common.py | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/youtube_dl/extractor/common.py b/youtube_dl/extractor/common.py index 10b0cbe69..cef8c523c 100644 --- a/youtube_dl/extractor/common.py +++ b/youtube_dl/extractor/common.py @@ -242,10 +242,11 @@ class InfoExtractor(object): url = url_or_request.get_full_url() except AttributeError: url = url_or_request - if len(url) > 200: - h = u'___' + hashlib.md5(url.encode('utf-8')).hexdigest() - url = url[:200 - len(h)] + h - raw_filename = ('%s_%s.dump' % (video_id, url)) + basen = video_id + '_' + url + if len(basen) > 240: + h = u'___' + hashlib.md5(basen.encode('utf-8')).hexdigest() + basen = basen[:240 - len(h)] + h + raw_filename = basen + '.dump' filename = sanitize_filename(raw_filename, restricted=True) self.to_screen(u'Saving request to ' + filename) with open(filename, 'wb') as outf: |