Optimization #4753
openlua: fix inconsistency in the init "needs" key
Description
In Suricata, there's a difference in the usage of needs key, depending on whether one is writing a match or a log function in the lua scripts.
It is better to have the same behavior for both use cases.
Current behavior:
If one wants to use the log ability, the usage is:
function init (args)
local needs = {}
needs["protocol"] = "tls"
return needs
end
If one wants to write a match function in Lua scripts, then it must be:
function init(args)
local needs = {}
needs["tls"] = "true"
return needs
end
Real-life examples:
Example for match: https://github.com/OISF/suricata-verify/blob/master/tests/dns-lua-rules/test-rrname.lua Example for log: https://github.com/OISF/suricata-verify/blob/master/tests/lua-output-dns/test.lua
Expected behavior:
regardless of what function is being written, users should be able to use needs in the same way.
Updated by Juliana Fajardini Reichow over 3 years ago
- Related to Documentation #4725: Inconsistent "needs" key documentation for Lua functions added
Updated by Juliana Fajardini Reichow over 3 years ago
- Status changed from New to In Review
PR: https://github.com/OISF/suricata/pull/6480
(this PR is actually for the documentation, not for the change in the code itself)
Updated by Juliana Fajardini Reichow about 3 years ago
- Status changed from In Review to Assigned
Updated by Victor Julien over 2 years ago
- Target version changed from 7.0.0-beta1 to 8.0.0-beta1
Updated by Victor Julien about 1 year ago
- Assignee changed from Juliana Fajardini Reichow to OISF Dev
Updated by Victor Julien about 1 year ago
- Status changed from Assigned to New
- Assignee changed from OISF Dev to Jo Johnson
Updated by Victor Julien 7 months ago
- Assignee changed from Jo Johnson to Jason Ish
Updated by Victor Julien 7 months ago
- Subject changed from Fix inconsistency in Lua functions for the "needs" key to lua: fix inconsistency in the init "needs" key
Updated by Victor Julien 7 months ago
- Blocks Story #7128: lua: sandboxed lua support with mimimum set of bindings added
Updated by Victor Julien 5 days ago
The idea of hooks as in #7485 will replace the hooks like registration the needs logic currently provides. This will allow the rule to control where the script is hooked in.
Updated by Victor Julien 5 days ago
- Related to Feature #7485: rules: allow specifying explicit hooks added
Updated by Victor Julien 5 days ago
- Related to Task #7486: lua: turn flowvars into lib added
Updated by Victor Julien 5 days ago
- Related to Task #7487: lua: turn flowints into lib added
Updated by Victor Julien 5 days ago
- Blocked by Task #7492: lua: remove script_api_ver check from needs block added