[project]
name = "jailbreakbench"
version = "1.0.0"
description = " An Open Robustness Benchmark for Jailbreaking Language Models"
readme = "README.md"
license = { file = "LICENSE" }
requires-python = ">= 3.10,<3.12"

classifiers = [
    "Development Status :: 4 - Beta",
    "Intended Audience :: Developers",
    "Intended Audience :: Science/Research",
    "Topic :: Scientific/Engineering :: Artificial Intelligence",
    "Topic :: Security",
    "License :: OSI Approved :: MIT License",
    "Environment :: GPU",
    "Programming Language :: Python :: 3",
    "Programming Language :: Python :: 3.10",
    "Programming Language :: Python :: 3.11",
    "Programming Language :: Python :: 3.12",
]

keywords = [
    "jailbreak",
    "benchmark",
    "llms",
    "jailbreakbench",
    "machine learning",
    "security",
]

dependencies = [
    "litellm>=1.20.0",
    "pandas>=2.2.0,<3.0.0",
    "pydantic>=2.6.1,<3.0.0",
    "protobuf>=4.25.3,<5.0.0",
    "requests>=2.31.0,<3.0.0",
    "sentencepiece>=0.2.0,<1.0.0",
    "tenacity>=8.2.3,<9.0.0",
    "torch>=2.0.0,<3.0.0",
    "transformers>=4.38.0,<5.0.0",
    "types-requests>=2.31.0,<3.0.0",
    "setuptools>=61.0",
    "tqdm>=4.66.2",
    "datasets>=2.19.2",
    "wordfreq>=3.1.1",
    "nltk>=3.8.1",
]

[project.optional-dependencies]
vllm = ["click>=8.1.7,<9.0.0", "accelerate>=0.27.2,<1.0.0", "vllm~=0.3.2"]

[project.urls]
Homepage = "https://jailbreakbench.github.io"
Repository = "https://github.com/JailbreakBench/jailbreakbench.git"
Issues = "https://github.com/JailbreakBench/jailbreakbench/issues"


[build-system]
requires = ["hatchling"]
build-backend = "hatchling.build"

[tool.rye]
managed = true
dev-dependencies = ["ruff>=0.2.1,<1.0.0", "mypy>=1.8.0,<2.0.0", "pytest>=8.1.1"]

[tool.hatch.metadata]
allow-direct-references = true

[tool.hatch.build.targets.wheel]
packages = ["src/jailbreakbench"]

[tool.ruff]
target-version = "py310"
line-length = 120
exclude = ["./data/"]

[tool.ruff.lint]
ignore = [
    "E731",
    "E402",
    "N812", # Uppercase import (for nn.functional as F)
]
select = [
    "F",   # pyflakes
    "UP",  # pyupgrade
    "I",   # isort
    "ERA", # eradicate
    "NPY", # numpy
    "N",   # pep8-naming
    "UP",  # pyupgrade
]

[tool.ruff.format]
docstring-code-format = true

[tool.mypy]
ignore_missing_imports = true
exclude = ["./data/"]

[tool.pytest.ini_options]
markers = [
    "gpu: marks tests as needs a GPU (deselect with '-m \"not gpu\"')",
    "nogpu: marks tests if it should be run without a GPU (deselect with '-m \"not nogpu\"')",
    "api_key: marks tests as needing an API key (deselect with '-m \"not api_key\"'",
]
filterwarnings = [
    "ignore:::.*litellm",
    "ignore::pydantic.warnings.PydanticDeprecatedSince20",
]
