failproofai 0.0.3 → 0.0.4
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]__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]__0bo8s~-._.js → [root-of-the-server]__0lty_fo._.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]__03kiqd5._.js → [root-of-the-server]__0v1egkj._.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/{03oepxbqx6o8~.js → 0b2_069x5qnxg.js} +2 -2
- package/.next/standalone/.next/static/chunks/{02t9.s735hqyq.js → 0de3q2juhg_dr.js} +1 -1
- package/.next/standalone/.next/static/chunks/{18cl6wups7ouq.js → 0p5sfob-upg0g.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0h5kbvg~.xf.v.js → 0tw_xfxb1tto..js} +1 -1
- package/.next/standalone/.next/static/chunks/{0od..umlku4bb.js → 0uxpbrcv44lga.js} +1 -1
- package/.next/standalone/.next/static/chunks/0xjz3w.yw5tza.js +1 -0
- package/.next/standalone/.next/static/chunks/{0xbwzy4dl87-0.js → 0y-bi_mp2rv4l.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0cwft44dh9bww.js → 11zlh73ggln0w.js} +1 -1
- package/.next/standalone/CHANGELOG.md +5 -0
- package/.next/standalone/dist/cli.mjs +4 -8
- package/.next/standalone/docs/ar/built-in-policies.mdx +100 -129
- package/.next/standalone/docs/ar/cli/install-policies.mdx +10 -11
- package/.next/standalone/docs/ar/cli/remove-policies.mdx +10 -12
- package/.next/standalone/docs/built-in-policies.mdx +3 -30
- package/.next/standalone/docs/cli/install-policies.mdx +0 -1
- package/.next/standalone/docs/cli/remove-policies.mdx +0 -1
- package/.next/standalone/docs/de/built-in-policies.mdx +65 -92
- package/.next/standalone/docs/de/cli/install-policies.mdx +3 -4
- package/.next/standalone/docs/de/cli/remove-policies.mdx +3 -4
- package/.next/standalone/docs/docs.json +5 -0
- package/.next/standalone/docs/es/built-in-policies.mdx +66 -93
- package/.next/standalone/docs/es/cli/install-policies.mdx +4 -5
- package/.next/standalone/docs/es/cli/remove-policies.mdx +4 -5
- package/.next/standalone/docs/fr/built-in-policies.mdx +83 -110
- package/.next/standalone/docs/fr/cli/install-policies.mdx +11 -12
- package/.next/standalone/docs/fr/cli/remove-policies.mdx +2 -3
- package/.next/standalone/docs/he/built-in-policies.mdx +131 -160
- package/.next/standalone/docs/he/cli/install-policies.mdx +14 -15
- package/.next/standalone/docs/he/cli/remove-policies.mdx +13 -14
- package/.next/standalone/docs/hi/built-in-policies.mdx +168 -197
- package/.next/standalone/docs/hi/cli/install-policies.mdx +10 -11
- package/.next/standalone/docs/hi/cli/remove-policies.mdx +13 -14
- package/.next/standalone/docs/it/built-in-policies.mdx +83 -110
- package/.next/standalone/docs/it/cli/install-policies.mdx +12 -13
- package/.next/standalone/docs/it/cli/remove-policies.mdx +5 -6
- package/.next/standalone/docs/ja/built-in-policies.mdx +119 -146
- package/.next/standalone/docs/ja/cli/install-policies.mdx +12 -13
- package/.next/standalone/docs/ja/cli/remove-policies.mdx +8 -9
- package/.next/standalone/docs/ko/built-in-policies.mdx +80 -107
- package/.next/standalone/docs/ko/cli/install-policies.mdx +10 -11
- package/.next/standalone/docs/ko/cli/remove-policies.mdx +2 -3
- package/.next/standalone/docs/pt-br/built-in-policies.mdx +46 -73
- package/.next/standalone/docs/pt-br/cli/install-policies.mdx +5 -6
- package/.next/standalone/docs/pt-br/cli/remove-policies.mdx +11 -12
- package/.next/standalone/docs/ru/built-in-policies.mdx +107 -132
- package/.next/standalone/docs/ru/cli/install-policies.mdx +10 -10
- package/.next/standalone/docs/ru/cli/remove-policies.mdx +13 -14
- package/.next/standalone/docs/tr/built-in-policies.mdx +106 -131
- package/.next/standalone/docs/tr/cli/install-policies.mdx +14 -15
- package/.next/standalone/docs/tr/cli/remove-policies.mdx +7 -8
- package/.next/standalone/docs/vi/built-in-policies.mdx +73 -100
- package/.next/standalone/docs/vi/cli/install-policies.mdx +17 -18
- package/.next/standalone/docs/vi/cli/remove-policies.mdx +11 -12
- package/.next/standalone/docs/zh/built-in-policies.mdx +77 -104
- package/.next/standalone/docs/zh/cli/install-policies.mdx +4 -5
- package/.next/standalone/docs/zh/cli/remove-policies.mdx +8 -9
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/server.js +1 -1
- package/.next/standalone/src/hooks/builtin-policies.ts +0 -4
- package/dist/cli.mjs +4 -8
- package/package.json +1 -1
- package/src/hooks/builtin-policies.ts +0 -4
- package/.next/standalone/.next/static/chunks/0e2uz2g026ckb.js +0 -1
- /package/.next/standalone/.next/static/{En9eEShUkUjgeYbY9v6Gy → LayjxQulxIcNH19Lqgjbf}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{En9eEShUkUjgeYbY9v6Gy → LayjxQulxIcNH19Lqgjbf}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{En9eEShUkUjgeYbY9v6Gy → LayjxQulxIcNH19Lqgjbf}/_ssgManifest.js +0 -0
|
@@ -4,16 +4,16 @@ description: "Las 30 políticas integradas que detectan los modos de fallo más
|
|
|
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 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
|
|
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 necesidad de escribir código. Cuatro políticas de flujo de trabajo imponen una secuencia 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 |
|
|
@@ -21,37 +21,37 @@ Las políticas están agrupadas por 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
|
-
| [Flujo de trabajo
|
|
24
|
+
| [Flujo de trabajo](#workflow) | require-commit-before-stop, require-push-before-stop, require-pr-before-stop, require-ci-green-before-stop | Stop |
|
|
25
25
|
|
|
26
26
|
- **`block-`** — impide que el agente continúe.
|
|
27
|
-
- **`warn-`** — proporciona contexto adicional
|
|
28
|
-
- **`sanitize-`** — elimina datos sensibles de la salida de
|
|
27
|
+
- **`warn-`** — proporciona al agente contexto adicional para que pueda corregirse.
|
|
28
|
+
- **`sanitize-`** — elimina datos sensibles de la salida de una herramienta antes de que el agente la reciba.
|
|
29
29
|
- **`require-`** — bloquea el evento Stop hasta que se cumplan las condiciones.
|
|
30
30
|
|
|
31
31
|
---
|
|
32
32
|
|
|
33
33
|
<Tip>
|
|
34
|
-
|
|
34
|
+
Toda política admite un campo opcional `hint` en `policyParams`. El hint se añade al mensaje deny o instruct que recibe Claude, ofreciendo orientación práctica sin necesidad de 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
35
|
</Tip>
|
|
36
36
|
|
|
37
37
|
---
|
|
38
38
|
|
|
39
39
|
## Comandos peligrosos
|
|
40
40
|
|
|
41
|
-
Evita que los agentes ejecuten operaciones difíciles de deshacer o que
|
|
41
|
+
Evita que los agentes ejecuten operaciones difíciles de deshacer o que puedan dañar el sistema anfitrión.
|
|
42
42
|
|
|
43
43
|
### `block-sudo`
|
|
44
44
|
|
|
45
45
|
**Evento:** PreToolUse (Bash)
|
|
46
46
|
**Comportamiento predeterminado:** Deniega cualquier comando `sudo`.
|
|
47
47
|
|
|
48
|
-
Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia de patrones se realiza sobre los tokens del comando
|
|
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 de texto sin procesar, para evitar eludir la política mediante inyección de operadores de shell.
|
|
49
49
|
|
|
50
50
|
**Parámetros:**
|
|
51
51
|
|
|
52
52
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
53
|
-
|
|
54
|
-
| `allowPatterns` | `string[]` | `[]` | Prefijos de
|
|
53
|
+
|-----------|------|----------------|-------------|
|
|
54
|
+
| `allowPatterns` | `string[]` | `[]` | Prefijos exactos de comandos que están permitidos. Cada entrada se compara con los tokens argv analizados. |
|
|
55
55
|
|
|
56
56
|
**Ejemplo:**
|
|
57
57
|
|
|
@@ -65,10 +65,10 @@ Bloquea las invocaciones que incluyen la palabra clave `sudo`. La coincidencia d
|
|
|
65
65
|
}
|
|
66
66
|
```
|
|
67
67
|
|
|
68
|
-
Con esta configuración, `sudo systemctl status nginx` está permitido, pero `sudo rm /etc/hosts`
|
|
68
|
+
Con esta configuración, `sudo systemctl status nginx` está permitido, pero `sudo rm /etc/hosts` está denegado.
|
|
69
69
|
|
|
70
70
|
<Note>
|
|
71
|
-
Los patrones se comparan con los tokens
|
|
71
|
+
Los patrones se comparan con los tokens analizados, no con la cadena de comandos sin procesar. Esto evita eludir la política mediante operadores de shell añadidos (por ejemplo, `sudo systemctl status x; rm -rf /` no coincide con `sudo systemctl status *`).
|
|
72
72
|
</Note>
|
|
73
73
|
|
|
74
74
|
---
|
|
@@ -81,8 +81,8 @@ Los patrones se comparan con los tokens parseados, no con la cadena de comando s
|
|
|
81
81
|
**Parámetros:**
|
|
82
82
|
|
|
83
83
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
84
|
-
|
|
85
|
-
| `allowPaths` | `string[]` | `[]` | Rutas
|
|
84
|
+
|-----------|------|----------------|-------------|
|
|
85
|
+
| `allowPaths` | `string[]` | `[]` | Rutas en las que es seguro realizar una eliminación recursiva (p. ej. `/tmp`). |
|
|
86
86
|
|
|
87
87
|
**Ejemplo:**
|
|
88
88
|
|
|
@@ -110,7 +110,7 @@ Sin parámetros.
|
|
|
110
110
|
### `block-failproofai-commands`
|
|
111
111
|
|
|
112
112
|
**Evento:** PreToolUse (Bash)
|
|
113
|
-
**Comportamiento predeterminado:** Deniega comandos que desinstalarían o
|
|
113
|
+
**Comportamiento predeterminado:** Deniega comandos que desinstalarían o desactivarían failproofai (p. ej. `npm uninstall failproofai`, `failproofai policies --uninstall`).
|
|
114
114
|
|
|
115
115
|
Sin parámetros.
|
|
116
116
|
|
|
@@ -118,7 +118,7 @@ Sin parámetros.
|
|
|
118
118
|
|
|
119
119
|
## Secretos (sanitizadores)
|
|
120
120
|
|
|
121
|
-
Evita que los agentes filtren credenciales en su contexto o salida. Las políticas
|
|
121
|
+
Evita que los agentes filtren credenciales en su contexto o en la 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 denegación que impide que la salida sea enviada de vuelta.
|
|
122
122
|
|
|
123
123
|
### `sanitize-jwt`
|
|
124
124
|
|
|
@@ -132,13 +132,13 @@ Sin parámetros.
|
|
|
132
132
|
### `sanitize-api-keys`
|
|
133
133
|
|
|
134
134
|
**Evento:** PostToolUse (todas las herramientas)
|
|
135
|
-
**Comportamiento predeterminado:** Redacta formatos
|
|
135
|
+
**Comportamiento predeterminado:** Redacta los formatos de clave API más comunes: 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`).
|
|
136
136
|
|
|
137
137
|
**Parámetros:**
|
|
138
138
|
|
|
139
139
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
140
|
-
|
|
141
|
-
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones
|
|
140
|
+
|-----------|------|----------------|-------------|
|
|
141
|
+
| `additionalPatterns` | `{ regex: string; label: string }[]` | `[]` | Patrones de expresiones regulares adicionales que deben tratarse como secretos. |
|
|
142
142
|
|
|
143
143
|
**Ejemplo:**
|
|
144
144
|
|
|
@@ -160,7 +160,7 @@ Sin parámetros.
|
|
|
160
160
|
### `sanitize-connection-strings`
|
|
161
161
|
|
|
162
162
|
**Evento:** PostToolUse (todas las herramientas)
|
|
163
|
-
**Comportamiento predeterminado:** Redacta cadenas de conexión a bases de datos que contienen credenciales embebidas (p. ej
|
|
163
|
+
**Comportamiento predeterminado:** Redacta cadenas de conexión a bases de datos que contienen credenciales embebidas (p. ej. `postgresql://user:password@host/db`).
|
|
164
164
|
|
|
165
165
|
Sin parámetros.
|
|
166
166
|
|
|
@@ -178,7 +178,7 @@ Sin parámetros.
|
|
|
178
178
|
### `sanitize-bearer-tokens`
|
|
179
179
|
|
|
180
180
|
**Evento:** PostToolUse (todas las herramientas)
|
|
181
|
-
**Comportamiento predeterminado:** Redacta
|
|
181
|
+
**Comportamiento predeterminado:** Redacta cabeceras `Authorization: Bearer <token>` cuando el token tiene 20 o más caracteres.
|
|
182
182
|
|
|
183
183
|
Sin parámetros.
|
|
184
184
|
|
|
@@ -186,14 +186,14 @@ Sin parámetros.
|
|
|
186
186
|
|
|
187
187
|
## Entorno
|
|
188
188
|
|
|
189
|
-
Protege la configuración
|
|
189
|
+
Protege la configuración sensible del entorno para que los agentes no puedan leerla ni exponerla.
|
|
190
190
|
|
|
191
191
|
### `block-env-files`
|
|
192
192
|
|
|
193
193
|
**Evento:** PreToolUse (Bash, Read)
|
|
194
194
|
**Comportamiento predeterminado:** Deniega la lectura de archivos `.env` mediante `cat .env`, llamadas a la herramienta `Read` con `.env` como ruta de archivo, etc.
|
|
195
195
|
|
|
196
|
-
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo bloquea archivos
|
|
196
|
+
No bloquea `.envrc` ni otros archivos relacionados con el entorno; solo bloquea archivos con el nombre exacto `.env`.
|
|
197
197
|
|
|
198
198
|
Sin parámetros.
|
|
199
199
|
|
|
@@ -220,8 +220,8 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
220
220
|
**Parámetros:**
|
|
221
221
|
|
|
222
222
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
223
|
-
|
|
224
|
-
| `allowPaths` | `string[]` | `[]` | Prefijos de
|
|
223
|
+
|-----------|------|----------------|-------------|
|
|
224
|
+
| `allowPaths` | `string[]` | `[]` | Prefijos de rutas absolutas que están permitidos aunque estén fuera del directorio de trabajo actual. |
|
|
225
225
|
|
|
226
226
|
**Ejemplo:**
|
|
227
227
|
|
|
@@ -240,13 +240,13 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
240
240
|
### `block-secrets-write`
|
|
241
241
|
|
|
242
242
|
**Evento:** PreToolUse (Write, Edit)
|
|
243
|
-
**Comportamiento predeterminado:** Deniega escrituras en archivos
|
|
243
|
+
**Comportamiento predeterminado:** Deniega escrituras en archivos habitualmente usados para claves privadas y certificados: `id_rsa`, `id_ed25519`, `*.key`, `*.pem`, `*.p12`, `*.pfx`.
|
|
244
244
|
|
|
245
245
|
**Parámetros:**
|
|
246
246
|
|
|
247
247
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
248
|
-
|
|
249
|
-
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob)
|
|
248
|
+
|-----------|------|----------------|-------------|
|
|
249
|
+
| `additionalPatterns` | `string[]` | `[]` | Patrones de nombre de archivo adicionales (estilo glob) que se deben bloquear. |
|
|
250
250
|
|
|
251
251
|
**Ejemplo:**
|
|
252
252
|
|
|
@@ -264,7 +264,7 @@ Mantiene a los agentes trabajando dentro de los límites del proyecto y alejados
|
|
|
264
264
|
|
|
265
265
|
## Git
|
|
266
266
|
|
|
267
|
-
|
|
267
|
+
Evita pushes accidentales, force-pushes y errores de rama difíciles de deshacer.
|
|
268
268
|
|
|
269
269
|
### `block-push-master`
|
|
270
270
|
|
|
@@ -274,7 +274,7 @@ Previene pushes accidentales, force-pushes y errores de rama que son difíciles
|
|
|
274
274
|
**Parámetros:**
|
|
275
275
|
|
|
276
276
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
277
|
-
|
|
277
|
+
|-----------|------|----------------|-------------|
|
|
278
278
|
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer push directamente. |
|
|
279
279
|
|
|
280
280
|
**Ejemplo:**
|
|
@@ -290,7 +290,7 @@ Previene pushes accidentales, force-pushes y errores de rama que son difíciles
|
|
|
290
290
|
```
|
|
291
291
|
|
|
292
292
|
<Tip>
|
|
293
|
-
Para permitir el push a todas las ramas (
|
|
293
|
+
Para permitir el push a todas las ramas (desactivando efectivamente esta política sin eliminarla de `enabledPolicies`), establece `protectedBranches: []`.
|
|
294
294
|
</Tip>
|
|
295
295
|
|
|
296
296
|
---
|
|
@@ -298,13 +298,13 @@ Para permitir el push a todas las ramas (deshabilitando esta política sin elimi
|
|
|
298
298
|
### `block-work-on-main`
|
|
299
299
|
|
|
300
300
|
**Evento:** PreToolUse (Bash)
|
|
301
|
-
**Comportamiento predeterminado:** Deniega hacer checkout directamente
|
|
301
|
+
**Comportamiento predeterminado:** Deniega hacer checkout directamente en las ramas `main` o `master`.
|
|
302
302
|
|
|
303
303
|
**Parámetros:**
|
|
304
304
|
|
|
305
305
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
306
|
-
|
|
307
|
-
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas que no
|
|
306
|
+
|-----------|------|----------------|-------------|
|
|
307
|
+
| `protectedBranches` | `string[]` | `["main", "master"]` | Nombres de ramas a las que no se puede hacer checkout directamente. |
|
|
308
308
|
|
|
309
309
|
---
|
|
310
310
|
|
|
@@ -313,7 +313,7 @@ Para permitir el push a todas las ramas (deshabilitando esta política sin elimi
|
|
|
313
313
|
**Evento:** PreToolUse (Bash)
|
|
314
314
|
**Comportamiento predeterminado:** Deniega `git push --force` y `git push -f`.
|
|
315
315
|
|
|
316
|
-
Sin parámetros específicos de
|
|
316
|
+
Sin parámetros específicos de política. Usa el campo transversal [`hint`](/es/configuration#hint-cross-cutting) para sugerir alternativas:
|
|
317
317
|
|
|
318
318
|
```json
|
|
319
319
|
{
|
|
@@ -330,7 +330,7 @@ Sin parámetros específicos de la política. Usa el [`hint`](/es/configuration#
|
|
|
330
330
|
### `warn-git-amend`
|
|
331
331
|
|
|
332
332
|
**Evento:** PreToolUse (Bash)
|
|
333
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
333
|
+
**Comportamiento predeterminado:** Instruye a Claude para que proceda con cuidado al ejecutar `git commit --amend`. No bloquea el comando.
|
|
334
334
|
|
|
335
335
|
Sin parámetros.
|
|
336
336
|
|
|
@@ -339,7 +339,7 @@ Sin parámetros.
|
|
|
339
339
|
### `warn-git-stash-drop`
|
|
340
340
|
|
|
341
341
|
**Evento:** PreToolUse (Bash)
|
|
342
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
342
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de ejecutar `git stash drop`. No bloquea el comando.
|
|
343
343
|
|
|
344
344
|
Sin parámetros.
|
|
345
345
|
|
|
@@ -348,7 +348,7 @@ Sin parámetros.
|
|
|
348
348
|
### `warn-all-files-staged`
|
|
349
349
|
|
|
350
350
|
**Evento:** PreToolUse (Bash)
|
|
351
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
351
|
+
**Comportamiento predeterminado:** Instruye a Claude para que revise lo que está añadiendo al área de staging cuando ejecuta `git add -A` o `git add .`. No bloquea el comando.
|
|
352
352
|
|
|
353
353
|
Sin parámetros.
|
|
354
354
|
|
|
@@ -361,7 +361,7 @@ Detecta operaciones SQL destructivas antes de que se ejecuten contra tu base de
|
|
|
361
361
|
### `warn-destructive-sql`
|
|
362
362
|
|
|
363
363
|
**Evento:** PreToolUse (Bash)
|
|
364
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
364
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de ejecutar SQL que contenga `DROP TABLE`, `DROP DATABASE` o `DELETE` sin cláusula `WHERE`.
|
|
365
365
|
|
|
366
366
|
Sin parámetros.
|
|
367
367
|
|
|
@@ -370,7 +370,7 @@ Sin parámetros.
|
|
|
370
370
|
### `warn-schema-alteration`
|
|
371
371
|
|
|
372
372
|
**Evento:** PreToolUse (Bash)
|
|
373
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
373
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de ejecutar sentencias `ALTER TABLE`.
|
|
374
374
|
|
|
375
375
|
Sin parámetros.
|
|
376
376
|
|
|
@@ -378,17 +378,17 @@ Sin parámetros.
|
|
|
378
378
|
|
|
379
379
|
## Advertencias
|
|
380
380
|
|
|
381
|
-
Proporciona
|
|
381
|
+
Proporciona a los agentes contexto adicional antes de operaciones potencialmente arriesgadas pero no destructivas.
|
|
382
382
|
|
|
383
383
|
### `warn-large-file-write`
|
|
384
384
|
|
|
385
385
|
**Evento:** PreToolUse (Write)
|
|
386
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
386
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de escribir archivos de más de 1024 KB.
|
|
387
387
|
|
|
388
388
|
**Parámetros:**
|
|
389
389
|
|
|
390
390
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
391
|
-
|
|
391
|
+
|-----------|------|----------------|-------------|
|
|
392
392
|
| `thresholdKb` | `number` | `1024` | Umbral de tamaño de archivo en kilobytes a partir del cual se emite una advertencia. |
|
|
393
393
|
|
|
394
394
|
**Ejemplo:**
|
|
@@ -404,7 +404,7 @@ Proporciona contexto adicional a los agentes antes de operaciones potencialmente
|
|
|
404
404
|
```
|
|
405
405
|
|
|
406
406
|
<Note>
|
|
407
|
-
El manejador de hooks
|
|
407
|
+
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` con un valor bastante inferior a 1024.
|
|
408
408
|
</Note>
|
|
409
409
|
|
|
410
410
|
---
|
|
@@ -412,7 +412,7 @@ El manejador de hooks aplica un límite de 1 MB en stdin para los payloads. Para
|
|
|
412
412
|
### `warn-package-publish`
|
|
413
413
|
|
|
414
414
|
**Evento:** PreToolUse (Bash)
|
|
415
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
415
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de ejecutar `npm publish`.
|
|
416
416
|
|
|
417
417
|
Sin parámetros.
|
|
418
418
|
|
|
@@ -421,7 +421,7 @@ Sin parámetros.
|
|
|
421
421
|
### `warn-background-process`
|
|
422
422
|
|
|
423
423
|
**Evento:** PreToolUse (Bash)
|
|
424
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
424
|
+
**Comportamiento predeterminado:** Instruye a Claude para que tenga cuidado al lanzar procesos en segundo plano mediante `nohup`, `&`, `disown` o `screen`.
|
|
425
425
|
|
|
426
426
|
Sin parámetros.
|
|
427
427
|
|
|
@@ -430,35 +430,35 @@ Sin parámetros.
|
|
|
430
430
|
### `warn-global-package-install`
|
|
431
431
|
|
|
432
432
|
**Evento:** PreToolUse (Bash)
|
|
433
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
433
|
+
**Comportamiento predeterminado:** Instruye a Claude para que confirme antes de ejecutar `npm install -g`, `yarn global add` o `pip install` sin un entorno virtual.
|
|
434
434
|
|
|
435
435
|
Sin parámetros.
|
|
436
436
|
|
|
437
437
|
---
|
|
438
438
|
|
|
439
|
-
## Comportamiento de IA
|
|
439
|
+
## Comportamiento de la IA
|
|
440
440
|
|
|
441
|
-
Detecta
|
|
441
|
+
Detecta cuándo los agentes se quedan bloqueados o se comportan de forma inesperada.
|
|
442
442
|
|
|
443
443
|
### `warn-repeated-tool-calls`
|
|
444
444
|
|
|
445
445
|
**Evento:** PreToolUse (todas las herramientas)
|
|
446
|
-
**Comportamiento predeterminado:** Instruye a Claude
|
|
446
|
+
**Comportamiento predeterminado:** Instruye a Claude para 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á atrapado en un bucle.
|
|
447
447
|
|
|
448
448
|
Sin parámetros.
|
|
449
449
|
|
|
450
450
|
---
|
|
451
451
|
|
|
452
|
-
## Flujo de trabajo
|
|
452
|
+
## Flujo de trabajo
|
|
453
453
|
|
|
454
|
-
|
|
454
|
+
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 de la cadena se omiten (la denegación provoca un cortocircuito).
|
|
455
455
|
|
|
456
|
-
Todas las políticas de flujo de trabajo son **fail-open**: si la herramienta requerida no está disponible (p. ej
|
|
456
|
+
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 continuar con un mensaje informativo que explica por qué se omitió la verificación.
|
|
457
457
|
|
|
458
458
|
### `require-commit-before-stop`
|
|
459
459
|
|
|
460
460
|
**Evento:** Stop
|
|
461
|
-
**Comportamiento predeterminado:** Deniega la detención cuando hay cambios sin confirmar (archivos modificados, en
|
|
461
|
+
**Comportamiento predeterminado:** Deniega la detención cuando hay cambios sin confirmar (archivos modificados, en staging o sin seguimiento). Devuelve un mensaje informativo cuando el directorio de trabajo está limpio.
|
|
462
462
|
|
|
463
463
|
Sin parámetros.
|
|
464
464
|
|
|
@@ -467,12 +467,12 @@ Sin parámetros.
|
|
|
467
467
|
### `require-push-before-stop`
|
|
468
468
|
|
|
469
469
|
**Evento:** Stop
|
|
470
|
-
**Comportamiento predeterminado:** Deniega la detención cuando hay commits sin enviar o cuando la rama actual no tiene rama de seguimiento
|
|
470
|
+
**Comportamiento predeterminado:** Deniega la detención cuando hay commits sin enviar o cuando la rama actual no tiene rama de seguimiento remota. Sugiere `git push -u` para crear una rama de seguimiento si es necesario. Es fail-open si no hay ningún remote configurado.
|
|
471
471
|
|
|
472
472
|
**Parámetros:**
|
|
473
473
|
|
|
474
474
|
| Parámetro | Tipo | Predeterminado | Descripción |
|
|
475
|
-
|
|
475
|
+
|-----------|------|----------------|-------------|
|
|
476
476
|
| `remote` | `string` | `"origin"` | Nombre del remote al que hacer push. |
|
|
477
477
|
|
|
478
478
|
**Ejemplo:**
|
|
@@ -492,14 +492,14 @@ Sin parámetros.
|
|
|
492
492
|
### `require-pr-before-stop`
|
|
493
493
|
|
|
494
494
|
**Evento:** Stop
|
|
495
|
-
**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
|
|
495
|
+
**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 ya fue mergeado. Instruye a Claude para que cree un PR con `gh pr create`.
|
|
496
496
|
|
|
497
497
|
Sin parámetros.
|
|
498
498
|
|
|
499
499
|
<Note>
|
|
500
500
|
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
|
|
501
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga alcance `repo` para acceso de lectura a
|
|
502
|
+
pull requests. Si `gh` no está instalado o no está autenticado, la política es fail-open e informa del motivo a Claude.
|
|
503
503
|
</Note>
|
|
504
504
|
|
|
505
505
|
---
|
|
@@ -507,50 +507,23 @@ pull requests. Si `gh` no está instalado o no está autenticado, la política f
|
|
|
507
507
|
### `require-ci-green-before-stop`
|
|
508
508
|
|
|
509
509
|
**Evento:** Stop
|
|
510
|
-
**Comportamiento predeterminado:** Deniega la detención cuando las verificaciones de CI están fallando o
|
|
510
|
+
**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 flujos de trabajo de GitHub Actions como las verificaciones de bots de terceros (p. ej. CodeRabbit, SonarCloud, Codecov). Trata las conclusiones `skipped` como éxito. Devuelve un mensaje informativo cuando todas las verificaciones pasan.
|
|
511
511
|
|
|
512
512
|
Sin parámetros.
|
|
513
513
|
|
|
514
514
|
<Note>
|
|
515
515
|
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
|
-
ejecuciones de flujos de trabajo de Actions y la API de Checks. Si `gh` no está instalado o no está autenticado, la política
|
|
516
|
+
Ejecuta `gh auth login` con un token de acceso personal que tenga alcance `repo` para acceso de lectura a
|
|
517
|
+
las ejecuciones de flujos de trabajo de Actions y la API de Checks. Si `gh` no está instalado o no está autenticado, la política es fail-open e informa del motivo a Claude.
|
|
518
518
|
</Note>
|
|
519
519
|
|
|
520
520
|
---
|
|
521
521
|
|
|
522
|
-
## Políticas beta
|
|
523
|
-
|
|
524
|
-
Algunas políticas están marcadas como `beta` y no se instalan por defecto. Las políticas beta pueden tener aristas imperfectas o generar falsos positivos. Pasan a estable en versiones futuras.
|
|
525
|
-
|
|
526
|
-
**Políticas beta actuales:**
|
|
527
|
-
|
|
528
|
-
- `require-commit-before-stop` — confirmar todos los cambios antes de detenerse
|
|
529
|
-
- `require-push-before-stop` — enviar todos los commits al remote
|
|
530
|
-
- `require-pr-before-stop` — asegurar que existe un PR para la rama
|
|
531
|
-
- `require-ci-green-before-stop` — todas las verificaciones de CI deben pasar
|
|
532
|
-
|
|
533
|
-
En conjunto, estas hacen cumplir un flujo de trabajo de **commit → push → PR → CI**.
|
|
534
|
-
|
|
535
|
-
Para instalar todas las políticas beta:
|
|
536
|
-
|
|
537
|
-
```bash
|
|
538
|
-
failproofai policies --install --beta
|
|
539
|
-
```
|
|
540
|
-
|
|
541
|
-
O instalar políticas de flujo de trabajo específicas:
|
|
542
|
-
|
|
543
|
-
```bash
|
|
544
|
-
failproofai policies --install require-commit-before-stop require-push-before-stop require-pr-before-stop require-ci-green-before-stop
|
|
545
|
-
```
|
|
546
|
-
|
|
547
|
-
Ejecuta `failproofai policies` para ver qué políticas llevan el indicador beta.
|
|
548
|
-
|
|
549
522
|
---
|
|
550
523
|
|
|
551
|
-
##
|
|
524
|
+
## Desactivar políticas individuales
|
|
552
525
|
|
|
553
|
-
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala en la pestaña Políticas del
|
|
526
|
+
Elimina una política específica de `enabledPolicies` en tu configuración, o desactívala en la pestaña Políticas del dashboard.
|
|
554
527
|
|
|
555
528
|
```json
|
|
556
529
|
{
|
|
@@ -561,4 +534,4 @@ Elimina una política específica de `enabledPolicies` en tu configuración, o d
|
|
|
561
534
|
}
|
|
562
535
|
```
|
|
563
536
|
|
|
564
|
-
Las políticas que no
|
|
537
|
+
Las políticas que no aparecen en `enabledPolicies` no se ejecutan, aunque existan entradas en `policyParams` para ellas.
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
---
|
|
2
2
|
title: Instalar políticas
|
|
3
|
-
description: "Habilita políticas para que se ejecuten en cada llamada
|
|
3
|
+
description: "Habilita políticas para que se ejecuten en cada llamada de herramienta del agente"
|
|
4
4
|
---
|
|
5
5
|
|
|
6
6
|
```bash
|
|
7
7
|
failproofai policies --install [policy-names...] [options]
|
|
8
8
|
```
|
|
9
9
|
|
|
10
|
-
Escribe entradas de hook en el
|
|
10
|
+
Escribe entradas de hook en el `settings.json` de Claude Code para que failproofai intercepte las llamadas de herramienta.
|
|
11
11
|
|
|
12
12
|
Alias: `failproofai p -i`
|
|
13
13
|
|
|
@@ -19,7 +19,6 @@ Alias: `failproofai p -i`
|
|
|
19
19
|
| `--scope project` | Instala en `.claude/settings.json` en el directorio actual |
|
|
20
20
|
| `--scope local` | Instala en `.claude/settings.local.json` en el directorio actual |
|
|
21
21
|
| `--custom <path>` / `-c` | Ruta a un archivo JS que contiene políticas de hook personalizadas |
|
|
22
|
-
| `--beta` | Incluye políticas en fase beta |
|
|
23
22
|
|
|
24
23
|
## Comportamiento
|
|
25
24
|
|
|
@@ -32,7 +31,7 @@ La instalación es acumulativa: ejecutar `--install` nuevamente agrega nuevas po
|
|
|
32
31
|
## Ejemplos
|
|
33
32
|
|
|
34
33
|
```bash
|
|
35
|
-
# Instalar todas las políticas predeterminadas
|
|
34
|
+
# Instalar todas las políticas predeterminadas globalmente (interactivo)
|
|
36
35
|
failproofai policies --install
|
|
37
36
|
|
|
38
37
|
# Instalar políticas específicas para el proyecto actual
|
|
@@ -45,4 +44,4 @@ failproofai policies --install all
|
|
|
45
44
|
failproofai policies --install --custom ./my-policies.js
|
|
46
45
|
```
|
|
47
46
|
|
|
48
|
-
Cuando se proporciona `--custom <path>`, el archivo se valida de inmediato
|
|
47
|
+
Cuando se proporciona `--custom <path>`, el archivo se valida de inmediato: debe llamar a `customPolicies.add()` al menos una vez. La ruta resuelta se guarda en `policies-config.json` como `customPoliciesPath`.
|
|
@@ -19,18 +19,17 @@ Alias: `failproofai p -u`
|
|
|
19
19
|
| `--scope project` | Eliminar de la configuración del proyecto |
|
|
20
20
|
| `--scope local` | Eliminar de la configuración local |
|
|
21
21
|
| `--scope all` | Eliminar de todos los ámbitos a la vez |
|
|
22
|
-
| `--custom` / `-c` | Limpiar
|
|
23
|
-
| `--beta` | Eliminar solo las políticas beta de la configuración |
|
|
22
|
+
| `--custom` / `-c` | Limpiar `customPoliciesPath` de la configuración |
|
|
24
23
|
|
|
25
24
|
## Comportamiento
|
|
26
25
|
|
|
27
|
-
- **Sin nombres de política**
|
|
28
|
-
- **Nombres específicos**
|
|
26
|
+
- **Sin nombres de política** — elimina todas las entradas de hooks de failproofai del archivo de configuración
|
|
27
|
+
- **Nombres específicos** — deshabilita esas políticas pero mantiene los hooks instalados
|
|
29
28
|
|
|
30
29
|
## Ejemplos
|
|
31
30
|
|
|
32
31
|
```bash
|
|
33
|
-
# Eliminar todos los hooks
|
|
32
|
+
# Eliminar todos los hooks globalmente
|
|
34
33
|
failproofai policies --uninstall
|
|
35
34
|
|
|
36
35
|
# Deshabilitar una política específica (mantiene los hooks instalados)
|