A sandbox for safely running Python code
Project description
Bexy
A sandbox for safely running Python code in isolated environments. Bexy is part of the PyLama ecosystem and integrates with LogLama as the primary service for centralized logging and environment management.
Features
- Code analysis for detecting dependencies
- Dependency management for automatic installation
- Python sandbox for running code in the current environment
- Docker sandbox for running code in isolated containers
- Interactive terminal menu for running examples (arrow keys + Enter)
- Utility functions for system information and execution results
- Integration with LogLama for centralized logging and environment management
- Structured logging with component context for better debugging and monitoring
Installation
# Install from PyPI
pip install bexy
# Or install locally in development mode
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
pip install -e . # This is important! Always install in development mode before starting
# Alternatively, use the Makefile
make setup
IMPORTANT: Always run
pip install -e .before starting the project to ensure all dependencies are properly installed and the package is available in development mode.
Usage
from bexy import PythonSandbox, DockerSandbox
# Run code in the current Python environment
python_sandbox = PythonSandbox()
result = python_sandbox.run_code("""
import math
print(f'The square root of 16 is {math.sqrt(16)}')
""")
print(result)
# Run code in an isolated Docker container
docker_sandbox = DockerSandbox()
result = docker_sandbox.run_code("""
import platform
print(f'Running on {platform.system()}')
""")
print(result)
Using the Makefile
Bexy includes a Makefile to simplify common development tasks:
# Set up the project (creates a virtual environment and installs dependencies)
make setup
# Run the API server (default port 8000)
make run
# Run the API server on a custom port
make run PORT=8080
# The run-port command is also available for backward compatibility
make run-port PORT=8080
# Run tests
make test
# Format code with black
make format
# Lint code with flake8
make lint
# Docker Testing
# Build Docker test images
make docker-build
# Run tests in Docker
make docker-test
# Start interactive Docker test environment
make docker-interactive
# Start Bexy mock service in Docker
make docker-mock
# Clean up Docker test resources
make docker-clean
# Clean up project (remove __pycache__, etc.)
make clean
# Show all available commands
make help
Docker Testing
Bexy includes a Docker-based testing infrastructure that allows you to run tests in isolated containers. This ensures consistent test environments and makes it easier to test integration with other components.
Using Docker Tests
# Build the Docker test images
make docker-build
# Run all tests in Docker
make docker-test
# Start an interactive Docker test environment
make docker-interactive
# Start a Bexy mock service for integration testing
make docker-mock
# Clean up Docker test resources
make docker-clean
Integration with PyLama Ecosystem
Bexy is part of the PyLama ecosystem and can be tested together with other components using the main Makefile in the PyLama project root:
# From the PyLama project root
make docker-test-bexy # Run Bexy tests only
make docker-integration-test # Run integration tests across all components
Running code from .py and .md files
You can use Bexy to safely run code from Python scripts (.py) or extract and run all Python code blocks from Markdown files (.md). This functionality is available both as a command-line tool and in the interactive menu.
Usage (CLI)
python -m bexy.bexy_run script.py
python -m bexy.bexy_run README.md
python -m bexy.bexy_run README.md --docker
- For
.pyfiles: the whole script is executed in a sandbox. - For
.mdfiles: all code blocks marked as ```python are extracted and executed one by one in isolation. - Add
--dockerto run code in an isolated Docker container.
Usage (Interactive Menu)
Launch the menu:
bexy
Choose "Uruchom kod z pliku .py lub .md" and follow the prompts to run any script or markdown code blocks, locally or in Docker.
Overview
Bexy is a sandbox system for safely running Python code from scripts or markdown, with support for dependency management and Docker isolation.
Mermaid Diagram – Main Flow
flowchart TD
A[User Input: .py/.md file] --> B{File Type?}
B -- .py --> C[Read Python file]
B -- .md --> D[Extract python code blocks]
C --> E[Choose Sandbox Type]
D --> E
E -- PythonSandbox --> F[Run code locally]
E -- DockerSandbox --> G[Run code in Docker]
F --> H[Collect Results]
G --> H
H --> I[Display Output]
ASCII Diagram – Component Overview
+-------------------+
| User/CLI/Menu |
+--------+----------+
|
v
+--------+----------+
| bexy_run / menu |
+--------+----------+
|
v
+-------------------+
| File Handler |
| (.py/.md parser) |
+--------+----------+
|
v
+-------------------+
| Sandbox Layer |
| PythonSandbox |
| DockerSandbox |
+--------+----------+
|
v
+-------------------+
| Output/Reporter |
+-------------------+
Flow Description
- User selects file via CLI or menu.
- File Handler detects file type:
.py: reads the script..md: extracts all ```python code blocks.
- Sandbox Layer runs code using
PythonSandbox(local) orDockerSandbox(container). - Output/Reporter collects and displays results for each code block/script.
Example Sequence (Markdown)
sequenceDiagram
participant U as User
participant P as bexy_run
participant F as FileHandler
participant S as Sandbox
participant O as Output
U->>P: Provide README.md
P->>F: Parse .md, extract python blocks
F->>S: Send code block to sandbox
S->>O: Return execution result
O->>U: Show output
loop for each block
F->>S: Next block
S->>O: Result
O->>U: Output
end
---
## Key Components
- **bexy_run**: CLI/utility for running code from files
- **examples.py**: Interactive menu, now integrates file execution
- **PythonSandbox/DockerSandbox**: Safe code execution layers
- **DependencyManager**: Handles required packages
- **Markdown Parser**: Extracts code blocks from `.md`
---
## Extending
- Add support for more file types (e.g., Jupyter).
- Enhance reporting (HTML, JSON output).
- Add block selection for markdown.
### Example
Suppose you have a Markdown file with:
```markdown
```python
print("Hello from markdown!")
Running `python -m bexy.bexy_run README.md` or using the interactive menu will execute the code above in a sandbox and print the results.
## Interactive Examples Menu
BEXY provides an interactive terminal menu for running usage examples. The menu allows you to navigate using arrow keys and select examples with Enter. Powered by the [`questionary`](https://github.com/tmbo/questionary) library.
### Running the interactive menu
You can start the interactive menu via the console script or directly:
```bash
# Using the installed entry point
bexy
# Or directly
python -m bexy.examples
Follow the on-screen menu to choose an example (e.g. CodeAnalyzer, DependencyManager, PythonSandbox, DockerSandbox, etc.).
Requirements
The interactive menu requires questionary (installed automatically with BEXY 0.1.1+):
pip install questionary
License
Apache License 2.0
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bexy-0.1.14.tar.gz.
File metadata
- Download URL: bexy-0.1.14.tar.gz
- Upload date:
- Size: 30.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.13.3 Linux/6.14.6-300.fc42.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8beb9a2c7908a43c29b1098d5611f1c5de0d6316d3de3fbb977fe85b2ffe838b
|
|
| MD5 |
cdfb628bc2ef4e4d393792e109d05cc1
|
|
| BLAKE2b-256 |
14eac3621d02309069533efdb7ed5fd4a7cd6b67c880e4eb5264a860207fd851
|
File details
Details for the file bexy-0.1.14-py3-none-any.whl.
File metadata
- Download URL: bexy-0.1.14-py3-none-any.whl
- Upload date:
- Size: 34.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.5 CPython/3.13.3 Linux/6.14.6-300.fc42.x86_64
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6c918c41886b3444160832987073e652f992da2b251d05310151609c639c4fd5
|
|
| MD5 |
fe7baab796bfe2217b548ead4db51152
|
|
| BLAKE2b-256 |
84425349e9812781cdd26ae32c983e4c302ef602cdc6bee8f36e4bcce04ae8cd
|