* rpm_key: Decode bytes to string to work with Python 3 (#20326)
The read() method will return bytes we need to then decode() those bytes
to a string before trying to match() it using the re module.
* Make the rpm_key pgp regex more robust on both py2 and py3
(cherry picked from commit cee8cc2a52
)
This commit is contained in:
parent
f2cf1dba92
commit
5f53a159a0
1 changed files with 9 additions and 7 deletions
|
@ -75,12 +75,19 @@ import re
|
|||
import os.path
|
||||
import tempfile
|
||||
|
||||
# import module snippets
|
||||
from ansible.module_utils.basic import AnsibleModule
|
||||
from ansible.module_utils.urls import fetch_url
|
||||
from ansible.module_utils._text import to_native
|
||||
|
||||
|
||||
def is_pubkey(string):
|
||||
"""Verifies if string is a pubkey"""
|
||||
pgp_regex = ".*?(-----BEGIN PGP PUBLIC KEY BLOCK-----.*?-----END PGP PUBLIC KEY BLOCK-----).*"
|
||||
return re.match(pgp_regex, string, re.DOTALL)
|
||||
return bool(re.match(pgp_regex, to_native(string, errors='surrogate_or_strict'), re.DOTALL))
|
||||
|
||||
class RpmKey:
|
||||
|
||||
class RpmKey(object):
|
||||
|
||||
def __init__(self, module):
|
||||
# If the key is a url, we need to check if it's present to be idempotent,
|
||||
|
@ -122,7 +129,6 @@ class RpmKey:
|
|||
else:
|
||||
module.exit_json(changed=False)
|
||||
|
||||
|
||||
def fetch_key(self, url):
|
||||
"""Downloads a key from url, returns a valid path to a gpg key"""
|
||||
rsp, info = fetch_url(self.module, url)
|
||||
|
@ -212,9 +218,5 @@ def main():
|
|||
RpmKey(module)
|
||||
|
||||
|
||||
|
||||
# import module snippets
|
||||
from ansible.module_utils.basic import *
|
||||
from ansible.module_utils.urls import *
|
||||
if __name__ == '__main__':
|
||||
main()
|
||||
|
|
Loading…
Reference in a new issue