You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
ansible/test/units/mock/vault_helper.py

40 lines
1.6 KiB
Python

from __future__ import annotations
from ansible._internal._datatag import _tags
from ansible.module_utils.common.text.converters import to_bytes
from ansible.parsing.vault import VaultSecret, VaultSecretsContext, VaultLib, EncryptedString
class TextVaultSecret(VaultSecret):
"""A secret piece of text. ie, a password. Tracks text encoding.
The text encoding of the text may not be the default text encoding so
we keep track of the encoding so we encode it to the same bytes."""
def __init__(self, text, encoding=None, errors=None, _bytes=None):
super(TextVaultSecret, self).__init__()
self.text = text
self.encoding = encoding or 'utf-8'
self._bytes = _bytes
self.errors = errors or 'strict'
@property
def bytes(self):
"""The text encoded with encoding, unless we specifically set _bytes."""
return self._bytes or to_bytes(self.text, encoding=self.encoding, errors=self.errors)
class VaultTestHelper:
@classmethod
def make_vault_ciphertext(cls, plaintext: str) -> str:
"""Creates an `EncryptedString` from the first secret in the active VaultSecretsContext."""
secrets = VaultSecretsContext.current().secrets
vl = VaultLib(secrets)
return vl.encrypt(plaintext, secrets[0][1]).decode()
@classmethod
def make_encrypted_string(cls, plaintext: str) -> EncryptedString:
"""Creates an `EncryptedString` from the first secret in the active VaultSecretsContext."""
return _tags.Origin(path="/tmp/sometest", line_num=42, col_num=42).tag(EncryptedString(ciphertext=cls.make_vault_ciphertext(plaintext)))