Commit 6714748e by Sam Dolan

Throw an exception for a missing <file_name> param in ansible-vault

Without this fix you have to enter your vault password before you realize
that you forgot to pass in the filename.  This commit checks that an
filename argument was at least passed on the command line.
parent 3fb3e7e6
...@@ -112,7 +112,6 @@ def _read_password(filename): ...@@ -112,7 +112,6 @@ def _read_password(filename):
return data return data
def execute_create(args, options, parser): def execute_create(args, options, parser):
if len(args) > 1: if len(args) > 1:
raise errors.AnsibleError("'create' does not accept more than one filename") raise errors.AnsibleError("'create' does not accept more than one filename")
...@@ -204,6 +203,11 @@ def main(): ...@@ -204,6 +203,11 @@ def main():
parser = build_option_parser(action) parser = build_option_parser(action)
(options, args) = parser.parse_args() (options, args) = parser.parse_args()
if not len(args):
raise errors.AnsibleError(
"The '%s' command requires a filename as the first argument" % action
)
# execute the desired action # execute the desired action
try: try:
fn = globals()["execute_%s" % action] fn = globals()["execute_%s" % action]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment