mirror of
https://github.com/zeek/zeek.git
synced 2025-10-08 09:38:19 +00:00

more cases. It will now not only fire after table-reads have been completed, but also after the last event of a whole-file-read (or whole-db-read, etc.). The interface also has been extended a bit to allow readers to directly fire the event should they so choose. This allows the event to be fired in direct table-setting/event-sending modes, which was previously not possible.
56 lines
1 KiB
Text
56 lines
1 KiB
Text
# (uses listen.bro just to ensure input sources are more reliably fully-read).
|
|
# @TEST-SERIALIZE: comm
|
|
#
|
|
# @TEST-EXEC: btest-bg-run bro bro -b %INPUT
|
|
# @TEST-EXEC: btest-bg-wait -k 5
|
|
# @TEST-EXEC: btest-diff out
|
|
|
|
@TEST-START-FILE input.log
|
|
#separator \x09
|
|
#path ssh
|
|
#fields i b
|
|
#types int bool
|
|
1 T
|
|
2 T
|
|
3 F
|
|
4 F
|
|
5 F
|
|
6 F
|
|
7 T
|
|
@TEST-END-FILE
|
|
|
|
@load frameworks/communication/listen
|
|
|
|
global outfile: file;
|
|
|
|
redef InputAscii::empty_field = "EMPTY";
|
|
|
|
module A;
|
|
|
|
type Idx: record {
|
|
i: int;
|
|
};
|
|
|
|
type Val: record {
|
|
b: bool;
|
|
notb: bool &optional;
|
|
};
|
|
|
|
global servers: table[int] of Val = table();
|
|
|
|
event bro_init()
|
|
{
|
|
outfile = open("../out");
|
|
# first read in the old stuff into the table...
|
|
Input::add_table([$source="../input.log", $name="input", $idx=Idx, $val=Val, $destination=servers,
|
|
$pred(typ: Input::Event, left: Idx, right: Val) = { right$notb = !right$b; return T; }
|
|
]);
|
|
Input::remove("input");
|
|
}
|
|
|
|
event Input::end_of_data(name: string, source: string)
|
|
{
|
|
print outfile, servers;
|
|
close(outfile);
|
|
terminate();
|
|
}
|