PandaAI 3.0 is currently in beta. This documentation reflects the latest features and functionality, which may evolve before the final release.

Code Execution and Sandbox Environment

PandaAI executes Python code that is generated by Large Language Models (LLMs). While this provides powerful data analysis capabilities, it’s crucial to understand the security implications, especially in production use cases where your application might be exposed to potential malicious attacks.

Why Use a Sandbox?

When building applications that allow users to interact with PandaAI, there’s a potential risk that malicious users might attempt to manipulate the LLM into generating harmful code. To mitigate this risk, PandaAI provides a secure sandbox environment with the following features:

  • Isolated Execution: Code runs in a completely isolated Docker container
  • Offline Operation: The sandbox runs entirely offline, preventing any external network requests
  • Resource Limitations: Strict controls on system resource usage
  • File System Isolation: Protected access to the file system

Using the Sandbox

To use the sandbox environment, you first need to install the required package and have Docker running on your system:

pip install pandasai-docker

Make sure you have Docker running on your system before using the sandbox environment.

Here’s how to enable the sandbox for your PandaAI chat:

import pandasai as pai
from pandasai_docker import DockerSandbox

pai.api_key.set("YOUR_API_KEY")

# initialize the sandbox
sandbox = DockerSandbox()
sandbox.start()

# read a csv as df
df = pai.read_csv("./data/heart.csv")

# pass the df and the sandbox
result = pai.chat("plot total heart patients by gender", df, sandbox=sandbox)

# display the chart
result.show()

# stop the sandbox (docker container)
sandbox.stop()

When to Use the Sandbox

We strongly recommend using the sandbox environment in the following scenarios:

  • Building public-facing applications
  • Processing untrusted user inputs
  • Deploying in production environments
  • Handling sensitive data
  • Multi-tenant environments

Enterprise Sandbox Options

For production-ready use cases, we offer several advanced sandbox options as part of our Enterprise license. These include:

  • Custom security policies
  • Advanced resource management
  • Enhanced monitoring capabilities
  • Additional isolation layers

If you need more information about our Enterprise sandbox options or require assistance with implementation, please contact us. Our team can help you choose and configure the right security solution for your specific use case.