zeek/testing/btest/spicy/event-cond.zeek
2024-03-15 17:36:11 +01:00

62 lines
1.7 KiB
Text

# @TEST-REQUIRES: have-spicy
#
# @TEST-EXEC: spicyz -d -o test.hlto ssh.spicy ./ssh-cond.evt
# @TEST-EXEC: zeek -r ${TRACES}/ssh/single-conn.trace test.hlto %INPUT | sort >output
# @TEST-EXEC: btest-diff output
event ssh::banner1(c: connection, is_orig: bool, version: string, software: string)
{
print "1", software;
}
event ssh::banner2(c: connection, is_orig: bool, version: string, software: string)
{
print "2", software;
}
event ssh::banner3(c: connection, is_orig: bool, version: string, software: string)
{
print "3", software;
}
event ssh::banner4(c: connection, is_orig: bool, version: string, software: string)
{
print "4", software;
}
event ssh::banner5(c: connection, is_orig: bool, version: string, software: string)
{
print "5", software;
}
event zeek_init()
{
Analyzer::register_for_port(Analyzer::ANALYZER_SPICY_SSH, 22/tcp);
}
# @TEST-START-FILE ssh.spicy
module SSH;
public type Banner = unit {
magic : /SSH-/;
version : /[^-]*/;
dash : /-/;
software: /[^\r\n]*/;
};
# @TEST-END-FILE
# @TEST-START-FILE ssh-cond.evt
import zeek;
protocol analyzer spicy::SSH over TCP:
parse with SSH::Banner,
replaces SSH;
on SSH::Banner if ( True ) -> event ssh::banner1($conn, $is_orig, self.version, self.software);
on SSH::Banner if ( False )-> event ssh::banner2($conn, $is_orig, self.version, self.software);
on SSH::Banner if ( self.software == b"OpenSSH_3.9p1" )-> event ssh::banner3($conn, $is_orig, self.version, self.software);
on SSH::Banner if ( self.software != b"OpenSSH_3.9p1" )-> event ssh::banner4($conn, $is_orig, self.version, self.software);
on SSH::Banner if ( zeek::is_orig() ) -> event ssh::banner5($conn, $is_orig, self.version, self.software);
# @TEST-END-FILE