@saulwade/swl-ses 1.4.1 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/CLAUDE.md +3 -3
  2. package/README.md +561 -560
  3. package/agentes/nemesis-auditor-swl.md +161 -161
  4. package/bin/swl-mcp-server.js +49 -22
  5. package/bin/swl-ses.js +74 -0
  6. package/comandos/swl/.evolved.json +22 -22
  7. package/comandos/swl/contribuir.md +233 -233
  8. package/comandos/swl/ejecutar-fase.md +33 -4
  9. package/comandos/swl/metricas.md +72 -0
  10. package/comandos/swl/nemesis.md +122 -122
  11. package/gateway/lib/event-channel.js +191 -191
  12. package/habilidades/backend-production-resilience/SKILL.md +288 -288
  13. package/habilidades/benchmark-memoria/SKILL.md +186 -186
  14. package/habilidades/diagrama-arquitectura/assets/template.html +276 -276
  15. package/habilidades/discutir-fase/SKILL.md +50 -2
  16. package/habilidades/doubt-driven-review/SKILL.md +171 -171
  17. package/habilidades/doubt-driven-review/recursos/EXAMPLES.md +130 -130
  18. package/habilidades/ejecutar-task-iterativo/SKILL.md +278 -0
  19. package/habilidades/eval-framework/SKILL.md +212 -212
  20. package/habilidades/feynman-auditor-swl/SKILL.md +123 -123
  21. package/habilidades/feynman-auditor-swl/recursos/preguntas-language-agnostic.md +108 -108
  22. package/habilidades/harness-claude-code/SKILL.md +299 -299
  23. package/habilidades/infra-github-actions/SKILL.md +166 -166
  24. package/habilidades/legacy-code-rescue/SKILL.md +267 -267
  25. package/habilidades/manejo-errores/.evolved.json +8 -8
  26. package/habilidades/meta-skills-estandar/recursos/convencion-examples.md +93 -93
  27. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  28. package/habilidades/patrones-python/SKILL.md +229 -229
  29. package/habilidades/patrones-python/recursos/patrones-avanzados.md +469 -469
  30. package/habilidades/planear-fase/SKILL.md +319 -319
  31. package/habilidades/protocolo-revision-swl/SKILL.md +276 -0
  32. package/habilidades/release-semver/.evolved.json +8 -8
  33. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +166 -166
  34. package/habilidades/state-inconsistency-auditor-swl/recursos/coupled-state-patterns.md +147 -147
  35. package/habilidades/testing-python/SKILL.md +340 -340
  36. package/habilidades/verificar-trabajo/SKILL.md +49 -5
  37. package/habilidades/web-fetcher-routing/SKILL.md +75 -75
  38. package/hooks/claudemd-bloat-detector.js +161 -161
  39. package/hooks/lib/agent-routing.js +107 -107
  40. package/hooks/lib/auto-consolidator.js +335 -335
  41. package/hooks/lib/error-classifier.js +308 -308
  42. package/hooks/lib/merkle-audit.js +96 -96
  43. package/hooks/lib/provenance-tracker.js +191 -191
  44. package/hooks/lib/rate-limit-tracker.js +253 -253
  45. package/hooks/lib/resource-quota.js +122 -122
  46. package/hooks/lib/retry-jitter.js +165 -165
  47. package/hooks/lib/security-net.js +201 -201
  48. package/hooks/lib/skill-auditor.js +588 -588
  49. package/hooks/lib/sync-status.js +228 -228
  50. package/hooks/lib/taint-tracker.js +107 -107
  51. package/hooks/lib/text-similarity.js +241 -241
  52. package/hooks/lib/toon-compressor.js +245 -245
  53. package/hooks/registro-turnos.js +209 -209
  54. package/hooks/sugerir-regenerar-inventario.js +170 -170
  55. package/hooks/validar-formato-post-subagente.js +140 -140
  56. package/hooks/validar-memoria-hook.js +218 -218
  57. package/instintos/prompt-appendices.yaml +57 -57
  58. package/manifiestos/agent-output-schemas.json +57 -57
  59. package/manifiestos/modulos.json +1321 -1262
  60. package/manifiestos/perfiles.json +2 -1
  61. package/manifiestos/skills-lock.json +1114 -1114
  62. package/package.json +3 -3
  63. package/plantillas/auditor-veto-template.md +105 -105
  64. package/plantillas/github-workflows/README.md +47 -47
  65. package/plantillas/github-workflows/release-please.yml +44 -44
  66. package/plantillas/github-workflows/swl-ci.yml +107 -107
  67. package/plantillas/github-workflows/swl-security.yml +51 -51
  68. package/plugin.json +351 -343
  69. package/reglas/analisis-previo-tareas-grandes.md +172 -172
  70. package/reglas/arreglar-al-detectar.md +147 -147
  71. package/reglas/fragmentos-compartidos.md +152 -152
  72. package/reglas/harness-claude-code.md +213 -213
  73. package/reglas/usar-context7.md +226 -226
  74. package/schemas/diary-entry.schema.json +80 -80
  75. package/scripts/audit-tools/audit-history.js +330 -330
  76. package/scripts/audit-tools/bundle-tracker.js +290 -290
  77. package/scripts/audit-tools/canary-monitor.js +352 -352
  78. package/scripts/audit-tools/code-profiler.js +605 -605
  79. package/scripts/audit-tools/dep-doctor.js +320 -320
  80. package/scripts/audit-tools/env-validator.js +206 -206
  81. package/scripts/audit-tools/lib/fs-walk.js +48 -48
  82. package/scripts/audit-tools/lib/output.js +23 -23
  83. package/scripts/audit-tools/migration-checker.js +392 -392
  84. package/scripts/audit-tools/pentest-scanner.js +1436 -1436
  85. package/scripts/benchmark-memoria.js +167 -167
  86. package/scripts/configurar-branch-protection.js +418 -418
  87. package/scripts/derivar-feature-list.js +489 -0
  88. package/scripts/detectar-aprendizajes-duplicados.js +151 -151
  89. package/scripts/doctor.js +31 -4
  90. package/scripts/field-report.js +199 -199
  91. package/scripts/generar-checklists-consolidados.js +273 -273
  92. package/scripts/generar-inventario.js +420 -420
  93. package/scripts/generar-matriz-lenguajes.js +271 -271
  94. package/scripts/instalador.js +56 -5
  95. package/scripts/lib/artefactos-python.js +43 -43
  96. package/scripts/lib/benchmark-metrics.js +160 -160
  97. package/scripts/lib/budget-enforcer.js +252 -252
  98. package/scripts/lib/configurar-ci.js +380 -380
  99. package/scripts/lib/contadores-inventario.js +217 -217
  100. package/scripts/lib/detectar-runtime.js +75 -9
  101. package/scripts/lib/detectar-stack-detallado.js +307 -307
  102. package/scripts/lib/diary-entry.js +234 -234
  103. package/scripts/lib/estado.js +13 -1
  104. package/scripts/lib/eval-metrics-store.js +218 -218
  105. package/scripts/lib/eval-quality.js +171 -171
  106. package/scripts/lib/eval-schemas.js +144 -144
  107. package/scripts/lib/eval-self-correct.js +106 -106
  108. package/scripts/lib/eval-validator.js +185 -185
  109. package/scripts/lib/expandir-targets.js +71 -0
  110. package/scripts/lib/jaccard-similarity.js +98 -98
  111. package/scripts/lib/longmemeval-runner.js +125 -125
  112. package/scripts/lib/manifiestos.js +42 -1
  113. package/scripts/lib/npm-version.js +261 -261
  114. package/scripts/lib/paquetes-conocidos.js +50 -50
  115. package/scripts/lib/parsear-opciones.js +3 -0
  116. package/scripts/lib/prompt-builder.js +264 -264
  117. package/scripts/lib/rrf-fusion.js +175 -175
  118. package/scripts/lib/scoring-instintos.js +277 -277
  119. package/scripts/lib/semantic-search.js +252 -252
  120. package/scripts/lib/toml-merge.js +204 -0
  121. package/scripts/lib/transformadores/base.js +43 -9
  122. package/scripts/lib/transformadores/codex.js +375 -115
  123. package/scripts/lib/transformadores/cursor.js +359 -0
  124. package/scripts/lib/transformadores/index.js +2 -0
  125. package/scripts/limpiar-artefactos-python.js +131 -131
  126. package/scripts/mcp-server/README.md +122 -80
  127. package/scripts/mcp-server/auth.js +105 -0
  128. package/scripts/mcp-server/cache.js +106 -0
  129. package/scripts/mcp-server/handlers.js +386 -206
  130. package/scripts/mcp-server/telemetry.js +78 -0
  131. package/scripts/migrar-csv-a-array.js +168 -168
  132. package/scripts/migrar-fase-dominio.js +201 -201
  133. package/scripts/publicar.js +511 -511
  134. package/scripts/run-eval.js +141 -141
  135. package/scripts/validar-manifest.js +231 -195
  136. package/scripts/validar-userland-vacio.js +110 -110
