feat: enhance 1Password lookup functionality with vault ID support and concealment option
Some checks failed
Nix Format Check / check-format (push) Failing after 37s
Some checks failed
Nix Format Check / check-format (push) Failing after 37s
This commit is contained in:
@@ -17,14 +17,22 @@ DOCUMENTATION = """
|
||||
required: false
|
||||
default: password
|
||||
vault:
|
||||
description: the vault to fetch from
|
||||
description: the vault to fetch from (name or ID)
|
||||
required: false
|
||||
reveal:
|
||||
description: whether to reveal concealed fields
|
||||
required: false
|
||||
default: true
|
||||
"""
|
||||
|
||||
EXAMPLES = """
|
||||
- name: fetch password for an item
|
||||
debug:
|
||||
msg: "{{ lookup('onepassword', 'storage-box', field='password') }}"
|
||||
msg: "{{ lookup('onepassword', 'xxxx', field='password') }}"
|
||||
|
||||
- name: fetch password from specific vault
|
||||
debug:
|
||||
msg: "{{ lookup('onepassword', 'xxxx', field='password', vault='xxxx') }}"
|
||||
"""
|
||||
|
||||
RETURN = """
|
||||
@@ -47,12 +55,17 @@ class LookupModule(LookupBase):
|
||||
item = terms[0]
|
||||
field = kwargs.get('field', 'password')
|
||||
vault = kwargs.get('vault', '')
|
||||
reveal = kwargs.get('reveal', True)
|
||||
|
||||
vault_arg = []
|
||||
cmd = ['op', 'item', 'get', item, '--field', field]
|
||||
|
||||
# Add vault parameter if specified
|
||||
if vault:
|
||||
vault_arg = ['--vault', vault]
|
||||
|
||||
cmd = ['op', 'item', 'get', item, '--field', field] + vault_arg
|
||||
cmd.extend(['--vault', vault])
|
||||
|
||||
# Add reveal flag for concealed fields
|
||||
if reveal and field.lower() in ['password', 'secret', 'token', 'key']:
|
||||
cmd.append('--reveal')
|
||||
|
||||
display.vvv(f"Executing command: {' '.join(cmd)}")
|
||||
|
||||
@@ -65,4 +78,11 @@ class LookupModule(LookupBase):
|
||||
)
|
||||
return [result.stdout.strip()]
|
||||
except subprocess.CalledProcessError as e:
|
||||
raise AnsibleError(f"Error fetching from 1Password: {e.stderr}")
|
||||
error_msg = e.stderr.strip()
|
||||
display.warning(f"Error executing 1Password CLI: {error_msg}")
|
||||
display.warning(f"Command used: {' '.join(cmd)}")
|
||||
|
||||
if "not found" in error_msg:
|
||||
return [f"Secret '{item}' not found in 1Password"]
|
||||
|
||||
raise AnsibleError(f"Error fetching from 1Password: {error_msg}")
|
||||
|
Reference in New Issue
Block a user