devsecops-engine-tools 1.30.2__tar.gz → 1.32.0__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of devsecops-engine-tools might be problematic. Click here for more details.
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/PKG-INFO +7 -2
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/defect_dojo/defect_dojo.py +87 -25
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/applications/runner_secret_scan.py +10 -0
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/gitleaks/gitleaks_deserealizator.py +36 -0
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/gitleaks/gitleaks_tool.py +150 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/__init__.py +2 -1
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/component.py +0 -1
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/finding.py +0 -3
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/applications/finding_exclusion.py +14 -0
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/finding_exclusion.py +20 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/serializers/finding.py +1 -1
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/finding_exclusion.py +9 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/import_scan.py +6 -6
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/finding_exclusion.py +28 -0
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/utils/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/utils.py +6 -1
- devsecops_engine_tools-1.32.0/devsecops_engine_tools/version.py +1 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/PKG-INFO +7 -2
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/SOURCES.txt +7 -0
- devsecops_engine_tools-1.30.2/devsecops_engine_tools/version.py +0 -1
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/README.md +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/applications/runner_engine_core.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/component.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/customs_exceptions.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/exclusions.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/finding.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/devops_platform_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/metrics_manager_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/printer_table_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/sbom_manager.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/secrets_manager_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/gateway/vulnerability_management_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/input_core.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/level_compliance.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/level_vulnerability.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/report.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/threshold.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/model/vulnerability_management.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/usecases/break_build.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/usecases/handle_risk.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/usecases/handle_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/domain/usecases/metrics_manager.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/aws/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/aws/s3_manager.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/aws/secrets_manager.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/azure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/azure/azure_devops.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/defect_dojo/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/github/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/github/github_actions.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/printer_pretty_table/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/printer_pretty_table/printer_pretty_table.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/printer_rich_table/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/printer_rich_table/printer_rich_table.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/runtime_local/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/runtime_local/runtime_local.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/syft/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/driven_adapters/syft/syft.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/entry_points/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/entry_points/entry_point_core.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/helpers/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/helpers/aws.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_core/src/infrastructure/helpers/util.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/infrastructure/entry_points/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_dast/src/infrastructure/helpers/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/applications/runner_engine_risk.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/model/gateways/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/model/gateways/add_epss_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/add_data.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/break_build.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/check_threshold.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/get_exclusions.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/domain/usecases/handle_filters.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/driven_adapters/first_csv/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/driven_adapters/first_csv/first_epss_csv.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/entry_points/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/entry_points/entry_point_risk.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_risk/src/infrastructure/helpers/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/applications/runner_engine_code.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/model/config_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/model/gateways/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/model/gateways/tool_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/domain/usecases/code_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/driven_adapters/bearer/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/driven_adapters/bearer/bearer_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/driven_adapters/bearer/bearer_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/entry_points/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/entry_points/entry_point_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_code/src/infrastructure/helpers/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/applications/runner_iac_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/model/config_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/model/gateways/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/model/gateways/tool_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/domain/usecases/iac_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/checkov/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/checkov/checkov_config.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/checkov/checkov_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/checkov/checkov_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kics/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kics/kics_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kics/kics_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kubescape/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kubescape/kubescape_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/driven_adapters/kubescape/kubescape_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/entry_points/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/entry_points/entry_point_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/helpers/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_iac/src/infrastructure/helpers/file_generator_tool.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/applications/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/deployment/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/deployment/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/model/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/model/gateway/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/model/gateway/gateway_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/model/gateway/tool_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/usecases/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/usecases/secret_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/domain/usecases/set_input_core.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/trufflehog → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/gitleaks}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/entry_points → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/trufflehog}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/trufflehog/trufflehog_deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/driven_adapters/trufflehog/trufflehog_run.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/entry_points}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sast/engine_secret/src/infrastructure/entry_points/entry_point_tool.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/applications → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/deployment → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/applications}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/applications/runner_container_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/deployment/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/deployment}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/domain → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/deployment/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/domain/model → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/domain}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/domain/model/gateways → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/domain/model}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/domain/usecases → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/domain/model/gateways}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/model/gateways/deserealizator_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/model/gateways/images_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/model/gateways/tool_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/domain/usecases}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/usecases/container_sca_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/usecases/handle_remote_config_patterns.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/domain/usecases/set_input_core.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/docker → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/prisma_cloud → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/docker}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/docker/docker_images.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/trivy_tool → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/prisma_cloud}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/prisma_cloud/prisma_cloud_manager_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/prisma_cloud/prisma_deserialize_output.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/entry_points → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/trivy_tool}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/trivy_tool/trivy_deserialize_output.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/driven_adapters/trivy_tool/trivy_manager_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/helpers → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/entry_points}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/entry_points/entry_point_tool.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_container/src/infrastructure/helpers}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/applications → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/deployment → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/applications}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/applications/runner_dependencies_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/deployment/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/deployment}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/deployment/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model/gateways → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/usecases → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model/gateways}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model/gateways/deserializator_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/model/gateways/tool_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/usecases}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/usecases/dependencies_sca_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/usecases/handle_remote_config_patterns.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/domain/usecases/set_input_core.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/dependency_check → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/xray_tool → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/dependency_check}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/dependency_check/dependency_check_deserialize.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/dependency_check/dependency_check_tool.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/entry_points → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/xray_tool}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/xray_tool/xray_deserialize_output.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/driven_adapters/xray_tool/xray_manager_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/helpers → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/entry_points}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/entry_points/entry_point_tool.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/helpers}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_sca/engine_dependencies/src/infrastructure/helpers/get_artifacts.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/azuredevops → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/azuredevops/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/azuredevops}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/azuredevops/models → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/azuredevops/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/azuredevops/infrastructure/azure_devops_api.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/azuredevops/models/AzureMessageLoggingPipeline.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/azuredevops/models/AzurePredefinedVariables.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/applications → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/azuredevops/models}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/domain → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/applications}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/connect.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/defect_dojo.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/engagement.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/applications/product.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/domain/request_objects → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/cmdb.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/component.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/engagement.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/finding.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/product.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/product_list.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/product_type.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/product_type_list.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/models/scan_configuration.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/domain/serializers → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/request_objects}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/request_objects/finding.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/request_objects/import_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/serializers}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/serializers/import_scan.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/cmdb.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/component.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/engagement.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/finding.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/domain/user_case/product.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/hello_world.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/settings → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/cmdb.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/component.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/engagement.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/finding.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/import_scan.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/product.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/product_type.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/scan_configurations.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/repository → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/settings}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/driver_adapters/settings/settings.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/git_cli → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/defect_dojo/infraestructure/repository}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/git_cli/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/git_cli}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/git_cli/model → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/git_cli/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/git_cli/infrastructure/git_run.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/git_cli/model/gateway → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/git_cli/model}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/github → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/git_cli/model/gateway}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/git_cli/model/gateway/git_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/github/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/github}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/github/models → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/github/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/github/infrastructure/github_api.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/github/models/GithubPredefinedVariables.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/input_validations → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/github/models}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sbom → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/input_validations}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/input_validations/env_utils.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/input_validations/validate_input_with_regex_letters_number_and_only.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sbom}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sbom/deserealizator.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/settings.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/applications → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/domain → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/applications}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/applications/runner_report_sonar.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/model → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/domain}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/model/gateways → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/model}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/usecases → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/model/gateways}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/model/gateways/sonar_gateway.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/usecases}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/domain/usecases/report_sonar.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/driven_adapters → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/driven_adapters/sonarqube → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/driven_adapters}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/entry_points → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/driven_adapters/sonarqube}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/driven_adapters/sonarqube/sonarqube_report.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/helpers → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/entry_points}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/entry_points/entry_point_report_sonar.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/ssh → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/helpers}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/sonarqube/src/infrastructure/helpers/utils.py +0 -0
- {devsecops_engine_tools-1.30.2/devsecops_engine_tools/engine_utilities/utils → devsecops_engine_tools-1.32.0/devsecops_engine_tools/engine_utilities/ssh}/__init__.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/ssh/managment_private_key.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/api_error.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/dataclass_classmethod.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/datetime_parsing.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/logger_info.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/name_conversion.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/printers.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools/engine_utilities/utils/session_manager.py +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/dependency_links.txt +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/entry_points.txt +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/requires.txt +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/devsecops_engine_tools.egg-info/top_level.txt +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/setup.cfg +0 -0
- {devsecops_engine_tools-1.30.2 → devsecops_engine_tools-1.32.0}/setup.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: devsecops-engine-tools
|
|
3
|
-
Version: 1.
|
|
3
|
+
Version: 1.32.0
|
|
4
4
|
Summary: Tool for DevSecOps strategy
|
|
5
5
|
Home-page: https://github.com/bancolombia/devsecops-engine-tools
|
|
6
6
|
Author: Bancolombia DevSecOps Team
|
|
@@ -36,6 +36,7 @@ Requires-Dist: packageurl-python==0.15.6
|
|
|
36
36
|
[](https://sonarcloud.io/summary/new_code?id=bancolombia_devsecops-engine-tools)
|
|
37
37
|
[](https://sonarcloud.io/summary/new_code?id=bancolombia_devsecops-engine-tools)
|
|
38
38
|
[](#)
|
|
39
|
+
[](https://pypi.org/project/devsecops-engine-tools/)
|
|
39
40
|
[](https://hub.docker.com/r/bancolombia/devsecops-engine-tools)
|
|
41
42
|
|
|
@@ -133,10 +134,14 @@ For more information visit [here](https://github.com/bancolombia/devsecops-engin
|
|
|
133
134
|
<td>Free</td>
|
|
134
135
|
</tr>
|
|
135
136
|
<tr>
|
|
136
|
-
<td>ENGINE_SECRET</td>
|
|
137
|
+
<td rowspan="2">ENGINE_SECRET</td>
|
|
137
138
|
<td><a href="https://trufflesecurity.com/trufflehog">TRUFFLEHOG</a></td>
|
|
138
139
|
<td>Free</td>
|
|
139
140
|
</tr>
|
|
141
|
+
<tr>
|
|
142
|
+
<td><a href="https://gitleaks.io/">GITLEAKS</a></td>
|
|
143
|
+
<td>Free</td>
|
|
144
|
+
</tr>
|
|
140
145
|
<tr>
|
|
141
146
|
<td rowspan="2">ENGINE_CONTAINER</td>
|
|
142
147
|
<td><a href="https://www.paloaltonetworks.com/prisma/cloud">PRISMA</a></td>
|
|
@@ -13,6 +13,7 @@ from devsecops_engine_tools.engine_utilities.defect_dojo import (
|
|
|
13
13
|
Engagement,
|
|
14
14
|
Product,
|
|
15
15
|
Component,
|
|
16
|
+
FindingExclusion
|
|
16
17
|
)
|
|
17
18
|
from devsecops_engine_tools.engine_core.src.domain.model.exclusions import Exclusions
|
|
18
19
|
from devsecops_engine_tools.engine_core.src.domain.model.report import Report
|
|
@@ -42,9 +43,11 @@ logger = MyLogger.__call__(**settings.SETTING_LOGGER).get_logger()
|
|
|
42
43
|
@dataclass
|
|
43
44
|
class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
44
45
|
|
|
46
|
+
RISK_ACCEPTED = "Risk Accepted"
|
|
45
47
|
OUT_OF_SCOPE = "Out of Scope"
|
|
46
48
|
FALSE_POSITIVE = "False Positive"
|
|
47
49
|
TRANSFERRED_FINDING = "Transferred Finding"
|
|
50
|
+
ON_WHITELIST = "On Whitelist"
|
|
48
51
|
|
|
49
52
|
def send_vulnerability_management(
|
|
50
53
|
self, vulnerability_management: VulnerabilityManagement
|
|
@@ -79,6 +82,7 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
79
82
|
"BEARER": "Bearer CLI",
|
|
80
83
|
"DEPENDENCY_CHECK": "Dependency Check Scan",
|
|
81
84
|
"SONARQUBE": "SonarQube API Import",
|
|
85
|
+
"GITLEAKS": "Gitleaks Scan"
|
|
82
86
|
}
|
|
83
87
|
|
|
84
88
|
if any(
|
|
@@ -203,6 +207,11 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
203
207
|
"tags": tool,
|
|
204
208
|
"limit": dd_limits_query,
|
|
205
209
|
}
|
|
210
|
+
white_list_query_params = {
|
|
211
|
+
"risk_status": self.ON_WHITELIST,
|
|
212
|
+
"tags": tool,
|
|
213
|
+
"limit": dd_limits_query,
|
|
214
|
+
}
|
|
206
215
|
|
|
207
216
|
exclusions_risk_accepted = self._get_findings_with_exclusions(
|
|
208
217
|
session_manager,
|
|
@@ -211,7 +220,7 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
211
220
|
risk_accepted_query_params,
|
|
212
221
|
tool,
|
|
213
222
|
self._format_date_to_dd_format,
|
|
214
|
-
|
|
223
|
+
self.RISK_ACCEPTED,
|
|
215
224
|
)
|
|
216
225
|
|
|
217
226
|
exclusions_false_positive = self._get_findings_with_exclusions(
|
|
@@ -244,11 +253,29 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
244
253
|
self.TRANSFERRED_FINDING,
|
|
245
254
|
)
|
|
246
255
|
|
|
256
|
+
white_list = self._get_finding_exclusion(
|
|
257
|
+
session_manager, dd_max_retries, {
|
|
258
|
+
"type": "white_list",
|
|
259
|
+
}
|
|
260
|
+
)
|
|
261
|
+
|
|
262
|
+
exclusions_white_list = self._get_findings_with_exclusions(
|
|
263
|
+
session_manager,
|
|
264
|
+
service,
|
|
265
|
+
dd_max_retries,
|
|
266
|
+
white_list_query_params,
|
|
267
|
+
tool,
|
|
268
|
+
self._format_date_to_dd_format,
|
|
269
|
+
self.ON_WHITELIST,
|
|
270
|
+
white_list=white_list,
|
|
271
|
+
)
|
|
272
|
+
|
|
247
273
|
return (
|
|
248
274
|
list(exclusions_risk_accepted)
|
|
249
275
|
+ list(exclusions_false_positive)
|
|
250
276
|
+ list(exclusions_out_of_scope)
|
|
251
277
|
+ list(exclusions_transfer_finding)
|
|
278
|
+
+ list(exclusions_white_list)
|
|
252
279
|
)
|
|
253
280
|
except Exception as ex:
|
|
254
281
|
raise ExceptionFindingsExcepted(
|
|
@@ -272,8 +299,10 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
272
299
|
"HOST_DEFECT_DOJO"
|
|
273
300
|
]
|
|
274
301
|
|
|
302
|
+
session_manager = self._get_session_manager(dict_args, secret_tool, config_tool)
|
|
303
|
+
|
|
275
304
|
findings = self._get_findings(
|
|
276
|
-
|
|
305
|
+
session_manager,
|
|
277
306
|
service,
|
|
278
307
|
max_retries,
|
|
279
308
|
all_findings_query_params,
|
|
@@ -286,8 +315,14 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
286
315
|
)
|
|
287
316
|
)
|
|
288
317
|
|
|
318
|
+
white_list = self._get_finding_exclusion(
|
|
319
|
+
session_manager, max_retries, {
|
|
320
|
+
"type": "white_list",
|
|
321
|
+
}
|
|
322
|
+
)
|
|
323
|
+
|
|
289
324
|
all_exclusions = self._get_report_exclusions(
|
|
290
|
-
all_findings, self._format_date_to_dd_format, host_dd=host_dd
|
|
325
|
+
all_findings, self._format_date_to_dd_format, host_dd=host_dd, white_list=white_list
|
|
291
326
|
)
|
|
292
327
|
|
|
293
328
|
return all_findings, all_exclusions
|
|
@@ -461,25 +496,25 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
461
496
|
config_tool["VULNERABILITY_MANAGER"]["DEFECT_DOJO"]["HOST_DEFECT_DOJO"],
|
|
462
497
|
)
|
|
463
498
|
|
|
464
|
-
def _get_report_exclusions(self, total_findings, date_fn, host_dd):
|
|
499
|
+
def _get_report_exclusions(self, total_findings, date_fn, host_dd, **kwargs):
|
|
465
500
|
exclusions = []
|
|
466
501
|
for finding in total_findings:
|
|
467
502
|
if finding.risk_accepted:
|
|
468
503
|
exclusions.append(
|
|
469
504
|
self._create_report_exclusion(
|
|
470
|
-
finding, date_fn, "engine_risk",
|
|
505
|
+
finding, date_fn, "engine_risk", self.RISK_ACCEPTED, host_dd, **kwargs
|
|
471
506
|
)
|
|
472
507
|
)
|
|
473
508
|
elif finding.false_p:
|
|
474
509
|
exclusions.append(
|
|
475
510
|
self._create_report_exclusion(
|
|
476
|
-
finding, date_fn, "engine_risk", self.FALSE_POSITIVE, host_dd
|
|
511
|
+
finding, date_fn, "engine_risk", self.FALSE_POSITIVE, host_dd, **kwargs
|
|
477
512
|
)
|
|
478
513
|
)
|
|
479
514
|
elif finding.out_of_scope:
|
|
480
515
|
exclusions.append(
|
|
481
516
|
self._create_report_exclusion(
|
|
482
|
-
finding, date_fn, "engine_risk", self.OUT_OF_SCOPE, host_dd
|
|
517
|
+
finding, date_fn, "engine_risk", self.OUT_OF_SCOPE, host_dd, **kwargs
|
|
483
518
|
)
|
|
484
519
|
)
|
|
485
520
|
elif finding.risk_status == "Transfer Accepted":
|
|
@@ -490,18 +525,26 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
490
525
|
"engine_risk",
|
|
491
526
|
self.TRANSFERRED_FINDING,
|
|
492
527
|
host_dd,
|
|
528
|
+
**kwargs
|
|
529
|
+
)
|
|
530
|
+
)
|
|
531
|
+
elif finding.risk_status == self.ON_WHITELIST:
|
|
532
|
+
exclusions.append(
|
|
533
|
+
self._create_report_exclusion(
|
|
534
|
+
finding, date_fn, "engine_risk", self.ON_WHITELIST, host_dd, **kwargs
|
|
493
535
|
)
|
|
494
536
|
)
|
|
495
537
|
return exclusions
|
|
496
538
|
|
|
497
539
|
def _get_findings_with_exclusions(
|
|
498
|
-
self, session_manager, service, max_retries, query_params, tool, date_fn, reason
|
|
540
|
+
self, session_manager, service, max_retries, query_params, tool, date_fn, reason, **kwargs
|
|
499
541
|
):
|
|
500
542
|
findings = self._get_findings(
|
|
501
543
|
session_manager, service, max_retries, query_params
|
|
502
544
|
)
|
|
545
|
+
|
|
503
546
|
return map(
|
|
504
|
-
partial(self._create_exclusion, date_fn=date_fn, tool=tool, reason=reason),
|
|
547
|
+
partial(self._create_exclusion, date_fn=date_fn, tool=tool, reason=reason, **kwargs),
|
|
505
548
|
findings,
|
|
506
549
|
)
|
|
507
550
|
|
|
@@ -512,6 +555,14 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
512
555
|
).results
|
|
513
556
|
|
|
514
557
|
return self._retries_requests(request_func, max_retries, retry_delay=5)
|
|
558
|
+
|
|
559
|
+
def _get_finding_exclusion(self, session_manager, max_retries, query_params):
|
|
560
|
+
def request_func():
|
|
561
|
+
return FindingExclusion.get_finding_exclusion(
|
|
562
|
+
session=session_manager, **query_params
|
|
563
|
+
).results
|
|
564
|
+
|
|
565
|
+
return self._retries_requests(request_func, max_retries, retry_delay=5)
|
|
515
566
|
|
|
516
567
|
def _retries_requests(self, request_func, max_retries, retry_delay):
|
|
517
568
|
for attempt in range(max_retries):
|
|
@@ -526,23 +577,34 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
526
577
|
logger.error("Maximum number of retries reached, aborting.")
|
|
527
578
|
raise e
|
|
528
579
|
|
|
529
|
-
def _date_reason_based(self, finding, date_fn, reason):
|
|
530
|
-
if reason in [self.FALSE_POSITIVE, self.OUT_OF_SCOPE]:
|
|
531
|
-
create_date = date_fn(finding.last_status_update)
|
|
532
|
-
expired_date = date_fn(None)
|
|
533
|
-
elif reason == self.TRANSFERRED_FINDING:
|
|
534
|
-
create_date = date_fn(finding.transfer_finding.date)
|
|
535
|
-
expired_date = date_fn(finding.transfer_finding.expiration_date)
|
|
536
|
-
else:
|
|
537
|
-
last_accepted_risk = finding.accepted_risks[-1]
|
|
538
|
-
create_date = date_fn(last_accepted_risk["created"])
|
|
539
|
-
expired_date = date_fn(last_accepted_risk["expiration_date"])
|
|
540
580
|
|
|
541
|
-
|
|
581
|
+
def _date_reason_based(self, finding, date_fn, reason, tool, **kwargs):
|
|
582
|
+
def get_vuln_id(finding, tool):
|
|
583
|
+
if tool == "engine_risk":
|
|
584
|
+
return finding.id[0]["vulnerability_id"] if finding.id else finding.vuln_id_from_tool
|
|
585
|
+
else:
|
|
586
|
+
return finding.vulnerability_ids[0]["vulnerability_id"] if finding.vulnerability_ids else finding.vuln_id_from_tool
|
|
587
|
+
|
|
588
|
+
def get_dates_from_whitelist(vuln_id, white_list):
|
|
589
|
+
matching_finding = next(filter(lambda x: x.unique_id_from_tool == vuln_id, white_list), None)
|
|
590
|
+
if matching_finding:
|
|
591
|
+
return date_fn(matching_finding.create_date), date_fn(matching_finding.expiration_date)
|
|
592
|
+
return date_fn(None), date_fn(None)
|
|
593
|
+
|
|
594
|
+
reason_to_dates = {
|
|
595
|
+
self.FALSE_POSITIVE: lambda: (date_fn(finding.last_status_update), date_fn(None)),
|
|
596
|
+
self.OUT_OF_SCOPE: lambda: (date_fn(finding.last_status_update), date_fn(None)),
|
|
597
|
+
self.TRANSFERRED_FINDING: lambda: (date_fn(finding.transfer_finding.date), date_fn(finding.transfer_finding.expiration_date)),
|
|
598
|
+
self.RISK_ACCEPTED: lambda: (date_fn(finding.accepted_risks[-1]["created"]), date_fn(finding.accepted_risks[-1]["expiration_date"])),
|
|
599
|
+
self.ON_WHITELIST: lambda: get_dates_from_whitelist(get_vuln_id(finding, tool), kwargs.get("white_list", [])),
|
|
600
|
+
}
|
|
542
601
|
|
|
543
|
-
|
|
544
|
-
create_date, expired_date
|
|
602
|
+
create_date, expired_date = reason_to_dates.get(reason, lambda: (date_fn(None), date_fn(None)))()
|
|
603
|
+
return create_date, expired_date
|
|
545
604
|
|
|
605
|
+
def _create_exclusion(self, finding, date_fn, tool, reason, **kwargs):
|
|
606
|
+
create_date, expired_date = self._date_reason_based(finding, date_fn, reason, tool, **kwargs)
|
|
607
|
+
|
|
546
608
|
return Exclusions(
|
|
547
609
|
id=(
|
|
548
610
|
finding.vuln_id_from_tool
|
|
@@ -560,8 +622,8 @@ class DefectDojoPlatform(VulnerabilityManagementGateway):
|
|
|
560
622
|
reason=reason,
|
|
561
623
|
)
|
|
562
624
|
|
|
563
|
-
def _create_report_exclusion(self, finding, date_fn, tool, reason, host_dd):
|
|
564
|
-
create_date, expired_date = self._date_reason_based(finding, date_fn, reason)
|
|
625
|
+
def _create_report_exclusion(self, finding, date_fn, tool, reason, host_dd, **kwargs):
|
|
626
|
+
create_date, expired_date = self._date_reason_based(finding, date_fn, reason, tool, **kwargs)
|
|
565
627
|
|
|
566
628
|
return Exclusions(
|
|
567
629
|
id=(
|
|
@@ -7,6 +7,12 @@ from devsecops_engine_tools.engine_sast.engine_secret.src.infrastructure.driven_
|
|
|
7
7
|
from devsecops_engine_tools.engine_sast.engine_secret.src.infrastructure.driven_adapters.trufflehog.trufflehog_deserealizator import (
|
|
8
8
|
SecretScanDeserealizator
|
|
9
9
|
)
|
|
10
|
+
from devsecops_engine_tools.engine_sast.engine_secret.src.infrastructure.driven_adapters.gitleaks.gitleaks_tool import (
|
|
11
|
+
GitleaksTool
|
|
12
|
+
)
|
|
13
|
+
from devsecops_engine_tools.engine_sast.engine_secret.src.infrastructure.driven_adapters.gitleaks.gitleaks_deserealizator import (
|
|
14
|
+
GitleaksDeserealizator
|
|
15
|
+
)
|
|
10
16
|
from devsecops_engine_tools.engine_utilities.git_cli.infrastructure.git_run import (
|
|
11
17
|
GitRun
|
|
12
18
|
)
|
|
@@ -19,6 +25,10 @@ def runner_secret_scan(dict_args, tool, devops_platform_gateway, secret_tool):
|
|
|
19
25
|
if (tool == "TRUFFLEHOG"):
|
|
20
26
|
tool_gateway = TrufflehogRun()
|
|
21
27
|
tool_deserealizator = SecretScanDeserealizator()
|
|
28
|
+
elif (tool == "GITLEAKS"):
|
|
29
|
+
tool_gateway = GitleaksTool()
|
|
30
|
+
tool_deserealizator = GitleaksDeserealizator()
|
|
31
|
+
|
|
22
32
|
return engine_secret_scan(
|
|
23
33
|
devops_platform_gateway = devops_platform_gateway,
|
|
24
34
|
tool_gateway = tool_gateway,
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
from datetime import datetime
|
|
2
|
+
from dataclasses import dataclass
|
|
3
|
+
from typing import List
|
|
4
|
+
from devsecops_engine_tools.engine_core.src.domain.model.finding import Finding, Category
|
|
5
|
+
from devsecops_engine_tools.engine_sast.engine_secret.src.domain.model.gateway.gateway_deserealizator import (
|
|
6
|
+
DeseralizatorGateway
|
|
7
|
+
)
|
|
8
|
+
|
|
9
|
+
@dataclass
|
|
10
|
+
class GitleaksDeserealizator(DeseralizatorGateway):
|
|
11
|
+
|
|
12
|
+
def get_list_vulnerability(self, results_scan_list: List[dict], path_directory: str, os: str) -> List[Finding]:
|
|
13
|
+
list_open_vulnerabilities = []
|
|
14
|
+
current_date=datetime.now().strftime("%d%m%Y")
|
|
15
|
+
|
|
16
|
+
for result in results_scan_list:
|
|
17
|
+
vulnerability_open = Finding(
|
|
18
|
+
id=result.get("RuleID", "SECRET_SCANNING"),
|
|
19
|
+
cvss=None,
|
|
20
|
+
where=self.get_where_correctly(result, path_directory),
|
|
21
|
+
description=result.get("Description", "No description available"),
|
|
22
|
+
severity="critical",
|
|
23
|
+
identification_date=current_date,
|
|
24
|
+
published_date_cve=None,
|
|
25
|
+
module="engine_secret",
|
|
26
|
+
category=Category.VULNERABILITY,
|
|
27
|
+
requirements="",
|
|
28
|
+
tool="Gitleaks",
|
|
29
|
+
)
|
|
30
|
+
list_open_vulnerabilities.append(vulnerability_open)
|
|
31
|
+
return list_open_vulnerabilities
|
|
32
|
+
|
|
33
|
+
def get_where_correctly(self, result: dict, path_directory=""):
|
|
34
|
+
path = result.get("File", "").replace(path_directory, "")
|
|
35
|
+
hidden_secret = str(result.get("Secret"))[:3] + '*' * 9 + str(result.get("Secret"))[-3:]
|
|
36
|
+
return f"{path}, Secret: {hidden_secret}"
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import json
|
|
2
|
+
import os
|
|
3
|
+
import re
|
|
4
|
+
import subprocess
|
|
5
|
+
import requests
|
|
6
|
+
from concurrent.futures import ThreadPoolExecutor, as_completed
|
|
7
|
+
from devsecops_engine_tools.engine_utilities.utils.utils import Utils
|
|
8
|
+
from devsecops_engine_tools.engine_sast.engine_secret.src.domain.model.gateway.tool_gateway import (
|
|
9
|
+
ToolGateway,
|
|
10
|
+
)
|
|
11
|
+
from devsecops_engine_tools.engine_utilities.utils.logger_info import MyLogger
|
|
12
|
+
from devsecops_engine_tools.engine_utilities import settings
|
|
13
|
+
from devsecops_engine_tools.engine_utilities.utils.utils import Utils
|
|
14
|
+
|
|
15
|
+
logger = MyLogger.__call__(**settings.SETTING_LOGGER).get_logger()
|
|
16
|
+
|
|
17
|
+
class GitleaksTool(ToolGateway):
|
|
18
|
+
_COMMAND = None
|
|
19
|
+
|
|
20
|
+
def install_tool(self, agent_os, agent_temp_dir, tool_version) -> any:
|
|
21
|
+
is_windows_os = re.search(r"Windows", agent_os)
|
|
22
|
+
is_linux_os = re.search(r"Linux", agent_os)
|
|
23
|
+
|
|
24
|
+
if is_windows_os:
|
|
25
|
+
file_extension = "windows_x64.zip"
|
|
26
|
+
elif is_linux_os:
|
|
27
|
+
file_extension = "linux_x64.tar.gz"
|
|
28
|
+
else:
|
|
29
|
+
file_extension = "darwin_x64.tar.gz"
|
|
30
|
+
|
|
31
|
+
command = f"{agent_temp_dir}{os.sep}gitleaks"
|
|
32
|
+
command = f"{command}.exe" if is_windows_os else command
|
|
33
|
+
|
|
34
|
+
self._COMMAND = command
|
|
35
|
+
result = subprocess.run(f"{command} --version", capture_output=True, shell=True, text=True)
|
|
36
|
+
is_tool_installed = re.search(fr"{tool_version}", result.stdout.strip())
|
|
37
|
+
|
|
38
|
+
if is_tool_installed: return
|
|
39
|
+
|
|
40
|
+
try:
|
|
41
|
+
url = f"https://github.com/gitleaks/gitleaks/releases/download/v{tool_version}/gitleaks_{tool_version}_{file_extension}"
|
|
42
|
+
response = requests.get(url, allow_redirects=True)
|
|
43
|
+
compressed_name = os.path.join(
|
|
44
|
+
agent_temp_dir, f"gitleaks_{tool_version}_{file_extension}"
|
|
45
|
+
)
|
|
46
|
+
with open(compressed_name, "wb") as f:
|
|
47
|
+
f.write(response.content)
|
|
48
|
+
|
|
49
|
+
if is_windows_os:
|
|
50
|
+
Utils().unzip_file(compressed_name, agent_temp_dir)
|
|
51
|
+
else:
|
|
52
|
+
Utils().extract_targz_file(compressed_name, agent_temp_dir)
|
|
53
|
+
|
|
54
|
+
except Exception as ex:
|
|
55
|
+
logger.error(f"An error ocurred downloading Gitleaks: {ex}")
|
|
56
|
+
|
|
57
|
+
def _extract_json_data(self, file_path):
|
|
58
|
+
if os.path.exists(file_path):
|
|
59
|
+
with open(file_path, 'r', encoding='utf-8') as f:
|
|
60
|
+
return json.load(f)
|
|
61
|
+
else:
|
|
62
|
+
print(f"File {file_path} does not exist")
|
|
63
|
+
return []
|
|
64
|
+
|
|
65
|
+
def _create_report(self, output_file, combined_data):
|
|
66
|
+
with open(output_file, 'w', encoding='utf-8') as f:
|
|
67
|
+
json.dump(combined_data, f, ensure_ascii=False, indent=4)
|
|
68
|
+
|
|
69
|
+
def _check_path(self, path, excluded_paths):
|
|
70
|
+
parts = path.split(os.sep)
|
|
71
|
+
for part in parts:
|
|
72
|
+
if part in excluded_paths: return True
|
|
73
|
+
return False
|
|
74
|
+
|
|
75
|
+
def _add_flags(self, config_tool, tool, agent_work_folder):
|
|
76
|
+
flags = []
|
|
77
|
+
if not config_tool[tool]["ALLOW_IGNORE_LEAKS"]:
|
|
78
|
+
flags.append("--ignore-gitleaks-allow")
|
|
79
|
+
|
|
80
|
+
if config_tool[tool]["ENABLE_CUSTOM_RULES"]:
|
|
81
|
+
flags.extend(["--config", f"{agent_work_folder}{os.sep}rules{os.sep}gitleaks{os.sep}gitleaks.toml"])
|
|
82
|
+
|
|
83
|
+
return flags
|
|
84
|
+
|
|
85
|
+
def run_tool_secret_scan(
|
|
86
|
+
self,
|
|
87
|
+
files,
|
|
88
|
+
agent_os,
|
|
89
|
+
agent_work_folder,
|
|
90
|
+
repository_name,
|
|
91
|
+
config_tool,
|
|
92
|
+
secret_tool, # For external checks
|
|
93
|
+
secret_external_checks, # For external checks
|
|
94
|
+
agent_temp_dir,
|
|
95
|
+
tool
|
|
96
|
+
):
|
|
97
|
+
command = [self._COMMAND, "dir"]
|
|
98
|
+
finding_path = os.path.join(agent_work_folder, "gitleaks_report.json")
|
|
99
|
+
excluded_paths = config_tool[tool]["EXCLUDE_PATH"]
|
|
100
|
+
|
|
101
|
+
if config_tool[tool]["ENABLE_CUSTOM_RULES"]:
|
|
102
|
+
Utils().configurate_external_checks(tool, config_tool, secret_tool, secret_external_checks, agent_work_folder)
|
|
103
|
+
|
|
104
|
+
try:
|
|
105
|
+
findings = []
|
|
106
|
+
flags = self._add_flags(config_tool, tool, agent_work_folder)
|
|
107
|
+
if len(files) > 1:
|
|
108
|
+
with ThreadPoolExecutor(max_workers=config_tool[tool]["NUMBER_THREADS"]) as executor:
|
|
109
|
+
futures = []
|
|
110
|
+
|
|
111
|
+
for pull_file in files:
|
|
112
|
+
if self._check_path(pull_file, excluded_paths): continue
|
|
113
|
+
|
|
114
|
+
aux_finding_path = os.path.join(
|
|
115
|
+
agent_work_folder, f"gitleaks_aux_report_{pull_file.replace(os.sep, '_')}.json"
|
|
116
|
+
)
|
|
117
|
+
|
|
118
|
+
command_aux = command.copy()
|
|
119
|
+
command_aux.extend([
|
|
120
|
+
os.path.join(agent_work_folder, repository_name, pull_file),
|
|
121
|
+
"--report-path", aux_finding_path
|
|
122
|
+
])
|
|
123
|
+
command_aux.extend(flags)
|
|
124
|
+
|
|
125
|
+
futures.append(executor.submit(self._run_subprocess_command, command_aux, aux_finding_path))
|
|
126
|
+
|
|
127
|
+
for future in as_completed(futures):
|
|
128
|
+
result = future.result()
|
|
129
|
+
findings.extend(result)
|
|
130
|
+
|
|
131
|
+
self._create_report(finding_path, findings)
|
|
132
|
+
else:
|
|
133
|
+
command.extend([files[0], "--report-path", finding_path])
|
|
134
|
+
command.extend(flags)
|
|
135
|
+
|
|
136
|
+
subprocess.run(command, capture_output=True, text=True)
|
|
137
|
+
findings = self._extract_json_data(finding_path)
|
|
138
|
+
|
|
139
|
+
return findings, finding_path
|
|
140
|
+
|
|
141
|
+
except Exception as e:
|
|
142
|
+
logger.error(f"Error executing gitleaks scan: {e}")
|
|
143
|
+
|
|
144
|
+
def _run_subprocess_command(self, command_aux, aux_finding_path):
|
|
145
|
+
try:
|
|
146
|
+
subprocess.run(command_aux, capture_output=True, text=True)
|
|
147
|
+
return self._extract_json_data(aux_finding_path)
|
|
148
|
+
except Exception as e:
|
|
149
|
+
logger.error(f"Error executing gitleaks on {command_aux}: {e}")
|
|
150
|
+
return []
|
|
@@ -5,4 +5,5 @@ from .applications.finding import Finding
|
|
|
5
5
|
from .applications.connect import Connect
|
|
6
6
|
from .applications.engagement import Engagement
|
|
7
7
|
from .applications.product import Product
|
|
8
|
-
from .applications.component import Component
|
|
8
|
+
from .applications.component import Component
|
|
9
|
+
from .applications.finding_exclusion import FindingExclusion
|
|
@@ -1,9 +1,6 @@
|
|
|
1
|
-
from devsecops_engine_tools.engine_utilities.defect_dojo.domain.request_objects.finding import FindingRequest
|
|
2
1
|
from devsecops_engine_tools.engine_utilities.defect_dojo.domain.serializers.finding import FindingSerializer
|
|
3
2
|
from devsecops_engine_tools.engine_utilities.defect_dojo.infraestructure.driver_adapters.finding import FindingRestConsumer
|
|
4
3
|
from devsecops_engine_tools.engine_utilities.defect_dojo.domain.user_case.finding import FindingUserCase, FindingGetUserCase
|
|
5
|
-
from devsecops_engine_tools.engine_utilities.utils.session_manager import SessionManager
|
|
6
|
-
from devsecops_engine_tools.engine_utilities.utils.api_error import ApiError
|
|
7
4
|
from devsecops_engine_tools.engine_utilities.utils.logger_info import MyLogger
|
|
8
5
|
from devsecops_engine_tools.engine_utilities import settings
|
|
9
6
|
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
from devsecops_engine_tools.engine_utilities.utils.api_error import ApiError
|
|
2
|
+
from devsecops_engine_tools.engine_utilities.defect_dojo.domain.user_case.finding_exclusion import FindingExclusionUserCase
|
|
3
|
+
from devsecops_engine_tools.engine_utilities.defect_dojo.infraestructure.driver_adapters.finding_exclusion import FindingExclusionRestConsumer
|
|
4
|
+
|
|
5
|
+
class FindingExclusion:
|
|
6
|
+
@staticmethod
|
|
7
|
+
def get_finding_exclusion(session, **request):
|
|
8
|
+
try:
|
|
9
|
+
rest_finding_exclusion = FindingExclusionRestConsumer(session=session)
|
|
10
|
+
|
|
11
|
+
uc = FindingExclusionUserCase(rest_finding_exclusion)
|
|
12
|
+
return uc.execute(request)
|
|
13
|
+
except ApiError as e:
|
|
14
|
+
raise e
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import dataclasses
|
|
2
|
+
from typing import List
|
|
3
|
+
from devsecops_engine_tools.engine_utilities.utils.dataclass_classmethod import FromDictMixin
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
@dataclasses.dataclass
|
|
7
|
+
class FindingExclusion(FromDictMixin):
|
|
8
|
+
uuid: str = ""
|
|
9
|
+
unique_id_from_tool: str = ""
|
|
10
|
+
type: str = ""
|
|
11
|
+
create_date: str = ""
|
|
12
|
+
expiration_date: str = ""
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
@dataclasses.dataclass
|
|
16
|
+
class FindingExclusionList(FromDictMixin):
|
|
17
|
+
count: int = 0
|
|
18
|
+
next = None
|
|
19
|
+
previous = None
|
|
20
|
+
results: List[FindingExclusion] = dataclasses.field(default_factory=list)
|
|
@@ -63,7 +63,7 @@ class FindingSerializer(Schema):
|
|
|
63
63
|
reviewers = fields.List(fields.Int, requerided=False)
|
|
64
64
|
risk_accetance = fields.Int(requerided=False)
|
|
65
65
|
risk_status = fields.Str(
|
|
66
|
-
required=False, validate=validate.OneOf(["Risk Pending", "Risk Rejected", "Risk Expired", "Risk Accepted", "Risk Active", "Transfer Pending", "Transfer Rejected", "Transfer Expired", "Transfer Accepted"])
|
|
66
|
+
required=False, validate=validate.OneOf(["Risk Pending", "Risk Rejected", "Risk Expired", "Risk Accepted", "Risk Active", "Transfer Pending", "Transfer Rejected", "Transfer Expired", "Transfer Accepted", "On Whitelist", "On Blacklist"])
|
|
67
67
|
)
|
|
68
68
|
risk_accepted = fields.Bool(requerided=False)
|
|
69
69
|
sast_sink_object = fields.Str(requeride=False)
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
from devsecops_engine_tools.engine_utilities.defect_dojo.infraestructure.driver_adapters.finding_exclusion import FindingExclusionRestConsumer
|
|
2
|
+
|
|
3
|
+
class FindingExclusionUserCase:
|
|
4
|
+
def __init__(self, rest_finding_exclusion: FindingExclusionRestConsumer):
|
|
5
|
+
self.__rest_finding_exclusion = rest_finding_exclusion
|
|
6
|
+
|
|
7
|
+
def execute(self, request):
|
|
8
|
+
response = self.__rest_finding_exclusion.get_finding_exclusions(request)
|
|
9
|
+
return response
|
|
@@ -66,12 +66,12 @@ class ImportScanUserCase:
|
|
|
66
66
|
with id {product_type_id}"
|
|
67
67
|
)
|
|
68
68
|
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
69
|
+
product = self.__rest_product.post_product(request, product_type_id)
|
|
70
|
+
product_id = product.id
|
|
71
|
+
logger.info(
|
|
72
|
+
f"product created: {product.name}\
|
|
73
|
+
found with id: {product.id}"
|
|
74
|
+
)
|
|
75
75
|
|
|
76
76
|
api_scan_bool = re.search(" API ", request.scan_type)
|
|
77
77
|
if api_scan_bool:
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
from devsecops_engine_tools.engine_utilities.utils.api_error import ApiError
|
|
2
|
+
from devsecops_engine_tools.engine_utilities.utils.logger_info import MyLogger
|
|
3
|
+
from devsecops_engine_tools.engine_utilities.defect_dojo.domain.models.finding_exclusion import FindingExclusionList
|
|
4
|
+
from devsecops_engine_tools.engine_utilities.defect_dojo.infraestructure.driver_adapters.settings.settings import VERIFY_CERTIFICATE
|
|
5
|
+
from devsecops_engine_tools.engine_utilities.utils.session_manager import SessionManager
|
|
6
|
+
from devsecops_engine_tools.engine_utilities.settings import SETTING_LOGGER
|
|
7
|
+
|
|
8
|
+
logger = MyLogger.__call__(**SETTING_LOGGER).get_logger()
|
|
9
|
+
|
|
10
|
+
class FindingExclusionRestConsumer:
|
|
11
|
+
def __init__(self, session: SessionManager):
|
|
12
|
+
self.__token = session._token
|
|
13
|
+
self.__host = session._host
|
|
14
|
+
self.__session = session._instance
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def get_finding_exclusions(self, request) -> FindingExclusionList:
|
|
18
|
+
url = f"{self.__host}/api/v2/finding_exclusions/"
|
|
19
|
+
headers = {"Authorization": f"Token {self.__token}", "Content-Type": "application/json"}
|
|
20
|
+
try:
|
|
21
|
+
response = self.__session.get(url, headers=headers, params=request, verify=VERIFY_CERTIFICATE)
|
|
22
|
+
if response.status_code != 200:
|
|
23
|
+
raise ApiError(response.json())
|
|
24
|
+
finding_exclusions_object = FindingExclusionList.from_dict(response.json())
|
|
25
|
+
except Exception as e:
|
|
26
|
+
logger.error(f"from dict FindingExclusion: {e}")
|
|
27
|
+
raise ApiError(e)
|
|
28
|
+
return finding_exclusions_object
|
|
File without changes
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import zipfile
|
|
2
|
+
import tarfile
|
|
2
3
|
import platform
|
|
3
4
|
from devsecops_engine_tools.engine_utilities.github.infrastructure.github_api import (
|
|
4
5
|
GithubApi,
|
|
@@ -29,6 +30,10 @@ class Utils:
|
|
|
29
30
|
def unzip_file(self, zip_file_path, extract_path):
|
|
30
31
|
with zipfile.ZipFile(zip_file_path, "r") as zip_ref:
|
|
31
32
|
zip_ref.extractall(extract_path)
|
|
33
|
+
|
|
34
|
+
def extract_targz_file(self, tar_file_path, extract_path):
|
|
35
|
+
with tarfile.open(tar_file_path, "r:gz") as tar_ref:
|
|
36
|
+
tar_ref.extractall(path=extract_path)
|
|
32
37
|
|
|
33
38
|
def configurate_external_checks(self, tool, config_tool, secret_tool, secret_external_checks, agent_work_folder="/tmp"):
|
|
34
39
|
try:
|
|
@@ -103,7 +108,7 @@ class Utils:
|
|
|
103
108
|
config_tool[tool]["EXTERNAL_DIR_OWNER"],
|
|
104
109
|
config_tool[tool]["EXTERNAL_DIR_REPOSITORY"],
|
|
105
110
|
github_token,
|
|
106
|
-
agent_work_folder
|
|
111
|
+
agent_work_folder
|
|
107
112
|
)
|
|
108
113
|
|
|
109
114
|
except Exception as ex:
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
version = '1.32.0'
|