zeek/doc/scripts/base/protocols/smb/main.zeek.rst
Tim Wojtulewicz ded98cd373 Copy docs into Zeek repo directly
This is based on commit 2731def9159247e6da8a3191783c89683363689c from the
zeek-docs repo.
2025-09-26 02:58:29 +00:00

445 lines
14 KiB
ReStructuredText

:tocdepth: 3
base/protocols/smb/main.zeek
============================
.. zeek:namespace:: SMB
:Namespace: SMB
:Imports: :doc:`base/protocols/smb/const-dos-error.zeek </scripts/base/protocols/smb/const-dos-error.zeek>`, :doc:`base/protocols/smb/const-nt-status.zeek </scripts/base/protocols/smb/const-nt-status.zeek>`, :doc:`base/protocols/smb/consts.zeek </scripts/base/protocols/smb/consts.zeek>`
Summary
~~~~~~~
Runtime Options
###############
================================================================================ ===========================================================
:zeek:id:`SMB::enable_clear_script_state`: :zeek:type:`bool` :zeek:attr:`&redef` Whether to reset a connection's SMB script state whenever a
:zeek:see:`smb2_discarded_messages_state` event is raised.
:zeek:id:`SMB::logged_file_actions`: :zeek:type:`set` :zeek:attr:`&redef` The file actions which are logged.
================================================================================ ===========================================================
Types
#####
=============================================== =======================================================
:zeek:type:`SMB::Action`: :zeek:type:`enum` Abstracted actions for SMB file actions.
:zeek:type:`SMB::CmdInfo`: :zeek:type:`record` This record is for the smb_cmd.log
:zeek:type:`SMB::FileInfo`: :zeek:type:`record` This record is for the smb_files.log
:zeek:type:`SMB::State`: :zeek:type:`record` This record stores the SMB state of in-flight commands,
the file and tree map of the connection.
:zeek:type:`SMB::TreeInfo`: :zeek:type:`record` This record is for the smb_mapping.log
=============================================== =======================================================
Redefinitions
#############
==================================================================== ============================================================
:zeek:type:`Log::ID`: :zeek:type:`enum`
* :zeek:enum:`SMB::FILES_LOG`
* :zeek:enum:`SMB::MAPPING_LOG`
:zeek:type:`SMB::FileInfo`: :zeek:type:`record`
:New Fields: :zeek:type:`SMB::FileInfo`
fid: :zeek:type:`count` :zeek:attr:`&optional`
ID referencing this file.
uuid: :zeek:type:`string` :zeek:attr:`&optional`
UUID referencing this file if DCE/RPC.
:zeek:type:`connection`: :zeek:type:`record` Everything below here is used internally in the SMB scripts.
:New Fields: :zeek:type:`connection`
smb_state: :zeek:type:`SMB::State` :zeek:attr:`&optional`
:zeek:id:`likely_server_ports`: :zeek:type:`set` :zeek:attr:`&redef`
==================================================================== ============================================================
Hooks
#####
================================================================ =
:zeek:id:`SMB::log_policy_files`: :zeek:type:`Log::PolicyHook`
:zeek:id:`SMB::log_policy_mapping`: :zeek:type:`Log::PolicyHook`
================================================================ =
Functions
#########
=========================================================================== ====================================
:zeek:id:`SMB::set_current_file`: :zeek:type:`function` :zeek:attr:`&redef` This is an internally used function.
:zeek:id:`SMB::write_file_log`: :zeek:type:`function` :zeek:attr:`&redef` This is an internally used function.
=========================================================================== ====================================
Detailed Interface
~~~~~~~~~~~~~~~~~~
Runtime Options
###############
.. zeek:id:: SMB::enable_clear_script_state
:source-code: base/protocols/smb/main.zeek 52 52
:Type: :zeek:type:`bool`
:Attributes: :zeek:attr:`&redef`
:Default: ``T``
Whether to reset a connection's SMB script state whenever a
:zeek:see:`smb2_discarded_messages_state` event is raised.
This setting protects from unbounded script state growth in
environments with high capture loss or traffic anomalies.
.. zeek:id:: SMB::logged_file_actions
:source-code: base/protocols/smb/main.zeek 38 38
:Type: :zeek:type:`set` [:zeek:type:`SMB::Action`]
:Attributes: :zeek:attr:`&redef`
:Default:
::
{
SMB::PRINT_CLOSE,
SMB::FILE_DELETE,
SMB::FILE_OPEN,
SMB::FILE_RENAME,
SMB::PRINT_OPEN
}
The file actions which are logged.
Types
#####
.. zeek:type:: SMB::Action
:source-code: base/protocols/smb/main.zeek 17 36
:Type: :zeek:type:`enum`
.. zeek:enum:: SMB::FILE_READ SMB::Action
.. zeek:enum:: SMB::FILE_WRITE SMB::Action
.. zeek:enum:: SMB::FILE_OPEN SMB::Action
.. zeek:enum:: SMB::FILE_CLOSE SMB::Action
.. zeek:enum:: SMB::FILE_DELETE SMB::Action
.. zeek:enum:: SMB::FILE_RENAME SMB::Action
.. zeek:enum:: SMB::FILE_SET_ATTRIBUTE SMB::Action
.. zeek:enum:: SMB::PIPE_READ SMB::Action
.. zeek:enum:: SMB::PIPE_WRITE SMB::Action
.. zeek:enum:: SMB::PIPE_OPEN SMB::Action
.. zeek:enum:: SMB::PIPE_CLOSE SMB::Action
.. zeek:enum:: SMB::PRINT_READ SMB::Action
.. zeek:enum:: SMB::PRINT_WRITE SMB::Action
.. zeek:enum:: SMB::PRINT_OPEN SMB::Action
.. zeek:enum:: SMB::PRINT_CLOSE SMB::Action
Abstracted actions for SMB file actions.
.. zeek:type:: SMB::CmdInfo
:source-code: base/protocols/smb/main.zeek 101 136
:Type: :zeek:type:`record`
.. zeek:field:: ts :zeek:type:`time` :zeek:attr:`&log` :zeek:attr:`&default` = ``0.0`` :zeek:attr:`&optional`
Timestamp of the command request.
.. zeek:field:: uid :zeek:type:`string` :zeek:attr:`&log`
Unique ID of the connection the request was sent over.
.. zeek:field:: id :zeek:type:`conn_id` :zeek:attr:`&log`
ID of the connection the request was sent over.
.. zeek:field:: command :zeek:type:`string` :zeek:attr:`&log`
The command sent by the client.
.. zeek:field:: sub_command :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
The subcommand sent by the client, if present.
.. zeek:field:: argument :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Command argument sent by the client, if any.
.. zeek:field:: status :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Server reply to the client's command.
.. zeek:field:: rtt :zeek:type:`interval` :zeek:attr:`&log` :zeek:attr:`&optional`
Round trip time from the request to the response.
.. zeek:field:: version :zeek:type:`string` :zeek:attr:`&log`
Version of SMB for the command.
.. zeek:field:: username :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Authenticated username, if available.
.. zeek:field:: tree :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
If this is related to a tree, this is the tree
that was used for the current command.
.. zeek:field:: tree_service :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
The type of tree (disk share, printer share, named pipe, etc.).
.. zeek:field:: referenced_file :zeek:type:`SMB::FileInfo` :zeek:attr:`&log` :zeek:attr:`&optional`
If the command referenced a file, store it here.
.. zeek:field:: referenced_tree :zeek:type:`SMB::TreeInfo` :zeek:attr:`&optional`
If the command referenced a tree, store it here.
.. zeek:field:: smb1_offered_dialects :zeek:type:`string_vec` :zeek:attr:`&optional`
(present if :doc:`/scripts/base/protocols/smb/smb1-main.zeek` is loaded)
Dialects offered by the client.
.. zeek:field:: smb2_offered_dialects :zeek:type:`index_vec` :zeek:attr:`&optional`
(present if :doc:`/scripts/base/protocols/smb/smb2-main.zeek` is loaded)
Dialects offered by the client.
.. zeek:field:: smb2_create_options :zeek:type:`count` :zeek:attr:`&default` = ``0`` :zeek:attr:`&optional`
(present if :doc:`/scripts/base/protocols/smb/smb2-main.zeek` is loaded)
Keep the create_options in the command for
referencing later.
This record is for the smb_cmd.log
.. zeek:type:: SMB::FileInfo
:source-code: base/protocols/smb/main.zeek 55 78
:Type: :zeek:type:`record`
.. zeek:field:: ts :zeek:type:`time` :zeek:attr:`&log` :zeek:attr:`&default` = ``0.0`` :zeek:attr:`&optional`
Time when the file was first discovered.
.. zeek:field:: uid :zeek:type:`string` :zeek:attr:`&log`
Unique ID of the connection the file was sent over.
.. zeek:field:: id :zeek:type:`conn_id` :zeek:attr:`&log`
ID of the connection the file was sent over.
.. zeek:field:: fuid :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Unique ID of the file.
.. zeek:field:: action :zeek:type:`SMB::Action` :zeek:attr:`&log` :zeek:attr:`&optional`
Action this log record represents.
.. zeek:field:: path :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Path pulled from the tree this file was transferred to or from.
.. zeek:field:: name :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Filename if one was seen.
.. zeek:field:: size :zeek:type:`count` :zeek:attr:`&log` :zeek:attr:`&default` = ``0`` :zeek:attr:`&optional`
Total size of the file.
.. zeek:field:: prev_name :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
If the rename action was seen, this will be
the file's previous name.
.. zeek:field:: times :zeek:type:`SMB::MACTimes` :zeek:attr:`&log` :zeek:attr:`&optional`
Last time this file was modified.
.. zeek:field:: fid :zeek:type:`count` :zeek:attr:`&optional`
ID referencing this file.
.. zeek:field:: uuid :zeek:type:`string` :zeek:attr:`&optional`
UUID referencing this file if DCE/RPC.
This record is for the smb_files.log
.. zeek:type:: SMB::State
:source-code: base/protocols/smb/main.zeek 140 161
:Type: :zeek:type:`record`
.. zeek:field:: current_cmd :zeek:type:`SMB::CmdInfo` :zeek:attr:`&optional`
A reference to the current command.
.. zeek:field:: current_file :zeek:type:`SMB::FileInfo` :zeek:attr:`&optional`
A reference to the current file.
.. zeek:field:: current_tree :zeek:type:`SMB::TreeInfo` :zeek:attr:`&optional`
A reference to the current tree.
.. zeek:field:: pending_cmds :zeek:type:`table` [:zeek:type:`count`] of :zeek:type:`SMB::CmdInfo` :zeek:attr:`&optional`
Indexed on MID to map responses to requests.
.. zeek:field:: fid_map :zeek:type:`table` [:zeek:type:`count`] of :zeek:type:`SMB::FileInfo` :zeek:attr:`&optional`
File map to retrieve file information based on the file ID.
.. zeek:field:: tid_map :zeek:type:`table` [:zeek:type:`count`] of :zeek:type:`SMB::TreeInfo` :zeek:attr:`&optional`
Tree map to retrieve tree information based on the tree ID.
.. zeek:field:: pipe_map :zeek:type:`table` [:zeek:type:`count`] of :zeek:type:`string` :zeek:attr:`&optional`
Pipe map to retrieve UUID based on the file ID of a pipe.
.. zeek:field:: recent_files :zeek:type:`set` [:zeek:type:`string`] :zeek:attr:`&default` = ``{ }`` :zeek:attr:`&optional`
A set of recent files to avoid logging the same
files over and over in the smb files log.
This only applies to files seen in a single connection.
This record stores the SMB state of in-flight commands,
the file and tree map of the connection.
.. zeek:type:: SMB::TreeInfo
:source-code: base/protocols/smb/main.zeek 81 98
:Type: :zeek:type:`record`
.. zeek:field:: ts :zeek:type:`time` :zeek:attr:`&log` :zeek:attr:`&default` = ``0.0`` :zeek:attr:`&optional`
Time when the tree was mapped.
.. zeek:field:: uid :zeek:type:`string` :zeek:attr:`&log`
Unique ID of the connection the tree was mapped over.
.. zeek:field:: id :zeek:type:`conn_id` :zeek:attr:`&log`
ID of the connection the tree was mapped over.
.. zeek:field:: path :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
Name of the tree path.
.. zeek:field:: service :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
The type of resource of the tree (disk share, printer share, named pipe, etc.).
.. zeek:field:: native_file_system :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&optional`
File system of the tree.
.. zeek:field:: share_type :zeek:type:`string` :zeek:attr:`&log` :zeek:attr:`&default` = ``"DISK"`` :zeek:attr:`&optional`
If this is SMB2, a share type will be included. For SMB1,
the type of share will be deduced and included as well.
This record is for the smb_mapping.log
Hooks
#####
.. zeek:id:: SMB::log_policy_files
:source-code: base/protocols/smb/main.zeek 13 13
:Type: :zeek:type:`Log::PolicyHook`
.. zeek:id:: SMB::log_policy_mapping
:source-code: base/protocols/smb/main.zeek 14 14
:Type: :zeek:type:`Log::PolicyHook`
Functions
#########
.. zeek:id:: SMB::set_current_file
:source-code: base/protocols/smb/main.zeek 195 205
:Type: :zeek:type:`function` (smb_state: :zeek:type:`SMB::State`, file_id: :zeek:type:`count`) : :zeek:type:`void`
:Attributes: :zeek:attr:`&redef`
This is an internally used function.
.. zeek:id:: SMB::write_file_log
:source-code: base/protocols/smb/main.zeek 207 241
:Type: :zeek:type:`function` (state: :zeek:type:`SMB::State`) : :zeek:type:`void`
:Attributes: :zeek:attr:`&redef`
This is an internally used function.