Files
fn_registry/functions/infra/vault_search.md
T
egutierrez cfdf515228 chore: auto-commit (799 archivos)
- .claude/CLAUDE.md
- .claude/commands/subagentes.md
- .claude/rules/INDEX.md
- .mcp.json
- bash/functions/cybersecurity/analyze_dns.md
- bash/functions/cybersecurity/audit_http_headers.md
- bash/functions/cybersecurity/audit_ssh_config.md
- bash/functions/cybersecurity/check_firewall.md
- bash/functions/cybersecurity/detect_suspicious_users.md
- bash/functions/cybersecurity/encrypt_file.md
- ...

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 00:28:20 +02:00

62 lines
2.3 KiB
Markdown

---
name: vault_search
kind: function
lang: go
domain: infra
version: "1.0.0"
purity: impure
signature: "func VaultSearch(vaultPath, query string, limit int) ([]VaultSearchHit, error)"
description: "Busca en vault_index.db de un vault usando FTS5 sobre files_fts. Si el query rompe el parser FTS5, hace fallback a LIKE sobre rel_path. Retorna hits con snippet de contexto."
tags: [vault, search, fts5, sqlite, infra, pendiente-usar]
uses_functions: ["vault_index_open_go_infra"]
uses_types: ["vault_file_go_infra"]
returns: []
returns_optional: false
error_type: "error_go_core"
imports: [database/sql, fmt, path/filepath, strings]
params:
- name: vaultPath
desc: "ruta absoluta al directorio raiz del vault (puede ser symlink)"
- name: query
desc: "termino o frase de busqueda; se escapa automaticamente para FTS5 salvo que ya incluya operadores booleanos o prefijos de columna"
- name: limit
desc: "maximo de resultados; si es <= 0 se usa 50"
output: "slice de VaultSearchHit ordenado por rank FTS5 (o mtime DESC en fallback LIKE); slice vacio si no hay resultados"
tested: true
tests:
- "FTS match devuelve hit con snippet"
- "query sin resultados retorna slice vacio"
- "limit se respeta"
- "query FTS invalida activa fallback LIKE"
- "limit cero usa 50 por defecto"
test_file_path: "functions/infra/vault_search_test.go"
file_path: "functions/infra/vault_search.go"
---
## Ejemplo
```go
hits, err := infra.VaultSearch("/home/lucas/vaults/turismo_spain", "hoteles", 20)
if err != nil {
log.Fatal(err)
}
for _, h := range hits {
fmt.Printf("[%s] %s %s\n", h.VaultName, h.RelPath, h.Snippet)
}
```
## Notas
`VaultSearchHit` es un struct local definido en este archivo (no en `vault_file.go`)
porque combina campos de `files` + metadatos de contexto de busqueda (Snippet, VaultPath, VaultName).
**FTS5 safety:** el helper `safeFTSQuery` envuelve la query en comillas dobles
cuando no contiene operadores booleanos ni prefijos de columna. Esto evita errores
del parser en tokens como `foo:bar:` o `hello-world`.
**Fallback LIKE:** si el MATCH falla con un error de sintaxis FTS5, se ejecuta
`WHERE rel_path LIKE '%' || query || '%'`. Los hits del fallback tienen `Snippet=""`.
**VaultName:** se deriva del `filepath.Base(filepath.EvalSymlinks(vaultPath))`.
Si `EvalSymlinks` falla (e.g. symlink roto), usa `filepath.Base(vaultPath)`.