This tutorial shows how OpenShell’s network policy system works in under five minutes. You create a sandbox, watch a request get blocked by the default-deny policy, apply a fine-grained L7 rule, and verify that reads are allowed while writes are blocked — all without restarting anything. After completing this tutorial, you will understand:Documentation Index
Fetch the complete documentation index at: https://mintlify.com/NVIDIA/OpenShell/llms.txt
Use this file to discover all available pages before exploring further.
- How default-deny networking blocks all outbound traffic from a sandbox.
- How to apply a network policy that grants read-only access to a specific API.
- How L7 enforcement distinguishes between HTTP methods such as GET and POST on the same endpoint.
- How to inspect deny logs for a complete audit trail.
Prerequisites
- A working OpenShell installation. Complete the Quickstart before proceeding.
- Docker Desktop running on your machine.
Tutorial
Create a sandbox
Create a sandbox with no network policies. This gives you a clean environment to observe default-deny behavior.
--keep keeps the sandbox running after you exit so you can reconnect later. --no-auto-providers skips the provider setup prompt since this tutorial uses curl instead of an AI agent.You land in an interactive shell inside the sandbox:Try to reach the GitHub API
With no network policy in place, every outbound connection is blocked. Test this by making a simple API call from inside the sandbox:Exit the sandbox. The
https://api.github.com/zen is a lightweight, unauthenticated GitHub REST endpoint that returns a random aphorism. It requires no tokens or parameters, which makes it a convenient smoke-test target for verifying outbound HTTPS connectivity.The request fails. The sandbox proxy intercepted the HTTPS CONNECT request to api.github.com:443 and rejected it because no network policy authorizes curl to reach that host.--keep flag keeps it running:Check the deny log
Every denied connection produces a structured log entry. Query the sandbox logs from your host to confirm the denial and inspect the reason.You see a line like:Every denied connection is logged with the destination, the binary that attempted it, and the reason. Nothing gets out silently.
Create the policy file
To allow the sandbox to reach the GitHub API, define a network policy that grants read-only access. Create a file called The
github-readonly.yaml with the following content:github-readonly.yaml
filesystem_policy, landlock, and process sections preserve the default sandbox settings. This is required because policy set replaces the entire policy.The network_policies section is the key part: curl may make GET, HEAD, and OPTIONS requests to api.github.com over HTTPS. Everything else is denied. The proxy auto-detects TLS on HTTPS endpoints and terminates it to inspect each HTTP request and enforce the read-only access preset at the method level.Apply the policy
Apply the policy to the running sandbox:
--wait blocks until the sandbox confirms the new policy is loaded. No restart required. Policies are hot-reloaded.Verify GET requests are allowed
Reconnect to the sandbox and retry the same request to confirm that read access works.Retry the request:The
read-only preset allows GET requests through.Try a write operation
The read-only preset allows GET but blocks mutating methods like POST, PUT, and DELETE. Test this by sending a POST request while still inside the sandbox:The CONNECT request succeeded because
api.github.com is allowed, but the L7 proxy inspected the HTTP method and returned 403. POST is not in the read-only preset. An agent with this policy can read code from GitHub but cannot create issues, push commits, or modify anything.Exit the sandbox:Check the L7 deny log
L7 denials are logged separately from connection-level denials. The log entry includes the exact HTTP method and path that the proxy rejected.The log captures the exact HTTP method, path, and deny reason. In production, pipe these logs to your SIEM for a complete audit trail of every request your agent makes.
What just happened
| State | What happens |
|---|---|
| Default deny | All outbound traffic is blocked — nothing gets out without an explicit policy |
| L7 read-only | GET to api.github.com is allowed; POST is blocked at the HTTP method level |
| Audit trail | Every request is logged with the method, path, binary, and decision |
--dangerously-skip-permissions.
What’s next
GitHub push access
Walk through a full policy iteration with Claude Code, including diagnosing denials and applying fixes from outside the sandbox.
Policy schema reference
Learn about all available policy fields, access presets, and rule syntax.
Sandbox policies
See full policy examples for PyPI, npm, and internal APIs.
Policy audit mode
Use enforcement: audit to log violations without blocking, then promote to enforce.