community.general/lib/ansible
Adrian Likins a14d0f3586 Use vault_id when encrypted via vault-edit (#30772)
* Use vault_id when encrypted via vault-edit

On the encryption stage of
'ansible-vault edit --vault-id=someid@passfile somefile',
the vault id was not being passed to encrypt() so the files were
always saved with the default vault id in the 1.1 version format.

When trying to edit that file a second time, also with a --vault-id,
the file would be decrypted with the secret associated with the
provided vault-id, but since the encrypted file had no vault id
in the envelope there would be no match for 'default' secrets.
(Only the --vault-id was included in the potential matches, so
the vault id actually used to decrypt was not).

If that list was empty, there would be an IndexError when trying
to encrypted the changed file. This would result in the displayed
error:

ERROR! Unexpected Exception, this is probably a bug: list index out of range

Fix is two parts:

1) use the vault id when encrypting from edit

2) when matching the secret to use for encrypting after edit,
include the vault id that was used for decryption and not just
the vault id (or lack of vault id) from the envelope.

add unit tests for #30575 and intg tests for 'ansible-vault edit'

Fixes #30575
2017-09-26 12:28:31 -04:00
..
cli add ability to set default tags in config 2017-09-22 19:21:13 -04:00
compat Remove wildcard imports 2017-07-28 22:10:17 -07:00
config add ability to set default tags in config 2017-09-22 19:21:13 -04:00
errors Ansible Config part2 (#27448) 2017-08-15 16:38:59 -04:00
executor made callbacks backwards compatible (#30625) 2017-09-20 15:20:19 -04:00
galaxy Removes container-enabled warning (#27578) 2017-08-01 12:51:03 -04:00
inventory use set to quicken group host membership 2017-09-22 19:07:37 -04:00
module_utils Fix 'distribution' fact for ArchLinux (#30723) 2017-09-25 15:00:31 -04:00
modules - Adds sub-interface support for nxos_interface and nxos_ip_interface (#30830) 2017-09-26 21:34:51 +05:30
parsing Use vault_id when encrypted via vault-edit (#30772) 2017-09-26 12:28:31 -04:00
playbook Remove print statements from play_context 2017-09-26 10:15:14 -04:00
plugins Add one-versus-many-matches logic to network filter plugin (#30511) 2017-09-26 05:44:07 -07:00
template Fix dangerous default args. (#29839) 2017-09-12 00:11:13 -07:00
utils Fix encoding error with path to ssh 2017-09-22 15:31:21 -07:00
vars remove fact namespacing 2017-09-10 17:37:52 -04:00
__init__.py Fix ziploader for the cornercase of ansible invoking ansible. 2016-04-29 08:47:49 -07:00
constants.py moved from eval to templating + literal_eval 2017-09-20 21:35:02 -04:00
release.py Bump the versions now that devel is 2.5 2017-09-06 13:13:57 -07:00