eb8dbf66a1
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
3.6 KiB
3.6 KiB
name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
| name | kind | lang | domain | version | purity | signature | description | tags | uses_functions | uses_types | returns | returns_optional | error_type | imports | params | output | tested | tests | test_file_path | file_path | |||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| pass_get_secret | function | py | infra | 1.0.0 | impure | def pass_get_secret(path: str, *, line: int = 1, timeout_s: float = 10.0) -> dict | Lee un secreto del gestor de contrasenas pass (passwordstore.org) ejecutando `pass show <path>` como subproceso (lista de args, nunca shell=True). Devuelve la linea solicitada (1-indexed): line=1 es la contrasena por convencion de pass, line=N es metadata multilinea (usuario, URL, notas). El valor es sensible y la funcion NUNCA lo logea. Maneja errores sin lanzar: pass no instalado, entry inexistente, linea fuera de rango. Solo usa stdlib (subprocess). |
|
false | error_go_core |
|
|
dict. En exito: {status: 'ok', value: str} con la linea pedida sin el salto de linea final. En error (sin lanzar): {status: 'error', error: str} para pass no instalado ('pass not installed'), entry inexistente o fallo de pass (stderr stripeado), o linea fuera de rango ('line N out of range'). | true |
|
python/functions/infra/pass_get_secret_test.py | python/functions/infra/pass_get_secret.py |
Ejemplo
import sys
sys.path.insert(0, "python/functions")
from infra.pass_get_secret import pass_get_secret
# Primera linea = la contrasena/token (convencion de pass).
res = pass_get_secret("gitea/dataforge-git-token")
print(res) # {"status": "ok", "value": "ghp_..."} -- NO logear el value en prod
# Linea 2 = metadata (p.ej. el usuario), si el entry es multilinea.
user = pass_get_secret("apis/licenseplatedata", line=2)
print(user) # {"status": "ok", "value": "user: neo"}
Cuando usarla
Cuando necesites resolver un secreto de pass para inyectarlo en una config,
un header HTTP, una variable de entorno o un body de request sin hardcodearlo en
el codigo. Es el lector de secretos del registry en Python: el caller pide la
ruta del store y recibe el valor en value, listo para enchufar donde haga
falta. line=1 para la password; line=N para metadata (usuario, URL, notas).
Gotchas
- Requiere
passinstalado y el GPG agent desbloqueado. Sipassno esta en el PATH devuelve{"status": "error", "error": "pass not installed"}. Si el agente GPG esta bloqueado,pass showpuede colgarse hasta eltimeout_s. - El valor es un secreto: no lo logees. La funcion nunca lo imprime ni lo
registra. Trata el campo
valuecomo sensible aguas arriba (noprinten produccion, no persistir en claro). - line=1 es la contrasena. Por convencion de pass la primera linea es el secreto principal; las lineas siguientes son metadata 1-indexed.
- No usa shell. Ejecuta
["pass", "show", path]como lista de args, nuncashell=True, asi quepathno puede inyectar comandos.
Capability growth log
v1.0.0 — version inicial. Lector de secretos pass para Python, base de la
resolucion pass: en hoppscotch_set_environment.