763e06c127
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
4.2 KiB
4.2 KiB
name, kind, lang, domain, version, purity, signature, description, tags, params, output, uses_functions, uses_types, returns, returns_optional, error_type, imports, tested, tests, test_file_path, file_path
| name | kind | lang | domain | version | purity | signature | description | tags | params | output | uses_functions | uses_types | returns | returns_optional | error_type | imports | tested | tests | test_file_path | file_path | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| add_contact_dav | pipeline | py | pipelines | 1.0.0 | impure | def add_contact_dav(name: str, *, tels=None, emails=None, adrs=None, org='', note='', uid='', base_url=DEFAULT_BASE_URL, username=DEFAULT_USERNAME, collection_path=DEFAULT_COLLECTION, secret_path='dav/xandikos-enmanuel', timeout_s=20.0, verify_tls=True) -> dict | One-shot que anade UN contacto a la libreta CardDAV de Enmanuel (Xandikos) en una sola llamada. Compone build_vcard + contact_import_key + pass_get_secret + carddav_put_vcard. Idempotente por uid: re-anadir el mismo contacto sobrescribe, no duplica. La contrasena se resuelve desde pass y nunca se logea. |
|
|
dict. Exito: {status:'ok', http_status:int, url:str, uid:str}. Error (sin lanzar): {status:'error', error:str, uid:str, http_status:int|None}. Si la pass no se encuentra, devuelve error sin tocar la red. |
|
false | error_go_core | false | python/functions/pipelines/add_contact_dav.py |
Ejemplo
# Anadir un contacto en una sola llamada (uid determinista por telefono):
./fn run add_contact_dav --name "Juan Perez" --tel +34600111222 --email juan@example.com --org "ACME"
# Multi-valor: --tel y --email son repetibles -> se serializan como listas.
./fn run add_contact_dav --name "Maria Lopez" \
--tel +34611000111 --tel +34922000222 \
--email maria@example.com --email m.lopez@work.com \
--note "Conocida del evento OSINT"
Salida (JSON): {"status": "ok", "http_status": 201, "url": "https://dav-.../enmanuel/contacts/addressbook/v1-<hash>.vcf", "uid": "v1-<hash>"}.
Cuando usarla
Usala cuando quieras dar de alta o actualizar UN contacto en la libreta CardDAV
de Enmanuel sin montar el flujo a mano (serializar vCard, sacar la pass, PUT).
Si re-ejecutas con el mismo telefono/email (o el mismo --uid), el contacto se
sobrescribe en vez de duplicarse. Para importar muchos contactos de golpe, este
pipeline no es lo idoneo: llamalo en bucle o construye un pipeline batch.
Gotchas
- Escritura remota real: hace un HTTP PUT contra el servidor DAV. No es un
dry-run. Cada llamada con
status:'ok'ha creado/actualizado un recurso real. - Idempotencia por uid: si no pasas
--uid, el UID se deriva de forma determinista (telefono > email > nombre). Mismo telefono/email = mismo recurso = sobrescritura. Distinto telefono pero mismo nombre = recurso distinto. - Secreto desde pass, nunca hardcode: la contrasena se lee de
pass show dav/xandikos-enmanuel(configurable consecret_path). Nunca se logea ni aparece en el dict de retorno. Sipassfalla o la entry no existe, devuelve{status:'error'}sin tocar la red. - verify_tls: por defecto verifica el certificado TLS.
--no-verify-tlssolo para pruebas controladas; nunca contra el servidor real de produccion.