mirror of
https://github.com/zeek/zeek.git
synced 2025-10-02 14:48:21 +00:00
Tune when c$conn is set.
After discussion with Seth we now set c$conn in connection_state_remove() with priority 5, and log it with priority -5. If users want to extend c$conn before connection_state_remove, they can just create c$conn and add custom fields. Addresses: #554
This commit is contained in:
parent
95d84da1b0
commit
89d5e01d38
1 changed files with 13 additions and 13 deletions
|
@ -158,21 +158,22 @@ function determine_service(c: connection): string
|
||||||
return to_lower(service);
|
return to_lower(service);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
## Fill out the c$conn record for logging
|
||||||
function set_conn(c: connection, eoc: bool)
|
function set_conn(c: connection, eoc: bool)
|
||||||
{
|
{
|
||||||
if ( ! c?$conn )
|
if ( ! c?$conn )
|
||||||
{
|
{
|
||||||
local id = c$id;
|
|
||||||
local tmp: Info;
|
local tmp: Info;
|
||||||
tmp$ts=c$start_time;
|
|
||||||
tmp$uid=c$uid;
|
|
||||||
tmp$id=id;
|
|
||||||
tmp$proto=get_port_transport_proto(id$resp_p);
|
|
||||||
if( |Site::local_nets| > 0 )
|
|
||||||
tmp$local_orig=Site::is_local_addr(id$orig_h);
|
|
||||||
c$conn = tmp;
|
c$conn = tmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c$conn$ts=c$start_time;
|
||||||
|
c$conn$uid=c$uid;
|
||||||
|
c$conn$id=c$id;
|
||||||
|
c$conn$proto=get_port_transport_proto(c$id$resp_p);
|
||||||
|
if( |Site::local_nets| > 0 )
|
||||||
|
c$conn$local_orig=Site::is_local_addr(c$id$orig_h);
|
||||||
|
|
||||||
if ( eoc )
|
if ( eoc )
|
||||||
{
|
{
|
||||||
if ( c$duration > 0secs )
|
if ( c$duration > 0secs )
|
||||||
|
@ -200,11 +201,6 @@ function set_conn(c: connection, eoc: bool)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
event new_connection(c: connection) &priority=5
|
|
||||||
{
|
|
||||||
set_conn(c, F);
|
|
||||||
}
|
|
||||||
|
|
||||||
event content_gap(c: connection, is_orig: bool, seq: count, length: count) &priority=5
|
event content_gap(c: connection, is_orig: bool, seq: count, length: count) &priority=5
|
||||||
{
|
{
|
||||||
set_conn(c, F);
|
set_conn(c, F);
|
||||||
|
@ -212,9 +208,13 @@ event content_gap(c: connection, is_orig: bool, seq: count, length: count) &prio
|
||||||
c$conn$missed_bytes = c$conn$missed_bytes + length;
|
c$conn$missed_bytes = c$conn$missed_bytes + length;
|
||||||
}
|
}
|
||||||
|
|
||||||
event connection_state_remove(c: connection) &priority=-5
|
event connection_state_remove(c: connection) &priority=5
|
||||||
{
|
{
|
||||||
set_conn(c, T);
|
set_conn(c, T);
|
||||||
|
}
|
||||||
|
|
||||||
|
event connection_state_remove(c: connection) &priority=-5
|
||||||
|
{
|
||||||
Log::write(CONN, c$conn);
|
Log::write(CONN, c$conn);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue