Skip to main content

Introduction and Goals

Initially, the goal of secureCodeBox was to provide a tool for easy integrating security test tools into your CI/CD pipeline to run against your web project. Some years ago we asked ourselves: Why only scan a single project? So a great idea was born: Consider the whole company as a project. Additionally, secureCodeBox can aid penetration testers in the recon and discovery phase of a security assessment. The purpose of secureCodeBox is not to replace the penetration testers or make them obsolete. We strongly recommend running extensive tests by experienced penetration testers on all your applications.

The following goals have been established for this project:

Priority
1The project shall be enhanced by features that are suitable to keep.
2The project is scalable and resource efficient (FaaS).
3The project implements additional scanners that are a useful addition for the current suite, limiting redundancy.
4The findings are displayed in a navigable way with least amount of duplication.
5SecureCodeBox starts new relevant scans in an agile way, based on previous findings.

Requirements Overview​

Use-case diagram

IdRequirementExplanation
UC1Initiate scansInitiating scans in parallel and orchestrating them.
UC1.1Initiating subsequent scansInitiate scans based on previous results, through cascading rules.
UC2Parse findingsParse findings in a human readable and friendly way.

Quality Goals​

Below, the most important qualities are described that this project strives for. The qualities are categorized using the ISO 25010 standard. Most of these qualities are derived from blog post The Architecture of secureCodeBox v2. For the entire list of quality-goals see Quality Requirements.

CategoryQualityDescriptionScenario
MaintainabilityModularAll components should be loosely coupled to easily swap them
Ease of integrationIt should be possible to easily integrate new scanners
Ease of ContributingSCB should be well documented
Ease of updatingThird-party software should be carefully chosen, for maintainabilitySC1
PortabilityAdaptableSCB Should run everywhere (local, VMs, Cloud, etc.)SC2
Performance EfficiencyResource EfficientSCB should scale to the available resourcesSC3
Time EfficientTasks should run parallel to optimize the use of resources
UsabilityEase of IntegrationThe definition and implementation of a scan process should be easySC4

Scenarios​

IdScenario
SC1A third-party updates their software with a breaking change. Effort to support this update is minimal
SC2A company is running SCB in the cloud, due to limited resources on premise
SC3SCB is out of resources and a new scan is initiated. The scan is queued until resources are available
SC4A scan is easily created and started by writing and loading a config file

Stakeholders​

CompanyNameRoleGitHub AccountExpectations
iteratecRobert SeedorffProduct Owner@rseerdorff
Sven StrittmatterScrum Master & Developer@Weltraumschaf
Jannik HollenbachCore Developer@J12934
Max MaassCore Developer@malexmave
Ilyes Ben DlalaCore Developer@Ilyesbdlala
Rami SouaiCore Developer@RamiSouai
SecuraRalph MoonenN/A
Sander Maijers@sanmai-NL
Jop Zitman@EndPositive
Stijn van EsDeveloper@Stijn-FEContributes