## Projects: apps, analysis y vaults bajo un tema comun Un project agrupa apps, analyses y vaults relacionados. Vive en `projects/{nombre}/` con esta estructura: ``` projects/{nombre}/ project.md # Frontmatter obligatorio (name, description, tags) apps/ # Apps del proyecto (cada una con app.md) {app_name}/ app.md ... analysis/ # Analyses del proyecto (cada uno con analysis.md) {analysis_name}/ analysis.md .venv/ notebooks/ run-jupyter-lab.sh ... vaults/ # Datos del proyecto vault.yaml # Manifest de vaults (nombre, descripcion, path, tags) {vault_name} -> /abs/path # Symlinks a directorios reales de datos ``` ### Reglas - `project.md` sigue el template de `docs/templates/project.md` — campos: `name`, `description`, `tags`, `repo_url` - `analysis.md` sigue el template de `docs/templates/analysis.md` — `dir_path` debe apuntar a `projects/{nombre}/analysis/{tema}/` - `vault.yaml` lista los vaults con nombre, descripcion, path absoluto y tags - Los vaults reales viven fuera del repo (ej: `~/vaults/{nombre}/`) con symlinks en el proyecto - `fn index` escanea `projects/*/` y setea `project_id` automaticamente en apps, analyses y vaults - Apps y analyses sueltos (sin proyecto) siguen en `apps/` y `analysis/` en la raiz ### Raiz vs proyecto | Ubicacion | Para que | |-----------|---------| | `apps/` | Apps independientes que no pertenecen a ningun proyecto | | `analysis/` | Analyses independientes | | `projects/{nombre}/apps/` | Apps de un proyecto — `project_id` se setea automaticamente | | `projects/{nombre}/analysis/` | Analyses de un proyecto — `project_id` se setea automaticamente | ### Crear un proyecto nuevo ```bash # 1. Crear estructura mkdir -p projects/{nombre}/{apps,analysis,vaults} # 2. Crear project.md con frontmatter fn add -k project # genera template # 3. Crear vault (datos fuera del repo, symlink dentro) mkdir -p ~/vaults/{vault_name}/{raw,processed,exports} ln -s ~/vaults/{vault_name} projects/{nombre}/vaults/{vault_name} # Crear vault.yaml con la entrada # 4. Crear analysis dentro del proyecto (un solo comando; ya indexa) fn run init_jupyter_analysis --project {nombre} {nombre_analysis} --desc "..." [paquetes...] # 5. Verificar fn show {nombre} # verifica el project y sus componentes # NUNCA: crear el analisis en analysis/ y luego mv al proyecto. # Al mover se rompe el .venv (paths hardcodeados en activate). # Si ya te paso: cd projects/{nombre}/analysis/{tema} && rm -rf .venv && uv sync ``` ### Consultas utiles ```sql -- Listar proyectos SELECT id, description FROM projects; -- Analysis de un proyecto SELECT id, name, dir_path FROM analysis WHERE project_id = 'app_turismo'; -- Vaults de un proyecto SELECT id, name, path, symlink FROM vaults WHERE project_id = 'app_turismo'; -- Apps de un proyecto SELECT id, name, dir_path FROM apps WHERE project_id = 'app_turismo'; -- Todo lo que pertenece a un proyecto SELECT 'analysis' as tipo, id, name FROM analysis WHERE project_id = ? UNION ALL SELECT 'vault', id, name FROM vaults WHERE project_id = ? UNION ALL SELECT 'app', id, name FROM apps WHERE project_id = ?; ```