failproofai 0.0.6-beta.1 → 0.0.6-beta.2
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.
- package/.next/standalone/.failproofai/policies/review-policies.mjs +4 -3
- package/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/build-manifest.json +3 -3
- package/.next/standalone/.next/prerender-manifest.json +3 -3
- package/.next/standalone/.next/required-server-files.json +1 -1
- package/.next/standalone/.next/server/app/_global-error/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/.next/server/app/_global-error.rsc +7 -7
- package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +2 -2
- package/.next/standalone/.next/server/app/_not-found.rsc +15 -15
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +15 -15
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +15 -15
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +15 -15
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/policies/page/server-reference-manifest.json +8 -8
- package/.next/standalone/.next/server/app/policies/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/policies/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/react-loadable-manifest.json +2 -2
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/server-reference-manifest.json +2 -2
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/projects/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/projects/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/projects/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0g72weg._.js +1 -1
- package/.next/standalone/.next/server/chunks/package_json_[json]_cjs_0z7w.hh._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0~kmh8w._.js → [root-of-the-server]__05akje6._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__092s1ta._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__09icjsf._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0g.lg8b._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0h..k-e._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0rh.18_._.js → [root-of-the-server]__0i5kvry._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0okos0k._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0w6l33k._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__11pa2ra._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__12t-wym._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/_10lm7or._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/app_global-error_tsx_0xerkr6._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_0q-m0y-._.js +1 -1
- package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
- package/.next/standalone/.next/server/pages/404.html +2 -2
- package/.next/standalone/.next/server/pages/500.html +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.json +9 -9
- package/.next/standalone/.next/static/chunks/{08t08igdql9yt.js → 00j0rr7rh8ef8.js} +1 -1
- package/.next/standalone/.next/static/chunks/{12~yi9oj8av8p.js → 05j1px0r8yzh6.js} +2 -2
- package/.next/standalone/.next/static/chunks/{09_k80d~cq2wg.js → 0badv41uxa56..js} +1 -1
- package/.next/standalone/.next/static/chunks/{0wlyoif4_kj_t.js → 0ijk_kek9_wyx.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0bvhsa6zva2o..js → 0ksdlt_1hucdm.js} +1 -1
- package/.next/standalone/.next/static/chunks/{03rz6ykw-a2xi.js → 0npb~873.wvg3.js} +1 -1
- package/.next/standalone/.next/static/chunks/{01b~z8f1ws0rk.js → 0xpl.oscrakvx.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0gbf4cphy8ksq.js → 1052sguyd-.ka.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0v.yd0kg_ld3r.js → 14cl9poem30dq.js} +1 -1
- package/.next/standalone/CHANGELOG.md +11 -0
- package/.next/standalone/dist/cli.mjs +3 -3
- package/.next/standalone/docs/ar/built-in-policies.mdx +124 -87
- package/.next/standalone/docs/ar/custom-policies.mdx +72 -72
- package/.next/standalone/docs/ar/examples.mdx +86 -33
- package/.next/standalone/docs/ar/getting-started.mdx +82 -29
- package/.next/standalone/docs/built-in-policies.mdx +1 -1
- package/.next/standalone/docs/de/built-in-policies.mdx +93 -56
- package/.next/standalone/docs/de/custom-policies.mdx +56 -56
- package/.next/standalone/docs/de/examples.mdx +72 -18
- package/.next/standalone/docs/de/getting-started.mdx +72 -20
- package/.next/standalone/docs/es/built-in-policies.mdx +115 -78
- package/.next/standalone/docs/es/custom-policies.mdx +55 -55
- package/.next/standalone/docs/es/examples.mdx +73 -19
- package/.next/standalone/docs/es/getting-started.mdx +72 -20
- package/.next/standalone/docs/fr/built-in-policies.mdx +83 -46
- package/.next/standalone/docs/fr/custom-policies.mdx +51 -51
- package/.next/standalone/docs/fr/examples.mdx +78 -24
- package/.next/standalone/docs/fr/getting-started.mdx +65 -13
- package/.next/standalone/docs/he/built-in-policies.mdx +156 -117
- package/.next/standalone/docs/he/custom-policies.mdx +75 -75
- package/.next/standalone/docs/he/examples.mdx +87 -33
- package/.next/standalone/docs/he/getting-started.mdx +84 -33
- package/.next/standalone/docs/hi/built-in-policies.mdx +101 -60
- package/.next/standalone/docs/hi/custom-policies.mdx +71 -70
- package/.next/standalone/docs/hi/examples.mdx +90 -36
- package/.next/standalone/docs/hi/getting-started.mdx +80 -27
- package/.next/standalone/docs/i18n/README.ar.md +69 -69
- package/.next/standalone/docs/i18n/README.de.md +46 -46
- package/.next/standalone/docs/i18n/README.es.md +42 -42
- package/.next/standalone/docs/i18n/README.fr.md +39 -39
- package/.next/standalone/docs/i18n/README.he.md +83 -83
- package/.next/standalone/docs/i18n/README.hi.md +69 -69
- package/.next/standalone/docs/i18n/README.it.md +72 -72
- package/.next/standalone/docs/i18n/README.ja.md +71 -71
- package/.next/standalone/docs/i18n/README.ko.md +52 -52
- package/.next/standalone/docs/i18n/README.pt-br.md +44 -44
- package/.next/standalone/docs/i18n/README.ru.md +66 -66
- package/.next/standalone/docs/i18n/README.tr.md +82 -83
- package/.next/standalone/docs/i18n/README.vi.md +70 -71
- package/.next/standalone/docs/i18n/README.zh.md +51 -51
- package/.next/standalone/docs/it/built-in-policies.mdx +118 -81
- package/.next/standalone/docs/it/custom-policies.mdx +69 -69
- package/.next/standalone/docs/it/examples.mdx +93 -39
- package/.next/standalone/docs/it/getting-started.mdx +73 -21
- package/.next/standalone/docs/ja/built-in-policies.mdx +98 -61
- package/.next/standalone/docs/ja/custom-policies.mdx +71 -71
- package/.next/standalone/docs/ja/examples.mdx +76 -22
- package/.next/standalone/docs/ja/getting-started.mdx +65 -13
- package/.next/standalone/docs/ko/built-in-policies.mdx +137 -100
- package/.next/standalone/docs/ko/custom-policies.mdx +67 -67
- package/.next/standalone/docs/ko/examples.mdx +87 -33
- package/.next/standalone/docs/ko/getting-started.mdx +61 -9
- package/.next/standalone/docs/pt-br/built-in-policies.mdx +94 -57
- package/.next/standalone/docs/pt-br/custom-policies.mdx +56 -56
- package/.next/standalone/docs/pt-br/examples.mdx +78 -24
- package/.next/standalone/docs/pt-br/getting-started.mdx +64 -12
- package/.next/standalone/docs/ru/built-in-policies.mdx +142 -105
- package/.next/standalone/docs/ru/custom-policies.mdx +82 -81
- package/.next/standalone/docs/ru/examples.mdx +77 -22
- package/.next/standalone/docs/ru/getting-started.mdx +74 -22
- package/.next/standalone/docs/tr/built-in-policies.mdx +104 -67
- package/.next/standalone/docs/tr/custom-policies.mdx +59 -60
- package/.next/standalone/docs/tr/examples.mdx +97 -42
- package/.next/standalone/docs/tr/getting-started.mdx +75 -23
- package/.next/standalone/docs/vi/built-in-policies.mdx +110 -72
- package/.next/standalone/docs/vi/custom-policies.mdx +68 -68
- package/.next/standalone/docs/vi/examples.mdx +93 -38
- package/.next/standalone/docs/vi/getting-started.mdx +74 -22
- package/.next/standalone/docs/zh/built-in-policies.mdx +132 -95
- package/.next/standalone/docs/zh/custom-policies.mdx +49 -49
- package/.next/standalone/docs/zh/examples.mdx +90 -36
- package/.next/standalone/docs/zh/getting-started.mdx +73 -21
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/server.js +1 -1
- package/.next/standalone/src/hooks/builtin-policies.ts +5 -1
- package/dist/cli.mjs +3 -3
- package/package.json +1 -1
- package/src/hooks/builtin-policies.ts +5 -1
- /package/.next/standalone/.next/static/{CkmOT-ZvDN-sVULinGVKT → A9pNTZdoYJTVyPAYwQMx5}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{CkmOT-ZvDN-sVULinGVKT → A9pNTZdoYJTVyPAYwQMx5}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{CkmOT-ZvDN-sVULinGVKT → A9pNTZdoYJTVyPAYwQMx5}/_ssgManifest.js +0 -0
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
---
|
|
2
|
-
title: Políticas
|
|
2
|
+
title: Políticas integradas
|
|
3
3
|
description: "Las 30 políticas integradas que detectan los modos de fallo más comunes en agentes"
|
|
4
4
|
icon: shield
|
|
5
5
|
---
|
|
6
6
|
|
|
7
|
-
failproofai incluye 30 políticas integradas que detectan los modos de fallo más comunes en agentes. Cada política se activa en un tipo de evento de hook específico y
|
|
7
|
+
failproofai incluye 30 políticas integradas que detectan los modos de fallo más comunes en agentes. Cada política se activa en un tipo de evento de hook específico y un nombre de herramienta determinado. Nueve políticas aceptan parámetros que permiten ajustar su comportamiento sin escribir código. Cuatro políticas de flujo de trabajo imponen un pipeline de commit → push → PR → CI antes de que Claude se detenga.
|
|
8
8
|
|
|
9
9
|
---
|
|
10
10
|
|
|
11
11
|
## Descripción general
|
|
12
12
|
|
|
13
|
-
Las políticas están agrupadas
|
|
13
|
+
Las políticas están agrupadas por categorías:
|
|
14
14
|
|
|
15
15
|
| Categoría | Políticas | Tipo de hook |
|
|
16
16
|
|-----------|-----------|--------------|
|
|
@@ -21,37 +21,38 @@ Las políticas están agrupadas en categorías:
|
|
|
21
21
|
| [Git](#git) | block-push-master, block-work-on-main, block-force-push, warn-git-amend, warn-git-stash-drop, warn-all-files-staged | PreToolUse |
|
|
22
22
|
| [Base de datos](#database) | warn-destructive-sql, warn-schema-alteration | PreToolUse |
|
|
23
23
|
| [Advertencias](#warnings) | warn-large-file-write, warn-package-publish, warn-background-process, warn-global-package-install | PreToolUse |
|
|
24
|
+
| [Gestores de paquetes](#package-managers) | prefer-package-manager | PreToolUse |
|
|
24
25
|
| [Flujo de trabajo](#workflow) | require-commit-before-stop, require-push-before-stop, require-pr-before-stop, require-ci-green-before-stop | Stop |
|
|
25
26
|
|
|
26
27
|
- **`block-`** — impide que el agente continúe.
|
|
27
|
-
- **`warn-`** — proporciona al agente
|
|
28
|
-
- **`sanitize-`** — elimina datos sensibles de la salida de
|
|
28
|
+
- **`warn-`** — proporciona contexto adicional al agente para que pueda corregirse.
|
|
29
|
+
- **`sanitize-`** — elimina datos sensibles de la salida de la herramienta antes de que el agente los vea.
|
|
29
30
|
- **`require-`** — bloquea el evento Stop hasta que se cumplan las condiciones.
|
|
30
31
|
|
|
31
32
|
---
|
|
32
33
|
|
|
33
34
|
<Tip>
|
|
34
|
-
|
|
35
|
+
Todas las políticas admiten un campo opcional `hint` en `policyParams`. El hint se añade al mensaje de deny o instruct que ve Claude, proporcionando orientación práctica sin modificar el código de la política. Funciona con políticas integradas, personalizadas y de convención. Consulta [Configuración → hint](/es/configuration#hint-cross-cutting) para más detalles.
|
|
35
36
|
</Tip>
|
|
36
37
|
|
|
37
38
|
---
|
|
38
39
|
|
|
39
40
|
## Comandos peligrosos
|
|
40
41
|
|
|
41
|
-
Evita que los agentes ejecuten operaciones difíciles de deshacer o que puedan dañar el sistema
|
|
42
|
+
Evita que los agentes ejecuten operaciones difíciles de deshacer o que puedan dañar el sistema host.
|
|
42
43
|
|
|
43
44
|
### `block-sudo`
|
|
44
45
|
|
|
45
46
|
**Evento:** PreToolUse (Bash)
|
|
46
|
-
**
|
|
47
|
+
**Por defecto:** Deniega cualquier comando `sudo`.
|
|
47
48
|
|
|
48
|
-
Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia de patrones se realiza sobre los tokens del comando analizado, no sobre la cadena
|
|
49
|
+
Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia de patrones se realiza sobre los tokens del comando analizado, no sobre la cadena sin procesar, para evitar evasiones mediante inyección de operadores de shell.
|
|
49
50
|
|
|
50
51
|
**Parámetros:**
|
|
51
52
|
|
|
52
|
-
| Parámetro | Tipo |
|
|
53
|
-
|
|
54
|
-
| `allowPatterns` | `string[]` | `[]` | Prefijos
|
|
53
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
54
|
+
|-----------|------|-------------|-------------|
|
|
55
|
+
| `allowPatterns` | `string[]` | `[]` | Prefijos de comando exactos que están permitidos. Cada entrada se compara con los tokens argv analizados. |
|
|
55
56
|
|
|
56
57
|
**Ejemplo:**
|
|
57
58
|
|
|
@@ -65,10 +66,10 @@ Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia d
|
|
|
65
66
|
}
|
|
66
67
|
```
|
|
67
68
|
|
|
68
|
-
Con esta configuración, `sudo systemctl status nginx` está permitido, pero `sudo rm /etc/hosts`
|
|
69
|
+
Con esta configuración, `sudo systemctl status nginx` está permitido, pero `sudo rm /etc/hosts` es denegado.
|
|
69
70
|
|
|
70
71
|
<Note>
|
|
71
|
-
Los patrones se comparan con los tokens analizados, no con la cadena
|
|
72
|
+
Los patrones se comparan con los tokens analizados, no con la cadena del comando sin procesar. Esto evita evasiones mediante operadores de shell añadidos (p. ej., `sudo systemctl status x; rm -rf /` no coincide con `sudo systemctl status *`).
|
|
72
73
|
</Note>
|
|
73
74
|
|
|
74
75
|
---
|
|
@@ -76,13 +77,13 @@ Los patrones se comparan con los tokens analizados, no con la cadena de comandos
|
|
|
76
77
|
### `block-rm-rf`
|
|
77
78
|
|
|
78
79
|
**Evento:** PreToolUse (Bash)
|
|
79
|
-
**
|
|
80
|
+
**Por defecto:** Deniega `rm -rf`, `rm -fr` y formas similares de eliminación recursiva.
|
|
80
81
|
|
|
81
82
|
**Parámetros:**
|
|
82
83
|
|
|
83
|
-
| Parámetro | Tipo |
|
|
84
|
-
|
|
85
|
-
| `allowPaths` | `string[]` | `[]` | Rutas
|
|
84
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
85
|
+
|-----------|------|-------------|-------------|
|
|
86
|
+
| `allowPaths` | `string[]` | `[]` | Rutas donde la eliminación recursiva está permitida (p. ej., `/tmp`). |
|
|
86
87
|
|
|
87
88
|
**Ejemplo:**
|
|
88
89
|
|
|
@@ -101,7 +102,7 @@ Los patrones se comparan con los tokens analizados, no con la cadena de comandos
|
|
|
101
102
|
### `block-curl-pipe-sh`
|
|
102
103
|
|
|
103
104
|
**Evento:** PreToolUse (Bash)
|
|
104
|
-
**
|
|
105
|
+
**Por defecto:** Deniega `curl <url> | bash`, `curl <url> | sh`, `wget <url> | bash` y patrones similares.
|
|
105
106
|
|
|
106
107
|
Sin parámetros.
|
|
107
108
|
|
|
@@ -110,7 +111,7 @@ Sin parámetros.
|
|
|
110
111
|
### `block-failproofai-commands`
|
|
111
112
|
|
|
112
113
|
**Evento:** PreToolUse (Bash)
|
|
113
|
-
**
|
|
114
|
+
**Por defecto:** Deniega comandos que desinstalarían o deshabilitarían failproofai (p. ej., `npm uninstall failproofai`, `failproofai policies --uninstall`).
|
|
114
115
|
|
|
115
116
|
Sin parámetros.
|
|
116
117
|
|
|
@@ -118,12 +119,12 @@ Sin parámetros.
|
|
|
118
119
|
|
|
119
120
|
## Secretos (sanitizadores)
|
|
120
121
|
|
|
121
|
-
Evita que los agentes filtren credenciales en su contexto o
|
|
122
|
+
Evita que los agentes filtren credenciales en su contexto o salida. Las políticas sanitizadoras se activan en eventos **PostToolUse**. Cuando Claude ejecuta un comando Bash, lee un archivo o llama a cualquier herramienta, estas políticas inspeccionan la salida antes de que se devuelva a Claude. Si se detecta un patrón de secreto, la política devuelve una decisión de deny que impide que la salida sea enviada de vuelta.
|
|
122
123
|
|
|
123
124
|
### `sanitize-jwt`
|
|
124
125
|
|
|
125
126
|
**Evento:** PostToolUse (todas las herramientas)
|
|
126
|
-
**
|
|
127
|
+
**Por defecto:** Elimina tokens JWT (tres segmentos base64url separados por `.`).
|
|
127
128
|
|
|
128
129
|
Sin parámetros.
|
|
129
130
|
|
|
@@ -132,13 +133,13 @@ Sin parámetros.
|
|
|
132
133
|
### `sanitize-api-keys`
|
|
133
134
|
|
|
134
135
|
**Evento:** PostToolUse (todas las herramientas)
|
|
135
|
-
**
|
|
136
|
+
**Por defecto:** Elimina formatos comunes de claves API: Anthropic (`sk-ant-`), OpenAI (`sk-`), GitHub PATs (`ghp_`), claves de acceso AWS (`AKIA`), claves de Stripe (`sk_live_`, `sk_test_`) y claves de API de Google (`AIza`).
|
|
136
137
|
|
|
137
138
|
**Parámetros:**
|
|
138
139
|
|
|
139
|
-
| Parámetro | Tipo |
|
|
140
|
-
|
|
141
|
-
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones
|
|
140
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
141
|
+
|-----------|------|-------------|-------------|
|
|
142
|
+
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones regex adicionales a tratar como secretos. |
|
|
142
143
|
|
|
143
144
|
**Ejemplo:**
|
|
144
145
|
|
|
@@ -160,7 +161,7 @@ Sin parámetros.
|
|
|
160
161
|
### `sanitize-connection-strings`
|
|
161
162
|
|
|
162
163
|
**Evento:** PostToolUse (todas las herramientas)
|
|
163
|
-
**
|
|
164
|
+
**Por defecto:** Elimina cadenas de conexión a bases de datos que contienen credenciales incrustadas (p. ej., `postgresql://user:password@host/db`).
|
|
164
165
|
|
|
165
166
|
Sin parámetros.
|
|
166
167
|
|
|
@@ -169,7 +170,7 @@ Sin parámetros.
|
|
|
169
170
|
### `sanitize-private-key-content`
|
|
170
171
|
|
|
171
172
|
**Evento:** PostToolUse (todas las herramientas)
|
|
172
|
-
**
|
|
173
|
+
**Por defecto:** Elimina bloques PEM (`-----BEGIN PRIVATE KEY-----`, `-----BEGIN RSA PRIVATE KEY-----`, etc.).
|
|
173
174
|
|
|
174
175
|
Sin parámetros.
|
|
175
176
|
|
|
@@ -178,7 +179,7 @@ Sin parámetros.
|
|
|
178
179
|
### `sanitize-bearer-tokens`
|
|
179
180
|
|
|
180
181
|
**Evento:** PostToolUse (todas las herramientas)
|
|
181
|
-
**
|
|
182
|
+
**Por defecto:** Elimina encabezados `Authorization: Bearer <token>` donde el token tiene 20 o más caracteres.
|
|
182
183
|
|
|
183
184
|
Sin parámetros.
|
|
184
185
|
|
|
@@ -191,9 +192,9 @@ Protege la configuración sensible del entorno para que los agentes no puedan le
|
|
|
191
192
|
### `block-env-files`
|
|
192
193
|
|
|
193
194
|
**Evento:** PreToolUse (Bash, Read)
|
|
194
|
-
**
|
|
195
|
+
**Por defecto:** Deniega la lectura de archivos `.env` mediante `cat .env`, llamadas a la herramienta `Read` con `.env` como ruta de archivo, etc.
|
|
195
196
|
|
|
196
|
-
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo
|
|
197
|
+
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo archivos con el nombre exacto `.env`.
|
|
197
198
|
|
|
198
199
|
Sin parámetros.
|
|
199
200
|
|
|
@@ -202,7 +203,7 @@ Sin parámetros.
|
|
|
202
203
|
### `protect-env-vars`
|
|
203
204
|
|
|
204
205
|
**Evento:** PreToolUse (Bash)
|
|
205
|
-
**
|
|
206
|
+
**Por defecto:** Deniega comandos que imprimen variables de entorno: `printenv`, `env`, `echo $VAR`.
|
|
206
207
|
|
|
207
208
|
Sin parámetros.
|
|
208
209
|
|
|
@@ -215,13 +216,13 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
215
216
|
### `block-read-outside-cwd`
|
|
216
217
|
|
|
217
218
|
**Evento:** PreToolUse (Read, Bash)
|
|
218
|
-
**
|
|
219
|
+
**Por defecto:** Deniega la lectura de archivos fuera del directorio de trabajo actual (la raíz del proyecto).
|
|
219
220
|
|
|
220
221
|
**Parámetros:**
|
|
221
222
|
|
|
222
|
-
| Parámetro | Tipo |
|
|
223
|
-
|
|
224
|
-
| `allowPaths` | `string[]` | `[]` | Prefijos de rutas absolutas
|
|
223
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
224
|
+
|-----------|------|-------------|-------------|
|
|
225
|
+
| `allowPaths` | `string[]` | `[]` | Prefijos de rutas absolutas permitidos aunque estén fuera del directorio de trabajo. |
|
|
225
226
|
|
|
226
227
|
**Ejemplo:**
|
|
227
228
|
|
|
@@ -240,13 +241,13 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
240
241
|
### `block-secrets-write`
|
|
241
242
|
|
|
242
243
|
**Evento:** PreToolUse (Write, Edit)
|
|
243
|
-
**
|
|
244
|
+
**Por defecto:** Deniega escrituras en archivos habitualmente usados para claves privadas y certificados: `id_rsa`, `id_ed25519`, `*.key`, `*.pem`, `*.p12`, `*.pfx`.
|
|
244
245
|
|
|
245
246
|
**Parámetros:**
|
|
246
247
|
|
|
247
|
-
| Parámetro | Tipo |
|
|
248
|
-
|
|
249
|
-
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob)
|
|
248
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
249
|
+
|-----------|------|-------------|-------------|
|
|
250
|
+
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob) a bloquear. |
|
|
250
251
|
|
|
251
252
|
**Ejemplo:**
|
|
252
253
|
|
|
@@ -264,17 +265,17 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
264
265
|
|
|
265
266
|
## Git
|
|
266
267
|
|
|
267
|
-
|
|
268
|
+
Previene pushes accidentales, force-pushes y errores de rama difíciles de deshacer.
|
|
268
269
|
|
|
269
270
|
### `block-push-master`
|
|
270
271
|
|
|
271
272
|
**Evento:** PreToolUse (Bash)
|
|
272
|
-
**
|
|
273
|
+
**Por defecto:** Deniega `git push origin main` y `git push origin master`.
|
|
273
274
|
|
|
274
275
|
**Parámetros:**
|
|
275
276
|
|
|
276
|
-
| Parámetro | Tipo |
|
|
277
|
-
|
|
277
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
278
|
+
|-----------|------|-------------|-------------|
|
|
278
279
|
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer push directamente. |
|
|
279
280
|
|
|
280
281
|
**Ejemplo:**
|
|
@@ -290,7 +291,7 @@ Evita pushes accidentales, force-pushes y errores de rama difíciles de deshacer
|
|
|
290
291
|
```
|
|
291
292
|
|
|
292
293
|
<Tip>
|
|
293
|
-
Para permitir
|
|
294
|
+
Para permitir push a todas las ramas (deshabilitando efectivamente esta política sin eliminarla de `enabledPolicies`), establece `protectedBranches: []`.
|
|
294
295
|
</Tip>
|
|
295
296
|
|
|
296
297
|
---
|
|
@@ -298,12 +299,12 @@ Para permitir el push a todas las ramas (desactivando efectivamente esta políti
|
|
|
298
299
|
### `block-work-on-main`
|
|
299
300
|
|
|
300
301
|
**Evento:** PreToolUse (Bash)
|
|
301
|
-
**
|
|
302
|
+
**Por defecto:** Deniega hacer checkout directamente a las ramas `main` o `master`.
|
|
302
303
|
|
|
303
304
|
**Parámetros:**
|
|
304
305
|
|
|
305
|
-
| Parámetro | Tipo |
|
|
306
|
-
|
|
306
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
307
|
+
|-----------|------|-------------|-------------|
|
|
307
308
|
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer checkout directamente. |
|
|
308
309
|
|
|
309
310
|
---
|
|
@@ -311,7 +312,7 @@ Para permitir el push a todas las ramas (desactivando efectivamente esta políti
|
|
|
311
312
|
### `block-force-push`
|
|
312
313
|
|
|
313
314
|
**Evento:** PreToolUse (Bash)
|
|
314
|
-
**
|
|
315
|
+
**Por defecto:** Deniega `git push --force` y `git push -f`.
|
|
315
316
|
|
|
316
317
|
Sin parámetros específicos de política. Usa el campo transversal [`hint`](/es/configuration#hint-cross-cutting) para sugerir alternativas:
|
|
317
318
|
|
|
@@ -330,7 +331,7 @@ Sin parámetros específicos de política. Usa el campo transversal [`hint`](/es
|
|
|
330
331
|
### `warn-git-amend`
|
|
331
332
|
|
|
332
333
|
**Evento:** PreToolUse (Bash)
|
|
333
|
-
**
|
|
334
|
+
**Por defecto:** Instruye a Claude a proceder con cuidado al ejecutar `git commit --amend`. No bloquea el comando.
|
|
334
335
|
|
|
335
336
|
Sin parámetros.
|
|
336
337
|
|
|
@@ -339,7 +340,7 @@ Sin parámetros.
|
|
|
339
340
|
### `warn-git-stash-drop`
|
|
340
341
|
|
|
341
342
|
**Evento:** PreToolUse (Bash)
|
|
342
|
-
**
|
|
343
|
+
**Por defecto:** Instruye a Claude a confirmar antes de ejecutar `git stash drop`. No bloquea el comando.
|
|
343
344
|
|
|
344
345
|
Sin parámetros.
|
|
345
346
|
|
|
@@ -348,7 +349,7 @@ Sin parámetros.
|
|
|
348
349
|
### `warn-all-files-staged`
|
|
349
350
|
|
|
350
351
|
**Evento:** PreToolUse (Bash)
|
|
351
|
-
**
|
|
352
|
+
**Por defecto:** Instruye a Claude a revisar qué está añadiendo al área de staging cuando ejecuta `git add -A` o `git add .`. No bloquea el comando.
|
|
352
353
|
|
|
353
354
|
Sin parámetros.
|
|
354
355
|
|
|
@@ -361,7 +362,7 @@ Detecta operaciones SQL destructivas antes de que se ejecuten contra tu base de
|
|
|
361
362
|
### `warn-destructive-sql`
|
|
362
363
|
|
|
363
364
|
**Evento:** PreToolUse (Bash)
|
|
364
|
-
**
|
|
365
|
+
**Por defecto:** Instruye a Claude a confirmar antes de ejecutar SQL que contenga `DROP TABLE`, `DROP DATABASE` o `DELETE` sin cláusula `WHERE`.
|
|
365
366
|
|
|
366
367
|
Sin parámetros.
|
|
367
368
|
|
|
@@ -370,7 +371,7 @@ Sin parámetros.
|
|
|
370
371
|
### `warn-schema-alteration`
|
|
371
372
|
|
|
372
373
|
**Evento:** PreToolUse (Bash)
|
|
373
|
-
**
|
|
374
|
+
**Por defecto:** Instruye a Claude a confirmar antes de ejecutar sentencias `ALTER TABLE`.
|
|
374
375
|
|
|
375
376
|
Sin parámetros.
|
|
376
377
|
|
|
@@ -378,17 +379,17 @@ Sin parámetros.
|
|
|
378
379
|
|
|
379
380
|
## Advertencias
|
|
380
381
|
|
|
381
|
-
Proporciona a los agentes
|
|
382
|
+
Proporciona contexto adicional a los agentes antes de operaciones potencialmente arriesgadas pero no destructivas.
|
|
382
383
|
|
|
383
384
|
### `warn-large-file-write`
|
|
384
385
|
|
|
385
386
|
**Evento:** PreToolUse (Write)
|
|
386
|
-
**
|
|
387
|
+
**Por defecto:** Instruye a Claude a confirmar antes de escribir archivos de más de 1024 KB.
|
|
387
388
|
|
|
388
389
|
**Parámetros:**
|
|
389
390
|
|
|
390
|
-
| Parámetro | Tipo |
|
|
391
|
-
|
|
391
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
392
|
+
|-----------|------|-------------|-------------|
|
|
392
393
|
| `thresholdKb` | `number` | `1024` | Umbral de tamaño de archivo en kilobytes a partir del cual se emite una advertencia. |
|
|
393
394
|
|
|
394
395
|
**Ejemplo:**
|
|
@@ -404,7 +405,7 @@ Proporciona a los agentes contexto adicional antes de operaciones potencialmente
|
|
|
404
405
|
```
|
|
405
406
|
|
|
406
407
|
<Note>
|
|
407
|
-
El manejador
|
|
408
|
+
El manejador del hook impone un límite de 1 MB en stdin para los payloads. Para probar esta política con contenido pequeño, establece `thresholdKb` a un valor muy inferior a 1024.
|
|
408
409
|
</Note>
|
|
409
410
|
|
|
410
411
|
---
|
|
@@ -412,7 +413,7 @@ El manejador de hooks impone un límite de 1 MB en stdin para los payloads. Para
|
|
|
412
413
|
### `warn-package-publish`
|
|
413
414
|
|
|
414
415
|
**Evento:** PreToolUse (Bash)
|
|
415
|
-
**
|
|
416
|
+
**Por defecto:** Instruye a Claude a confirmar antes de ejecutar `npm publish`.
|
|
416
417
|
|
|
417
418
|
Sin parámetros.
|
|
418
419
|
|
|
@@ -421,7 +422,7 @@ Sin parámetros.
|
|
|
421
422
|
### `warn-background-process`
|
|
422
423
|
|
|
423
424
|
**Evento:** PreToolUse (Bash)
|
|
424
|
-
**
|
|
425
|
+
**Por defecto:** Instruye a Claude a tener cuidado al lanzar procesos en segundo plano mediante `nohup`, `&`, `disown` o `screen`.
|
|
425
426
|
|
|
426
427
|
Sin parámetros.
|
|
427
428
|
|
|
@@ -430,20 +431,56 @@ Sin parámetros.
|
|
|
430
431
|
### `warn-global-package-install`
|
|
431
432
|
|
|
432
433
|
**Evento:** PreToolUse (Bash)
|
|
433
|
-
**
|
|
434
|
+
**Por defecto:** Instruye a Claude a confirmar antes de ejecutar `npm install -g`, `yarn global add` o `pip install` sin un entorno virtual.
|
|
434
435
|
|
|
435
436
|
Sin parámetros.
|
|
436
437
|
|
|
437
438
|
---
|
|
438
439
|
|
|
440
|
+
## Gestores de paquetes
|
|
441
|
+
|
|
442
|
+
Impone qué gestores de paquetes puede utilizar el agente.
|
|
443
|
+
|
|
444
|
+
### `prefer-package-manager`
|
|
445
|
+
|
|
446
|
+
**Evento:** PreToolUse (Bash)
|
|
447
|
+
**Por defecto:** Deshabilitado. Cuando está habilitado, bloquea cualquier comando de gestor de paquetes que no esté en la lista `allowed` e indica a Claude que reescriba el comando usando un gestor permitido.
|
|
448
|
+
|
|
449
|
+
Detecta: pip, pip3, python -m pip, npm, npx, yarn, pnpm, pnpx, bun, bunx, uv, poetry, pipenv, conda, cargo.
|
|
450
|
+
|
|
451
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
452
|
+
|-----------|------|-------------|-------------|
|
|
453
|
+
| `allowed` | string[] | `[]` | Nombres de gestores de paquetes permitidos. Cualquier gestor detectado que no esté en esta lista será bloqueado. Si está vacío, la política no hace nada. |
|
|
454
|
+
| `blocked` | string[] | `[]` | Nombres de gestores adicionales a bloquear más allá de la lista integrada (p. ej., `['pdm', 'pipx']`). |
|
|
455
|
+
|
|
456
|
+
La lista de bloqueo integrada incluye: pip, pip3, npm, npx, yarn, pnpm, pnpx, bun, bunx, uv, poetry, pipenv, conda, cargo. Usa `blocked` para añadir gestores que no estén en esta lista.
|
|
457
|
+
|
|
458
|
+
**Ejemplo de configuración:**
|
|
459
|
+
|
|
460
|
+
```json
|
|
461
|
+
{
|
|
462
|
+
"enabledPolicies": ["prefer-package-manager"],
|
|
463
|
+
"policyParams": {
|
|
464
|
+
"prefer-package-manager": {
|
|
465
|
+
"allowed": ["uv", "bun"],
|
|
466
|
+
"blocked": ["pdm", "pipx"]
|
|
467
|
+
}
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
```
|
|
471
|
+
|
|
472
|
+
Con esta configuración, tanto `pip install flask` como `pdm install flask` son denegados con un mensaje que indica a Claude que use `uv` o `bun`. Comandos como `uv pip install flask` están permitidos porque `uv` está en la lista de permitidos y se comprueba primero.
|
|
473
|
+
|
|
474
|
+
---
|
|
475
|
+
|
|
439
476
|
## Comportamiento de la IA
|
|
440
477
|
|
|
441
|
-
Detecta cuándo los agentes se quedan
|
|
478
|
+
Detecta cuándo los agentes se quedan atascados o se comportan de forma inesperada.
|
|
442
479
|
|
|
443
480
|
### `warn-repeated-tool-calls`
|
|
444
481
|
|
|
445
482
|
**Evento:** PreToolUse (todas las herramientas)
|
|
446
|
-
**
|
|
483
|
+
**Por defecto:** Instruye a Claude a reconsiderar cuando la misma herramienta es llamada 3 o más veces con parámetros idénticos, lo que suele ser una señal de que el agente está atascado en un bucle.
|
|
447
484
|
|
|
448
485
|
Sin parámetros.
|
|
449
486
|
|
|
@@ -451,14 +488,14 @@ Sin parámetros.
|
|
|
451
488
|
|
|
452
489
|
## Flujo de trabajo
|
|
453
490
|
|
|
454
|
-
Impone un flujo de trabajo disciplinado al final de la sesión. Estas políticas se activan en el evento **Stop** y
|
|
491
|
+
Impone un flujo de trabajo disciplinado al final de la sesión. Estas políticas se activan en el evento **Stop** y evitan que Claude se detenga hasta que se cumpla cada condición. Siguen una cadena de dependencia natural: commit → push → PR → CI. Si una política deniega, las políticas posteriores de la cadena se omiten (deny cortocircuita la cadena).
|
|
455
492
|
|
|
456
|
-
Todas las políticas de flujo de trabajo son **fail-open**: si la herramienta requerida no está disponible (p. ej
|
|
493
|
+
Todas las políticas de flujo de trabajo son **fail-open**: si la herramienta requerida no está disponible (p. ej., `gh` no instalado, sin remote de git), la política permite la acción con un mensaje informativo explicando por qué se omitió la comprobación.
|
|
457
494
|
|
|
458
495
|
### `require-commit-before-stop`
|
|
459
496
|
|
|
460
497
|
**Evento:** Stop
|
|
461
|
-
**
|
|
498
|
+
**Por defecto:** Deniega la detención cuando hay cambios sin commitear (archivos modificados, en staging o sin seguimiento). Devuelve un mensaje informativo cuando el directorio de trabajo está limpio.
|
|
462
499
|
|
|
463
500
|
Sin parámetros.
|
|
464
501
|
|
|
@@ -467,12 +504,12 @@ Sin parámetros.
|
|
|
467
504
|
### `require-push-before-stop`
|
|
468
505
|
|
|
469
506
|
**Evento:** Stop
|
|
470
|
-
**
|
|
507
|
+
**Por defecto:** Deniega la detención cuando hay commits sin hacer push o cuando la rama actual no tiene una rama de seguimiento remota. Sugiere `git push -u` para crear una rama de seguimiento si es necesario. Falla de forma abierta si no hay remote configurado.
|
|
471
508
|
|
|
472
509
|
**Parámetros:**
|
|
473
510
|
|
|
474
|
-
| Parámetro | Tipo |
|
|
475
|
-
|
|
511
|
+
| Parámetro | Tipo | Por defecto | Descripción |
|
|
512
|
+
|-----------|------|-------------|-------------|
|
|
476
513
|
| `remote` | `string` | `"origin"` | Nombre del remote al que hacer push. |
|
|
477
514
|
|
|
478
515
|
**Ejemplo:**
|
|
@@ -492,14 +529,14 @@ Sin parámetros.
|
|
|
492
529
|
### `require-pr-before-stop`
|
|
493
530
|
|
|
494
531
|
**Evento:** Stop
|
|
495
|
-
**
|
|
532
|
+
**Por defecto:** Deniega la detención cuando no existe ningún pull request para la rama actual, o cuando el PR existente está cerrado o fusionado. Instruye a Claude a crear un PR con `gh pr create`.
|
|
496
533
|
|
|
497
534
|
Sin parámetros.
|
|
498
535
|
|
|
499
536
|
<Note>
|
|
500
537
|
Esta política requiere que [GitHub CLI](https://cli.github.com/) (`gh`) esté instalado y autenticado.
|
|
501
|
-
Ejecuta `gh auth login` con un token de acceso personal que tenga
|
|
502
|
-
pull requests. Si `gh` no está instalado o no está autenticado, la política
|
|
538
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga el scope `repo` para acceso de lectura a
|
|
539
|
+
pull requests. Si `gh` no está instalado o no está autenticado, la política falla de forma abierta e informa del motivo a Claude.
|
|
503
540
|
</Note>
|
|
504
541
|
|
|
505
542
|
---
|
|
@@ -507,23 +544,23 @@ pull requests. Si `gh` no está instalado o no está autenticado, la política e
|
|
|
507
544
|
### `require-ci-green-before-stop`
|
|
508
545
|
|
|
509
546
|
**Evento:** Stop
|
|
510
|
-
**
|
|
547
|
+
**Por defecto:** Deniega la detención cuando las comprobaciones de CI están fallando o aún en ejecución en la rama actual. Comprueba tanto las ejecuciones de flujos de trabajo de GitHub Actions como las comprobaciones de bots de terceros (p. ej., CodeRabbit, SonarCloud, Codecov). Trata las conclusiones `skipped` como éxito. Devuelve un mensaje informativo cuando todas las comprobaciones pasan.
|
|
511
548
|
|
|
512
549
|
Sin parámetros.
|
|
513
550
|
|
|
514
551
|
<Note>
|
|
515
552
|
Esta política requiere que [GitHub CLI](https://cli.github.com/) (`gh`) esté instalado y autenticado.
|
|
516
|
-
Ejecuta `gh auth login` con un token de acceso personal que tenga
|
|
517
|
-
|
|
553
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga el scope `repo` para acceso de lectura a
|
|
554
|
+
ejecuciones de flujos de trabajo de Actions y la API de Checks. Si `gh` no está instalado o no está autenticado, la política falla de forma abierta e informa del motivo a Claude.
|
|
518
555
|
</Note>
|
|
519
556
|
|
|
520
557
|
---
|
|
521
558
|
|
|
522
559
|
---
|
|
523
560
|
|
|
524
|
-
##
|
|
561
|
+
## Deshabilitar políticas individuales
|
|
525
562
|
|
|
526
|
-
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala en la pestaña
|
|
563
|
+
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala en la pestaña Policies del panel de control.
|
|
527
564
|
|
|
528
565
|
```json
|
|
529
566
|
{
|