@@ -1,175 +1,175 @@
1
- 'use strict';
2
-
3
- /**
4
- * rrf-fusion.js — Reciprocal Rank Fusion para combinar streams de búsqueda.
5
- *
6
- * Patrón adoptado de `temp/agentmemory-main/src/state/hybrid-search.ts`. El
7
- * algoritmo RRF combina rankings de múltiples sistemas de retrieval (BM25,
8
- * vector, graph) sin requerir que sus scores sean comparables — solo importa
9
- * la posición relativa (rank) en cada lista.
10
- *
11
- * Fórmula:
12
- *
13
- * RRF(d) = Σ_i w_i / (k + rank_i(d))
14
- *
15
- * donde:
16
- * d = un documento candidato
17
- * i = índice del stream (BM25, vector, graph, ...)
18
- * w_i = peso del stream i (default 1.0 si no se especifica)
19
- * rank_i(d) = posición 1-indexed de d en el stream i, o ∞ si no aparece
20
- * k = constante de smoothing (default 60, estándar Cormack 2009)
21
- *
22
- * Propiedades:
23
- * - Robust frente a magnitudes de score heterogéneas — solo usa rank.
24
- * - Documentos que aparecen en múltiples streams reciben boost natural.
25
- * - Documentos que aparecen solo una vez no son penalizados — su rank ∞ en
26
- * otros streams contribuye 0.
27
- * - k ≈ 60 minimiza el peso de ranks bajos (< 60 efectivos).
28
- *
29
- * Versus suma simple de scores:
30
- * - No requiere normalización entre streams (BM25 vs vector cosine son
31
- * incomparables).
32
- * - Más resistente a outliers (un score muy alto en un stream no domina).
33
- *
34
- * Sin dependencias — Node stdlib only. Backward compatible: el caller puede
35
- * mantener su lógica anterior y usar RRF solo cuando combine ≥2 streams.
36
- *
37
- * @module scripts/lib/rrf-fusion
38
- */
39
-
40
- // ── constantes ────────────────────────────────────────────────────────────────
41
-
42
- /** Constante k del RRF estándar (Cormack et al., 2009). */
43
- const RRF_K_DEFAULT = 60;
44
-
45
- // ── funciones puras ───────────────────────────────────────────────────────────
46
-
47
- /**
48
- * Construye un mapa `id → rank` desde un stream de resultados ordenados.
49
- * Rank es 1-indexed: el primer elemento tiene rank 1.
50
- * Si un id aparece varias veces, conserva el rank más bajo (mejor).
51
- *
52
- * @param {Array<{id: string}>} stream - Resultados ordenados (mejor primero).
53
- * @returns {Map<string, number>} Mapa id → rank.
54
- */
55
- function rankMap(stream) {
56
- const map = new Map();
57
- if (!Array.isArray(stream)) return map;
58
- for (let i = 0; i < stream.length; i++) {
59
- const item = stream[i];
60
- if (!item || typeof item.id !== 'string') continue;
61
- const rank = i + 1;
62
- const previo = map.get(item.id);
63
- if (previo === undefined || rank < previo) {
64
- map.set(item.id, rank);
65
- }
66
- }
67
- return map;
68
- }
69
-
70
- /**
71
- * Score parcial del stream para un id dado.
72
- * Si el id NO aparece en el stream, devuelve 0 (rank ∞).
73
- *
74
- * @param {Map<string, number>} map - Resultado de rankMap().
75
- * @param {string} id
76
- * @param {number} k
77
- * @returns {number} contribución 1/(k + rank), o 0 si no aparece.
78
- */
79
- function streamScore(map, id, k) {
80
- const rank = map.get(id);
81
- if (rank === undefined) return 0;
82
- return 1 / (k + rank);
83
- }
84
-
85
- /**
86
- * Reciprocal Rank Fusion: combina N streams de búsqueda en un ranking unificado.
87
- *
88
- * Cada stream es un array de objetos con al menos `{ id: string }`. La posición
89
- * en el array determina el rank (1-indexed). Cualquier metadata extra (titulo,
90
- * fecha, score, etc.) del primer stream donde aparece el id se preserva en el
91
- * resultado.
92
- *
93
- * Si se proveen `weights`, se ponderan los streams. El array de pesos debe
94
- * tener el mismo largo que `streams`. Si no se provee, todos los streams pesan
95
- * 1.0. Pesos no positivos se tratan como 0 (efectivamente desactivan el stream).
96
- *
97
- * Si todos los pesos suman > 0, se normalizan a 1.0 para que el `combinedScore`
98
- * resultante sea comparable entre invocaciones con distintos pesos.
99
- *
100
- * @param {Array<Array<object>>} streams - Lista de streams ordenados.
101
- * @param {object} [opts]
102
- * @param {number} [opts.k=60] - Constante k del RRF.
103
- * @param {number[]} [opts.weights] - Pesos por stream (alineado con streams[]).
104
- * @param {number} [opts.limit] - Limita la salida a N elementos top.
105
- * @returns {Array<object>} Resultados combinados con `combinedScore`,
106
- * ordenados descendente. Conserva metadata del primer stream donde apareció
107
- * cada id.
108
- */
109
- function rrfFusion(streams, opts = {}) {
110
- if (!Array.isArray(streams) || streams.length === 0) return [];
111
-
112
- const k = typeof opts.k === 'number' && opts.k > 0 ? opts.k : RRF_K_DEFAULT;
113
-
114
- // Normalizar pesos
115
- let weights;
116
- if (Array.isArray(opts.weights) && opts.weights.length === streams.length) {
117
- const positivos = opts.weights.map(w =>
118
- typeof w === 'number' && w > 0 ? w : 0,
119
- );
120
- const total = positivos.reduce((a, b) => a + b, 0);
121
- weights = total > 0 ? positivos.map(w => w / total) : positivos;
122
- } else {
123
- // Sin weights explícitos: todos iguales y normalizados (suman 1.0).
124
- const efectivos = streams.filter(s => Array.isArray(s) && s.length > 0).length;
125
- if (efectivos === 0) return [];
126
- weights = streams.map(s =>
127
- Array.isArray(s) && s.length > 0 ? 1 / efectivos : 0,
128
- );
129
- }
130
-
131
- // Construir rankMap por stream + recolectar metadata por id
132
- const maps = streams.map(rankMap);
133
- const metadata = new Map(); // id → primer item visto
134
-
135
- for (const stream of streams) {
136
- if (!Array.isArray(stream)) continue;
137
- for (const item of stream) {
138
- if (!item || typeof item.id !== 'string') continue;
139
- if (!metadata.has(item.id)) {
140
- metadata.set(item.id, item);
141
- }
142
- }
143
- }
144
-
145
- // Calcular combinedScore para cada id
146
- const combined = [];
147
- for (const id of metadata.keys()) {
148
- let score = 0;
149
- for (let i = 0; i < streams.length; i++) {
150
- score += weights[i] * streamScore(maps[i], id, k);
151
- }
152
- if (score > 0) {
153
- combined.push({
154
- ...metadata.get(id),
155
- combinedScore: score,
156
- });
157
- }
158
- }
159
-
160
- combined.sort((a, b) => b.combinedScore - a.combinedScore);
161
-
162
- if (typeof opts.limit === 'number' && opts.limit > 0) {
163
- return combined.slice(0, opts.limit);
164
- }
165
- return combined;
166
- }
167
-
168
- // ── exports ───────────────────────────────────────────────────────────────────
169
-
170
- module.exports = {
171
- rrfFusion,
172
- rankMap,
173
- streamScore,
174
- RRF_K_DEFAULT,
175
- };
1
+ 'use strict';
2
+
3
+ /**
4
+ * rrf-fusion.js — Reciprocal Rank Fusion para combinar streams de búsqueda.
5
+ *
6
+ * Patrón adoptado de `temp/agentmemory-main/src/state/hybrid-search.ts`. El
7
+ * algoritmo RRF combina rankings de múltiples sistemas de retrieval (BM25,
8
+ * vector, graph) sin requerir que sus scores sean comparables — solo importa
9
+ * la posición relativa (rank) en cada lista.
10
+ *
11
+ * Fórmula:
12
+ *
13
+ * RRF(d) = Σ_i w_i / (k + rank_i(d))
14
+ *
15
+ * donde:
16
+ * d = un documento candidato
17
+ * i = índice del stream (BM25, vector, graph, ...)
18
+ * w_i = peso del stream i (default 1.0 si no se especifica)
19
+ * rank_i(d) = posición 1-indexed de d en el stream i, o ∞ si no aparece
20
+ * k = constante de smoothing (default 60, estándar Cormack 2009)
21
+ *
22
+ * Propiedades:
23
+ * - Robust frente a magnitudes de score heterogéneas — solo usa rank.
24
+ * - Documentos que aparecen en múltiples streams reciben boost natural.
25
+ * - Documentos que aparecen solo una vez no son penalizados — su rank ∞ en
26
+ * otros streams contribuye 0.
27
+ * - k ≈ 60 minimiza el peso de ranks bajos (< 60 efectivos).
28
+ *
29
+ * Versus suma simple de scores:
30
+ * - No requiere normalización entre streams (BM25 vs vector cosine son
31
+ * incomparables).
32
+ * - Más resistente a outliers (un score muy alto en un stream no domina).
33
+ *
34
+ * Sin dependencias — Node stdlib only. Backward compatible: el caller puede
35
+ * mantener su lógica anterior y usar RRF solo cuando combine ≥2 streams.
36
+ *
37
+ * @module scripts/lib/rrf-fusion
38
+ */
39
+
40
+ // ── constantes ────────────────────────────────────────────────────────────────
41
+
42
+ /** Constante k del RRF estándar (Cormack et al., 2009). */
43
+ const RRF_K_DEFAULT = 60;
44
+
45
+ // ── funciones puras ───────────────────────────────────────────────────────────
46
+
47
+ /**
48
+ * Construye un mapa `id → rank` desde un stream de resultados ordenados.
49
+ * Rank es 1-indexed: el primer elemento tiene rank 1.
50
+ * Si un id aparece varias veces, conserva el rank más bajo (mejor).
51
+ *
52
+ * @param {Array<{id: string}>} stream - Resultados ordenados (mejor primero).
53
+ * @returns {Map<string, number>} Mapa id → rank.
54
+ */
55
+ function rankMap(stream) {
56
+ const map = new Map();
57
+ if (!Array.isArray(stream)) return map;
58
+ for (let i = 0; i < stream.length; i++) {
59
+ const item = stream[i];
60
+ if (!item || typeof item.id !== 'string') continue;
61
+ const rank = i + 1;
62
+ const previo = map.get(item.id);
63
+ if (previo === undefined || rank < previo) {
64
+ map.set(item.id, rank);
65
+ }
66
+ }
67
+ return map;
68
+ }
69
+
70
+ /**
71
+ * Score parcial del stream para un id dado.
72
+ * Si el id NO aparece en el stream, devuelve 0 (rank ∞).
73
+ *
74
+ * @param {Map<string, number>} map - Resultado de rankMap().
75
+ * @param {string} id
76
+ * @param {number} k
77
+ * @returns {number} contribución 1/(k + rank), o 0 si no aparece.
78
+ */
79
+ function streamScore(map, id, k) {
80
+ const rank = map.get(id);
81
+ if (rank === undefined) return 0;
82
+ return 1 / (k + rank);
83
+ }
84
+
85
+ /**
86
+ * Reciprocal Rank Fusion: combina N streams de búsqueda en un ranking unificado.
87
+ *
88
+ * Cada stream es un array de objetos con al menos `{ id: string }`. La posición
89
+ * en el array determina el rank (1-indexed). Cualquier metadata extra (titulo,
90
+ * fecha, score, etc.) del primer stream donde aparece el id se preserva en el
91
+ * resultado.
92
+ *
93
+ * Si se proveen `weights`, se ponderan los streams. El array de pesos debe
94
+ * tener el mismo largo que `streams`. Si no se provee, todos los streams pesan
95
+ * 1.0. Pesos no positivos se tratan como 0 (efectivamente desactivan el stream).
96
+ *
97
+ * Si todos los pesos suman > 0, se normalizan a 1.0 para que el `combinedScore`
98
+ * resultante sea comparable entre invocaciones con distintos pesos.
99
+ *
100
+ * @param {Array<Array<object>>} streams - Lista de streams ordenados.
101
+ * @param {object} [opts]
102
+ * @param {number} [opts.k=60] - Constante k del RRF.
103
+ * @param {number[]} [opts.weights] - Pesos por stream (alineado con streams[]).
104
+ * @param {number} [opts.limit] - Limita la salida a N elementos top.
105
+ * @returns {Array<object>} Resultados combinados con `combinedScore`,
106
+ * ordenados descendente. Conserva metadata del primer stream donde apareció
107
+ * cada id.
108
+ */
109
+ function rrfFusion(streams, opts = {}) {
110
+ if (!Array.isArray(streams) || streams.length === 0) return [];
111
+
112
+ const k = typeof opts.k === 'number' && opts.k > 0 ? opts.k : RRF_K_DEFAULT;
113
+
114
+ // Normalizar pesos
115
+ let weights;
116
+ if (Array.isArray(opts.weights) && opts.weights.length === streams.length) {
117
+ const positivos = opts.weights.map(w =>
118
+ typeof w === 'number' && w > 0 ? w : 0,
119
+ );
120
+ const total = positivos.reduce((a, b) => a + b, 0);
121
+ weights = total > 0 ? positivos.map(w => w / total) : positivos;
122
+ } else {
123
+ // Sin weights explícitos: todos iguales y normalizados (suman 1.0).
124
+ const efectivos = streams.filter(s => Array.isArray(s) && s.length > 0).length;
125
+ if (efectivos === 0) return [];
126
+ weights = streams.map(s =>
127
+ Array.isArray(s) && s.length > 0 ? 1 / efectivos : 0,
128
+ );
129
+ }
130
+
131
+ // Construir rankMap por stream + recolectar metadata por id
132
+ const maps = streams.map(rankMap);
133
+ const metadata = new Map(); // id → primer item visto
134
+
135
+ for (const stream of streams) {
136
+ if (!Array.isArray(stream)) continue;
137
+ for (const item of stream) {
138
+ if (!item || typeof item.id !== 'string') continue;
139
+ if (!metadata.has(item.id)) {
140
+ metadata.set(item.id, item);
141
+ }
142
+ }
143
+ }
144
+
145
+ // Calcular combinedScore para cada id
146
+ const combined = [];
147
+ for (const id of metadata.keys()) {
148
+ let score = 0;
149
+ for (let i = 0; i < streams.length; i++) {
150
+ score += weights[i] * streamScore(maps[i], id, k);
151
+ }
152
+ if (score > 0) {
153
+ combined.push({
154
+ ...metadata.get(id),
155
+ combinedScore: score,
156
+ });
157
+ }
158
+ }
159
+
160
+ combined.sort((a, b) => b.combinedScore - a.combinedScore);
161
+
162
+ if (typeof opts.limit === 'number' && opts.limit > 0) {
163
+ return combined.slice(0, opts.limit);
164
+ }
165
+ return combined;
166
+ }
167
+
168
+ // ── exports ───────────────────────────────────────────────────────────────────
169
+
170
+ module.exports = {
171
+ rrfFusion,
172
+ rankMap,
173
+ streamScore,
174
+ RRF_K_DEFAULT,
175
+ };