mirror of
https://github.com/ansible-collections/community.general.git
synced 2025-10-23 20:44:00 -07:00
[PR #8238/a05a5982 backport][stable-7] bitwarden_secrets_manager: implement rate limit retry with backoff (#8260)
* bitwarden_secrets_manager: implement rate limit retry with backoff (#8238) * bitwarden_secrets_manager: implement rate limit retry with backoff (#8230) * bitwarden_secrets_manager: add changelog fragment for90cd2d61
(#8238) * bitwarden_secrets_manager: clarify "Too many requests" is an error condition (#8238) * bitwarden_secrets_manager: avoid an extra _run_with_retry execution after the last (very long) delay * bitwarden_secrets_manager: changelog fragment key and reference issue url (cherry picked from commita05a5982a6
) * Make Python 2 compatible. --------- Co-authored-by: Matt Adams <matt@4dk.me> Co-authored-by: Felix Fontein <felix@fontein.de>
This commit is contained in:
parent
2583e3993d
commit
32338f14e5
2 changed files with 22 additions and 1 deletions
|
@ -70,6 +70,7 @@ RETURN = """
|
|||
"""
|
||||
|
||||
from subprocess import Popen, PIPE
|
||||
from time import sleep
|
||||
|
||||
from ansible.errors import AnsibleLookupError
|
||||
from ansible.module_utils.common.text.converters import to_text
|
||||
|
@ -84,11 +85,29 @@ class BitwardenSecretsManagerException(AnsibleLookupError):
|
|||
class BitwardenSecretsManager(object):
|
||||
def __init__(self, path='bws'):
|
||||
self._cli_path = path
|
||||
self._max_retries = 3
|
||||
self._retry_delay = 1
|
||||
|
||||
@property
|
||||
def cli_path(self):
|
||||
return self._cli_path
|
||||
|
||||
def _run_with_retry(self, args, stdin=None, retries=0):
|
||||
out, err, rc = self._run(args, stdin)
|
||||
|
||||
if rc != 0:
|
||||
if retries >= self._max_retries:
|
||||
raise BitwardenSecretsManagerException("Max retries exceeded. Unable to retrieve secret.")
|
||||
|
||||
if "Too many requests" in err:
|
||||
delay = self._retry_delay * (2 ** retries)
|
||||
sleep(delay)
|
||||
return self._run_with_retry(args, stdin, retries + 1)
|
||||
else:
|
||||
raise BitwardenSecretsManagerException("Command failed with return code {rc}: {err}".format(rc=rc, err=err))
|
||||
|
||||
return out, err, rc
|
||||
|
||||
def _run(self, args, stdin=None):
|
||||
p = Popen([self.cli_path] + args, stdout=PIPE, stderr=PIPE, stdin=PIPE)
|
||||
out, err = p.communicate(stdin)
|
||||
|
@ -107,7 +126,7 @@ class BitwardenSecretsManager(object):
|
|||
'get', 'secret', secret_id
|
||||
]
|
||||
|
||||
out, err, rc = self._run(params)
|
||||
out, err, rc = self._run_with_retry(params)
|
||||
if rc != 0:
|
||||
raise BitwardenSecretsManagerException(to_text(err))
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue