failproofai 0.0.6-beta.2 → 0.0.6-beta.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.
- 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]__092s1ta._.js +2 -2
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__05akje6._.js → [root-of-the-server]__096k.db._.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]__0i5kvry._.js → [root-of-the-server]__0kyh86x._.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/{1052sguyd-.ka.js → 0-dm_9a6nsc2l.js} +1 -1
- package/.next/standalone/.next/static/chunks/{05j1px0r8yzh6.js → 01pmw1-asbek~.js} +2 -2
- package/.next/standalone/.next/static/chunks/{14cl9poem30dq.js → 051m32nx~n5yr.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0badv41uxa56..js → 0a-yctdwn368y.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0xpl.oscrakvx.js → 0l-mu4okl-cj1.js} +1 -1
- package/.next/standalone/.next/static/chunks/{00j0rr7rh8ef8.js → 0mazj-p-~2kc6.js} +1 -1
- package/.next/standalone/.next/static/chunks/0qakntsrpc~1j.js +6 -0
- package/.next/standalone/.next/static/chunks/{0npb~873.wvg3.js → 156zca6aewyr-.js} +1 -1
- package/.next/standalone/CHANGELOG.md +7 -0
- package/.next/standalone/bin/failproofai.mjs +91 -4
- package/.next/standalone/dist/cli.mjs +1155 -54
- package/.next/standalone/docs/ar/built-in-policies.mdx +118 -118
- package/.next/standalone/docs/built-in-policies.mdx +2 -2
- package/.next/standalone/docs/de/built-in-policies.mdx +48 -48
- package/.next/standalone/docs/es/built-in-policies.mdx +82 -82
- package/.next/standalone/docs/fr/built-in-policies.mdx +72 -72
- package/.next/standalone/docs/he/built-in-policies.mdx +129 -128
- package/.next/standalone/docs/hi/built-in-policies.mdx +178 -182
- package/.next/standalone/docs/it/built-in-policies.mdx +64 -64
- package/.next/standalone/docs/ja/built-in-policies.mdx +128 -128
- package/.next/standalone/docs/ko/built-in-policies.mdx +111 -111
- package/.next/standalone/docs/pt-br/built-in-policies.mdx +65 -65
- package/.next/standalone/docs/ru/built-in-policies.mdx +72 -72
- package/.next/standalone/docs/tr/built-in-policies.mdx +99 -99
- package/.next/standalone/docs/vi/built-in-policies.mdx +69 -72
- package/.next/standalone/docs/zh/built-in-policies.mdx +76 -78
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/server.js +1 -1
- package/.next/standalone/src/auth/login.ts +104 -0
- package/.next/standalone/src/auth/logout.ts +50 -0
- package/.next/standalone/src/auth/token-store.ts +64 -0
- package/.next/standalone/src/hooks/builtin-policies.ts +22 -20
- package/.next/standalone/src/hooks/handler.ts +35 -15
- package/.next/standalone/src/relay/daemon.ts +362 -0
- package/.next/standalone/src/relay/pid.ts +76 -0
- package/.next/standalone/src/relay/queue.ts +225 -0
- package/bin/failproofai.mjs +91 -4
- package/dist/cli.mjs +1155 -54
- package/package.json +1 -1
- package/src/auth/login.ts +104 -0
- package/src/auth/logout.ts +50 -0
- package/src/auth/token-store.ts +64 -0
- package/src/hooks/builtin-policies.ts +22 -20
- package/src/hooks/handler.ts +35 -15
- package/src/relay/daemon.ts +362 -0
- package/src/relay/pid.ts +76 -0
- package/src/relay/queue.ts +225 -0
- package/.next/standalone/.next/static/chunks/0ijk_kek9_wyx.js +0 -6
- /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → r-wX0MuAfCjbhJm3phQc8}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → r-wX0MuAfCjbhJm3phQc8}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{A9pNTZdoYJTVyPAYwQMx5 → r-wX0MuAfCjbhJm3phQc8}/_ssgManifest.js +0 -0
|
@@ -1,19 +1,19 @@
|
|
|
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 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.
|
|
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 en 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 en categorías:
|
|
14
14
|
|
|
15
15
|
| Categoría | Políticas | Tipo de hook |
|
|
16
|
-
|
|
16
|
+
|----------|----------|-----------|
|
|
17
17
|
| [Comandos peligrosos](#dangerous-commands) | block-sudo, block-rm-rf, block-curl-pipe-sh, block-failproofai-commands | PreToolUse |
|
|
18
18
|
| [Secretos (sanitizadores)](#secrets-sanitizers) | sanitize-jwt, sanitize-api-keys, sanitize-connection-strings, sanitize-private-key-content, sanitize-bearer-tokens | PostToolUse |
|
|
19
19
|
| [Entorno](#environment) | block-env-files, protect-env-vars | PreToolUse |
|
|
@@ -26,33 +26,33 @@ Las políticas están agrupadas por categorías:
|
|
|
26
26
|
|
|
27
27
|
- **`block-`** — impide que el agente continúe.
|
|
28
28
|
- **`warn-`** — proporciona contexto adicional al agente para que pueda corregirse.
|
|
29
|
-
- **`sanitize-`** — elimina datos sensibles de la salida de
|
|
29
|
+
- **`sanitize-`** — elimina datos sensibles de la salida de una herramienta antes de que el agente la vea.
|
|
30
30
|
- **`require-`** — bloquea el evento Stop hasta que se cumplan las condiciones.
|
|
31
31
|
|
|
32
32
|
---
|
|
33
33
|
|
|
34
34
|
<Tip>
|
|
35
|
-
Todas las políticas admiten un campo opcional `hint` en `policyParams`. El hint se
|
|
35
|
+
Todas las políticas admiten un campo opcional `hint` en `policyParams`. El hint se agrega al mensaje de deny o instruct que ve Claude, ofreciendo 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.
|
|
36
36
|
</Tip>
|
|
37
37
|
|
|
38
38
|
---
|
|
39
39
|
|
|
40
40
|
## Comandos peligrosos
|
|
41
41
|
|
|
42
|
-
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 anfitrión.
|
|
43
43
|
|
|
44
44
|
### `block-sudo`
|
|
45
45
|
|
|
46
46
|
**Evento:** PreToolUse (Bash)
|
|
47
|
-
**
|
|
47
|
+
**Comportamiento predeterminado:** Deniega cualquier comando `sudo`.
|
|
48
48
|
|
|
49
|
-
Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia de patrones se realiza sobre los tokens
|
|
49
|
+
Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia de patrones se realiza sobre los tokens de comando analizados, no sobre la cadena sin procesar, para evitar elusiones mediante inyección de operadores de shell.
|
|
50
50
|
|
|
51
51
|
**Parámetros:**
|
|
52
52
|
|
|
53
|
-
| Parámetro | Tipo |
|
|
54
|
-
|
|
55
|
-
| `allowPatterns` | `string[]` | `[]` | Prefijos de
|
|
53
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
54
|
+
|-------|------|---------|-------------|
|
|
55
|
+
| `allowPatterns` | `string[]` | `[]` | Prefijos de comandos exactos que están permitidos. Cada entrada se compara con los tokens argv analizados. |
|
|
56
56
|
|
|
57
57
|
**Ejemplo:**
|
|
58
58
|
|
|
@@ -69,7 +69,7 @@ Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia d
|
|
|
69
69
|
Con esta configuración, `sudo systemctl status nginx` está permitido, pero `sudo rm /etc/hosts` es denegado.
|
|
70
70
|
|
|
71
71
|
<Note>
|
|
72
|
-
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 de comando sin procesar. Esto evita elusiones mediante operadores de shell añadidos (p. ej., `sudo systemctl status x; rm -rf /` no coincide con `sudo systemctl status *`).
|
|
73
73
|
</Note>
|
|
74
74
|
|
|
75
75
|
---
|
|
@@ -77,13 +77,13 @@ Los patrones se comparan con los tokens analizados, no con la cadena del comando
|
|
|
77
77
|
### `block-rm-rf`
|
|
78
78
|
|
|
79
79
|
**Evento:** PreToolUse (Bash)
|
|
80
|
-
**
|
|
80
|
+
**Comportamiento predeterminado:** Deniega `rm -rf`, `rm -fr` y formas similares de eliminación recursiva.
|
|
81
81
|
|
|
82
82
|
**Parámetros:**
|
|
83
83
|
|
|
84
|
-
| Parámetro | Tipo |
|
|
85
|
-
|
|
86
|
-
| `allowPaths` | `string[]` | `[]` | Rutas donde
|
|
84
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
85
|
+
|-------|------|---------|-------------|
|
|
86
|
+
| `allowPaths` | `string[]` | `[]` | Rutas donde es seguro eliminar de forma recursiva (p. ej., `/tmp`). |
|
|
87
87
|
|
|
88
88
|
**Ejemplo:**
|
|
89
89
|
|
|
@@ -102,7 +102,7 @@ Los patrones se comparan con los tokens analizados, no con la cadena del comando
|
|
|
102
102
|
### `block-curl-pipe-sh`
|
|
103
103
|
|
|
104
104
|
**Evento:** PreToolUse (Bash)
|
|
105
|
-
**
|
|
105
|
+
**Comportamiento predeterminado:** Deniega `curl <url> | bash`, `curl <url> | sh`, `wget <url> | bash` y patrones similares.
|
|
106
106
|
|
|
107
107
|
Sin parámetros.
|
|
108
108
|
|
|
@@ -111,7 +111,7 @@ Sin parámetros.
|
|
|
111
111
|
### `block-failproofai-commands`
|
|
112
112
|
|
|
113
113
|
**Evento:** PreToolUse (Bash)
|
|
114
|
-
**
|
|
114
|
+
**Comportamiento predeterminado:** Deniega comandos que desinstalarían o desactivarían failproofai (p. ej., `npm uninstall failproofai`, `failproofai policies --uninstall`).
|
|
115
115
|
|
|
116
116
|
Sin parámetros.
|
|
117
117
|
|
|
@@ -119,12 +119,12 @@ Sin parámetros.
|
|
|
119
119
|
|
|
120
120
|
## Secretos (sanitizadores)
|
|
121
121
|
|
|
122
|
-
Evita que los agentes filtren credenciales en su contexto o salida. Las políticas
|
|
122
|
+
Evita que los agentes filtren credenciales en su contexto o salida. Las políticas de sanitización se activan en eventos **PostToolUse**. Cuando Claude ejecuta un comando Bash, lee un archivo o invoca 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 procesada.
|
|
123
123
|
|
|
124
124
|
### `sanitize-jwt`
|
|
125
125
|
|
|
126
126
|
**Evento:** PostToolUse (todas las herramientas)
|
|
127
|
-
**
|
|
127
|
+
**Comportamiento predeterminado:** Redacta tokens JWT (tres segmentos base64url separados por `.`).
|
|
128
128
|
|
|
129
129
|
Sin parámetros.
|
|
130
130
|
|
|
@@ -133,13 +133,13 @@ Sin parámetros.
|
|
|
133
133
|
### `sanitize-api-keys`
|
|
134
134
|
|
|
135
135
|
**Evento:** PostToolUse (todas las herramientas)
|
|
136
|
-
**
|
|
136
|
+
**Comportamiento predeterminado:** Redacta formatos comunes de claves API: Anthropic (`sk-ant-`), OpenAI (`sk-`), PATs de GitHub (`ghp_`), claves de acceso de AWS (`AKIA`), claves de Stripe (`sk_live_`, `sk_test_`) y claves de API de Google (`AIza`).
|
|
137
137
|
|
|
138
138
|
**Parámetros:**
|
|
139
139
|
|
|
140
|
-
| Parámetro | Tipo |
|
|
141
|
-
|
|
142
|
-
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones regex adicionales
|
|
140
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
141
|
+
|-------|------|---------|-------------|
|
|
142
|
+
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones regex adicionales para tratar como secretos. |
|
|
143
143
|
|
|
144
144
|
**Ejemplo:**
|
|
145
145
|
|
|
@@ -161,7 +161,7 @@ Sin parámetros.
|
|
|
161
161
|
### `sanitize-connection-strings`
|
|
162
162
|
|
|
163
163
|
**Evento:** PostToolUse (todas las herramientas)
|
|
164
|
-
**
|
|
164
|
+
**Comportamiento predeterminado:** Redacta cadenas de conexión a bases de datos que contienen credenciales embebidas (p. ej., `postgresql://user:password@host/db`).
|
|
165
165
|
|
|
166
166
|
Sin parámetros.
|
|
167
167
|
|
|
@@ -170,7 +170,7 @@ Sin parámetros.
|
|
|
170
170
|
### `sanitize-private-key-content`
|
|
171
171
|
|
|
172
172
|
**Evento:** PostToolUse (todas las herramientas)
|
|
173
|
-
**
|
|
173
|
+
**Comportamiento predeterminado:** Redacta bloques PEM (`-----BEGIN PRIVATE KEY-----`, `-----BEGIN RSA PRIVATE KEY-----`, etc.).
|
|
174
174
|
|
|
175
175
|
Sin parámetros.
|
|
176
176
|
|
|
@@ -179,7 +179,7 @@ Sin parámetros.
|
|
|
179
179
|
### `sanitize-bearer-tokens`
|
|
180
180
|
|
|
181
181
|
**Evento:** PostToolUse (todas las herramientas)
|
|
182
|
-
**
|
|
182
|
+
**Comportamiento predeterminado:** Redacta encabezados `Authorization: Bearer <token>` donde el token tiene 20 o más caracteres.
|
|
183
183
|
|
|
184
184
|
Sin parámetros.
|
|
185
185
|
|
|
@@ -192,9 +192,9 @@ Protege la configuración sensible del entorno para que los agentes no puedan le
|
|
|
192
192
|
### `block-env-files`
|
|
193
193
|
|
|
194
194
|
**Evento:** PreToolUse (Bash, Read)
|
|
195
|
-
**
|
|
195
|
+
**Comportamiento predeterminado:** Deniega la lectura de archivos `.env` mediante `cat .env`, llamadas a la herramienta `Read` con `.env` como ruta de archivo, etc.
|
|
196
196
|
|
|
197
|
-
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo archivos
|
|
197
|
+
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo archivos denominados exactamente `.env`.
|
|
198
198
|
|
|
199
199
|
Sin parámetros.
|
|
200
200
|
|
|
@@ -203,7 +203,7 @@ Sin parámetros.
|
|
|
203
203
|
### `protect-env-vars`
|
|
204
204
|
|
|
205
205
|
**Evento:** PreToolUse (Bash)
|
|
206
|
-
**
|
|
206
|
+
**Comportamiento predeterminado:** Deniega comandos que imprimen variables de entorno: `printenv`, `env`, `echo $VAR`.
|
|
207
207
|
|
|
208
208
|
Sin parámetros.
|
|
209
209
|
|
|
@@ -216,13 +216,13 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
216
216
|
### `block-read-outside-cwd`
|
|
217
217
|
|
|
218
218
|
**Evento:** PreToolUse (Read, Bash)
|
|
219
|
-
**
|
|
219
|
+
**Comportamiento predeterminado:** Deniega la lectura de archivos fuera del directorio de trabajo actual (la raíz del proyecto).
|
|
220
220
|
|
|
221
221
|
**Parámetros:**
|
|
222
222
|
|
|
223
|
-
| Parámetro | Tipo |
|
|
224
|
-
|
|
225
|
-
| `allowPaths` | `string[]` | `[]` | Prefijos de rutas absolutas permitidos aunque estén fuera del
|
|
223
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
224
|
+
|-------|------|---------|-------------|
|
|
225
|
+
| `allowPaths` | `string[]` | `[]` | Prefijos de rutas absolutas que están permitidos aunque estén fuera del cwd. |
|
|
226
226
|
|
|
227
227
|
**Ejemplo:**
|
|
228
228
|
|
|
@@ -241,13 +241,13 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
241
241
|
### `block-secrets-write`
|
|
242
242
|
|
|
243
243
|
**Evento:** PreToolUse (Write, Edit)
|
|
244
|
-
**
|
|
244
|
+
**Comportamiento predeterminado:** Deniega escrituras en archivos habitualmente usados para claves privadas y certificados: `id_rsa`, `id_ed25519`, `*.key`, `*.pem`, `*.p12`, `*.pfx`.
|
|
245
245
|
|
|
246
246
|
**Parámetros:**
|
|
247
247
|
|
|
248
|
-
| Parámetro | Tipo |
|
|
249
|
-
|
|
250
|
-
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob)
|
|
248
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
249
|
+
|-------|------|---------|-------------|
|
|
250
|
+
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob) que se deben bloquear. |
|
|
251
251
|
|
|
252
252
|
**Ejemplo:**
|
|
253
253
|
|
|
@@ -265,17 +265,17 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
265
265
|
|
|
266
266
|
## Git
|
|
267
267
|
|
|
268
|
-
Previene pushes accidentales, force-pushes y errores de rama difíciles de deshacer.
|
|
268
|
+
Previene pushes accidentales, force-pushes y errores de rama que son difíciles de deshacer.
|
|
269
269
|
|
|
270
270
|
### `block-push-master`
|
|
271
271
|
|
|
272
272
|
**Evento:** PreToolUse (Bash)
|
|
273
|
-
**
|
|
273
|
+
**Comportamiento predeterminado:** Deniega `git push origin main` y `git push origin master`.
|
|
274
274
|
|
|
275
275
|
**Parámetros:**
|
|
276
276
|
|
|
277
|
-
| Parámetro | Tipo |
|
|
278
|
-
|
|
277
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
278
|
+
|-------|------|---------|-------------|
|
|
279
279
|
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer push directamente. |
|
|
280
280
|
|
|
281
281
|
**Ejemplo:**
|
|
@@ -291,7 +291,7 @@ Previene pushes accidentales, force-pushes y errores de rama difíciles de desha
|
|
|
291
291
|
```
|
|
292
292
|
|
|
293
293
|
<Tip>
|
|
294
|
-
Para permitir push a todas las ramas (
|
|
294
|
+
Para permitir push a todas las ramas (desactivando efectivamente esta política sin eliminarla de `enabledPolicies`), establece `protectedBranches: []`.
|
|
295
295
|
</Tip>
|
|
296
296
|
|
|
297
297
|
---
|
|
@@ -299,12 +299,12 @@ Para permitir push a todas las ramas (deshabilitando efectivamente esta polític
|
|
|
299
299
|
### `block-work-on-main`
|
|
300
300
|
|
|
301
301
|
**Evento:** PreToolUse (Bash)
|
|
302
|
-
**
|
|
302
|
+
**Comportamiento predeterminado:** Deniega hacer checkout directamente de las ramas `main` o `master`.
|
|
303
303
|
|
|
304
304
|
**Parámetros:**
|
|
305
305
|
|
|
306
|
-
| Parámetro | Tipo |
|
|
307
|
-
|
|
306
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
307
|
+
|-------|------|---------|-------------|
|
|
308
308
|
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer checkout directamente. |
|
|
309
309
|
|
|
310
310
|
---
|
|
@@ -312,9 +312,9 @@ Para permitir push a todas las ramas (deshabilitando efectivamente esta polític
|
|
|
312
312
|
### `block-force-push`
|
|
313
313
|
|
|
314
314
|
**Evento:** PreToolUse (Bash)
|
|
315
|
-
**
|
|
315
|
+
**Comportamiento predeterminado:** Deniega `git push --force` y `git push -f`.
|
|
316
316
|
|
|
317
|
-
Sin parámetros específicos de política. Usa el
|
|
317
|
+
Sin parámetros específicos de la política. Usa el [`hint`](/es/configuration#hint-cross-cutting) transversal para sugerir alternativas:
|
|
318
318
|
|
|
319
319
|
```json
|
|
320
320
|
{
|
|
@@ -331,7 +331,7 @@ Sin parámetros específicos de política. Usa el campo transversal [`hint`](/es
|
|
|
331
331
|
### `warn-git-amend`
|
|
332
332
|
|
|
333
333
|
**Evento:** PreToolUse (Bash)
|
|
334
|
-
**
|
|
334
|
+
**Comportamiento predeterminado:** Indica a Claude que proceda con cuidado al ejecutar `git commit --amend`. No bloquea el comando.
|
|
335
335
|
|
|
336
336
|
Sin parámetros.
|
|
337
337
|
|
|
@@ -340,7 +340,7 @@ Sin parámetros.
|
|
|
340
340
|
### `warn-git-stash-drop`
|
|
341
341
|
|
|
342
342
|
**Evento:** PreToolUse (Bash)
|
|
343
|
-
**
|
|
343
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de ejecutar `git stash drop`. No bloquea el comando.
|
|
344
344
|
|
|
345
345
|
Sin parámetros.
|
|
346
346
|
|
|
@@ -349,7 +349,7 @@ Sin parámetros.
|
|
|
349
349
|
### `warn-all-files-staged`
|
|
350
350
|
|
|
351
351
|
**Evento:** PreToolUse (Bash)
|
|
352
|
-
**
|
|
352
|
+
**Comportamiento predeterminado:** Indica a Claude que revise lo que está añadiendo al área de preparación cuando ejecuta `git add -A` o `git add .`. No bloquea el comando.
|
|
353
353
|
|
|
354
354
|
Sin parámetros.
|
|
355
355
|
|
|
@@ -362,7 +362,7 @@ Detecta operaciones SQL destructivas antes de que se ejecuten contra tu base de
|
|
|
362
362
|
### `warn-destructive-sql`
|
|
363
363
|
|
|
364
364
|
**Evento:** PreToolUse (Bash)
|
|
365
|
-
**
|
|
365
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de ejecutar SQL que contenga `DROP TABLE`, `DROP DATABASE` o `DELETE` sin una cláusula `WHERE`.
|
|
366
366
|
|
|
367
367
|
Sin parámetros.
|
|
368
368
|
|
|
@@ -371,7 +371,7 @@ Sin parámetros.
|
|
|
371
371
|
### `warn-schema-alteration`
|
|
372
372
|
|
|
373
373
|
**Evento:** PreToolUse (Bash)
|
|
374
|
-
**
|
|
374
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de ejecutar sentencias `ALTER TABLE`.
|
|
375
375
|
|
|
376
376
|
Sin parámetros.
|
|
377
377
|
|
|
@@ -384,12 +384,12 @@ Proporciona contexto adicional a los agentes antes de operaciones potencialmente
|
|
|
384
384
|
### `warn-large-file-write`
|
|
385
385
|
|
|
386
386
|
**Evento:** PreToolUse (Write)
|
|
387
|
-
**
|
|
387
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de escribir archivos de más de 1024 KB.
|
|
388
388
|
|
|
389
389
|
**Parámetros:**
|
|
390
390
|
|
|
391
|
-
| Parámetro | Tipo |
|
|
392
|
-
|
|
391
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
392
|
+
|-------|------|---------|-------------|
|
|
393
393
|
| `thresholdKb` | `number` | `1024` | Umbral de tamaño de archivo en kilobytes a partir del cual se emite una advertencia. |
|
|
394
394
|
|
|
395
395
|
**Ejemplo:**
|
|
@@ -405,7 +405,7 @@ Proporciona contexto adicional a los agentes antes de operaciones potencialmente
|
|
|
405
405
|
```
|
|
406
406
|
|
|
407
407
|
<Note>
|
|
408
|
-
El manejador
|
|
408
|
+
El manejador de hooks impone un límite de 1 MB en stdin para los payloads. Para probar esta política con contenido pequeño, establece `thresholdKb` en un valor muy inferior a 1024.
|
|
409
409
|
</Note>
|
|
410
410
|
|
|
411
411
|
---
|
|
@@ -413,7 +413,7 @@ El manejador del hook impone un límite de 1 MB en stdin para los payloads. Para
|
|
|
413
413
|
### `warn-package-publish`
|
|
414
414
|
|
|
415
415
|
**Evento:** PreToolUse (Bash)
|
|
416
|
-
**
|
|
416
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de ejecutar `npm publish`.
|
|
417
417
|
|
|
418
418
|
Sin parámetros.
|
|
419
419
|
|
|
@@ -422,7 +422,7 @@ Sin parámetros.
|
|
|
422
422
|
### `warn-background-process`
|
|
423
423
|
|
|
424
424
|
**Evento:** PreToolUse (Bash)
|
|
425
|
-
**
|
|
425
|
+
**Comportamiento predeterminado:** Indica a Claude que tenga cuidado al lanzar procesos en segundo plano mediante `nohup`, `&`, `disown` o `screen`.
|
|
426
426
|
|
|
427
427
|
Sin parámetros.
|
|
428
428
|
|
|
@@ -431,7 +431,7 @@ Sin parámetros.
|
|
|
431
431
|
### `warn-global-package-install`
|
|
432
432
|
|
|
433
433
|
**Evento:** PreToolUse (Bash)
|
|
434
|
-
**
|
|
434
|
+
**Comportamiento predeterminado:** Indica a Claude que confirme antes de ejecutar `npm install -g`, `yarn global add` o `pip install` sin un entorno virtual.
|
|
435
435
|
|
|
436
436
|
Sin parámetros.
|
|
437
437
|
|
|
@@ -444,16 +444,16 @@ Impone qué gestores de paquetes puede utilizar el agente.
|
|
|
444
444
|
### `prefer-package-manager`
|
|
445
445
|
|
|
446
446
|
**Evento:** PreToolUse (Bash)
|
|
447
|
-
**
|
|
447
|
+
**Comportamiento predeterminado:** Desactivado. 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
448
|
|
|
449
449
|
Detecta: pip, pip3, python -m pip, npm, npx, yarn, pnpm, pnpx, bun, bunx, uv, poetry, pipenv, conda, cargo.
|
|
450
450
|
|
|
451
|
-
| Parámetro | Tipo |
|
|
452
|
-
|
|
453
|
-
| `allowed` | string[] | `[]` | Nombres de gestores de paquetes permitidos. Cualquier gestor detectado que no esté en esta lista
|
|
451
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
452
|
+
|-----------|------|---------|-------------|
|
|
453
|
+
| `allowed` | string[] | `[]` | Nombres de gestores de paquetes permitidos. Cualquier gestor detectado que no esté en esta lista es bloqueado. Cuando está vacío, la política no tiene efecto. |
|
|
454
454
|
| `blocked` | string[] | `[]` | Nombres de gestores adicionales a bloquear más allá de la lista integrada (p. ej., `['pdm', 'pipx']`). |
|
|
455
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
|
|
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
457
|
|
|
458
458
|
**Ejemplo de configuración:**
|
|
459
459
|
|
|
@@ -469,18 +469,18 @@ La lista de bloqueo integrada incluye: pip, pip3, npm, npx, yarn, pnpm, pnpx, bu
|
|
|
469
469
|
}
|
|
470
470
|
```
|
|
471
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
|
|
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` en su lugar. Comandos como `uv pip install flask` están permitidos porque `uv` está en la lista de permitidos y se verifica primero.
|
|
473
473
|
|
|
474
474
|
---
|
|
475
475
|
|
|
476
476
|
## Comportamiento de la IA
|
|
477
477
|
|
|
478
|
-
Detecta cuándo los agentes se quedan
|
|
478
|
+
Detecta cuándo los agentes se quedan bloqueados o se comportan de forma inesperada.
|
|
479
479
|
|
|
480
480
|
### `warn-repeated-tool-calls`
|
|
481
481
|
|
|
482
482
|
**Evento:** PreToolUse (todas las herramientas)
|
|
483
|
-
**
|
|
483
|
+
**Comportamiento predeterminado:** Indica a Claude que reconsidere cuando la misma herramienta se llama 3 o más veces con parámetros idénticos, lo cual es una señal habitual de que el agente está atascado en un bucle.
|
|
484
484
|
|
|
485
485
|
Sin parámetros.
|
|
486
486
|
|
|
@@ -488,14 +488,14 @@ Sin parámetros.
|
|
|
488
488
|
|
|
489
489
|
## Flujo de trabajo
|
|
490
490
|
|
|
491
|
-
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 deniegan a Claude la posibilidad de detenerse hasta que se cumpla cada condición. Siguen una cadena de dependencias natural: commit → push → PR → CI. Si una política deniega, las políticas posteriores en la cadena se omiten (la denegación interrumpe la cadena).
|
|
492
492
|
|
|
493
|
-
Todas las políticas de flujo de trabajo son **fail-open**: si la herramienta requerida no está disponible (p. ej., `gh` no instalado,
|
|
493
|
+
Todas las políticas de flujo de trabajo son **fail-open**: si la herramienta requerida no está disponible (p. ej., `gh` no está instalado, no hay remote de git), la política permite la operación con un mensaje informativo que explica por qué se omitió la verificación.
|
|
494
494
|
|
|
495
495
|
### `require-commit-before-stop`
|
|
496
496
|
|
|
497
497
|
**Evento:** Stop
|
|
498
|
-
**
|
|
498
|
+
**Comportamiento predeterminado:** Deniega la detención cuando hay cambios sin confirmar (archivos modificados, en el área de preparación o sin seguimiento). Devuelve un mensaje informativo cuando el directorio de trabajo está limpio.
|
|
499
499
|
|
|
500
500
|
Sin parámetros.
|
|
501
501
|
|
|
@@ -504,12 +504,12 @@ Sin parámetros.
|
|
|
504
504
|
### `require-push-before-stop`
|
|
505
505
|
|
|
506
506
|
**Evento:** Stop
|
|
507
|
-
**
|
|
507
|
+
**Comportamiento predeterminado:** Deniega la detención cuando hay commits sin enviar 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 un remote configurado.
|
|
508
508
|
|
|
509
509
|
**Parámetros:**
|
|
510
510
|
|
|
511
|
-
| Parámetro | Tipo |
|
|
512
|
-
|
|
511
|
+
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
512
|
+
|-------|------|---------|-------------|
|
|
513
513
|
| `remote` | `string` | `"origin"` | Nombre del remote al que hacer push. |
|
|
514
514
|
|
|
515
515
|
**Ejemplo:**
|
|
@@ -529,13 +529,13 @@ Sin parámetros.
|
|
|
529
529
|
### `require-pr-before-stop`
|
|
530
530
|
|
|
531
531
|
**Evento:** Stop
|
|
532
|
-
**
|
|
532
|
+
**Comportamiento predeterminado:** Deniega la detención cuando no existe ningún pull request para la rama actual, o cuando el PR existente está cerrado o fusionado. Indica a Claude que cree un PR con `gh pr create`.
|
|
533
533
|
|
|
534
534
|
Sin parámetros.
|
|
535
535
|
|
|
536
536
|
<Note>
|
|
537
537
|
Esta política requiere que [GitHub CLI](https://cli.github.com/) (`gh`) esté instalado y autenticado.
|
|
538
|
-
Ejecuta `gh auth login` con un token de acceso personal que tenga el
|
|
538
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga el ámbito `repo` para acceso de lectura a
|
|
539
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.
|
|
540
540
|
</Note>
|
|
541
541
|
|
|
@@ -544,23 +544,23 @@ pull requests. Si `gh` no está instalado o no está autenticado, la política f
|
|
|
544
544
|
### `require-ci-green-before-stop`
|
|
545
545
|
|
|
546
546
|
**Evento:** Stop
|
|
547
|
-
**
|
|
547
|
+
**Comportamiento predeterminado:** Deniega la detención cuando las verificaciones de CI están fallando o aún en ejecución en la rama actual. Comprueba tanto las ejecuciones de flujo de trabajo de GitHub Actions como las verificaciones de bots de terceros (p. ej., CodeRabbit, SonarCloud, Codecov). Trata las conclusiones `skipped` y `cancelled` como éxito. Devuelve un mensaje informativo cuando todas las verificaciones pasan.
|
|
548
548
|
|
|
549
549
|
Sin parámetros.
|
|
550
550
|
|
|
551
551
|
<Note>
|
|
552
552
|
Esta política requiere que [GitHub CLI](https://cli.github.com/) (`gh`) esté instalado y autenticado.
|
|
553
|
-
Ejecuta `gh auth login` con un token de acceso personal que tenga el
|
|
554
|
-
ejecuciones de
|
|
553
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga el ámbito `repo` para acceso de lectura a
|
|
554
|
+
ejecuciones de flujo 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.
|
|
555
555
|
</Note>
|
|
556
556
|
|
|
557
557
|
---
|
|
558
558
|
|
|
559
559
|
---
|
|
560
560
|
|
|
561
|
-
##
|
|
561
|
+
## Desactivar políticas individuales
|
|
562
562
|
|
|
563
|
-
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala
|
|
563
|
+
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala desde la pestaña Políticas del panel de control.
|
|
564
564
|
|
|
565
565
|
```json
|
|
566
566
|
{
|