diff --git a/library/packaging/apt_key b/library/packaging/apt_key index 1cfd1eb6209..f0d7f8ba81f 100644 --- a/library/packaging/apt_key +++ b/library/packaging/apt_key @@ -58,6 +58,11 @@ options: default: none description: - url to retrieve key from. + keyserver: + required: false + default: none + description: + - keyserver to retrieve key from. state: required: false choices: [ absent, present ] @@ -145,6 +150,10 @@ def download_key(module, url): except Exception: module.fail_json(msg="error getting key id from url", traceback=format_exc()) +def import_key(module, keyserver, key_id): + cmd = "apt-key adv --keyserver %s --recv %s" % (keyserver, key_id) + (rc, out, err) = module.run_command(cmd, check_rc=True) + return True def add_key(module, keyfile, keyring, data=None): if data is not None: @@ -179,8 +188,9 @@ def main(): file=dict(required=False), key=dict(required=False), keyring=dict(required=False), - state=dict(required=False, choices=['present', 'absent'], default='present'), validate_certs=dict(default='yes', type='bool'), + keyserver=dict(required=False), + state=dict(required=False, choices=['present', 'absent'], default='present') ), supports_check_mode=True ) @@ -191,6 +201,7 @@ def main(): filename = module.params['file'] keyring = module.params['keyring'] state = module.params['state'] + keyserver = module.params['keyserver'] changed = False if key_id: @@ -211,7 +222,7 @@ def main(): if key_id and key_id in keys: module.exit_json(changed=False) else: - if not filename and not data: + if not filename and not data and not keyserver: data = download_key(module, url) if key_id and key_id in keys: module.exit_json(changed=False) @@ -220,6 +231,8 @@ def main(): module.exit_json(changed=True) if filename: add_key(module, filename, keyring) + elif keyserver: + import_key(module, keyserver, key_id) else: add_key(module, "-", keyring, data) changed=False