Skip to main content

A Python library for code analysis and sandboxing

Project description

GuardX

A Python package for code analysis and sandbox.

This library can be used to create pipelines that filter code generated by GenAI code models, and for guarding the execution of generated code.

Quick start

To install the library, choose one of the following methods:

pip install guardx

Dev: Create a python virtual env

This is recommended.

python -m venv .venv
source .venv/bin/activate

Initialization

The library container images must be built before importing and using the library.

guardx init

Note: Depending on your system, you may need to run as sudo .venv/bin/guardx init.

Podman: GuardX uses the docker python package to communicate with containers. Hence, if you are using Podman, you will need to set the env variable DOCKER_HOST to point to the unix socket used by Podman. See docs/container.rst.

podman machine inspect --format '{{.ConnectionInfo.PodmanSocket.Path}}'
export DOCKER_HOST=unix://<your_podman_socket_location>

Test using provided example

python example.py --file example_gen_code.py

Library Usage

Here is an example of how to use this library in your code.

from guardx import Guardx
from guardx.analysis import AnalysisType

python_code = """<your code here>"""

g = Guardx(config_path="./resources/config.yaml")

# To analyze code
result = g.analyze(python_code, {AnalysisType.DETECT_SECRET, AnalysisType.UNSAFE_CODE})
print(result)

# To execute code in sandbox with a default security policy
result = g.execute(python_code).get_docker_result()
print(result)

Development

Install from a branch

git+https (using a github personal access token):

pip install git+https://github.com/ibm/guardx.git@{branch/tag}

git+ssh:

pip install git+ssh://git@github.com/ibm/guardx.git@${branch/tag}

Setting up the development environment

git clone:

git clone git@github.com:ibm/guardx.git
make -C guardx init
make -C guardx install

Install pre-requisites

git clone git@github.com:ibm/guardx.git
cd guardx
make init

Note: This installs Poetry. Make sure to configure your PATH to access poetry.

Install dependencies

To install the dev dependencies (editable mode):

make install/dev

Note: To add additional dependencies, use poetry add "package". For help, poetry add -h.

Build the library container images

make containers/docker

OR

make containers/podman

Note: Fresh build takes 5-10 minutes. Make sure to update the GuardX config file in resources/config.yaml to match built image name and tag.

Testing

Test modules are created under the tests directory.

To run all tests, use the following command:

make test

Note: To enable logging, set log_cli = true in tests/pytest.ini.

Code Linting

Before checking in any code for the project, please lint the code. This can be done using:

make lint

Precommit Hooks

We are currently using detect-secrets in our precommit hooks. Refer to this repo for configuration instructions

Docs config & build

cd docs
make html

Seccomp policy category

Set the seccomp policy category in resources/config.yaml. Categories description below:

  • memory: only allow rt_sigaction, exit_group, munmap, read stdin, write stdout, write stderr
  • nonet: disallow network related syscalls
  • crit_syscalls: disallow syscalls associated with known CVEs or used as launchpad to carry out attacks.
  • log: logs all syscalls to auditd.log
  • unconfined: no seccomp

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

guardx-0.2.1.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

guardx-0.2.1-py3-none-any.whl (31.8 kB view details)

Uploaded Python 3

File details

Details for the file guardx-0.2.1.tar.gz.

File metadata

  • Download URL: guardx-0.2.1.tar.gz
  • Upload date:
  • Size: 25.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for guardx-0.2.1.tar.gz
Algorithm Hash digest
SHA256 4935f64665148e7ca7a0aae9c70638265edb77ec6fd341c6266bba7c4c15b100
MD5 7b31accbe50af07d74e1d36bd685e701
BLAKE2b-256 e93406c342825f00bfd8dd97631a1903628123078147591a87682b2e8d2436c5

See more details on using hashes here.

Provenance

The following attestation bundles were made for guardx-0.2.1.tar.gz:

Publisher: publish-to-pypi.yml on IBM/guardx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file guardx-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: guardx-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 31.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for guardx-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ed81b25d2f02486215eff7e71a8e0b8513b356ddfaf5a7f740cd49b6ccba038b
MD5 3b553e9d4b89032a241538473259fda1
BLAKE2b-256 ba6ddd7844621fcf54836a7e28517064f7357202836f0c69acbbab84fbe45c6a

See more details on using hashes here.

Provenance

The following attestation bundles were made for guardx-0.2.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on IBM/guardx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page