mirror of
https://github.com/elicpeter/nyx.git
synced 2026-06-09 19:45:13 +02:00
Phase 1 (#33)
* chore: Exclude CLAUDE.md from Cargo.toml * feat: add callgraph module and integrate into main analysis flow * feat: enhance CLI with new severity filtering and analysis modes * feat: update CHANGELOG with recent enhancements and fixes to severity filtering and output handling * feat: implement state-model dataflow analysis for resource lifecycle and auth state * feat: enhance diagnostic output formatting and add evidence structure * feat: implement attack surface ranking for diagnostics with scoring and sorting * feat: add comprehensive documentation for installation, usage, and rules reference * feat: add multiple language support for command execution and evaluation endpoints * feat: implement inline suppression for findings using `nyx:ignore` comments * feat: add confidence levels to AST patterns and update output structure * feat: implement low-noise prioritization system with category filtering, rollup grouping, and configurable budgets * feat: bump version to 0.4.0 and update changelog with new features and improvements * feat: add dead code allowances to various functions in mod.rs and real_world_tests.rs
This commit is contained in:
parent
19b578c5c4
commit
1bbe4b1cfb
456 changed files with 25628 additions and 1228 deletions
|
|
@ -8,7 +8,19 @@ pub static RULES: &[LabelRule] = &[
|
|||
label: DataLabel::Source(Cap::all()),
|
||||
},
|
||||
LabelRule {
|
||||
matchers: &["getParameter", "getInputStream", "getHeader", "getCookies"],
|
||||
matchers: &[
|
||||
"getParameter",
|
||||
"getInputStream",
|
||||
"getHeader",
|
||||
"getCookies",
|
||||
"getReader",
|
||||
"getQueryString",
|
||||
"getPathInfo",
|
||||
],
|
||||
label: DataLabel::Source(Cap::all()),
|
||||
},
|
||||
LabelRule {
|
||||
matchers: &["readObject", "readLine"],
|
||||
label: DataLabel::Source(Cap::all()),
|
||||
},
|
||||
// ───────── Sanitizers ──────────
|
||||
|
|
@ -18,13 +30,21 @@ pub static RULES: &[LabelRule] = &[
|
|||
},
|
||||
// ─────────── Sinks ─────────────
|
||||
LabelRule {
|
||||
matchers: &["Runtime.exec"],
|
||||
matchers: &["Runtime.exec", "ProcessBuilder"],
|
||||
label: DataLabel::Sink(Cap::SHELL_ESCAPE),
|
||||
},
|
||||
LabelRule {
|
||||
matchers: &["executeQuery", "executeUpdate", "prepareStatement"],
|
||||
label: DataLabel::Sink(Cap::SHELL_ESCAPE),
|
||||
},
|
||||
LabelRule {
|
||||
matchers: &["Class.forName"],
|
||||
label: DataLabel::Sink(Cap::SHELL_ESCAPE),
|
||||
},
|
||||
LabelRule {
|
||||
matchers: &["println", "print", "write"],
|
||||
label: DataLabel::Sink(Cap::HTML_ESCAPE),
|
||||
},
|
||||
];
|
||||
|
||||
pub static KINDS: Map<&'static str, Kind> = phf_map! {
|
||||
|
|
@ -33,8 +53,10 @@ pub static KINDS: Map<&'static str, Kind> = phf_map! {
|
|||
"while_statement" => Kind::While,
|
||||
"for_statement" => Kind::For,
|
||||
"enhanced_for_statement" => Kind::For,
|
||||
"do_statement" => Kind::While,
|
||||
|
||||
"return_statement" => Kind::Return,
|
||||
"throw_statement" => Kind::Return,
|
||||
"break_statement" => Kind::Break,
|
||||
"continue_statement" => Kind::Continue,
|
||||
|
||||
|
|
@ -46,6 +68,15 @@ pub static KINDS: Map<&'static str, Kind> = phf_map! {
|
|||
"interface_body" => Kind::Block,
|
||||
"method_declaration" => Kind::Function,
|
||||
"constructor_declaration" => Kind::Function,
|
||||
"switch_expression" => Kind::Block,
|
||||
"switch_block" => Kind::Block,
|
||||
"switch_block_statement_group" => Kind::Block,
|
||||
"try_statement" => Kind::Block,
|
||||
"catch_clause" => Kind::Block,
|
||||
"finally_clause" => Kind::Block,
|
||||
"lambda_expression" => Kind::Block,
|
||||
"constructor_body" => Kind::Block,
|
||||
"static_initializer" => Kind::Block,
|
||||
|
||||
// data-flow
|
||||
"method_invocation" => Kind::CallMethod,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue