diff options
| author | Sergey M․ <dstftw@gmail.com> | 2017-02-04 21:06:07 +0700 | 
|---|---|---|
| committer | Sergey M <dstftw@gmail.com> | 2017-02-19 05:10:08 +0800 | 
| commit | 0016b84e16965a07c52946c4672363153e8b18a2 (patch) | |
| tree | 8879bee8b1c97b7db653d6f44e9e4f3be3d4f7a7 /youtube_dl/YoutubeDL.py | |
| parent | 18a0defab063523cd76a30be2dd5a80e9f9172d6 (diff) | |
Add faked X-Forwarded-For to formats' HTTP headers
Diffstat (limited to 'youtube_dl/YoutubeDL.py')
| -rwxr-xr-x | youtube_dl/YoutubeDL.py | 14 | 
1 files changed, 14 insertions, 0 deletions
| diff --git a/youtube_dl/YoutubeDL.py b/youtube_dl/YoutubeDL.py index ebace6b57..1c04e46c1 100755 --- a/youtube_dl/YoutubeDL.py +++ b/youtube_dl/YoutubeDL.py @@ -864,8 +864,14 @@ class YoutubeDL(object):              if self.params.get('playlistrandom', False):                  random.shuffle(entries) +            x_forwarded_for = ie_result.get('__x_forwarded_for_ip') +              for i, entry in enumerate(entries, 1):                  self.to_screen('[download] Downloading video %s of %s' % (i, n_entries)) +                # This __x_forwarded_for_ip thing is a bit ugly but requires +                # minimal changes +                if x_forwarded_for: +                    entry['__x_forwarded_for_ip'] = x_forwarded_for                  extra = {                      'n_entries': n_entries,                      'playlist': playlist, @@ -1250,6 +1256,11 @@ class YoutubeDL(object):          if cookies:              res['Cookie'] = cookies +        if 'X-Forwarded-For' not in res: +            x_forwarded_for_ip = info_dict.get('__x_forwarded_for_ip') +            if x_forwarded_for_ip: +                res['X-Forwarded-For'] = x_forwarded_for_ip +          return res      def _calc_cookies(self, info_dict): @@ -1392,6 +1403,9 @@ class YoutubeDL(object):              full_format_info = info_dict.copy()              full_format_info.update(format)              format['http_headers'] = self._calc_headers(full_format_info) +        # Remove private housekeeping stuff +        if '__x_forwarded_for_ip' in info_dict: +            del info_dict['__x_forwarded_for_ip']          # TODO Central sorting goes here | 
