diff options
author | vijayanand nandam <vijay@cybrilla.com> | 2015-02-02 20:51:40 +0530 |
---|---|---|
committer | vijayanand nandam <vijay@cybrilla.com> | 2015-02-02 20:51:40 +0530 |
commit | 6a66904f8ed469a547d8781fd61b26a97a6ae7aa (patch) | |
tree | ff06b02a90cf300c3ac2793ee175f3a48480edfd /youtube_dl/downloader/external.py | |
parent | 12832049170e8b3bd457706f49e8e09de12a368c (diff) |
passing source address option to external downloaders
Diffstat (limited to 'youtube_dl/downloader/external.py')
-rw-r--r-- | youtube_dl/downloader/external.py | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/youtube_dl/downloader/external.py b/youtube_dl/downloader/external.py index af9fdba75..3d6554fe4 100644 --- a/youtube_dl/downloader/external.py +++ b/youtube_dl/downloader/external.py @@ -45,6 +45,12 @@ class ExternalFD(FileDownloader): def supports(cls, info_dict): return info_dict['protocol'] in ('http', 'https', 'ftp', 'ftps') + def _source_address(self, command_option): + command_part = [] + if self.ydl.params['source_address'] is not None: + command_part = [command_option, self.ydl.params['source_address']] + return command_part + def _call_downloader(self, tmpfilename, info_dict): """ Either overwrite this or implement _make_cmd """ cmd = self._make_cmd(tmpfilename, info_dict) @@ -72,6 +78,7 @@ class CurlFD(ExternalFD): cmd = [self.exe, '-o', tmpfilename] for key, val in info_dict['http_headers'].items(): cmd += ['--header', '%s: %s' % (key, val)] + cmd += self._source_address('--interface') cmd += ['--', info_dict['url']] return cmd @@ -81,6 +88,7 @@ class WgetFD(ExternalFD): cmd = [self.exe, '-O', tmpfilename, '-nv', '--no-cookies'] for key, val in info_dict['http_headers'].items(): cmd += ['--header', '%s: %s' % (key, val)] + cmd += self._source_address('--bind-address') cmd += ['--', info_dict['url']] return cmd @@ -96,6 +104,7 @@ class Aria2cFD(ExternalFD): cmd += ['--out', os.path.basename(tmpfilename)] for key, val in info_dict['http_headers'].items(): cmd += ['--header', '%s: %s' % (key, val)] + cmd += self._source_address('--interface') cmd += ['--', info_dict['url']] return cmd |