@saulwade/swl-ses 1.6.0 → 1.6.3

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 (82) hide show
  1. package/CLAUDE.md +32 -61
  2. package/README.md +4 -4
  3. package/agentes/_intent-spec.md +73 -0
  4. package/agentes/auto-evolucion-swl.md +24 -0
  5. package/agentes/cloud-infra-swl.md +25 -0
  6. package/agentes/datos-swl.md +24 -1
  7. package/agentes/devops-ci-swl.md +24 -0
  8. package/agentes/frontend-angular-swl.md +7 -7
  9. package/agentes/frontend-css-swl.md +4 -4
  10. package/agentes/frontend-react-swl.md +7 -7
  11. package/agentes/frontend-swl.md +9 -9
  12. package/agentes/frontend-tailwind-swl.md +4 -4
  13. package/agentes/migrador-swl.md +22 -0
  14. package/agentes/pagos-swl.md +25 -0
  15. package/agentes/release-manager-swl.md +24 -0
  16. package/agentes/rendimiento-swl.md +2 -2
  17. package/agentes/sre-swl.md +24 -0
  18. package/comandos/swl/brainstorm.md +1 -0
  19. package/comandos/swl/compactar.md +1 -1
  20. package/comandos/swl/discutir-fase.md +15 -1
  21. package/comandos/swl/mapear-codebase.md +1 -1
  22. package/comandos/swl/nemesis.md +29 -0
  23. package/comandos/swl/planear-fase.md +18 -2
  24. package/comandos/swl/verificar.md +4 -4
  25. package/habilidades/aprender-de-git-diff/SKILL.md +288 -0
  26. package/habilidades/aprendizaje-continuo/SKILL.md +7 -1
  27. package/habilidades/diseno-herramientas-agente/SKILL.md +17 -0
  28. package/habilidades/doc-sync/SKILL.md +441 -1
  29. package/habilidades/doubt-driven-review/SKILL.md +177 -171
  30. package/habilidades/feynman-auditor-swl/SKILL.md +129 -123
  31. package/habilidades/infra-github-actions/SKILL.md +172 -166
  32. package/habilidades/meta-skills-estandar/SKILL.md +6 -0
  33. package/habilidades/meta-skills-estandar/recursos/skill-judge-rubrica.md +281 -0
  34. package/habilidades/meta-skills-estandar/recursos/skills-as-agents.md +163 -163
  35. package/habilidades/nemesis-evaluacion-json/SKILL.md +5 -0
  36. package/habilidades/nemesis-redistribuir/SKILL.md +5 -0
  37. package/habilidades/node-experto/SKILL.md +197 -3
  38. package/habilidades/prevencion-racionalizacion/SKILL.md +1 -0
  39. package/habilidades/privacy-memoria/SKILL.md +1 -0
  40. package/habilidades/proceso-autoverificacion-evidencias/SKILL.md +258 -0
  41. package/habilidades/proceso-confianza-pre-implementacion/SKILL.md +246 -0
  42. package/habilidades/proceso-ddia-fundamentos/SKILL.md +255 -0
  43. package/habilidades/proceso-ddia-streaming/SKILL.md +231 -0
  44. package/habilidades/proceso-intent-engineering/SKILL.md +269 -0
  45. package/habilidades/reducir-entropia/SKILL.md +219 -0
  46. package/habilidades/sre-patrones/SKILL.md +1 -1
  47. package/habilidades/state-inconsistency-auditor-swl/SKILL.md +172 -166
  48. package/habilidades/tdd-workflow/SKILL.md +178 -3
  49. package/habilidades/verificacion-evidencia/SKILL.md +1 -0
  50. package/habilidades/web-fetcher-routing/SKILL.md +81 -75
  51. package/habilidades/workflow-claude-code/SKILL.md +2 -2
  52. package/hooks/lib/task-budget.js +218 -0
  53. package/hooks/validar-intent-spec.js +222 -0
  54. package/manifiestos/hooks-config.json +9 -0
  55. package/manifiestos/modulos.json +12 -2
  56. package/manifiestos/skills-lock.json +1191 -1142
  57. package/package.json +5 -3
  58. package/plugin.json +9 -2
  59. package/reglas/auditorias-documentales-estructurales.md +205 -0
  60. package/reglas/fragmentos-compartidos.md +26 -0
  61. package/reglas/intent-engineering.md +214 -0
  62. package/reglas/registro-componentes-nuevos.md +38 -0
  63. package/schemas/agent-frontmatter.schema.json +294 -167
  64. package/schemas/agent-message.schema.json +73 -53
  65. package/schemas/agent-output-implementacion.schema.json +114 -85
  66. package/schemas/agent-output-planificacion.schema.json +150 -113
  67. package/schemas/agent-output-review.schema.json +98 -78
  68. package/schemas/diary-entry.schema.json +42 -10
  69. package/schemas/hook-profiles.schema.json +54 -39
  70. package/schemas/hooks-config.schema.json +89 -74
  71. package/schemas/instinct.schema.json +152 -115
  72. package/schemas/modulos.schema.json +38 -29
  73. package/schemas/perfiles.schema.json +36 -28
  74. package/schemas/plugin.schema.json +77 -64
  75. package/schemas/skill-evals.schema.json +119 -95
  76. package/schemas/skill-frontmatter.schema.json +245 -170
  77. package/scripts/generar-inventario.js +452 -420
  78. package/scripts/lib/schema-version.js +164 -0
  79. package/scripts/validar-manifest.js +1 -1
  80. package/scripts/validar.js +3 -2
  81. package/scripts/verificar-docs-vs-codigo.js +654 -425
  82. package/scripts/verificar-evolucion.js +19 -3
@@ -1,170 +1,245 @@
1
- {
2
- "$schema": "https://json-schema.org/draft/2020-12/schema",
3
- "$id": "https://swl-ses.dev/schemas/skill-frontmatter.json",
4
- "title": "SWL Skill Frontmatter",
5
- "description": "Schema de validacion para el frontmatter YAML de skills del sistema SWL",
6
- "type": "object",
7
- "required": ["name", "description"],
8
- "properties": {
9
- "name": {
10
- "type": "string",
11
- "pattern": "^[a-z][a-z0-9-]+$",
12
- "maxLength": 64,
13
- "description": "Nombre en kebab-case que coincide con el directorio"
14
- },
15
- "description": {
16
- "type": "string",
17
- "minLength": 20,
18
- "maxLength": 1024,
19
- "description": "Descripcion que incluye QUE hace y CUANDO cargarla"
20
- },
21
- "version": {
22
- "type": "string",
23
- "pattern": "^\\d+\\.\\d+\\.\\d+$"
24
- },
25
- "provenance": {
26
- "type": "object",
27
- "description": "Campo legacy. Equivalente espanol: 'procedencia'. Si ambos presentes deben coincidir (W010).",
28
- "properties": {
29
- "origin": {
30
- "type": "string",
31
- "enum": ["manual", "auto-evolution", "imported", "community"]
32
- },
33
- "created_at": {
34
- "type": "string",
35
- "format": "date"
36
- },
37
- "confidence": {
38
- "type": "number",
39
- "minimum": 0,
40
- "maximum": 1
41
- },
42
- "author": {
43
- "type": "string"
44
- }
45
- }
46
- },
47
- "procedencia": {
48
- "type": "object",
49
- "description": "Alias en espanol de 'provenance'. Campo propio de swl-ses. Si ambos presentes, deben coincidir (W010).",
50
- "properties": {
51
- "origin": {
52
- "type": "string",
53
- "enum": ["manual", "auto-evolution", "imported", "community"]
54
- },
55
- "created_at": {
56
- "type": "string",
57
- "format": "date"
58
- },
59
- "confidence": {
60
- "type": "number",
61
- "minimum": 0,
62
- "maximum": 1
63
- },
64
- "author": {
65
- "type": "string"
66
- }
67
- }
68
- },
69
- "targets": {
70
- "type": "array",
71
- "items": {
72
- "type": "string",
73
- "enum": ["claude", "openclaude", "copilot", "opencode", "codex", "gemini"]
74
- },
75
- "description": "Campo legacy. Equivalente espanol: 'destinos'. Runtimes a los que se sincroniza este skill. Patron adoptado de skillshare (targets.yaml). Si ambos presentes deben coincidir (W010)."
76
- },
77
- "destinos": {
78
- "type": "array",
79
- "items": {
80
- "type": "string",
81
- "enum": ["claude", "openclaude", "copilot", "opencode", "codex", "gemini"]
82
- },
83
- "description": "Alias en espanol de 'targets'. Campo propio de swl-ses. Runtimes a los que se sincroniza este skill."
84
- },
85
- "user-invocable": {
86
- "type": "boolean",
87
- "description": "Si el usuario puede invocar este skill directamente con Skill(nombre)"
88
- },
89
- "license": {
90
- "type": "string",
91
- "description": "Licencia del skill si es externo o adaptado"
92
- },
93
- "evolvable": {
94
- "type": "boolean",
95
- "description": "Campo legacy. Equivalente espanol: 'evolucionable'. Marca AGP learnability. Si false, el loop de auto-evolucion NO debe proponer cambios a este skill. Recomendado: false para skills criticos. Si ambos presentes deben coincidir (W010)."
96
- },
97
- "evolucionable": {
98
- "type": "boolean",
99
- "description": "Alias en espanol de 'evolvable'. Campo propio de swl-ses. Marca AGP learnability. Si false, el loop de auto-evolucion NO propone cambios a este skill."
100
- },
101
- "evolvable_scope": {
102
- "type": "array",
103
- "items": {
104
- "type": "string",
105
- "enum": ["description", "content", "examples", "references", "anti-patterns"]
106
- },
107
- "description": "Campo legacy. Equivalente espanol: 'evolucionable_alcance'. Si evolvable=true, limita las secciones del SKILL.md que pueden modificarse. Ausente implica 'content' y 'examples' unicamente. Si ambos presentes deben coincidir (W010)."
108
- },
109
- "evolucionable_alcance": {
110
- "type": "array",
111
- "items": {
112
- "type": "string",
113
- "enum": ["description", "content", "examples", "references", "anti-patterns"]
114
- },
115
- "description": "Alias en espanol de 'evolvable_scope'. Campo propio de swl-ses. Si evolucionable=true, limita las secciones modificables."
116
- },
117
- "when_to_use": {
118
- "type": "string",
119
- "maxLength": 512,
120
- "description": "Campo del protocolo Anthropic. Contexto adicional sobre cuando activar la skill, leido por Claude Code como bloque combinado con description (total max 1536 chars). Usar cuando description ocupa mas de 900 chars y aun hay triggers que no caben."
121
- },
122
- "exclusiones": {
123
- "type": "array",
124
- "items": { "type": "string" },
125
- "description": "Situaciones donde esta skill NO debe activarse aunque parezca relevante superficialmente. Campo propio de swl-ses; previene skill hijacking por similitud de terminos. Equivalente estructural de la seccion 'Cuando NO cargar' en el cuerpo de SKILL.md, legible por herramientas de analisis sin parsear markdown."
126
- },
127
- "allowed-tools": {
128
- "type": "array",
129
- "items": {
130
- "type": "string",
131
- "enum": ["Read", "Write", "Edit", "Bash", "Glob", "Grep", "WebSearch", "WebFetch"]
132
- },
133
- "description": "Campo del protocolo Anthropic. Pre-aprobacion de UX leida por Claude Code. NO es restriccion de seguridad real. Las restricciones reales provienen de permission rules en .claude/settings.json o del matcher en hooks."
134
- },
135
- "herramientasPermitidas": {
136
- "type": "array",
137
- "items": {
138
- "type": "string",
139
- "enum": ["Read", "Write", "Edit", "Bash", "Glob", "Grep", "WebSearch", "WebFetch"]
140
- },
141
- "description": "Campo propio de swl-ses. Alias semantico de allowed-tools, usado por las herramientas internas (evaluar-skill, validadores). Debe coincidir con allowed-tools cuando ambos estan presentes. Si divergen, el validador emite W011. Para skills nuevos en swl-ses, declarar solo este campo; una herramienta de sincronizacion propagara el valor a allowed-tools al construir artefactos para Claude Code."
142
- },
143
- "nist_csf": {
144
- "type": "array",
145
- "items": { "type": "string", "pattern": "^(GV|ID|PR|DE|RS|RC)\\.[A-Z]{2}(-[0-9]{2})?$" },
146
- "description": "Campo propio de swl-ses. Mapeo a NIST Cybersecurity Framework 2.0. Cada entrada es un ID de subcategoria tipo 'GV.SC-07', 'PR.PS-01', 'DE.CM-01'. Opcional. Usado para reportes de cobertura en /swl:salud y /swl:dashboard. Referencia: https://www.nist.gov/cyberframework"
147
- },
148
- "nist_ai_rmf": {
149
- "type": "array",
150
- "items": { "type": "string", "pattern": "^(GOVERN|MAP|MEASURE|MANAGE)(-[0-9]+(\\.[0-9]+)?)?$" },
151
- "description": "Campo propio de swl-ses. Mapeo a NIST AI Risk Management Framework 1.0. Cada entrada es un ID de subcategoria tipo 'GOVERN-1.1', 'MAP-5.1', 'MEASURE-2.7'. Opcional. Particularmente relevante para skills de seguridad de sistemas agenticos. Referencia: https://airc.nist.gov/AI_RMF"
152
- },
153
- "atlas_techniques": {
154
- "type": "array",
155
- "items": { "type": "string", "pattern": "^AML\\.T[0-9]{4}(\\.[0-9]{3})?$" },
156
- "description": "Campo propio de swl-ses. Mapeo a MITRE ATLAS v5.4 (Adversarial Threat Landscape for AI Systems). Cada entrada es una tecnica tipo 'AML.T0051' (LLM Prompt Injection), 'AML.T0080' (AI Agent Context Poisoning). Opcional. Critico para skills que protegen el sistema agentico mismo. Referencia: https://atlas.mitre.org"
157
- },
158
- "attack_techniques": {
159
- "type": "array",
160
- "items": { "type": "string", "pattern": "^T[0-9]{4}(\\.[0-9]{3})?$" },
161
- "description": "Campo propio de swl-ses. Mapeo a MITRE ATT&CK v18. Cada entrada es una tecnica tipo 'T1071' (Application Layer Protocol), 'T1190' (Exploit Public-Facing Application). Opcional. Mas aplicable a skills de defensa de infraestructura o deteccion de amenazas en el sistema desplegado. Referencia: https://attack.mitre.org"
162
- },
163
- "d3fend_techniques": {
164
- "type": "array",
165
- "items": { "type": "string", "pattern": "^D3-[A-Z]+$" },
166
- "description": "Campo propio de swl-ses. Mapeo a MITRE D3FEND v1.3 (Defensive countermeasures). Cada entrada es una tecnica tipo 'D3-NTA' (Network Traffic Analysis), 'D3-PSA' (Process Spawn Analysis). Opcional. Referencia: https://d3fend.mitre.org"
167
- }
168
- },
169
- "additionalProperties": true
170
- }
1
+ {
2
+ "$schema": "https://json-schema.org/draft/2020-12/schema",
3
+ "$id": "https://swl-ses.dev/schemas/skill-frontmatter.json",
4
+ "$schemaVersion": "1.0.0",
5
+ "title": "SWL Skill Frontmatter",
6
+ "description": "Schema de validacion para el frontmatter YAML de skills del sistema SWL",
7
+ "type": "object",
8
+ "required": [
9
+ "name",
10
+ "description"
11
+ ],
12
+ "properties": {
13
+ "name": {
14
+ "type": "string",
15
+ "pattern": "^[a-z][a-z0-9-]+$",
16
+ "maxLength": 64,
17
+ "description": "Nombre en kebab-case que coincide con el directorio"
18
+ },
19
+ "description": {
20
+ "type": "string",
21
+ "minLength": 20,
22
+ "maxLength": 1024,
23
+ "description": "Descripcion que incluye QUE hace y CUANDO cargarla"
24
+ },
25
+ "version": {
26
+ "type": "string",
27
+ "pattern": "^\\d+\\.\\d+\\.\\d+$"
28
+ },
29
+ "provenance": {
30
+ "type": "object",
31
+ "description": "Campo legacy. Equivalente espanol: 'procedencia'. Si ambos presentes deben coincidir (W010).",
32
+ "properties": {
33
+ "origin": {
34
+ "type": "string",
35
+ "enum": [
36
+ "manual",
37
+ "auto-evolution",
38
+ "imported",
39
+ "community"
40
+ ]
41
+ },
42
+ "created_at": {
43
+ "type": "string",
44
+ "format": "date"
45
+ },
46
+ "confidence": {
47
+ "type": "number",
48
+ "minimum": 0,
49
+ "maximum": 1
50
+ },
51
+ "author": {
52
+ "type": "string"
53
+ }
54
+ }
55
+ },
56
+ "procedencia": {
57
+ "type": "object",
58
+ "description": "Alias en espanol de 'provenance'. Campo propio de swl-ses. Si ambos presentes, deben coincidir (W010).",
59
+ "properties": {
60
+ "origin": {
61
+ "type": "string",
62
+ "enum": [
63
+ "manual",
64
+ "auto-evolution",
65
+ "imported",
66
+ "community"
67
+ ]
68
+ },
69
+ "created_at": {
70
+ "type": "string",
71
+ "format": "date"
72
+ },
73
+ "confidence": {
74
+ "type": "number",
75
+ "minimum": 0,
76
+ "maximum": 1
77
+ },
78
+ "author": {
79
+ "type": "string"
80
+ }
81
+ }
82
+ },
83
+ "targets": {
84
+ "type": "array",
85
+ "items": {
86
+ "type": "string",
87
+ "enum": [
88
+ "claude",
89
+ "openclaude",
90
+ "copilot",
91
+ "opencode",
92
+ "codex",
93
+ "gemini"
94
+ ]
95
+ },
96
+ "description": "Campo legacy. Equivalente espanol: 'destinos'. Runtimes a los que se sincroniza este skill. Patron adoptado de skillshare (targets.yaml). Si ambos presentes deben coincidir (W010)."
97
+ },
98
+ "destinos": {
99
+ "type": "array",
100
+ "items": {
101
+ "type": "string",
102
+ "enum": [
103
+ "claude",
104
+ "openclaude",
105
+ "copilot",
106
+ "opencode",
107
+ "codex",
108
+ "gemini"
109
+ ]
110
+ },
111
+ "description": "Alias en espanol de 'targets'. Campo propio de swl-ses. Runtimes a los que se sincroniza este skill."
112
+ },
113
+ "user-invocable": {
114
+ "type": "boolean",
115
+ "description": "Si el usuario puede invocar este skill directamente con Skill(nombre)"
116
+ },
117
+ "license": {
118
+ "type": "string",
119
+ "description": "Licencia del skill si es externo o adaptado"
120
+ },
121
+ "evolvable": {
122
+ "type": "boolean",
123
+ "description": "Campo legacy. Equivalente espanol: 'evolucionable'. Marca AGP learnability. Si false, el loop de auto-evolucion NO debe proponer cambios a este skill. Recomendado: false para skills criticos. Si ambos presentes deben coincidir (W010)."
124
+ },
125
+ "evolucionable": {
126
+ "type": "boolean",
127
+ "description": "Alias en espanol de 'evolvable'. Campo propio de swl-ses. Marca AGP learnability. Si false, el loop de auto-evolucion NO propone cambios a este skill."
128
+ },
129
+ "evolvable_scope": {
130
+ "type": "array",
131
+ "items": {
132
+ "type": "string",
133
+ "enum": [
134
+ "description",
135
+ "content",
136
+ "examples",
137
+ "references",
138
+ "anti-patterns"
139
+ ]
140
+ },
141
+ "description": "Campo legacy. Equivalente espanol: 'evolucionable_alcance'. Si evolvable=true, limita las secciones del SKILL.md que pueden modificarse. Ausente implica 'content' y 'examples' unicamente. Si ambos presentes deben coincidir (W010)."
142
+ },
143
+ "evolucionable_alcance": {
144
+ "type": "array",
145
+ "items": {
146
+ "type": "string",
147
+ "enum": [
148
+ "description",
149
+ "content",
150
+ "examples",
151
+ "references",
152
+ "anti-patterns"
153
+ ]
154
+ },
155
+ "description": "Alias en espanol de 'evolvable_scope'. Campo propio de swl-ses. Si evolucionable=true, limita las secciones modificables."
156
+ },
157
+ "when_to_use": {
158
+ "type": "string",
159
+ "maxLength": 512,
160
+ "description": "Campo del protocolo Anthropic. Contexto adicional sobre cuando activar la skill, leido por Claude Code como bloque combinado con description (total max 1536 chars). Usar cuando description ocupa mas de 900 chars y aun hay triggers que no caben."
161
+ },
162
+ "exclusiones": {
163
+ "type": "array",
164
+ "items": {
165
+ "type": "string"
166
+ },
167
+ "description": "Situaciones donde esta skill NO debe activarse aunque parezca relevante superficialmente. Campo propio de swl-ses; previene skill hijacking por similitud de terminos. Equivalente estructural de la seccion 'Cuando NO cargar' en el cuerpo de SKILL.md, legible por herramientas de analisis sin parsear markdown."
168
+ },
169
+ "allowed-tools": {
170
+ "type": "array",
171
+ "items": {
172
+ "type": "string",
173
+ "enum": [
174
+ "Read",
175
+ "Write",
176
+ "Edit",
177
+ "Bash",
178
+ "Glob",
179
+ "Grep",
180
+ "WebSearch",
181
+ "WebFetch"
182
+ ]
183
+ },
184
+ "description": "Campo del protocolo Anthropic. Pre-aprobacion de UX leida por Claude Code. NO es restriccion de seguridad real. Las restricciones reales provienen de permission rules en .claude/settings.json o del matcher en hooks."
185
+ },
186
+ "herramientasPermitidas": {
187
+ "type": "array",
188
+ "items": {
189
+ "type": "string",
190
+ "enum": [
191
+ "Read",
192
+ "Write",
193
+ "Edit",
194
+ "Bash",
195
+ "Glob",
196
+ "Grep",
197
+ "WebSearch",
198
+ "WebFetch"
199
+ ]
200
+ },
201
+ "description": "Campo propio de swl-ses. Alias semantico de allowed-tools, usado por las herramientas internas (evaluar-skill, validadores). Debe coincidir con allowed-tools cuando ambos estan presentes. Si divergen, el validador emite W011. Para skills nuevos en swl-ses, declarar solo este campo; una herramienta de sincronizacion propagara el valor a allowed-tools al construir artefactos para Claude Code."
202
+ },
203
+ "nist_csf": {
204
+ "type": "array",
205
+ "items": {
206
+ "type": "string",
207
+ "pattern": "^(GV|ID|PR|DE|RS|RC)\\.[A-Z]{2}(-[0-9]{2})?$"
208
+ },
209
+ "description": "Campo propio de swl-ses. Mapeo a NIST Cybersecurity Framework 2.0. Cada entrada es un ID de subcategoria tipo 'GV.SC-07', 'PR.PS-01', 'DE.CM-01'. Opcional. Usado para reportes de cobertura en /swl:salud y /swl:dashboard. Referencia: https://www.nist.gov/cyberframework"
210
+ },
211
+ "nist_ai_rmf": {
212
+ "type": "array",
213
+ "items": {
214
+ "type": "string",
215
+ "pattern": "^(GOVERN|MAP|MEASURE|MANAGE)(-[0-9]+(\\.[0-9]+)?)?$"
216
+ },
217
+ "description": "Campo propio de swl-ses. Mapeo a NIST AI Risk Management Framework 1.0. Cada entrada es un ID de subcategoria tipo 'GOVERN-1.1', 'MAP-5.1', 'MEASURE-2.7'. Opcional. Particularmente relevante para skills de seguridad de sistemas agenticos. Referencia: https://airc.nist.gov/AI_RMF"
218
+ },
219
+ "atlas_techniques": {
220
+ "type": "array",
221
+ "items": {
222
+ "type": "string",
223
+ "pattern": "^AML\\.T[0-9]{4}(\\.[0-9]{3})?$"
224
+ },
225
+ "description": "Campo propio de swl-ses. Mapeo a MITRE ATLAS v5.4 (Adversarial Threat Landscape for AI Systems). Cada entrada es una tecnica tipo 'AML.T0051' (LLM Prompt Injection), 'AML.T0080' (AI Agent Context Poisoning). Opcional. Critico para skills que protegen el sistema agentico mismo. Referencia: https://atlas.mitre.org"
226
+ },
227
+ "attack_techniques": {
228
+ "type": "array",
229
+ "items": {
230
+ "type": "string",
231
+ "pattern": "^T[0-9]{4}(\\.[0-9]{3})?$"
232
+ },
233
+ "description": "Campo propio de swl-ses. Mapeo a MITRE ATT&CK v18. Cada entrada es una tecnica tipo 'T1071' (Application Layer Protocol), 'T1190' (Exploit Public-Facing Application). Opcional. Mas aplicable a skills de defensa de infraestructura o deteccion de amenazas en el sistema desplegado. Referencia: https://attack.mitre.org"
234
+ },
235
+ "d3fend_techniques": {
236
+ "type": "array",
237
+ "items": {
238
+ "type": "string",
239
+ "pattern": "^D3-[A-Z]+$"
240
+ },
241
+ "description": "Campo propio de swl-ses. Mapeo a MITRE D3FEND v1.3 (Defensive countermeasures). Cada entrada es una tecnica tipo 'D3-NTA' (Network Traffic Analysis), 'D3-PSA' (Process Spawn Analysis). Opcional. Referencia: https://d3fend.mitre.org"
242
+ }
243
+ },
244
+ "additionalProperties": true
245
+ }