Suricata is a network Intrusion Detection System, Intrusion Prevention System and Network Security Monitoring engine developed by the OISF and the Suricata community.
Suricata is a network IDS, IPS and NSM engine
developed by the OISF and the Suricata community.
We’re happily taking patches and other contributions. Please see our
Contribution
Process
for how to get started.
Suricata is a complex piece of software dealing with mostly untrusted
input. Mishandling this input will have serious consequences:
In other words, we think the stakes are pretty high, especially since
in many common cases the IDS/IPS will be directly reachable by an
attacker.
For this reason, we have developed a QA process that is quite
extensive. A consequence is that contributing to Suricata can be a
somewhat lengthy process.
On a high level, the steps are:
OISF team members are able to submit builds to our private QA
setup. It will run a series of build tests and a regression suite to
confirm no existing features break.
The final QA runs takes a few hours minimally, and generally runs
overnight. It currently runs:
Next to these tests, based on the type of code change further tests
can be run manually:
It’s important to realize that almost all of the tests above are used
as acceptance tests. If something fails, it’s up to you to address
this in your code.
One step of the QA is currently run post-merge. We submit builds to
the Coverity Scan program. Due to limitations of this (free) service,
we can submit once a day max. Of course it can happen that after the
merge the community will find issues. For both cases we request you to
help address the issues as they may come up.
Q: Will you accept my PR?
A: That depends on a number of things, including the code
quality. With new features it also depends on whether the team and/or
the community think the feature is useful, how much it affects other
code and features, the risk of performance regressions, etc.
Q: When will my PR be merged?
A: It depends, if it’s a major feature or considered a high risk
change, it will probably go into the next major version.
Q: Why was my PR closed?
A: As documented in the Suricata GitHub
workflow,
we expect a new pull request for every change.
Normally, the team (or community) will give feedback on a pull request
after which it is expected to be replaced by an improved PR. So look
at the comments. If you disagree with the comments we can still
discuss them in the closed PR.
If the PR was closed without comments it’s likely due to QA
failure. If the GitHub-CI checks failed, the PR should be fixed right
away. No need for a discussion about it, unless you believe the QA
failure is incorrect.
Q: The compiler/code analyser/tool is wrong, what now?
A: To assist in the automation of the QA, we’re not accepting warnings
or errors to stay. In some cases this could mean that we add a
suppression if the tool supports that (e.g. valgrind, DrMemory). Some
warnings can be disabled. In some exceptional cases the only
‘solution’ is to refactor the code to work around a static code
checker limitation false positive. While frustrating, we prefer this
over leaving warnings in the output. Warnings tend to get ignored and
then increase risk of hiding other warnings.
Q: I think your QA test is wrong
A: If you really think it is, we can discuss how to improve it. But
don’t come to this conclusion too quickly, more often it’s the code
that turns out to be wrong.
Q: Do you require signing of a contributor license agreement?
A: Yes, we do this to keep the ownership of Suricata in one hand: the
Open Information Security Foundation. See
http://suricata.io/about/open-source/ and
http://suricata.io/about/contribution-agreement/