aboutsummaryrefslogtreecommitdiffstats
path: root/youtube_dl/options.py
diff options
context:
space:
mode:
authorYen Chi Hsuan <yan12125@gmail.com>2017-07-23 16:21:35 +0800
committerYen Chi Hsuan <yan12125@gmail.com>2017-07-23 16:22:14 +0800
commit905d18a7aa42263c66f311ac0cdf46b2caa2f4d6 (patch)
tree83f1167fc8e3d879789bb6624125524775852a78 /youtube_dl/options.py
parent0db492c02a60dbfb44514833445bf267f5319ae2 (diff)
downloadyoutube-dl-905d18a7aa42263c66f311ac0cdf46b2caa2f4d6.zip
youtube-dl-905d18a7aa42263c66f311ac0cdf46b2caa2f4d6.tar.gz
youtube-dl-905d18a7aa42263c66f311ac0cdf46b2caa2f4d6.tar.bz2
[options] Correctly hide login info from debug outputs (#13696)
Iterate over opts instead of PRIVATE_OPTS for both performance and correctness
Diffstat (limited to 'youtube_dl/options.py')
-rw-r--r--youtube_dl/options.py38
1 files changed, 18 insertions, 20 deletions
diff --git a/youtube_dl/options.py b/youtube_dl/options.py
index 79e9fd1..38439c9 100644
--- a/youtube_dl/options.py
+++ b/youtube_dl/options.py
@@ -20,6 +20,24 @@ from .utils import (
from .version import __version__
+def _hide_login_info(opts):
+ PRIVATE_OPTS = set(['-p', '--password', '-u', '--username', '--video-password', '--ap-password', '--ap-username'])
+ eqre = re.compile('^(?P<key>' + ('|'.join(re.escape(po) for po in PRIVATE_OPTS)) + ')=.+$')
+
+ def _scrub_eq(o):
+ m = eqre.match(o)
+ if m:
+ return m.group('key') + '=PRIVATE'
+ else:
+ return o
+
+ opts = list(map(_scrub_eq, opts))
+ for idx, opt in enumerate(opts):
+ if opt in PRIVATE_OPTS and idx + 1 < len(opts):
+ opts[idx + 1] = 'PRIVATE'
+ return opts
+
+
def parseOpts(overrideArguments=None):
def _readOptions(filename_bytes, default=[]):
try:
@@ -93,26 +111,6 @@ def parseOpts(overrideArguments=None):
def _comma_separated_values_options_callback(option, opt_str, value, parser):
setattr(parser.values, option.dest, value.split(','))
- def _hide_login_info(opts):
- PRIVATE_OPTS = ['-p', '--password', '-u', '--username', '--video-password', '--ap-password', '--ap-username']
- eqre = re.compile('^(?P<key>' + ('|'.join(re.escape(po) for po in PRIVATE_OPTS)) + ')=.+$')
-
- def _scrub_eq(o):
- m = eqre.match(o)
- if m:
- return m.group('key') + '=PRIVATE'
- else:
- return o
-
- opts = list(map(_scrub_eq, opts))
- for private_opt in PRIVATE_OPTS:
- try:
- i = opts.index(private_opt)
- opts[i + 1] = 'PRIVATE'
- except ValueError:
- pass
- return opts
-
# No need to wrap help messages if we're on a wide console
columns = compat_get_terminal_size().columns
max_width = columns if columns else 80