64391e31fa
Diff: https://github.com/oscal-compass/compliance-trestle/compare/v3.9.1...v3.11.0 Changelog: https://github.com/oscal-compass/compliance-trestle/blob/v3.11.0/CHANGELOG.md
144 lines
3.4 KiB
Nix
144 lines
3.4 KiB
Nix
{
|
|
lib,
|
|
buildPythonPackage,
|
|
fetchFromGitHub,
|
|
pythonAtLeast,
|
|
|
|
# build-system
|
|
hatchling,
|
|
|
|
# dependencies
|
|
attrs,
|
|
cmarkgfm,
|
|
cryptography,
|
|
defusedxml,
|
|
furl,
|
|
ilcli,
|
|
importlib-resources,
|
|
jinja2,
|
|
openpyxl,
|
|
orjson,
|
|
paramiko,
|
|
pydantic,
|
|
python-dotenv,
|
|
python-frontmatter,
|
|
requests,
|
|
ruamel-yaml,
|
|
|
|
# tests
|
|
datamodel-code-generator,
|
|
pytestCheckHook,
|
|
mypy,
|
|
}:
|
|
|
|
let
|
|
# nist-content is a git submodule, but using fetchSubmodules in src fails while recursing into
|
|
# nist-content itself.
|
|
# Thus we simply inject it after the fact in postPatch.
|
|
nist-content = fetchFromGitHub {
|
|
name = "nist-content";
|
|
owner = "usnistgov";
|
|
repo = "oscal-content";
|
|
rev = "941c978d14c57379fbf6f7fb388f675067d5bff7";
|
|
hash = "sha256-sDvNMheZZhk09YEfY5ocmZmAC3t3KenqD3PaNsi0mMU=";
|
|
};
|
|
in
|
|
buildPythonPackage (finalAttrs: {
|
|
pname = "compliance-trestle";
|
|
version = "3.11.0";
|
|
pyproject = true;
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "oscal-compass";
|
|
repo = "compliance-trestle";
|
|
tag = "v${finalAttrs.version}";
|
|
# TODO: Try to fall back to fetchSubmodules at the next release
|
|
# fetchSubmodules = true;
|
|
hash = "sha256-vhRD2NTt9F/7lgbmrjp5AWSUIs/iaqUAAAxs8T4Ap4A=";
|
|
};
|
|
|
|
postPatch = ''
|
|
substituteInPlace tests/trestle/misc/mypy_test.py \
|
|
--replace-fail "trestle'," "${placeholder "out"}/bin/trestle',"
|
|
''
|
|
# Replace the expected nist-content git submodule with the pre-fetched path.
|
|
+ ''
|
|
rmdir ./nist-content
|
|
ln -s ${nist-content} ./nist-content
|
|
'';
|
|
|
|
build-system = [
|
|
hatchling
|
|
];
|
|
|
|
dependencies = [
|
|
attrs
|
|
cmarkgfm
|
|
cryptography
|
|
defusedxml
|
|
furl
|
|
ilcli
|
|
importlib-resources
|
|
jinja2
|
|
openpyxl
|
|
orjson
|
|
paramiko
|
|
pydantic
|
|
python-dotenv
|
|
python-frontmatter
|
|
requests
|
|
ruamel-yaml
|
|
]
|
|
++ pydantic.optional-dependencies.email;
|
|
|
|
nativeCheckInputs = [
|
|
datamodel-code-generator
|
|
mypy
|
|
pytestCheckHook
|
|
];
|
|
|
|
disabledTests = [
|
|
# Requires network access
|
|
"test_import_from_url"
|
|
"test_import_from_nist"
|
|
"test_remote_profile_relative_cat"
|
|
|
|
# AssertionError
|
|
"test_profile_generate_assemble_rev_5"
|
|
"test_ssp_assemble_fedramp_profile"
|
|
"test_ssp_generate_aggregates_no_cds"
|
|
"test_ssp_generate_aggregates_no_param_value_orig"
|
|
]
|
|
++ lib.optionals (pythonAtLeast "3.14") [
|
|
# AssertionError: assert 1 == 0
|
|
# AttributeError: 'AliasTracker' object has no attribute 'aliases'
|
|
"test_arguments"
|
|
"test_get_list_cli"
|
|
"test_load_custom_config"
|
|
"test_load_default_config"
|
|
"test_split_catalog_star"
|
|
"test_split_comp_def"
|
|
];
|
|
|
|
disabledTestPaths = [
|
|
# Requires network access
|
|
"tests/trestle/core/remote"
|
|
]
|
|
++ lib.optionals (pythonAtLeast "3.14") [
|
|
# pydantic.v1.errors.ConfigError: unable to infer type for attribute "poam"
|
|
"tests/trestle/core/models/interfaces_test.py"
|
|
"tests/trestle/tasks/ocp4_cis_profile_to_oscal_catalog_test.py"
|
|
];
|
|
|
|
pythonImportsCheck = [ "trestle" ];
|
|
|
|
meta = {
|
|
description = "Opinionated tooling platform for managing compliance as code, using continuous integration and NIST's OSCAL standard";
|
|
homepage = "https://github.com/oscal-compass/compliance-trestle";
|
|
changelog = "https://github.com/oscal-compass/compliance-trestle/blob/${finalAttrs.src.tag}/CHANGELOG.md";
|
|
license = lib.licenses.asl20;
|
|
maintainers = with lib.maintainers; [ tochiaha ];
|
|
mainProgram = "trestle";
|
|
};
|
|
})
|