38 tests covering the pure worker-line logic: Classifyline rules, Routeline TLP/country/incident-type gates, Sealine seal/unseal round-trip, Proofline confidence scoring, Mapline CVEResolver escalation, Trainline dataset well-posedness (the v1/v3 input-signal bugs are now regression-guarded), and the Scoutline feed parsers. pytest added as a dev extra. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
44 lines
828 B
TOML
44 lines
828 B
TOML
[build-system]
|
|
requires = ["hatchling"]
|
|
build-backend = "hatchling.build"
|
|
|
|
[project]
|
|
name = "psyc"
|
|
version = "0.1.0"
|
|
description = "Defensive CTI routing & evidence-sealing platform"
|
|
requires-python = ">=3.10"
|
|
dependencies = [
|
|
"fastapi>=0.115",
|
|
"uvicorn[standard]>=0.30",
|
|
"jinja2>=3.1",
|
|
"python-multipart>=0.0.9",
|
|
"pydantic>=2.7",
|
|
"httpx>=0.27",
|
|
"typer>=0.12",
|
|
"pynacl>=1.5",
|
|
"structlog>=24.1",
|
|
"sqlalchemy>=2.0",
|
|
]
|
|
|
|
[project.optional-dependencies]
|
|
dev = ["pytest>=8.0"]
|
|
|
|
[project.scripts]
|
|
psyc = "psyc.cli:app"
|
|
|
|
[tool.hatch.build.targets.wheel]
|
|
packages = ["src/psyc"]
|
|
|
|
[tool.pytest.ini_options]
|
|
testpaths = ["tests"]
|
|
|
|
[tool.ruff]
|
|
line-length = 120
|
|
|
|
[tool.ruff.lint]
|
|
select = ["E", "F", "I", "B"]
|
|
ignore = ["UP006", "UP007", "UP035"]
|
|
|
|
[tool.ruff.lint.isort]
|
|
known-first-party = ["psyc"]
|