diff options
| author | Yen Chi Hsuan <yan12125@gmail.com> | 2016-01-30 20:05:56 +0800 | 
|---|---|---|
| committer | Yen Chi Hsuan <yan12125@gmail.com> | 2016-01-30 20:05:56 +0800 | 
| commit | 05d0d131a76e34af843d982dd47b556ddc8b9e44 (patch) | |
| tree | 639bb81adb7e5aca8a4ed82bc44c48d14a11a725 | |
| parent | c1406299959b780e7b86b567bd4eeecc8556dce0 (diff) | |
[youtube] Move decrypt_sig out of _parse_dash_manifest
| -rw-r--r-- | youtube_dl/extractor/youtube.py | 32 | 
1 files changed, 14 insertions, 18 deletions
| diff --git a/youtube_dl/extractor/youtube.py b/youtube_dl/extractor/youtube.py index a24c73584..08b7e15c4 100644 --- a/youtube_dl/extractor/youtube.py +++ b/youtube_dl/extractor/youtube.py @@ -1035,22 +1035,7 @@ class YoutubeIE(YoutubeBaseInfoExtractor):          url = 'https://www.youtube.com/annotations_invideo?features=1&legacy=1&video_id=%s' % video_id          return self._download_webpage(url, video_id, note='Searching for annotations.', errnote='Unable to download video annotations.') -    def _parse_dash_manifest( -            self, video_id, dash_manifest_url, player_url, age_gate, fatal=True): -        def decrypt_sig(mobj): -            s = mobj.group(1) -            dec_s = self._decrypt_signature(s, video_id, player_url, age_gate) -            return '/signature/%s' % dec_s -        dash_manifest_url = re.sub(r'/s/([a-fA-F0-9\.]+)', decrypt_sig, dash_manifest_url) -        dash_doc = self._download_xml( -            dash_manifest_url, video_id, -            note='Downloading DASH manifest', -            errnote='Could not download DASH manifest', -            fatal=fatal) - -        if dash_doc is False: -            return [] - +    def _parse_dash_manifest(self, video_id, dash_doc, fatal=True):          formats = []          for a in dash_doc.findall('.//{urn:mpeg:DASH:schema:MPD:2011}AdaptationSet'):              mime_type = a.attrib.get('mimeType') @@ -1533,8 +1518,19 @@ class YoutubeIE(YoutubeBaseInfoExtractor):              for dash_manifest_url in dash_mpds:                  dash_formats = {}                  try: -                    for df in self._parse_dash_manifest( -                            video_id, dash_manifest_url, player_url, age_gate, dash_mpd_fatal): +                    def decrypt_sig(mobj): +                        s = mobj.group(1) +                        dec_s = self._decrypt_signature(s, video_id, player_url, age_gate) +                        return '/signature/%s' % dec_s + +                    dash_manifest_url = re.sub(r'/s/([a-fA-F0-9\.]+)', decrypt_sig, dash_manifest_url) +                    dash_doc = self._download_xml( +                        dash_manifest_url, video_id, +                        note='Downloading DASH manifest', +                        errnote='Could not download DASH manifest', +                        fatal=dash_mpd_fatal) + +                    for df in self._parse_dash_manifest(video_id, dash_doc, dash_mpd_fatal):                          # Do not overwrite DASH format found in some previous DASH manifest                          if df['format_id'] not in dash_formats:                              dash_formats[df['format_id']] = df | 
