diff options
Diffstat (limited to 'youtube_dl/downloader/external.py')
| -rw-r--r-- | youtube_dl/downloader/external.py | 28 | 
1 files changed, 16 insertions, 12 deletions
| diff --git a/youtube_dl/downloader/external.py b/youtube_dl/downloader/external.py index 6c310346c..2bc011266 100644 --- a/youtube_dl/downloader/external.py +++ b/youtube_dl/downloader/external.py @@ -5,6 +5,10 @@ import subprocess  from .common import FileDownloader  from ..utils import ( +    cli_option, +    cli_valueless_option, +    cli_bool_option, +    cli_configuration_args,      encodeFilename,      encodeArgument,  ) @@ -46,19 +50,16 @@ class ExternalFD(FileDownloader):          return info_dict['protocol'] in ('http', 'https', 'ftp', 'ftps')      def _option(self, command_option, param): -        param = self.params.get(param) -        if param is None: -            return [] -        if isinstance(param, bool): -            return [command_option] -        return [command_option, param] +        return cli_option(self.params, command_option, param) + +    def _bool_option(self, command_option, param, true_value='true', false_value='false', separator=None): +        return cli_bool_option(self.params, command_option, param, true_value, false_value, separator) + +    def _valueless_option(self, command_option, param, expected_value=True): +        return cli_valueless_option(self.params, command_option, param, expected_value)      def _configuration_args(self, default=[]): -        ex_args = self.params.get('external_downloader_args') -        if ex_args is None: -            return default -        assert isinstance(ex_args, list) -        return ex_args +        return cli_configuration_args(self.params, 'external_downloader_args', default)      def _call_downloader(self, tmpfilename, info_dict):          """ Either overwrite this or implement _make_cmd """ @@ -80,6 +81,8 @@ class CurlFD(ExternalFD):          for key, val in info_dict['http_headers'].items():              cmd += ['--header', '%s: %s' % (key, val)]          cmd += self._option('--interface', 'source_address') +        cmd += self._option('--proxy', 'proxy') +        cmd += self._valueless_option('--insecure', 'nocheckcertificate')          cmd += self._configuration_args()          cmd += ['--', info_dict['url']]          return cmd @@ -102,7 +105,7 @@ class WgetFD(ExternalFD):              cmd += ['--header', '%s: %s' % (key, val)]          cmd += self._option('--bind-address', 'source_address')          cmd += self._option('--proxy', 'proxy') -        cmd += self._option('--no-check-certificate', 'nocheckcertificate') +        cmd += self._valueless_option('--no-check-certificate', 'nocheckcertificate')          cmd += self._configuration_args()          cmd += ['--', info_dict['url']]          return cmd @@ -121,6 +124,7 @@ class Aria2cFD(ExternalFD):              cmd += ['--header', '%s: %s' % (key, val)]          cmd += self._option('--interface', 'source_address')          cmd += self._option('--all-proxy', 'proxy') +        cmd += self._bool_option('--check-certificate', 'nocheckcertificate', 'false', 'true', '=')          cmd += ['--', info_dict['url']]          return cmd | 
