Overview
Usesettings.yaml to control what Poolside agents can do when you run pool or pool exec.
For a complete reference of supported settings keys, see Settings file reference.
You can use settings.yaml to:
- Allow or block specific tools
- Automatically approve or deny certain tool calls
- Limit which files agents can read or modify
- Run agents inside a local sandbox with stronger runtime boundaries
Main controls in settings.yaml
Most users interact with three configuration areas. Other supported settings include personal MCP server configuration, secret rules, prompt defaults, and API connection settings. For the full schema, see Settings file reference.| Setting | Purpose |
|---|---|
tools | Turn tools off or define auto-approval rules |
paths | Restrict which files the agent can read or modify |
sandbox | Run agents inside an isolated runtime environment |
- Tools decide what actions the agent can attempt.
- Paths decide which files the agent can access through file tools.
- Sandbox defines where the agent runs.
tools and paths mainly control approvals and explicit file operations. They do not fully sandbox the agent. If you need an enforced runtime boundary, use a sandbox.The shell tool
Treat theshell tool as high risk. Shell commands can:
- Install software
- Modify files
- Run scripts
shell may read or modify files outside the restrictions defined in paths.
If you need strict file access controls, turn off shell or run agents inside a sandbox.
File locations
Poolside readssettings.yaml from three locations.
| File location | Use this for |
|---|---|
.poolside/settings.local.yaml | Personal, project-specific. Do not commit. Takes precedence over all other files. |
.poolside/settings.yaml | Shared, project-specific. Commit and share with your team. |
~/.config/poolside/settings.yaml | Personal defaults (all projects). Applies when no project-level settings override it. |
.poolside/settings.local.yaml.poolside/settings.yaml~/.config/poolside/settings.yaml
~/.config/poolside/settings.yaml for personal defaults across all projects. Use .poolside/settings.local.yaml for personal, project-specific restrictions. Use .poolside/settings.yaml for shared project defaults.
For example settings files for each location, see Settings file reference.
Approvals
Approvals let you automatically allow or deny specific tool calls, which reduces repeated confirmation prompts when you trust certain operations. Rules:- If a tool call does not match an
allowrule, Poolside asks for approval. denyrules always overrideallow.
Command-line approvals
Inpool, tool calls require approval unless a matching allow rule exists in settings.yaml.
To run pool exec without approval prompts, use --unsafe-auto-allow:
--unsafe-auto-allow is set:
- Tool calls run without prompts.
- Deny rules still apply.
Tool rules
Usetools to turn tools off or configure approval rules. File access tools such as read and edit are controlled by paths, not tools.
Tools example
- Tool rules support only
*wildcards.**is not supported. - The rule string must match the tool call shown in the approval prompt.
- Subshells and composite shell commands always require manual approval.
- Shell commands that use control operators such as
|are not supported by auto-approval.
Path rules
Usepaths to control which files agents can access through explicit file tools.
Paths example for .poolside/settings.local.yaml or ~/.config/poolside/settings.yaml
- Poolside treats paths as read-only by default.
write: trueallows edits, deletes, moves, and renames.denyoverridesallow.- Path patterns support
*and**. - Use forward slashes for all paths, including Windows paths.
- Windows-volume paths do not match on Linux, and Linux paths do not match on Windows.
*:/Program Files/**matches any Windows volume.- In
.poolside/settings.local.yamland~/.config/poolside/settings.yaml, paths must be absolute or start with~. - In
.poolside/settings.yaml, paths must be relative to the project.
Read-only configuration
Read-only paths example for .poolside/settings.yaml
Read-write configuration
Read-write paths example for .poolside/settings.yaml
Protect sensitive files across projects
To block access to sensitive files in every project, add deny rules to your personal defaults file,~/.config/poolside/settings.yaml:
Protect sensitive files example for ~/.config/poolside/settings.yaml
deny rules always override allow.
Local sandbox
A sandbox creates a stronger runtime boundary. Sandbox workspace access supports two modes:read-only: Tools can read files, and you review changes before Poolside applies them.read-write: Tools can modify workspace files directly.
~/.config/poolside/settings.yaml file.
Sandbox example for ~/.config/poolside/settings.yaml
- Container runtime image
- Workspace file access
- Extra host mounts
- Network destinations
Use volume mounts in local sandboxes
Use volume mounts to mount extra host paths into the sandbox. If your development workflow depends on host resources outside the workspace, add extra mounts undersandbox.filesystem.mounts.
For example, you can mount a persistent host cache directory, the local Docker socket, and a Docker config directory into the sandbox:
Volume mounts example for ~/.config/poolside/settings.yaml
/var/run/docker.sock gives processes inside the sandbox access to your host Docker daemon. Use that mount only when your workflow requires it.
Best practices:
- Use absolute host paths.
- Put reusable build caches outside the workspace, then mount them into the sandbox.
- Mount config directories as
read-onlyunless the tool must write to them. - Do not mount a workspace directory again through
mounts. - Choose a container image that already includes the tools your workflow needs.
Use private or local images
For local sandboxes, Poolside uses your local Docker engine to resolve the sandbox image.Private image example for ~/.config/poolside/settings.yaml
- Use a private image only after Docker on your machine is already authenticated to that registry.
- You can also use an image that you built or pulled locally.
Glob reference
Tool rule syntax
| Pattern | Matches | Does not match |
|---|---|---|
go vet * | go vet, go vet -vettool shadow | go run |
gh * list * | gh pr list, gh gist list | gh list |
*matches zero or more characters including/.**is not supported.
Path rule syntax
| Pattern | Matches | Does not match |
|---|---|---|
/src/**/*.go | /src/main.go, /src/pkg/run.go | /other/src/main.go |
C:/**/bin/* | C:/Tools/bin/app.exe | D:/Tools/bin/app.exe |
*matches characters except/.**matches across directories.*:/Program Files/**matches any Windows volume.