# Development Repository for BaxBench Agent

## Setup

The project uses the conda package manager. Please install it from [here](https://docs.conda.io/projects/conda/en/latest/user-guide/install/index.html). If you would like to have a lightweight installation, consider [Miniconda](https://docs.anaconda.com/miniconda/).

Then, the environment can be installed by running the following command:

```
conda env create -f env.yaml
```

Activate the environment:

```
conda activate baxbench-agent
```

Then, install the module:
```
pip install -e .
```

Optional system dependencies:
- **imagemagick** - For image conversion scenarios
- **ffmpeg** - For video processing scenarios  
- **poppler-utils** - For PDF text extraction (provides `pdftotext`)
- **nodejs** - For TypeScript compilation scenarios
- **g++** and **make** - For C++ compilation scenarios

```bash
sudo apt install imagemagick ffmpeg poppler-utils nodejs g++ make
```

Finally, set up the pre-commit hooks:

```
pre-commit install
```

Running inside Docker, with the provided Dockerfile

To rebuild the image:
```
docker build -t baxbench-agent .
```

To run a containerized shell as the current user, mounted with the current directory with docker access and loaded env file:
```bash
docker run \
  --add-host=localhost:host-gateway \
  --user $(id -u):$(id -g) \
  --env-file /path/to/env \
  -it \
  --memory="2g" \
  --memory-swap="4g" \
  --rm \
  -v /var/run/docker.sock:/var/run/docker.sock \
  -v $(which docker):/usr/bin/docker \
  -v $(pwd):/app \
  baxbench-agent /bin/bash
```

Depending on your configuration, you may need to run with `--network host` mode instead of `--add-host=localhost:host-gateway`.
Note that the user must be added the docker group on the host.

## Usage
Run the agent from the root directory with `python src/main.py`. It runs in 3 modes, specified by the 3 flags:

### Modes
- `--generate_scenarios`: Generate scenarios
- `--generate_tests`: Generate tests (requires `--scenario` parameter)
- `--generate_exploits`: Generate exploits (requires `--scenario` parameter)

### Required Parameters
- `--scenario`: Scenario name (required when using `--generate_tests` or `--generate_exploits`)

### Optional Parameters
- `--complexity N`
- `--N_RETRIES N`
- `--N_BLACKBOX_STEPS N`
- `--N_WHITEBOX_STEPS N`
- `--N_SEC_STEPS N`
- `--debug`
- `--path PATH`

### Examples
```bash
# Generate scenarios
python src/main.py --generate_scenarios

# Generate tests for a specific scenario
python src/main.py --generate_tests --scenario FooBarScenario

# Generate exploits for a specific scenario
python src/main.py --generate_exploits --scenario FooBarScenario

# Run in debug mode
python src/main.py --generate_tests --debug

# Save artifacts in a different directory
python src/main.py --generate_scenarios --path /path/to/artifacts/
```
