Struct cbfsfilter::CBMonitor
Properties Methods Events Config Settings Errors
The CBMonitor struct allows applications to monitor filesystem requests.
Syntax
cbfsfilter::CBMonitor
Remarks
The CBMonitor struct is a "monitoring-only" subset of the CBFilter struct; it gives applications the ability to monitor filesystem requests, allowing them to be logged and reported. Applications use standard filter rules to specify which requests they are interested in monitoring.
To learn more about the struct's capabilities, please refer to the product's General Information topics.
Getting Started
- If the struct's system driver has not been installed yet, call the install method to do so. This needs to be done only once.
- In production, the driver can be installed (or updated) ahead of time by the application's installation script using the Installer DLL. Please refer to the Driver Installation topic for more information.
- Call the initialize method to initialize the CBMonitor struct. This must be done each time the application starts.
- Add one or more filter rules using methods like add_filter_rule. (Rules can also be added/removed after the filter is started.)
- Call the start_filter method to start monitoring filesystem requests.
- When finished, call the stop_filter method to stop monitoring filesystem requests.
- To uninstall the struct's system driver, call the uninstall method. This should not be done as part of the driver upgrade process.
- In production, the driver can be uninstalled by the application's uninstallation script using the Installer DLL. Please refer to the Driver Installation topic for more information.
Object Lifetime
The new() method returns a mutable reference to a struct instance. The object itself is kept in the global list maintainted by CBFSFilter. Due to this, the CBMonitor struct cannot be disposed of automatically. Please, call the dispose(&mut self) method of CBMonitor when you have finished using the instance.
Property List
The following is the full list of the properties of the struct with short descriptions. Click on the links for further details.
active | This property notes whether the struct is active and processing requests. |
altitude | This property specifies the altitude the struct's system driver should use . |
filter_rule_count | The number of records in the FilterRule arrays. |
filter_rule_access_flags | This property indicates the access restrictions enforced by the rule (CBFilter only). |
filter_rule_control_flags | This property indicates which control events the rule causes the struct to fire (CBFilter only). |
filter_rule_ea_name | This property indicates the name of an extended attribute that a file or directory must have to match the rule. |
filter_rule_excluded_attributes | This property indicates the file attributes that a file or directory must not have to match the rule. |
filter_rule_included_attributes | This property indicates the file attributes that a file or directory must have to match the rule. |
filter_rule_mask | This property indicates a file mask that determines which files and directories match the rule. |
filter_rule_max_size | This property indicates the maximum size a file can be to match the rule. |
filter_rule_min_size | This property indicates the minimum size a file can be to match the rule. |
filter_rule_notify_flags | This property indicates which notification events the rule causes the struct to fire. |
fire_volume_events | This property specifies the events that should be fired when a filesystem volume is mounted to or unmounted from the system. |
normalize_short_file_names | This property is not used. |
passthrough_rule_count | The number of records in the PassthroughRule arrays. |
passthrough_rule_access_flags | This property specifies the access restrictions lifted by the rule (CBFilter only). |
passthrough_rule_control_flags | This property indicates which control events the rule prevents the struct from firing (CBFilter only). |
passthrough_rule_ea_name | This property indicates the name of an extended attribute that a file or directory must have to match the rule. |
passthrough_rule_excluded_attributes | This property indicates the file attributes that a file or directory must not have to match the rule. |
passthrough_rule_included_attributes | This property indicates the file attributes that a file or directory must have to match the rule. |
passthrough_rule_mask | This property indicates a file mask that determines which files and directories match the rule. |
passthrough_rule_max_size | This property indicates the maximum size a file can be to match the rule. |
passthrough_rule_min_size | This property indicates the minimum size a file can be to match the rule. |
passthrough_rule_notify_flags | This property indicates which notification events the rule prevents the struct from firing. |
process_cached_io_requests | This property specifies whether cached file read/write requests should be processed. |
process_failed_requests | This property specifies whether failed requests should be processed. |
serialize_events | Whether events should be fired on a single worker thread, or many. |
tag | This property stores application-defined data specific to a particular instance of the struct. |
Method List
The following is the full list of the methods of the struct with short descriptions. Click on the links for further details.
add_filter_rule | This method adds a standard filter rule. |
add_filter_rule_ex | This method adds a standard filter rule with additional match qualifiers. |
add_passthrough_rule | This method adds a passthrough rule. |
add_passthrough_rule_ex | This method adds a passthrough rule with additional match qualifiers. |
config | Sets or retrieves a configuration setting. |
delete_all_filter_rules | This method deletes all standard filter rules. |
delete_all_passthrough_rules | This method deletes all passthrough rules. |
delete_filter_rule | This method deletes a particular standard filter rule. |
delete_passthrough_rule | This method deletes a particular passthrough rule. |
file_matches_mask | This method checks whether a particular file or directory name matches the specified mask. |
get_dos_path_name | This method retrieves the DOS path name of the file or directory by its native (NT) path. |
get_driver_status | This method retrieves the status of the struct's system driver. |
get_driver_version | This method retrieves the version of the struct's system driver. |
get_event_file_name | This method retrieves the name of the file or directory, to which the event applies. |
get_nt_path_name | This method retrieves the NT (native) path name of the file or directory by its DOS path. |
get_operation_time | This method returns the time at which the request was received by the filter driver. |
get_originator_process_id | Retrieves the Id of the process (PID) that initiated the operation. |
get_originator_process_name | Retrieves the name of the process that initiated the operation. |
get_originator_thread_id | Retrieves the Id of the thread that initiated the operation. |
get_remote_access_information | This method returns networking-related information about the operation. |
get_volume_guid | This method retrieves the volume GUID of the device targeted by a filesystem operation. |
initialize | This method initializes the struct. |
install | This method installs (or upgrades) the struct's system driver. |
nt_status_to_win32_error | This method converts a native status code to a Win32 error code. |
shutdown_system | Shuts down or reboots the operating system. |
start_filter | This method starts filtering filesystem operations. |
stop_filter | This method stops filtering filesystem operations. |
uninstall | This method uninstalls the struct's system driver. |
Event List
The following is the full list of the events fired by the struct with short descriptions. Click on the links for further details.
on_after_filter_attach_to_volume | This event fires after the filter attaches to a newly mounted filesystem volume. |
on_after_filter_detach_from_volume | This event fires after the filter detaches from a filesystem volume. |
on_before_filter_attach_to_volume | This event fires before the filter attaches to a newly mounted filesystem volume. |
on_bypass_io_request | This event fires when the OS sends one of BypassIO commands. |
on_error | This event fires if an unhandled error occurs during an event. |
on_filter_start | This event fires once the filter has attached and filtering has started. |
on_filter_stop | This event fires once filtering has stopped and the filter has detached. |
on_notify_can_file_be_deleted | This event fires when the OS marks a file or directory for deletion or removes such a mark. |
on_notify_cleanup_file | This event fires when a file or directory handle has been closed. |
on_notify_close_file | This event fires when a file or directory has been closed. |
on_notify_create_file | This event fires when a file or directory has been created. |
on_notify_create_hard_link | This event fires when a hard link has been created. |
on_notify_delete_file | This event fires when a file or directory has been deleted. |
on_notify_delete_reparse_point | This event fires when a file or directory's reparse point has been deleted. |
on_notify_enumerate_directory | This event fires when a directory entry has been returned during directory enumeration. |
on_notify_filter_attach_to_volume | This event fires when the filter has been attached to a newly mounted filesystem volume. |
on_notify_filter_detach_from_volume | This event fires when the filter has been detached from a filesystem volume. |
on_notify_fsctl | This event fires when an IRP_MJ_FILE_SYSTEM_CONTROL operation has occurred. |
on_notify_get_file_security | This event fires when a file or directory's security attributes have been retrieved. |
on_notify_get_file_sizes | This event fires when a file's size information has been retrieved. |
on_notify_get_reparse_point | This event fires when a file or directory's reparse point information has been retrieved. |
on_notify_ioctl | This event fires when an IRP_MJ_DEVICE_CONTROL operation has occurred. |
on_notify_lock | This event fires when a range of bytes in a file has been locked. |
on_notify_open_file | This event fires when a file or directory has been opened. |
on_notify_query_ea | This event fires when information about the extended attributes of a file has been retrieved. |
on_notify_query_file_info | This event fires when information about a file or directory has been retrieved. |
on_notify_read_file | This event fires when data have been read from a file. |
on_notify_rename_or_move_file | This event fires when a file or directory has been renamed or moved. |
on_notify_set_allocation_size | This event fires when a file's allocation size has been changed. |
on_notify_set_ea | This event fires when information about the extended attributes of a file has been changed. |
on_notify_set_file_attributes | This event fires when a file or directory's attributes or times have been changed. |
on_notify_set_file_info | This event fires when information about a file or directory has been changed. |
on_notify_set_file_security | This event fires when a file or directory's security attributes have been changed. |
on_notify_set_file_size | This event fires when a file has been resized. |
on_notify_set_reparse_point | This event fires when a file or directory's reparse point has been created or updated. |
on_notify_unlock_all | This event fires when all locked byte ranges in a file have been unlocked. |
on_notify_unlock_all_by_key | This event fires when all locked byte ranges in a file, associated with a particular key, have been unlocked. |
on_notify_unlock_single | This event fires when a particular locked byte range in a file has been unlocked. |
on_notify_write_file | This event fires when data have been written to a file. |
on_worker_thread_creation | Fires just after a new worker thread is created. |
on_worker_thread_termination | Fires just before a worker thread is terminated. |
Config Settings
The following is a list of config settings for the struct with short descriptions. Click on the links for further details.
AlwaysPrepareFiles | Whether the driver should keep track of information for files that are already open when (i.e., were opened before) the struct is initialized. |
AlwaysRequestAttributesOnOpen | Whether the driver should keep request existing attributes before file create/open operation. |
CollectRemoteOpenInformation | Enables collection of information about remote filesystem requests. |
FilterOwnRequests | Whether the struct's system driver should filter requests made by the application itself. |
ForceAppPermissionCheck | Whether the driver should require the controller process to have elevated or system privileges. |
ForceSecurityChecks | Whether the driver should prevent the controller process from filtering files that it would not normally have access to. |
LoggingEnabled | Whether extended logging is enabled. |
MaxWorkerThreadCount | The maximum number of worker threads to use to fire events. |
MinWorkerThreadCount | The minimum number of worker threads to use to fire events. |
NormalizeShortFileNames | Whether the driver should attempt to resolve short file names and convert them to regular ones. |
OmitEventFileNames | Whether the filename parameter should be empty in events. |
PassAllFileNames | Whether the driver should pass all known names of a file, including hardlinks and previous names, to event handlers. |
PassSecurityInFileOpenEvents | Whether security information, associated with the file create/open request, is passed to file creation and opening events. |
PreprocessedRulesCacheSize | Maximum number of preprocessed rules to keep cached. |
RecordOperationTime | Enables collection of operation time. |
ResolveNtDeviceToDriveLetter | Whether native device names are translated to drive letters. |
RetrieveLinkNamesOnOpen | Specifies that the driver should collect all hard links when a file is opened. |
SendRequestsViaDriverStack | Whether internal requests to the filesystem are sent directly to the filesystem driver or through the stack of filesystem filter drivers. |
SetFileSizeOnWrite | Specifies whether *SetFileSize events should fire during file write requests that extend file size. |
WorkerInitialStackSize | The initial stack size to create worker threads with. |
BuildInfo | Information about the product's build. |
LicenseInfo | Information about the current license. |
active Property (CBMonitor Struct)
This property notes whether the struct is active and processing requests.
Syntax
fn active(&self ) -> Result<bool, CBFSFilterError>
Default Value
false
Remarks
This property reflects whether the struct is active and currently processing requests. It will be true after the filter has been attached successfully via a call to start_filter.
This property is read-only.
Data Type
bool
altitude Property (CBMonitor Struct)
This property specifies the altitude the struct's system driver should use .
Syntax
fn altitude(&self ) -> Result<String, CBFSFilterError>
fn set_altitude(&self, value : &str) -> Option<CBFSFilterError> fn set_altitude_ref(&self, value : &String) -> Option<CBFSFilterError>
Default Value
String::default()
Remarks
This property specifies the altitude that the struct's system driver should use . A driver's altitude determines its absolute position in the stack of filter drivers; drivers with higher altitudes are attached toward the top of the stack, closer to the user mode, which allows them to process requests earlier.
Microsoft manages and assigns filesystem minifilter driver altitudes directly, so an application-specific altitude value must be obtained from Microsoft before an application is deployed in production. Please refer to the Driver Altitudes topic for more information. During development, an appropriate arbitrary value, such as 360000 (which is not registered with Microsoft), can be used.
If this property is queried before an altitude has been set (via this property or the install method), it will return an empty string.
Note: This property cannot be changed when active is true. Additionally, the initialize method must be called before attempting to get or set this property's value, which is stored in the registry.
Data Type
String
filter_rule_count Property (CBMonitor Struct)
The number of records in the FilterRule arrays.
Syntax
fn filter_rule_count(&self ) -> Result<i32, CBFSFilterError>
Default Value
0
Remarks
This property controls the size of the following arrays:
- filter_rule_access_flags
- filter_rule_control_flags
- filter_rule_ea_name
- filter_rule_excluded_attributes
- filter_rule_included_attributes
- filter_rule_mask
- filter_rule_max_size
- filter_rule_min_size
- filter_rule_notify_flags
This property is read-only.
Data Type
i32
filter_rule_access_flags Property (CBMonitor Struct)
This property indicates the access restrictions enforced by the rule (CBFilter only).
Syntax
fn filter_rule_access_flags(&self , FilterRuleIndex : i32) -> Result<i32, CBFSFilterError>
Default Value
0
Remarks
This property indicates the access restrictions enforced by the rule (CBFilter only).
This property indicates which access restrictions are enforced by the rule. Please refer to the Access Rules topic for more information. The value of this property is a combination of zero or more of the following:
ACCESS_NONE | 0x00 | No access restrictions. |
ACCESS_READ_ONLY | 0x01 | Read-only access; writing and deleting are prohibited. |
ACCESS_WRITE_ONLY | 0x02 | Write-only access; reading and deleting are prohibited. |
ACCESS_DELETE_PROTECT | 0x04 | Deleting and renaming are prohibited. |
ACCESS_EXECUTE_PROTECT | 0x08 | Execution is prohibited. |
ACCESS_NO_CHANGE_DAC | 0x10 | Change of security attributes is prohibited. |
ACCESS_NO_CHANGE_OWNER | 0x20 | Change of owner is prohibited. |
ACCESS_RENAME_PROTECT | 0x40 | Renaming is prohibited. |
ACCESS_DELETE_ONLY_PROTECT | 0x80 | Deleting is prohibited (renaming is not affected). |
ACCESS_REMOTE_ACCESS_PROTECT | 0x100 | Access from other systems is prohibited. |
ACCESS_DENY_ALL | 0x200 | All access is denied. |
ACCESS_ALL_FLAGS | -1 | Used to denote all currently set access restriction flags. |
Note: This property is always 0 for the CBMonitor struct, which does not support access rules.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i32
filter_rule_control_flags Property (CBMonitor Struct)
This property indicates which control events the rule causes the struct to fire (CBFilter only).
Syntax
fn filter_rule_control_flags(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates which control events the rule causes the struct to fire (CBFilter only).
This property indicates which filesystem operations, of those performed on matching files and directories, the struct should fire Control Events for. The value of this property is a combination of zero or more of the following:
FS_CE_NONE | 0 | Don't fire for any filesystem operations.
Control Events will not fire for any filesystem operations. |
FS_CE_BEFORE_CREATE | 0x000000000001L | Fire before file creation operations.
The on_before_create_file event will fire anytime the OS attempts to create a file or directory. In some cases, this event can cause the on_before_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_AFTER_CREATE | 0x000000000002L | Fire after file creation operations.
The on_after_create_file event will fire after a file or directory creation request has been processed, before the response is returned. In some cases, this event can cause the on_after_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_BEFORE_OPEN | 0x000000000004L | Fire before file open operations.
The on_before_open_file event will fire anytime the OS attempts to open a file or directory. In some cases, this event can cause the on_before_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_AFTER_OPEN | 0x000000000008L | Fire after file open operations.
The on_after_open_file event will fire after a file or directory open request has been processed, before the response is returned. In some cases, this event can cause the on_after_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_BEFORE_READ | 0x000000000010L | Fire before read operations.
The on_before_read_file event will fire anytime the OS attempts to read data from a file. |
FS_CE_AFTER_READ | 0x000000000020L | Fire after read operations.
The on_after_read_file event will fire after a read request has been processed, before the response is returned. |
FS_CE_BEFORE_WRITE | 0x000000000040L | Fire before write operations.
The on_before_write_file event will fire anytime the OS attempts to write data to a file. |
FS_CE_AFTER_WRITE | 0x000000000080L | Fire after write operations.
The on_after_read_file event will fire after a write request has been processed, before the response is returned. |
FS_CE_BEFORE_LOCK_CONTROL | 0x000000000100L | Fire before lock and unlock operations.
The on_before_lock, on_before_unlock_all, on_before_unlock_all_by_key, and on_before_unlock_single events will fire, as applicable, before the OS attempts to lock or unlock a range of bytes in a file. |
FS_CE_AFTER_LOCK_CONTROL | 0x000000000200L | Fire before and after lock and unlock operations.
The on_after_lock, on_after_unlock_all, on_after_unlock_all_by_key, and on_after_unlock_single, events will fire, as applicable, after a lock or unlock request has been processed, before the response is returned. |
FS_CE_BEFORE_CLEANUP | 0x000000000400L | Fire before file handle cleanup operations.
The on_before_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_CE_AFTER_CLEANUP | 0x000000000800L | Fire after file handle cleanup operations.
The on_after_cleanup_file event will fire after a file handle cleanup request has been processed, before the response is returned. |
FS_CE_BEFORE_CLOSE | 0x000000001000L | Fire before file close operations.
The on_before_close_file event will fire anytime the OS closes a file or directory. Also, the on_after_close_enumeration event will fire anytime the OS closes a directory enumeration (which typically occurs immediately before the directory is closed). |
FS_CE_AFTER_CLOSE | 0x000000002000L | Fire after file close operations.
The on_after_close_file event will fire after a file/directory close request has been processed, before the response is returned. |
FS_CE_BEFORE_CAN_DELETE | 0x000000004000L | Fire before 'can be deleted' operations.
The on_before_can_file_be_deleted event will fire anytime the OS checks whether a file or directory can be deleted. |
FS_CE_AFTER_CAN_DELETE | 0x000000008000L | Fire after 'can be deleted' operations.
The on_after_can_file_be_deleted event will fire after a can be deleted request has been processed, before the response is returned. |
FS_CE_BEFORE_DELETE | 0x000000010000L | Fire before delete operations
The on_before_delete_file event will fire anytime the OS attempts to delete a file or directory. |
FS_CE_AFTER_DELETE | 0x000000020000L | Fire after delete operations.
The on_after_delete_file event will fire after a delete request has been processed, before the response is returned. |
FS_CE_BEFORE_RENAME | 0x000000040000L | Fire before rename/move operations.
The on_before_rename_or_move_file event will fire anytime the OS attempts to rename or move a file or directory. |
FS_CE_AFTER_RENAME | 0x000000080000L | Fire after rename/move operations.
The on_after_rename_or_move_file event will fire after a rename or move request has been processed, before the response is returned. |
FS_CE_BEFORE_GET_SECURITY | 0x000000100000L | Fire before get security operations.
The on_before_get_file_security event will fire before the OS queries the security attributes of a file or directory. |
FS_CE_AFTER_GET_SECURITY | 0x000000200000L | Fire after get security operations.
The on_after_get_file_security events will fire after a get security operation has been processed, before the response is returned. |
FS_CE_BEFORE_ENUMERATE_DIRECTORY | 0x000000400000L | Fire before directory enumeration operations.
The on_before_enumerate_directory event will fire anytime the OS needs to read information about directory entries. |
FS_CE_AFTER_ENUMERATE_DIRECTORY | 0x000000800000L | Fire after directory enumeration operations.
The on_after_enumerate_directory event will fire after information about a directory entry has been retrieved during directory enumeration, before the response is returned. |
FS_CE_BEFORE_QUERY_FILE_INFO | 0x000001000000L | Fire before 'query file information' operations.
The on_before_query_file_info event will fire anytime the OS needs to retrieve information about a file or directory. |
FS_CE_AFTER_QUERY_FILE_INFO | 0x000002000000L | Fire after 'query file information' operations.
The on_after_query_file_info event will fire after a file or directory information query request has been processed, before the response is returned. |
FS_CE_AFTER_GET_SIZES | 0x000008000000L | Fire after get size operations.
The on_after_get_file_sizes event will fire after a file's size information is retrieved, before the response is returned. |
FS_CE_BEFORE_SET_SECURITY | 0x000010000000L | Fire before set security operations.
The on_before_set_file_security event will fire anytime the OS needs to change the security attributes of a file or directory. |
FS_CE_AFTER_SET_SECURITY | 0x000020000000L | Fire after set security operations.
The on_after_set_file_security event will fire after a security attribute change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_ATTRIBUTES | 0x000040000000L | Fire before file attribute update operations.
The on_before_set_file_attributes event will fire anytime the OS attempts to change the attributes of a file or directory. |
FS_CE_AFTER_SET_ATTRIBUTES | 0x000080000000L | Fire after file attribute update operations.
The on_after_set_file_attributes event will fire after a file attribute change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_SIZES | 0x000100000000L | Fire before file resize operations.
The on_before_set_file_size event will fire anytime the OS attempts to resize a file, and the on_before_set_allocation_size event will fire anytime the OS attempts to change a file's allocation size. |
FS_CE_AFTER_SET_SIZES | 0x000200000000L | Fire after file resize operations.
The on_after_set_file_size event will fire after a file resize request has been processed, and the on_after_set_allocation_size event will fire after a file allocation size change request has been processed, before the response is returned. |
FS_CE_BEFORE_CREATE_HARD_LINK | 0x000400000000L | Fire before hard link creation operations.
The on_before_create_hard_link event will fire anytime the OS attempts to create a hard link. |
FS_CE_AFTER_CREATE_HARD_LINK | 0x000800000000L | Fire after hard link creation operations.
The on_after_create_hard_link events will fire after a hard link creation request has been processed, before the response is returned. |
FS_CE_BEFORE_FSCTL | 0x001000000000L | Fire before FSCTL operations.
The on_before_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL request occurs. |
FS_CE_AFTER_FSCTL | 0x002000000000L | Fire after FSCTL operations.
The on_after_fsctl event will fire after an IRP_MJ_FILE_SYSTEM_CONTROL request has been processed, before the response is returned. |
FS_CE_BEFORE_IOCTL | 0x004000000000L | Fire before IOCTL operations.
The on_before_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL request occurs. |
FS_CE_AFTER_IOCTL | 0x008000000000L | Fire after IOCTL operations.
The on_after_ioctl event will fire after an IRP_MJ_DEVICE_CONTROL request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_FILE_INFO | 0x010000000000L | Fire before 'set file information' operations.
The on_before_set_file_info event will fire anytime the OS needs to change information about a file or directory. |
FS_CE_AFTER_SET_FILE_INFO | 0x020000000000L | Fire after 'set file information' operations.
The on_after_set_file_info event will fire after a file or directory information change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_EA | 0x040000000000L | Fire before Set Extended Attributes operations.
The on_before_set_ea event will fire anytime the OS needs to set extended attributes of a file. |
FS_CE_AFTER_SET_EA | 0x080000000000L | Fire after Set Extended Attributes operations.
The on_after_set_ea event will fire after the OS request to set extended attributes of a file has been processed, before the response is returned. |
FS_CE_BEFORE_QUERY_EA | 0x100000000000L | Fire before Query Extended Attributes operations.
The on_before_query_ea event will fire anytime the OS needs to retrieve extended attributes of a file. |
FS_CE_AFTER_QUERY_EA | 0x200000000000L | Fire after Query Extended Attributes operations.
The on_after_query_ea event will fire after the OS request to retrieve extended attributes of a file has been processed, before the response is returned. |
FS_CE_BEFORE_GET_REPARSE_POINT | 0x400000000000L | Fire before Get Reparse Point operations.
The on_before_get_reparse_point event will fire anytime the OS needs to read a reparse point of a file or directory. |
FS_CE_AFTER_GET_REPARSE_POINT | 0x800000000000L | Fire after Get Reparse Point operations.
The on_after_get_reparse_point event will fire after the OS request to read a reparse point of a file or directory has been processed, before the response is returned. |
FS_CE_BEFORE_SET_REPARSE_POINT | 0x1000000000000L | Fire before Set Reparse Point operations.
The on_before_set_reparse_point event will fire anytime the OS needs to set or update a reparse point for a file or directory. |
FS_CE_AFTER_SET_REPARSE_POINT | 0x2000000000000L | Fire after Set Reparse Point operations.
The on_after_set_reparse_point event will fire after the OS request to set or update a reparse point for a file or directory has been processed, before the response is returned. |
FS_CE_BEFORE_DELETE_REPARSE_POINT | 0x4000000000000L | Fire before Delete Reparse Point operations.
The on_before_delete_reparse_point event will fire anytime the OS needs to remove reparse point information from a file or directory. |
FS_CE_AFTER_DELETE_REPARSE_POINT | 0x8000000000000L | Fire after Delete Reparse Point operations.
The on_after_delete_reparse_point event will fire after the OS request to remove reparse point information from a file or directory has been processed, before the response is returned. |
FS_CE_REPARSE_FILENAME | 0x40000000000000L | Fire before various operations for the purpose of file redirection.
The on_reparse_file_name event will fire before any operation that includes a file or directory name, giving the application a chance to redirect it. This event is typically used when an application requires more advanced redirection logic than Reparse Rules can provide; please refer to that topic for more information. |
FS_CE_REPARSE_TAG | 0x80000000000000L | Fire for reparse operations.
The on_reparse_with_tag event will fire anytime a file/directory open operation returns a STATUS_REPARSE result, allowing the application to handle the reparse point. Please refer to Microsoft's Reparse Points article for more information. |
FS_CE_ALL | -1 | Fire for all filesystem operations.
Control Events will fire for all filesystem operations that the struct tracks. |
Note: This property is always 0 for the CBMonitor struct, which does not provide any Control Events for filesystem operations.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
filter_rule_ea_name Property (CBMonitor Struct)
This property indicates the name of an extended attribute that a file or directory must have to match the rule.
Syntax
fn filter_rule_ea_name(&self , FilterRuleIndex : i32) -> Result<String, CBFSFilterError>
Default Value
String::default()
Remarks
This property indicates the name of an extended attribute that a file or directory must have to match the rule.
This property reflects the name of an extended attribute that a file or directory must have to qualify as a match for the rule. A value of an empty string indicates that the rule does not use this property as a match qualifier.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
String
filter_rule_excluded_attributes Property (CBMonitor Struct)
This property indicates the file attributes that a file or directory must not have to match the rule.
Syntax
fn filter_rule_excluded_attributes(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the file attributes that a file or directory must not have to match the rule.
This property indicates which file attributes a file or directory must not have to qualify as a match for the rule. A value of 0 indicates that the rule does not use this property as a match qualifier.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
filter_rule_included_attributes Property (CBMonitor Struct)
This property indicates the file attributes that a file or directory must have to match the rule.
Syntax
fn filter_rule_included_attributes(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the file attributes that a file or directory must have to match the rule.
This property indicates which file attributes a file or directory must have to qualify as a match for the rule. A value of 0 indicates that the rule does not use this property as a match qualifier.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
filter_rule_mask Property (CBMonitor Struct)
This property indicates a file mask that determines which files and directories match the rule.
Syntax
fn filter_rule_mask(&self , FilterRuleIndex : i32) -> Result<String, CBFSFilterError>
Default Value
String::default()
Remarks
This property indicates a file mask that determines which files and directories match the rule.
This property reflects the file mask used to determine whether a file or directory matches the rule. In addition to being its primary match qualifier, a rule's mask also serves as its identifier; every rule in a ruleset must have a unique mask.
Note: When a rule with a drive letter is added, said drive letter is automatically converted to NT Device format. When the ResolveNtDeviceToDriveLetter configuration setting is disabled, this property's value will contain the NT Device name. When the ResolveNtDeviceToDriveLetter configuration setting is enabled, the struct attempts to convert the mask back to the DOS format with a drive letter. In some situations, such backward conversion can lead to a path that was different from the original path added.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
String
filter_rule_max_size Property (CBMonitor Struct)
This property indicates the maximum size a file can be to match the rule.
Syntax
fn filter_rule_max_size(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the maximum size a file can be to match the rule.
This property indicates the maximum size, in bytes, that a file can be to qualify as a match for the rule. A value of -1 indicates that the rule does not use this property as a match qualifier.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
filter_rule_min_size Property (CBMonitor Struct)
This property indicates the minimum size a file can be to match the rule.
Syntax
fn filter_rule_min_size(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the minimum size a file can be to match the rule.
This property indicates the minimum size, in bytes, that a file can be to qualify as a match for the rule. A value of -1 indicates that the rule does not use this property as a match qualifier.
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
filter_rule_notify_flags Property (CBMonitor Struct)
This property indicates which notification events the rule causes the struct to fire.
Syntax
fn filter_rule_notify_flags(&self , FilterRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates which notification events the rule causes the struct to fire.
This property indicates which filesystem operations, of those performed on matching files and directories, the struct should fire Notification Events for. The value of this property is a combination of zero or more of the following:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
The FilterRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the FilterRuleCount property.
This property is read-only.
Data Type
i64
fire_volume_events Property (CBMonitor Struct)
This property specifies the events that should be fired when a filesystem volume is mounted to or unmounted from the system.
Syntax
fn fire_volume_events(&self ) -> Result<i32, CBFSFilterError>
fn set_fire_volume_events(&self, value : i32) -> Option<CBFSFilterError>
Default Value
0
Remarks
This property specifies the events that the struct should fire when a filesystem volume is mounted to or unmounted from the system. Possible values are as follows:
FS_MOUNT_IGNORE | 0 | Don't fire any events when volumes are mounted or unmounted. |
FS_MOUNT_NOTIFY | 64 | Fire Notification Events when volumes are mounted or unmounted.
The on_notify_filter_attach_to_volume and on_notify_filter_detach_from_volume events will fire, asynchronously, as necessary. |
FS_MOUNT_CONTROL | 128 | Fire Control Events when volumes are mounted or unmounted.
The on_before_filter_attach_to_volume, on_after_filter_attach_to_volume, and on_after_filter_detach_from_volume events will fire, synchronously, as necessary. |
FS_MOUNT_BOTH | 192 | Fire all events when volumes are mounted or unmounted. |
Note: The aforementioned events are fired only for volumes mounted/unmounted after the start_filter method is called. Typically, applications use these events to dynamically add or remove volume-specific filter rules that target removable volumes (e.g., USB drives) as well as to create virtual files on such volumes. Please refer to the File Masks topic for more information.
Data Type
i32
normalize_short_file_names Property (CBMonitor Struct)
This property is not used.
Syntax
fn normalize_short_file_names(&self ) -> Result<i32, CBFSFilterError>
fn set_normalize_short_file_names(&self, value : i32) -> Option<CBFSFilterError>
Default Value
0
Remarks
Please, use the NormalizeShortFileNames configuration setting.
Data Type
i32
passthrough_rule_count Property (CBMonitor Struct)
The number of records in the PassthroughRule arrays.
Syntax
fn passthrough_rule_count(&self ) -> Result<i32, CBFSFilterError>
Default Value
0
Remarks
This property controls the size of the following arrays:
- passthrough_rule_access_flags
- passthrough_rule_control_flags
- passthrough_rule_ea_name
- passthrough_rule_excluded_attributes
- passthrough_rule_included_attributes
- passthrough_rule_mask
- passthrough_rule_max_size
- passthrough_rule_min_size
- passthrough_rule_notify_flags
This property is read-only.
Data Type
i32
passthrough_rule_access_flags Property (CBMonitor Struct)
This property specifies the access restrictions lifted by the rule (CBFilter only).
Syntax
fn passthrough_rule_access_flags(&self , PassthroughRuleIndex : i32) -> Result<i32, CBFSFilterError>
Default Value
0
Remarks
This property specifies the access restrictions lifted by the rule (CBFilter only).
This property indicates which access restrictions are lifted by the rule. Please refer to the Passthrough Rules topic for more information. The value of this property is a combination of zero or more of the following:
ACCESS_NONE | 0x00 | No access restrictions. |
ACCESS_READ_ONLY | 0x01 | Read-only access; writing and deleting are prohibited. |
ACCESS_WRITE_ONLY | 0x02 | Write-only access; reading and deleting are prohibited. |
ACCESS_DELETE_PROTECT | 0x04 | Deleting and renaming are prohibited. |
ACCESS_EXECUTE_PROTECT | 0x08 | Execution is prohibited. |
ACCESS_NO_CHANGE_DAC | 0x10 | Change of security attributes is prohibited. |
ACCESS_NO_CHANGE_OWNER | 0x20 | Change of owner is prohibited. |
ACCESS_RENAME_PROTECT | 0x40 | Renaming is prohibited. |
ACCESS_DELETE_ONLY_PROTECT | 0x80 | Deleting is prohibited (renaming is not affected). |
ACCESS_REMOTE_ACCESS_PROTECT | 0x100 | Access from other systems is prohibited. |
ACCESS_DENY_ALL | 0x200 | All access is denied. |
ACCESS_ALL_FLAGS | -1 | Used to denote all currently set access restriction flags. |
Note: This property is always 0 for the CBMonitor struct, which does not support access rules.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i32
passthrough_rule_control_flags Property (CBMonitor Struct)
This property indicates which control events the rule prevents the struct from firing (CBFilter only).
Syntax
fn passthrough_rule_control_flags(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates which control events the rule prevents the struct from firing (CBFilter only).
This property indicates which filesystem operations, of those performed on matching files and directories, the struct should not fire Control Events for. Please refer to the Passthrough Rules topic for more information. The value of this property is a combination of zero or more of the following:
FS_CE_NONE | 0 | Don't fire for any filesystem operations.
Control Events will not fire for any filesystem operations. |
FS_CE_BEFORE_CREATE | 0x000000000001L | Fire before file creation operations.
The on_before_create_file event will fire anytime the OS attempts to create a file or directory. In some cases, this event can cause the on_before_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_AFTER_CREATE | 0x000000000002L | Fire after file creation operations.
The on_after_create_file event will fire after a file or directory creation request has been processed, before the response is returned. In some cases, this event can cause the on_after_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_BEFORE_OPEN | 0x000000000004L | Fire before file open operations.
The on_before_open_file event will fire anytime the OS attempts to open a file or directory. In some cases, this event can cause the on_before_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_AFTER_OPEN | 0x000000000008L | Fire after file open operations.
The on_after_open_file event will fire after a file or directory open request has been processed, before the response is returned. In some cases, this event can cause the on_after_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_CE_BEFORE_READ | 0x000000000010L | Fire before read operations.
The on_before_read_file event will fire anytime the OS attempts to read data from a file. |
FS_CE_AFTER_READ | 0x000000000020L | Fire after read operations.
The on_after_read_file event will fire after a read request has been processed, before the response is returned. |
FS_CE_BEFORE_WRITE | 0x000000000040L | Fire before write operations.
The on_before_write_file event will fire anytime the OS attempts to write data to a file. |
FS_CE_AFTER_WRITE | 0x000000000080L | Fire after write operations.
The on_after_read_file event will fire after a write request has been processed, before the response is returned. |
FS_CE_BEFORE_LOCK_CONTROL | 0x000000000100L | Fire before lock and unlock operations.
The on_before_lock, on_before_unlock_all, on_before_unlock_all_by_key, and on_before_unlock_single events will fire, as applicable, before the OS attempts to lock or unlock a range of bytes in a file. |
FS_CE_AFTER_LOCK_CONTROL | 0x000000000200L | Fire before and after lock and unlock operations.
The on_after_lock, on_after_unlock_all, on_after_unlock_all_by_key, and on_after_unlock_single, events will fire, as applicable, after a lock or unlock request has been processed, before the response is returned. |
FS_CE_BEFORE_CLEANUP | 0x000000000400L | Fire before file handle cleanup operations.
The on_before_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_CE_AFTER_CLEANUP | 0x000000000800L | Fire after file handle cleanup operations.
The on_after_cleanup_file event will fire after a file handle cleanup request has been processed, before the response is returned. |
FS_CE_BEFORE_CLOSE | 0x000000001000L | Fire before file close operations.
The on_before_close_file event will fire anytime the OS closes a file or directory. Also, the on_after_close_enumeration event will fire anytime the OS closes a directory enumeration (which typically occurs immediately before the directory is closed). |
FS_CE_AFTER_CLOSE | 0x000000002000L | Fire after file close operations.
The on_after_close_file event will fire after a file/directory close request has been processed, before the response is returned. |
FS_CE_BEFORE_CAN_DELETE | 0x000000004000L | Fire before 'can be deleted' operations.
The on_before_can_file_be_deleted event will fire anytime the OS checks whether a file or directory can be deleted. |
FS_CE_AFTER_CAN_DELETE | 0x000000008000L | Fire after 'can be deleted' operations.
The on_after_can_file_be_deleted event will fire after a can be deleted request has been processed, before the response is returned. |
FS_CE_BEFORE_DELETE | 0x000000010000L | Fire before delete operations
The on_before_delete_file event will fire anytime the OS attempts to delete a file or directory. |
FS_CE_AFTER_DELETE | 0x000000020000L | Fire after delete operations.
The on_after_delete_file event will fire after a delete request has been processed, before the response is returned. |
FS_CE_BEFORE_RENAME | 0x000000040000L | Fire before rename/move operations.
The on_before_rename_or_move_file event will fire anytime the OS attempts to rename or move a file or directory. |
FS_CE_AFTER_RENAME | 0x000000080000L | Fire after rename/move operations.
The on_after_rename_or_move_file event will fire after a rename or move request has been processed, before the response is returned. |
FS_CE_BEFORE_GET_SECURITY | 0x000000100000L | Fire before get security operations.
The on_before_get_file_security event will fire before the OS queries the security attributes of a file or directory. |
FS_CE_AFTER_GET_SECURITY | 0x000000200000L | Fire after get security operations.
The on_after_get_file_security events will fire after a get security operation has been processed, before the response is returned. |
FS_CE_BEFORE_ENUMERATE_DIRECTORY | 0x000000400000L | Fire before directory enumeration operations.
The on_before_enumerate_directory event will fire anytime the OS needs to read information about directory entries. |
FS_CE_AFTER_ENUMERATE_DIRECTORY | 0x000000800000L | Fire after directory enumeration operations.
The on_after_enumerate_directory event will fire after information about a directory entry has been retrieved during directory enumeration, before the response is returned. |
FS_CE_BEFORE_QUERY_FILE_INFO | 0x000001000000L | Fire before 'query file information' operations.
The on_before_query_file_info event will fire anytime the OS needs to retrieve information about a file or directory. |
FS_CE_AFTER_QUERY_FILE_INFO | 0x000002000000L | Fire after 'query file information' operations.
The on_after_query_file_info event will fire after a file or directory information query request has been processed, before the response is returned. |
FS_CE_AFTER_GET_SIZES | 0x000008000000L | Fire after get size operations.
The on_after_get_file_sizes event will fire after a file's size information is retrieved, before the response is returned. |
FS_CE_BEFORE_SET_SECURITY | 0x000010000000L | Fire before set security operations.
The on_before_set_file_security event will fire anytime the OS needs to change the security attributes of a file or directory. |
FS_CE_AFTER_SET_SECURITY | 0x000020000000L | Fire after set security operations.
The on_after_set_file_security event will fire after a security attribute change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_ATTRIBUTES | 0x000040000000L | Fire before file attribute update operations.
The on_before_set_file_attributes event will fire anytime the OS attempts to change the attributes of a file or directory. |
FS_CE_AFTER_SET_ATTRIBUTES | 0x000080000000L | Fire after file attribute update operations.
The on_after_set_file_attributes event will fire after a file attribute change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_SIZES | 0x000100000000L | Fire before file resize operations.
The on_before_set_file_size event will fire anytime the OS attempts to resize a file, and the on_before_set_allocation_size event will fire anytime the OS attempts to change a file's allocation size. |
FS_CE_AFTER_SET_SIZES | 0x000200000000L | Fire after file resize operations.
The on_after_set_file_size event will fire after a file resize request has been processed, and the on_after_set_allocation_size event will fire after a file allocation size change request has been processed, before the response is returned. |
FS_CE_BEFORE_CREATE_HARD_LINK | 0x000400000000L | Fire before hard link creation operations.
The on_before_create_hard_link event will fire anytime the OS attempts to create a hard link. |
FS_CE_AFTER_CREATE_HARD_LINK | 0x000800000000L | Fire after hard link creation operations.
The on_after_create_hard_link events will fire after a hard link creation request has been processed, before the response is returned. |
FS_CE_BEFORE_FSCTL | 0x001000000000L | Fire before FSCTL operations.
The on_before_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL request occurs. |
FS_CE_AFTER_FSCTL | 0x002000000000L | Fire after FSCTL operations.
The on_after_fsctl event will fire after an IRP_MJ_FILE_SYSTEM_CONTROL request has been processed, before the response is returned. |
FS_CE_BEFORE_IOCTL | 0x004000000000L | Fire before IOCTL operations.
The on_before_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL request occurs. |
FS_CE_AFTER_IOCTL | 0x008000000000L | Fire after IOCTL operations.
The on_after_ioctl event will fire after an IRP_MJ_DEVICE_CONTROL request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_FILE_INFO | 0x010000000000L | Fire before 'set file information' operations.
The on_before_set_file_info event will fire anytime the OS needs to change information about a file or directory. |
FS_CE_AFTER_SET_FILE_INFO | 0x020000000000L | Fire after 'set file information' operations.
The on_after_set_file_info event will fire after a file or directory information change request has been processed, before the response is returned. |
FS_CE_BEFORE_SET_EA | 0x040000000000L | Fire before Set Extended Attributes operations.
The on_before_set_ea event will fire anytime the OS needs to set extended attributes of a file. |
FS_CE_AFTER_SET_EA | 0x080000000000L | Fire after Set Extended Attributes operations.
The on_after_set_ea event will fire after the OS request to set extended attributes of a file has been processed, before the response is returned. |
FS_CE_BEFORE_QUERY_EA | 0x100000000000L | Fire before Query Extended Attributes operations.
The on_before_query_ea event will fire anytime the OS needs to retrieve extended attributes of a file. |
FS_CE_AFTER_QUERY_EA | 0x200000000000L | Fire after Query Extended Attributes operations.
The on_after_query_ea event will fire after the OS request to retrieve extended attributes of a file has been processed, before the response is returned. |
FS_CE_BEFORE_GET_REPARSE_POINT | 0x400000000000L | Fire before Get Reparse Point operations.
The on_before_get_reparse_point event will fire anytime the OS needs to read a reparse point of a file or directory. |
FS_CE_AFTER_GET_REPARSE_POINT | 0x800000000000L | Fire after Get Reparse Point operations.
The on_after_get_reparse_point event will fire after the OS request to read a reparse point of a file or directory has been processed, before the response is returned. |
FS_CE_BEFORE_SET_REPARSE_POINT | 0x1000000000000L | Fire before Set Reparse Point operations.
The on_before_set_reparse_point event will fire anytime the OS needs to set or update a reparse point for a file or directory. |
FS_CE_AFTER_SET_REPARSE_POINT | 0x2000000000000L | Fire after Set Reparse Point operations.
The on_after_set_reparse_point event will fire after the OS request to set or update a reparse point for a file or directory has been processed, before the response is returned. |
FS_CE_BEFORE_DELETE_REPARSE_POINT | 0x4000000000000L | Fire before Delete Reparse Point operations.
The on_before_delete_reparse_point event will fire anytime the OS needs to remove reparse point information from a file or directory. |
FS_CE_AFTER_DELETE_REPARSE_POINT | 0x8000000000000L | Fire after Delete Reparse Point operations.
The on_after_delete_reparse_point event will fire after the OS request to remove reparse point information from a file or directory has been processed, before the response is returned. |
FS_CE_REPARSE_FILENAME | 0x40000000000000L | Fire before various operations for the purpose of file redirection.
The on_reparse_file_name event will fire before any operation that includes a file or directory name, giving the application a chance to redirect it. This event is typically used when an application requires more advanced redirection logic than Reparse Rules can provide; please refer to that topic for more information. |
FS_CE_REPARSE_TAG | 0x80000000000000L | Fire for reparse operations.
The on_reparse_with_tag event will fire anytime a file/directory open operation returns a STATUS_REPARSE result, allowing the application to handle the reparse point. Please refer to Microsoft's Reparse Points article for more information. |
FS_CE_ALL | -1 | Fire for all filesystem operations.
Control Events will fire for all filesystem operations that the struct tracks. |
Note: This property is always 0 for the CBMonitor struct, which does not provide any Control Events for filesystem operations.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
passthrough_rule_ea_name Property (CBMonitor Struct)
This property indicates the name of an extended attribute that a file or directory must have to match the rule.
Syntax
fn passthrough_rule_ea_name(&self , PassthroughRuleIndex : i32) -> Result<String, CBFSFilterError>
Default Value
String::default()
Remarks
This property indicates the name of an extended attribute that a file or directory must have to match the rule.
This property reflects the name of an extended attribute that a file or directory must have to qualify as a match for the rule. A value of an empty string indicates that the rule does not use this property as a match qualifier.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
String
passthrough_rule_excluded_attributes Property (CBMonitor Struct)
This property indicates the file attributes that a file or directory must not have to match the rule.
Syntax
fn passthrough_rule_excluded_attributes(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the file attributes that a file or directory must not have to match the rule.
This property indicates which file attributes a file or directory must not have to qualify as a match for the rule. A value of 0 indicates that the rule does not use this property as a match qualifier.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
passthrough_rule_included_attributes Property (CBMonitor Struct)
This property indicates the file attributes that a file or directory must have to match the rule.
Syntax
fn passthrough_rule_included_attributes(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the file attributes that a file or directory must have to match the rule.
This property indicates which file attributes a file or directory must have to qualify as a match for the rule. A value of 0 indicates that the rule does not use this property as a match qualifier.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
passthrough_rule_mask Property (CBMonitor Struct)
This property indicates a file mask that determines which files and directories match the rule.
Syntax
fn passthrough_rule_mask(&self , PassthroughRuleIndex : i32) -> Result<String, CBFSFilterError>
Default Value
String::default()
Remarks
This property indicates a file mask that determines which files and directories match the rule.
This property reflects the file mask used to determine whether a file or directory matches the rule. In addition to being its primary match qualifier, a rule's mask also serves as its identifier; every rule in a ruleset must have a unique mask.
Note: When a rule with a drive letter is added, said drive letter is automatically converted to NT Device format. When the ResolveNtDeviceToDriveLetter configuration setting is disabled, this property's value will contain the NT Device name. When the ResolveNtDeviceToDriveLetter configuration setting is enabled, the struct attempts to convert the mask back to the DOS format with a drive letter. In some situations, such backward conversion can lead to a path that was different from the original path added.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
String
passthrough_rule_max_size Property (CBMonitor Struct)
This property indicates the maximum size a file can be to match the rule.
Syntax
fn passthrough_rule_max_size(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the maximum size a file can be to match the rule.
This property indicates the maximum size, in bytes, that a file can be to qualify as a match for the rule. A value of -1 indicates that the rule does not use this property as a match qualifier.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
passthrough_rule_min_size Property (CBMonitor Struct)
This property indicates the minimum size a file can be to match the rule.
Syntax
fn passthrough_rule_min_size(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates the minimum size a file can be to match the rule.
This property indicates the minimum size, in bytes, that a file can be to qualify as a match for the rule. A value of -1 indicates that the rule does not use this property as a match qualifier.
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
passthrough_rule_notify_flags Property (CBMonitor Struct)
This property indicates which notification events the rule prevents the struct from firing.
Syntax
fn passthrough_rule_notify_flags(&self , PassthroughRuleIndex : i32) -> Result<i64, CBFSFilterError>
Default Value
0
Remarks
This property indicates which notification events the rule prevents the struct from firing.
This property indicates which filesystem operations, of those performed on matching files and directories, the struct should not fire Notification Events for. Please refer to the Passthrough Rules topic for more information. The value of this property is a combination of zero or more of the following:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
The PassthroughRuleIndex parameter specifies the index of the item in the array. The size of the array is controlled by the PassthroughRuleCount property.
This property is read-only.
Data Type
i64
process_cached_io_requests Property (CBMonitor Struct)
This property specifies whether cached file read/write requests should be processed.
Syntax
fn process_cached_io_requests(&self ) -> Result<bool, CBFSFilterError>
fn set_process_cached_io_requests(&self, value : bool) -> Option<CBFSFilterError>
Default Value
false
Remarks
This property specifies whether the struct's system driver should process cached file read/write requests (i.e., fire *ReadFile and *WriteFile events for them). Please refer to the Cached and Non-Cached Requests topic for more information.
Note: This property cannot be changed when active is true.
Data Type
bool
process_failed_requests Property (CBMonitor Struct)
This property specifies whether failed requests should be processed.
Syntax
fn process_failed_requests(&self ) -> Result<bool, CBFSFilterError>
fn set_process_failed_requests(&self, value : bool) -> Option<CBFSFilterError>
Default Value
false
Remarks
This property specifies whether the struct's system driver should process failed requests (i.e., fire After* or Notify* events for them).
When this property is enabled, applications can inspect the Status parameter of the aforementioned events to determine whether an operation has failed. If an operation fails, then the corresponding event's Status parameter will contain a nonzero native status code. Applications generally can use the nt_status_to_win32_error method to convert these status codes into Win32 error codes (but keep in mind that not all native status codes have direct Win32 error code mapping).
Data Type
bool
serialize_events Property (CBMonitor Struct)
Whether events should be fired on a single worker thread, or many.
Syntax
fn serialize_events(&self ) -> Result<i32, CBFSFilterError>
fn set_serialize_events(&self, value : i32) -> Option<CBFSFilterError>
Default Value
0
Remarks
This property specifies whether the struct should fire all events serially on a single worker thread, or concurrently on multiple worker threads. The possible values are:
0 (seOnMultipleThreads) | The struct fires events in the context of multiple worker threads. The MinWorkerThreadCount and MaxWorkerThreadCount configuration settings control how many worker threads are used for this. |
1 (seOnOneWorkerThread) | The struct fires events in the context of one background worker thread. |
Please refer to the Threading and Concurrency topic for more information.
Note: This property cannot be changed when active is true, and it cannot be changed within events.
Data Type
i32
tag Property (CBMonitor Struct)
This property stores application-defined data specific to a particular instance of the struct.
Syntax
fn tag(&self ) -> Result<i64, CBFSFilterError>
fn set_tag(&self, value : i64) -> Option<CBFSFilterError>
Default Value
0
Remarks
This property can be used to store data specific to a particular instance of the struct.
Data Type
i64
add_filter_rule Method (CBMonitor Struct)
This method adds a standard filter rule.
Syntax
fn add_filter_rule(&self, mask : &str, notify_flags : i64) -> Result<bool, CBFSFilterError>
Remarks
This method adds a standard filter rule for the files and directories that match the specified Mask. Each rule in a ruleset is uniquely identified by its mask; if a rule with the specified mask already exists, the new rule's parameters are merged into it.
If the rule is added successfully, this method returns true; otherwise, it returns false.
Standard filter rules determine which filesystem operations, of those performed on matching files and directories, the struct should fire its events for. To add a standard filter rule, use the ControlFlags and NotifyFlags parameters.
The Mask parameter must be a valid file mask according to the File Masks topic. Only the files and directories that match the specified mask will be covered by the rule.
The NotifyFlags parameter specifies which filesystem operations the struct should fire Notification Events for. For example, if the FS_NE_READ flag is present, the on_notify_read_file event will fire after a read operation is performed on any file that matches Mask. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
add_filter_rule_ex Method (CBMonitor Struct)
This method adds a standard filter rule with additional match qualifiers.
Syntax
fn add_filter_rule_ex(&self, mask : &str, ea_name : &str, notify_flags : i64, min_size : i64, max_size : i64, included_attributes : i64, excluded_attributes : i64) -> Result<bool, CBFSFilterError>
Remarks
This method adds a standard filter rule for the files and directories that match the specified Mask (which must be provided) and other qualifiers (which are optional). Each rule in a ruleset is uniquely identified by its mask; if a rule with the specified mask already exists, the new rule's parameters are merged into it.
If the rule is added successfully, this method returns true; otherwise, it returns false.
Standard filter rules determine which filesystem operations, of those performed on matching files and directories, the struct should fire its events for. To add a standard filter rule, use the ControlFlags and NotifyFlags parameters.
The Mask parameter must be a valid file mask according to the File Masks topic. Only the files and directories that match the specified mask will be covered by the rule.
The EaName parameter specifies the name of an extended attribute that a file or directory must have to qualify as a match; wildcards are not allowed. Pass an empty string if this parameter should not be used as a match qualifier.
The NotifyFlags parameter specifies which filesystem operations the struct should fire Notification Events for. For example, if the FS_NE_READ flag is present, the on_notify_read_file event will fire after a read operation is performed on any file that matches Mask. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
The MinSize and MaxSize parameters specify the minimum and maximum size, in bytes, that a file can be to qualify as a match. Pass -1 for either parameter if it should not be used as a match qualifier.
The IncludedAttributes and ExcludedAttributes parameters specify which file attributes a file or directory must have or not have to qualify as a match. Pass 0 for either parameter if it should not be used as a match qualifier.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
add_passthrough_rule Method (CBMonitor Struct)
This method adds a passthrough rule.
Syntax
fn add_passthrough_rule(&self, mask : &str, notify_flags : i64) -> Result<bool, CBFSFilterError>
Remarks
This method adds a passthrough rule for the files and directories that match the specified Mask. Each rule in a ruleset is uniquely identified by its mask; if a rule with the specified mask already exists, the new rule's parameters are merged into it.
If the rule is added successfully, this method returns true; otherwise, it returns false.
Passthrough rules exclude matching files and directories from being processed by other filter rules.
The Mask parameter must be a valid file mask according to the File Masks topic. Only the files and directories that match the specified mask will be covered by the rule.
The NotifyFlags parameter specifies which filesystem operations the struct should not fire Notification Events for. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
add_passthrough_rule_ex Method (CBMonitor Struct)
This method adds a passthrough rule with additional match qualifiers.
Syntax
fn add_passthrough_rule_ex(&self, mask : &str, ea_name : &str, notify_flags : i64, min_size : i64, max_size : i64, included_attributes : i64, excluded_attributes : i64) -> Result<bool, CBFSFilterError>
Remarks
This method adds a passthrough rule for the files and directories that match the specified Mask (which must be provided) and other qualifiers (which are optional). Each rule in a ruleset is uniquely identified by its mask; if a rule with the specified mask already exists, the new rule's parameters are merged into it.
If the rule is added successfully, this method returns true; otherwise, it returns false.
Passthrough rules exclude matching files and directories from being processed by other filter rules.
The Mask parameter must be a valid file mask according to the File Masks topic. Only the files and directories that match the specified mask will be covered by the rule.
The EaName parameter specifies the name of an extended attribute that a file or directory must have to qualify as a match; wildcards are not allowed. Pass an empty string if this parameter should not be used as a match qualifier.
The NotifyFlags parameter specifies which filesystem operations the struct should not fire Notification Events for. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
The MinSize and MaxSize parameters specify the minimum and maximum size, in bytes, that a file can be to qualify as a match. Pass -1 for either parameter if it should not be used as a match qualifier.
The IncludedAttributes and ExcludedAttributes parameters specify which file attributes a file or directory must have or not have to qualify as a match. Pass 0 for either parameter if it should not be used as a match qualifier.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
config Method (CBMonitor Struct)
Sets or retrieves a configuration setting.
Syntax
fn config(&self, configuration_string : &str) -> Result<String, CBFSFilterError>
Remarks
config is a generic method available in every struct. It is used to set and retrieve configuration settings for the struct.
These settings are similar in functionality to properties, but they are rarely used. In order to avoid "polluting" the property namespace of the struct, access to these internal properties is provided through the config method.
To set a configuration setting named PROPERTY, you must call Config("PROPERTY=VALUE"), where VALUE is the value of the setting expressed as a string. For boolean values, use the strings "True", "False", "0", "1", "Yes", or "No" (case does not matter).
To read (query) the value of a configuration setting, you must call Config("PROPERTY"). The value will be returned as a string.
delete_all_filter_rules Method (CBMonitor Struct)
This method deletes all standard filter rules.
Syntax
fn delete_all_filter_rules(&self) -> Result<bool, CBFSFilterError>
Remarks
This method deletes all standard filter rules that are currently present.
If the rules are deleted successfully, this method returns true; otherwise, it returns false.
To delete standard filter rules individually, use the delete_filter_rule method instead.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
delete_all_passthrough_rules Method (CBMonitor Struct)
This method deletes all passthrough rules.
Syntax
fn delete_all_passthrough_rules(&self) -> Result<bool, CBFSFilterError>
Remarks
This method deletes all passthrough rules that are currently present.
If the rules are deleted successfully, this method returns true; otherwise, it returns false.
To delete passthrough rules individually, use the delete_passthrough_rule method instead.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
delete_filter_rule Method (CBMonitor Struct)
This method deletes a particular standard filter rule.
Syntax
fn delete_filter_rule(&self, mask : &str, notify_flags : i64) -> Result<bool, CBFSFilterError>
Remarks
This method deletes the specified NotifyFlags from the standard filter rule identified by Mask. If NotifyFlags includes all flags currently present in the rule, then the entire rule is deleted; otherwise, the flags specified by NotifyFlags are simply removed from the rule. If the flags or this rule are deleted successfully, this method returns true; otherwise, it returns false.
The Mask parameter must be the file mask of an existing rule. If a rule with the specified mask cannot be found, this method will fail.
The NotifyFlags parameter specifies which Notification Event flags should be removed from the rule. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
To delete all standard filter rules, use the delete_all_filter_rules method instead.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
delete_passthrough_rule Method (CBMonitor Struct)
This method deletes a particular passthrough rule.
Syntax
fn delete_passthrough_rule(&self, mask : &str, notify_flags : i64) -> Result<bool, CBFSFilterError>
Remarks
This method deletes the specified NotifyFlags from the passthrough rule identified by Mask. If NotifyFlags includes all flags currently present in the rule, then the entire rule is deleted; otherwise, the flags specified by NotifyFlags are simply removed from the rule. If the flags or this rule are deleted successfully, this method returns true; otherwise, it returns false.
The Mask parameter must be the file mask of an existing rule. If a rule with the specified mask cannot be found, this method will fail.
The NotifyFlags parameter specifies which Notification Event flags should be removed from the rule. The value passed for this parameter should be constructed by ORing together zero or more of the following flags:
FS_NE_NONE | 0 | Don't fire for any filesystem operations.
Notification Events will not fire for any filesystem operations. |
FS_NE_CREATE | 0x00000001L | Fire for file creation operations.
The on_notify_create_file event will fire anytime the OS creates a file or directory. In some cases, this event can cause the on_notify_open_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_OPEN | 0x00000002L | Fire for file open operations.
The on_notify_open_file event will fire anytime the OS opens a file or directory. In some cases, this event can cause the on_notify_create_file event to fire; refer to the File Create/Open Events topic for more information. |
FS_NE_READ | 0x00000004L | Fire for read operations.
The on_notify_read_file event will fire anytime the OS reads data from a file. |
FS_NE_WRITE | 0x00000008L | Fire for write operations.
The on_notify_write_file event will fire anytime the OS writes data to a file. |
FS_NE_LOCK_CONTROL | 0x00000010L | Fire for lock and unlock operations.
The on_notify_lock, on_notify_unlock_all, on_notify_unlock_all_by_key, and on_notify_unlock_single events will fire, as applicable, anytime the OS locks or unlocks a range of bytes in a file. |
FS_NE_CLEANUP | 0x00000020L | Fire for file handle cleanup operations.
The on_notify_cleanup_file event will fire anytime a process closes a file or directory handle. |
FS_NE_CLOSE | 0x00000040L | Fire for file close operations.
The on_notify_close_file event will fire anytime the OS closes a file or directory. |
FS_NE_CAN_DELETE | 0x00000080L | Fire for 'can be deleted' operations.
The on_notify_can_file_be_deleted event will fire anytime the OS checks whether or not a file or directory can be deleted. |
FS_NE_DELETE | 0x00000100L | Fire for delete operations.
The on_notify_delete_file event will fire anytime the OS deletes a file or directory. |
FS_NE_RENAME | 0x00000200L | Fire for rename/move operations.
The on_notify_rename_or_move_file event will fire anytime the OS renames or moves a file or directory. |
FS_NE_GET_SECURITY | 0x00000400L | Fire for get security operations.
The on_notify_get_file_security event will fire anytime the OS queries the security attributes of a file or directory. |
FS_NE_ENUMERATE_DIRECTORY | 0x00000800L | Fire for directory enumeration operations.
The on_notify_enumerate_directory event will fire anytime the OS retrieves a directory entry during directory enumeration. |
FS_NE_QUERY_FILE_INFO | 0x00001000L | Fire for QueryFileInformation operations.
The on_notify_query_file_info event will fire anytime the OS retrieves information about a file or directory. |
FS_NE_GET_SIZES | 0x00002000L | Fire for get size operations.
The on_notify_get_file_sizes event will fire anytime the OS retrieves a file's size information. |
FS_NE_SET_SECURITY | 0x00004000L | Fire for set security operations.
The on_notify_set_file_security event will fire anytime the OS changes the security attributes of a file or directory. |
FS_NE_SET_ATTRIBUTES | 0x00008000L | Fire for file attribute update operations.
The on_notify_set_file_attributes event will fire anytime the OS changes the attributes of a file or directory. |
FS_NE_SET_SIZES | 0x00010000L | Fire for file resize operations.
The on_notify_set_file_size event will fire anytime the OS resizes a file, and the on_notify_set_allocation_size event will fire anytime the OS changes a file's allocation size. |
FS_NE_CREATE_HARD_LINK | 0x00020000L | Fire for hard link creation operations.
The on_notify_create_hard_link event will fire anytime the OS creates a hard link. |
FS_NE_FSCTL | 0x00040000L | Fire for FSCTL operations.
The on_notify_fsctl event will fire anytime an IRP_MJ_FILE_SYSTEM_CONTROL operation occurs. |
FS_NE_IOCTL | 0x00080000L | Fire for IOCTL operations.
The on_notify_ioctl event will fire anytime an IRP_MJ_DEVICE_CONTROL operation occurs. |
FS_NE_SET_FILE_INFO | 0x00100000L | Fire for SetFileInformation operations.
The on_notify_set_file_info event will fire anytime the OS changes information about a file or directory. |
FS_NE_SET_EA | 0x00200000L | Fire for Set Extended Attributes operations.
The on_notify_set_ea event will fire anytime the OS sets extended attributes of a file. |
FS_NE_QUERY_EA | 0x00400000L | Fire for Query Extended Attributes operations.
The on_notify_query_ea event will fire anytime the OS retrieves extended attributes of a file. |
FS_NE_GET_REPARSE_POINT | 0x00800000L | Fire for Get Reparse Point operations.
The on_notify_get_reparse_point event will fire anytime the OS reads reparse point information of a file or directory. |
FS_NE_SET_REPARSE_POINT | 0x01000000L | Fire for Set Reparse Point operations.
The on_notify_set_reparse_point event will fire anytime the OS sets or updates reparse point information for a file or directory. |
FS_NE_DELETE_REPARSE_POINT | 0x02000000L | Fire for Delete Reparse Point operations.
The on_notify_delete_reparse_point event will fire anytime the OS deletes reparse point information from a file or directory. |
FS_BYPASS_IO | 0x40000000L | Fire for BypassIO operations.
The on_bypass_io_request event will fire anytime the OS sends a BypassIO request related to some file. This flag should be passed with notification flags, even though the event is synchronous. |
FS_NE_ALL | -1 | Fire for all filesystem operations.
Notification Events will fire for all filesystem operations that the struct tracks. |
To delete all passthrough rules, use the delete_all_passthrough_rules method instead.
Note: The methods and properties related to rule management are not intended to be used from multiple threads at once. Applications that wish to use said methods and properties from multiple threads (e.g., during the on_after_filter_attach_to_volume and on_after_filter_detach_from_volume events) are responsible for employing proper thread synchronization techniques to ensure that manipulation and enumeration of the rule lists both occur in a thread-safe manner.
file_matches_mask Method (CBMonitor Struct)
This method checks whether a particular file or directory name matches the specified mask.
Syntax
fn file_matches_mask(&self, mask : &str, file_name : &str, case_sensitive : bool) -> Result<bool, CBFSFilterError>
Remarks
This method checks whether the file or directory name specified by FileName matches Mask; if it does, this method returns true. The CaseSensitive parameter controls whether a case-sensitive match should be performed.
Note: This method does not handle so-called DOS_* wildcards (DOS_STAR, DOS_QM, DOS_DOT). The explanation about the characters can be found in the MSDN article. If you have a mask that includes one of those characters on Windows, you can use the RtlIsNameInExpression function of Windows API.
Note: As the explanation states, "When you do a case-insensitive search and do not provide a translation table, the name is converted to uppercase."
get_dos_path_name Method (CBMonitor Struct)
This method retrieves the DOS path name of the file or directory by its native (NT) path.
Syntax
fn get_dos_path_name(&self, nt_path : &str) -> Result<String, CBFSFilterError>
Remarks
This method retrieves the DOS path name of the file or directory by its native path, specified in the NTPath parameter.
Note: Such name conversion is not always possible (e.g., the volume can have none or more than one DOS names). In this case, an empty string is returned.
Note: This method can be called only within events, and it must be called in the same thread that the event was originally fired on.
get_driver_status Method (CBMonitor Struct)
This method retrieves the status of the struct's system driver.
Syntax
fn get_driver_status(&self, product_guid : &str) -> Result<i32, CBFSFilterError>
Remarks
This method retrieves the status of the struct's system driver. This status can then be used to verify whether it has been properly installed and is ready for use.
The value returned by the method corresponds to the dwCurrentState field of the SERVICE_STATUS structure from the Windows API. It will be one of the following:
MODULE_STATUS_NOT_PRESENT | 0x00000000 | The specified module is not present on the system.
Note: This functionality is only available in Windows. |
MODULE_STATUS_STOPPED | 0x00000001 | The specified module is in the Stopped state.
Note: This functionality is only available in Windows. |
MODULE_STATUS_RUNNING | 0x00000004 | The specified module is loaded and running.
Note: This functionality is only available in Windows. |
ProductGUID is used to distinguish among driver installations performed by different applications. Such information is necessary to guard against unexpected situations, such as the driver being uninstalled by one application despite other applications still needing it.
Therefore, to ensure proper operation, it is critical that each individual application have its own unique ProductGUID value, and that applications (and their installation scripts) use that value when calling any of the following methods:
- install
- uninstall
- get_driver_status
- get_driver_version
- initialize
This method is available in both the struct API and the Installer DLL included with the product; please refer to the Driver Installation topic for more information about the latter.
Note: This method cannot be called within events.
get_driver_version Method (CBMonitor Struct)
This method retrieves the version of the struct's system driver.
Syntax
fn get_driver_version(&self, product_guid : &str) -> Result<i64, CBFSFilterError>
Remarks
This method retrieves the version of the struct's system driver. The value is returned as a 64-bit integer composed of four 16-bit words that each correspond to a piece of the overall module version. For example, a version of 2.32.6.28 would cause the value 0x000200200006001C to be returned.
If the struct's system driver is not installed, this method returns 0.
ProductGUID is used to distinguish among driver installations performed by different applications. Such information is necessary to guard against unexpected situations, such as the driver being uninstalled by one application despite other applications still needing it.
Therefore, to ensure proper operation, it is critical that each individual application have its own unique ProductGUID value, and that applications (and their installation scripts) use that value when calling any of the following methods:
- install
- uninstall
- get_driver_status
- get_driver_version
- initialize
This method is available in both the struct API and the Installer DLL included with the product; please refer to the Driver Installation topic for more information about the latter.
Note: This method cannot be called within events.
get_event_file_name Method (CBMonitor Struct)
This method retrieves the name of the file or directory, to which the event applies.
Syntax
fn get_event_file_name(&self) -> Result<String, CBFSFilterError>
Remarks
This method can be called within event handlers of events, related to the file or directory operations, to retrieve the name of the file or directory, to which the operation applies. If the query fails or an event does not have an associated file name, this method returns an empty string.
get_nt_path_name Method (CBMonitor Struct)
This method retrieves the NT (native) path name of the file or directory by its DOS path.
Syntax
fn get_nt_path_name(&self, dos_path : &str) -> Result<String, CBFSFilterError>
Remarks
This method retrieves the NT (native) path name of the file or directory by its path, specified in the DOSPath parameter.
get_operation_time Method (CBMonitor Struct)
This method returns the time at which the request was received by the filter driver.
Syntax
fn get_operation_time(&self) -> Result<chrono::DateTime<Utc>, CBFSFilterError>
Remarks
This method can be called within operation-related events to retrieve the time at which the filter driver received the request. The time is recorded before an event is fired but only when the RecordOperationTime configuration setting is enabled.
The timestamps returned by this method are specified in UTC.
get_originator_process_id Method (CBMonitor Struct)
Retrieves the Id of the process (PID) that initiated the operation.
Syntax
fn get_originator_process_id(&self) -> Result<i32, CBFSFilterError>
Remarks
This method can be called within events fired for filesystem operations to retrieve the Id of the process (PID) that initiated the operation. If the query fails, this method returns 0.
Please note that PIDs are not unique, and may be reused by different processes over time (though in practice, this is uncommon).
Applications cannot use this method to retrieve information about remote processes accessing drives shared on the network. Windows does not provide such information due to the nature of remote access.
Note: This method can be called only within events, and it must be called in the same thread that the event was originally fired on. However, it must not be called within events that work with opened files since such events can be initiated by system components (e.g., the cache manager, memory manager, etc.). If applications need the information this method returns during such events, they may do the following:
- Call this method within the on_before_create_file, on_before_open_file, on_after_create_file, or on_after_open_file event.
- Store the information somewhere, and store a reference to it in the event's HandleContext parameter.
- In a later event, access the information via the reference stored in HandleContext.
Note: Renaming and deletion of files is performed after the file is opened. Thus, access checks should be performed during file opening as described above.
Note: This method cannot be used from on_cleanup_context event handlers.
get_originator_process_name Method (CBMonitor Struct)
Retrieves the name of the process that initiated the operation.
Syntax
fn get_originator_process_name(&self) -> Result<String, CBFSFilterError>
Remarks
This method can be called within events fired for filesystem operations to retrieve the name of the process that initiated the operation. If the query fails, this method returns empty string.
Applications cannot use this method to retrieve information about remote processes accessing drives shared on the network. Windows does not provide such information due to the nature of remote access.
Note: This method can be called only within events, and it must be called in the same thread that the event was originally fired on. However, it must not be called within events that work with opened files since such events can be initiated by system components (e.g., the cache manager, memory manager, etc.). If applications need the information this method returns during such events, they may do the following:
- Call this method within the on_before_create_file, on_before_open_file, on_after_create_file, or on_after_open_file event.
- Store the information somewhere, and store a reference to it in the event's HandleContext parameter.
- In a later event, access the information via the reference stored in HandleContext.
Note: Renaming and deletion of files is performed after the file is opened. Thus, access checks should be performed during file opening as described above.
Note: This method cannot be used from on_cleanup_context event handlers.
get_originator_thread_id Method (CBMonitor Struct)
Retrieves the Id of the thread that initiated the operation.
Syntax
fn get_originator_thread_id(&self) -> Result<i32, CBFSFilterError>
Remarks
This method can be called within events fired for filesystem operations to retrieve the Id of the thread that initiated the operation. If the query fails, this method returns 0.
Please note that thread Ids are not unique, and may be reused by different threads over time.
Note: This method can be called only within events, and it must be called in the same thread that the event was originally fired on. However, it must not be called within events that work with opened files since such events can be initiated by system components (e.g., the cache manager, memory manager, etc.). If applications need the information this method returns during such events, they may do the following:
- Call this method within the on_before_create_file, on_before_open_file, on_after_create_file, or on_after_open_file event.
- Store the information somewhere, and store a reference to it in the event's HandleContext parameter.
- In a later event, access the information via the reference stored in HandleContext.
Note: Renaming and deletion of files is performed after the file is opened. Thus, access checks should be performed during file opening as described above.
Note: This method cannot be used from on_cleanup_context event handlers.
get_remote_access_information Method (CBMonitor Struct)
This method returns networking-related information about the operation.
Syntax
fn get_remote_access_information(&self, share_name : &mut String, client_socket_address_buffer : usize, client_socket_address_buffer_size : &mut i32) -> Result<(), CBFSFilterError>
Remarks
Call this method from *CreateFile/*OpenFile events to retrieve the collected networking details information related to the filesystem operation performed across the network.
Note: The information will be available only when the CollectRemoteOpenInformation configuration setting is enabled.
This method returns the contents of one of two structures, SRV_OPEN_ECP_CONTEXT or NFS_OPEN_ECP_CONTEXT. These structures contain various networking information that differs depending on the remote access type. Please refer to the documentation on these structures for additional information.
Depending on the type of remote access, the information is extracted from one of those structures. When the method returns, ShareName will contain the value of either ShareName or ExportAlias field of the corresponding structure. ClientSocketAddressBuffer will contain the value of the SocketAddress or ClientSocketAddress field of the corresponding structure. This field is a structure of the SOCKADDR_STORAGE_NFS type.
When calling the method, an application needs to prepare the buffer of the required size and specify this size of the ClientSocketAddressBuffer buffer in the ClientSocketAddressBufferSize argument.
get_volume_guid Method (CBMonitor Struct)
This method retrieves the volume GUID of the device targeted by a filesystem operation.
Syntax
fn get_volume_guid(&self) -> Result<String, CBFSFilterError>
Remarks
This method can be called within events fired for filesystem operations to retrieve the volume GUID of the device targeted by the operation, returned in the Volume{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx} format. If the query fails, this method returns an empty string.
Volume GUIDs can be used to enumerate the mounting points of a device using the Windows API's GetVolumePathNamesForVolumeName function.
Note: This method can be called only within events.
initialize Method (CBMonitor Struct)
This method initializes the struct.
Syntax
fn initialize(&self, product_guid : &str) -> Result<(), CBFSFilterError>
Remarks
This method initializes the struct and must be called each time the application starts before attempting to call any of the struct's other methods with the exception of installation-related methods.
ProductGUID is used to distinguish among driver installations performed by different applications. Such information is necessary to guard against unexpected situations, such as the driver being uninstalled by one application despite other applications still needing it.
Therefore, to ensure proper operation, it is critical that each individual application have its own unique ProductGUID value, and that applications (and their installation scripts) use that value when calling any of the following methods:
If the required driver was not installed using the install method with the same value of ProductGUID, initialize will return a ERROR_FILE_NOT_FOUND error (Win32 error code 2).
If the loaded kernel-mode driver is older than the user-mode API, initialize will return a ERROR_INVALID_KERNEL_INFO_VERSION error (Win32 error code 340). In this situation, an update of the driver using the install method is required before the struct can be used.
install Method (CBMonitor Struct)
This method installs (or upgrades) the struct's system driver.
Syntax
fn install(&self, cab_file_name : &str, product_guid : &str, path_to_install : &str, altitude : &str, flags : i32, allowed_controllers : &str) -> Result<bool, CBFSFilterError>
Remarks
This method is used to install or upgrade the struct's system driver. If the system must be rebooted to complete the installation process, this method returns true; otherwise, it returns false.
Important: To upgrade the struct's driver, use only the install method. Previously installed versions of the driver should not be uninstalled first. Calling the install method will upgrade the previously installed version.
Please refer to the Driver Installation topic for more information.
CabFileName must be the path of the cbfilter.cab file containing the struct's system driver.
Note: This .cab file must remain on the target system (or be available in some other way) after installation, as it is required to uninstall the driver from the system.
ProductGUID is used to distinguish among driver installations performed by different applications. Such information is necessary to guard against unexpected situations, such as the driver being uninstalled by one application despite other applications still needing it.
Therefore, to ensure proper operation, it is critical that each individual application have its own unique ProductGUID value, and that applications (and their installation scripts) use that value when calling any of the following methods:
PathToInstall controls where the driver is installed. Pass empty string (highly recommended) to automatically install them to the appropriate Windows system directory.
Altitude specifies the driver altitude to use . During development, you can use any acceptable altitude value. For deployment, an altitude value must be assigned by Microsoft before deploying a filesystem minifilter in production. After installation, the altitude can be changed at any time using the altitude property. Please refer to the Driver Altitudes topic for more information.
Flags specifies various installation options. It should contain zero or more of the following flags, ORed together:
INSTALL_REMOVE_OLD_VERSIONS | 0x00000001 | Uninstall drivers from previous struct versions (e.g., 2017). |
INSTALL_KEEP_START_TYPE | 0x00000002 | Keep the driver's current start type setting in the registry.
If this flag is not set (default), the installation logic will reset the driver's start type setting in the Windows registry to the default value. Setting this flag causes the installation logic to preserve the current value, which may be necessary if the user (or the application) set it previously. |
INSTALL_OVERWRITE_SAME_VERSION | 0x00000004 | Install the driver file when its version and build number is the same as the version of the already installed driver. |
INSTALL_REQUESTS_VIA_DRIVER_STACK | 0x00001000 | Whether internal requests to the filesystem are sent directly to the filesystem driver or through the stack of filesystem filter drivers.
This flag is applicable only for CBFilter and CBMonitor. After installation, the effects of this flag can be changed using the SendRequestsViaDriverStack configuration setting. |
INSTALL_ALWAYS_PREPARE_FILES | 0x00010000 | Whether the driver should keep track of information for files that are already open when (i.e., were opened before) the struct is initialized.
This flag is applicable only for CBFilter and CBMonitor. If this flag is set, the driver will prepare information about each file as it is opened, regardless of whether a CBFilter/CBMonitor-based application is actually running at the time. This information then allows applications to receive events for any files that are already open when the CBFilter/CBMonitor struct is initialized. Note: These preparations will slow down all file open operations; do not enable this feature unless it is actually necessary. After installation, the effects of this flag can be changed using the AlwaysPrepareFiles configuration setting. |
INSTALL_FORCE_APP_PERMISSION_CHECK | 0x00020000 | Whether the driver should require the controller process to have elevated or system privileges.
This flag is not applicable for CBProcess. If this flag is set, the driver will verify that the controller process is a system service (or is executing with elevated privileges) anytime a file is opened. If the controller process does not meet these requirements, the file will be skipped (i.e., not filtered in any way). Note: This additional verification will slow down all file open operations. After installation, the effects of this flag can be changed using the ForceAppPermissionCheck configuration setting. |
INSTALL_FORCE_SECURITY_CHECKS | 0x00040000 | Whether the driver should prevent the controller process from filtering files that it would not normally have access to.
This flag is not applicable for CBProcess. If this flag is set, the driver will check the security permissions of the controller process anytime a file is opened to verify that the process has access to the file. If the controller process does not have access to the file, the file will be skipped (i.e., not filtered in any way). For example, if this flag is set and the controller process is running with limited privileges, then the driver will not allow it to filter files that require greater privileges to access. Note: This additional verification will slow down all file open operations. After installation, the effects of this flag can be changed using the ForceSecurityChecks configuration setting. |
Note: Enabling the AlwaysPrepareFiles and/or SendRequestsViaDriverStack configuration settings before calling this method will cause the corresponding flags to be added automatically. These configuration settings can also be used to toggle the corresponding options at any time after installation.
AllowedControllers is the optional parameter that makes it possible to limit communication with the driver to just the predefined set of processes. When the caller specifies one or more names of the executable files, filtering can be started with the specified ProductGUID only when filtering is initiated by the process created from one of the listed executable files. If the name of the caller process does not match any of the allowed names, the call to start_filter will fail with an error.
The parameter may be either empty or contain one or more EXE file names with complete paths. Separate names/paths should be separated by the LF character (numeric code 10).
This method is available in both the struct API and the Installer DLL included with the product; please refer to the Driver Installation topic for more information about the latter.
This method requires administrative rights to execute successfully. If the user account of the process that calls this method doesn't have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD () error.
Note: This method cannot be called within events.
nt_status_to_win32_error Method (CBMonitor Struct)
This method converts a native status code to a Win32 error code.
Syntax
fn nt_status_to_win32_error(&self, status : i32) -> Result<i32, CBFSFilterError>
Remarks
This method converts the native status code specified by Status to a Win32 error code. If the specified native status code does not map directly to a Win32 error code, this method returns ERROR_MR_MID_NOT_FOUND (317).
shutdown_system Method (CBMonitor Struct)
Shuts down or reboots the operating system.
Syntax
fn shutdown_system(&self, shutdown_prompt : &str, timeout : i32, force_close_apps : bool, reboot : bool) -> Result<bool, CBFSFilterError>
Remarks
This method shuts down or (if Reboot is true) reboots the operating system. If the appropriate privileges cannot be obtained, or if the InitiateSystemShutdown system call returns false, then this method will return false; otherwise, it returns true. This method can be used if the installation or uninstallation function requires the system to be rebooted in order to complete.
ShutdownPrompt, if non-empty, specifies a message that the OS should display to the user for Timeout seconds. If empty string is passed for ShutdownPrompt, no message is displayed and the Timeout parameter's value is ignored.
ForceCloseApps specifies whether the OS should forcefully close all applications. Please keep in mind that forceful closing of applications with unsaved data can lead to data loss.
Reboot specifies whether the OS should reboot (true) or just shut down (false).
This method is available in both the struct API and the Installer DLL included with the product; please refer to the Driver Installation topic for more information about the latter.
Note: This method cannot be called within events.
start_filter Method (CBMonitor Struct)
This method starts filtering filesystem operations.
Syntax
fn start_filter(&self) -> Result<(), CBFSFilterError>
Remarks
This method attaches the filter, causing the struct's system driver to start filtering filesystem operations according to the filter rules currently present. Rules can be added and removed both before and after this method is called, as long as the initialize method is called before doing anything else.
This method can fail for a number of reasons, including (but not limited to) the following:
- If the struct's system driver has not been properly installed, or is awaiting a system reboot (as indicated by the return value of install), this method fails with an ERROR_FILE_NOT_FOUND (2) error code.
- If the initialize method has not been called yet, this method fails with an ERROR_NOT_READY (21) error code.
- If the filter is already active, this method fails with an ERROR_CONNECTION_ACTIVE (1230) error code.
stop_filter Method (CBMonitor Struct)
This method stops filtering filesystem operations.
Syntax
fn stop_filter(&self) -> Result<(), CBFSFilterError>
Remarks
This method detaches the filter, causing the struct's system driver to stop filtering filesystem operations. This method will block until all pending requests have been completed and the filter has been detached.
uninstall Method (CBMonitor Struct)
This method uninstalls the struct's system driver.
Syntax
fn uninstall(&self, cab_file_name : &str, product_guid : &str, installed_path : &str, flags : i32) -> Result<bool, CBFSFilterError>
Remarks
This method is used to uninstall the struct's system driver. If the system must be rebooted to complete the uninstallation process, this method returns true; otherwise, it returns false.
Important: To upgrade the struct's driver, use only the install method. Previously installed versions of the driver should not be uninstalled first. Calling the install method will upgrade the previously installed version.
Please refer to the Driver Installation topic for more information.
The same values must be passed for the CabFileName, ProductGUID, and InstalledPath parameters as were passed when install was called; please refer to its documentation for more information.
Flags specifies which versions of the struct's system driver should be uninstalled and which should be set by ORing together one or more of the following values:
UNINSTALL_VERSION_PREVIOUS | 0x00000001 | Uninstall modules from previous product versions.
Note: This functionality is only available in Windows. |
UNINSTALL_VERSION_CURRENT | 0x00000002 | Uninstall modules from the current product version.
Note: This functionality is only available in Windows. |
UNINSTALL_VERSION_ALL | 0x00000003 | Uninstall modules from all product versions.
Note: This functionality is only available in Windows. |
This method is available in both the struct API and the Installer DLL included with the product; please refer to the Driver Installation topic for more information about the latter.
This method requires administrative rights to execute successfully. If the user account of the process that calls this method doesn't have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD () error.
Note: This method cannot be called within events.
on_after_filter_attach_to_volume Event (CBMonitor Struct)
This event fires after the filter attaches to a newly mounted filesystem volume.
Syntax
// CBMonitorAfterFilterAttachToVolumeEventArgs carries the CBMonitor AfterFilterAttachToVolume event's parameters. pub struct CBMonitorAfterFilterAttachToVolumeEventArgs { fn volume_name(&self) -> &String fn volume_name_nt(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorAfterFilterAttachToVolumeEvent defines the signature of the CBMonitor AfterFilterAttachToVolume event's handler function. pub trait CBMonitorAfterFilterAttachToVolumeEvent { fn on_after_filter_attach_to_volume(&self, sender : CBMonitor, e : &mut CBMonitorAfterFilterAttachToVolumeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_after_filter_attach_to_volume(&self) -> &'a dyn CBMonitorAfterFilterAttachToVolumeEvent; pub fn set_on_after_filter_attach_to_volume(&mut self, value : &'a dyn CBMonitorAfterFilterAttachToVolumeEvent); ... }
Remarks
This event fires after the filter attaches to the newly mounted filesystem volume specified by VolumeNameNT and, when possible, VolumeName. Please refer to the fire_volume_events property for more information.
Applications need to handle this event only if the fire_volume_events property includes the FS_MOUNT_CONTROL flag.
Note: This event won't fire for any volumes skipped during the on_before_filter_attach_to_volume event; please refer to its documentation for more information.
VolumeNameNT contains the name of the volume in the NT-native format, as received from the system. If the ResolveNtDeviceToDriveLetter configuration setting is enabled, and if it was possible to convert the NT name to the DOS format with a drive letter, VolumeName will contain the name in this format; otherwise, it will be empty.
Applications can obtain additional information about a volume by retrieving its GUID using the get_volume_guid method, and then using that GUID to call various Windows API functions.
Applications can use this event to add volume-specific rules for the volume that has been mounted (keeping in mind that this event does not fire for volumes that are already present when start_filter is called). Applications that intend to do so must ensure that proper thread synchronization techniques are used when manipulating or enumerating the rule lists, because this event's handler will always execute in the context of some worker thread. Note: if a path-based rule is added or removed, such a path should use the value from VolumeNameNT to avoid a possible deadlock, which may occur during resolving a DOS name to the NT format.
Applications must be aware that this event fires as a direct response to a filesystem state change (mount or unmount). Various system components or third-party actors can perform supplementary filesystem mounting and unmounting during main unmount operations (e.g., Volume Service is one such component). This can cause seemingly excessive events to be fired, and sometimes they can be fired out of order (such as two *Attach or *Detach events fired in a row).
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource is not available or security checks failed), set it to a nonzero value to report an appropriate error. Please see the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_after_filter_detach_from_volume Event (CBMonitor Struct)
This event fires after the filter detaches from a filesystem volume.
Syntax
// CBMonitorAfterFilterDetachFromVolumeEventArgs carries the CBMonitor AfterFilterDetachFromVolume event's parameters. pub struct CBMonitorAfterFilterDetachFromVolumeEventArgs { fn volume_name(&self) -> &String fn volume_name_nt(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorAfterFilterDetachFromVolumeEvent defines the signature of the CBMonitor AfterFilterDetachFromVolume event's handler function. pub trait CBMonitorAfterFilterDetachFromVolumeEvent { fn on_after_filter_detach_from_volume(&self, sender : CBMonitor, e : &mut CBMonitorAfterFilterDetachFromVolumeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_after_filter_detach_from_volume(&self) -> &'a dyn CBMonitorAfterFilterDetachFromVolumeEvent; pub fn set_on_after_filter_detach_from_volume(&mut self, value : &'a dyn CBMonitorAfterFilterDetachFromVolumeEvent); ... }
Remarks
This event fires after the filter detaches from the filesystem volume specified by VolumeNameNT and, when possible, VolumeName, typically because of the volume being unmounted. Please refer to the fire_volume_events property for more information.
Applications need to handle this event only if the fire_volume_events property includes the FS_MOUNT_CONTROL flag.
Note: This event won't fire for any volumes skipped during the on_before_filter_attach_to_volume event; please refer to its documentation for more information.
Applications should use this event to remove volume-specific rules for the volume that has been unmounted. Applications that intend to do so must ensure that proper thread synchronization techniques are used when manipulating or enumerating the rule lists, because this event's handler will always execute in the context of some worker thread. Note: if a path-based rule is added or removed, such a path should use the value from VolumeNameNT to avoid a possible deadlock, which may occur during resolving a DOS name to the NT format.
Applications must be aware that this event fires as a direct response to a filesystem state change (mount or unmount). Various system components or third-party actors can perform supplementary filesystem mounting and unmounting during main unmount operations (e.g., Volume Service is one such component). This can cause seemingly excessive events to be fired, and sometimes they can be fired out of order (such as two *Attach or *Detach events fired in a row).
VolumeNameNT contains the name of the volume in the NT-native format, as received from the system. If the ResolveNtDeviceToDriveLetter configuration setting is enabled, and if it was possible to convert the NT name to the DOS format with a drive letter, VolumeName will contain the name in this format; otherwise, it will be empty.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource is not available or security checks failed), set it to a nonzero value to report an appropriate error. Please see the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_before_filter_attach_to_volume Event (CBMonitor Struct)
This event fires before the filter attaches to a newly mounted filesystem volume.
Syntax
// CBMonitorBeforeFilterAttachToVolumeEventArgs carries the CBMonitor BeforeFilterAttachToVolume event's parameters. pub struct CBMonitorBeforeFilterAttachToVolumeEventArgs { fn volume_name(&self) -> &String fn volume_name_nt(&self) -> &String fn skip_volume(&self) -> bool fn set_skip_volume(&self, value : bool) fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorBeforeFilterAttachToVolumeEvent defines the signature of the CBMonitor BeforeFilterAttachToVolume event's handler function. pub trait CBMonitorBeforeFilterAttachToVolumeEvent { fn on_before_filter_attach_to_volume(&self, sender : CBMonitor, e : &mut CBMonitorBeforeFilterAttachToVolumeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_before_filter_attach_to_volume(&self) -> &'a dyn CBMonitorBeforeFilterAttachToVolumeEvent; pub fn set_on_before_filter_attach_to_volume(&mut self, value : &'a dyn CBMonitorBeforeFilterAttachToVolumeEvent); ... }
Remarks
This event fires before the filter attaches to the newly mounted filesystem volume specified by VolumeNameNT and, when possible, VolumeName. Please refer to the fire_volume_events property for more information.
Applications need to handle this event only if the fire_volume_events property includes the FS_MOUNT_CONTROL flag.
VolumeNameNT contains the name of the volume in the NT-native format, as received from the system. If the ResolveNtDeviceToDriveLetter configuration setting is enabled, and if it was possible to convert the NT name to the DOS format with a drive letter, VolumeName will contain the name in this format; otherwise, it will be empty.
Applications can obtain additional information about a volume by retrieving its GUID using the get_volume_guid method, and then using that GUID to call various Windows API functions.
The SkipVolume parameter specifies whether the struct's system driver should skip the specified volume (i.e., not attach the filter to it). Setting this parameter to true will cause all filesystem operations that target to volume to be completely ignored by the struct's system driver. It also will prevent any of the following events from firing for the volume:
- on_after_filter_attach_to_volume
- on_notify_filter_attach_to_volume
- on_after_filter_detach_from_volume
- on_notify_filter_detach_from_volume
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource is not available or security checks failed), set it to a nonzero value to report an appropriate error. Please see the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
Applications must be aware that this event fires as a direct response to a filesystem state change (mount or unmount). Various system components or third-party actors can perform supplementary filesystem mounting and unmounting during main unmount operations (e.g., Volume Service is one such component). This can cause seemingly excessive events to be fired, and sometimes they can be fired out of order (such as two *Attach or *Detach events fired in a row).
on_bypass_io_request Event (CBMonitor Struct)
This event fires when the OS sends one of BypassIO commands.
Syntax
// CBMonitorBypassIORequestEventArgs carries the CBMonitor BypassIORequest event's parameters. pub struct CBMonitorBypassIORequestEventArgs { fn file_name(&self) -> &String fn request_code(&self) -> i32 fn status(&self) -> i32 fn set_status(&self, value : i32) fn reason(&self) -> &String fn set_reason(&self, value : String) fn set_reason_ref(&self, value : &String) } // CBMonitorBypassIORequestEvent defines the signature of the CBMonitor BypassIORequest event's handler function. pub trait CBMonitorBypassIORequestEvent { fn on_bypass_io_request(&self, sender : CBMonitor, e : &mut CBMonitorBypassIORequestEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_bypass_io_request(&self) -> &'a dyn CBMonitorBypassIORequestEvent; pub fn set_on_bypass_io_request(&mut self, value : &'a dyn CBMonitorBypassIORequestEvent); ... }
Remarks
This event fires when the OS sends a BypassIO request to a file specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic.
If BypassIO is enabled successfully future operations on the specified file handle will not be visible to the struct. To ensure all future operations on the file are visible to the struct BypassIO should not be enabled. BypassIO is present in Windows 11; it is not used in Windows 10 and earlier systems, and also is not used in Server systems.
Applications need to handle this event only if they have added a standard filter rule that includes the any of the following flags: FS_BYPASS_IO (it should be passed among notification flags), FS_CE_BEFORE_READ, FS_CE_AFTER_READ, FS_CE_BEFORE_WRITE, FS_CE_AFTER_WRITE.
The RequestCode parameter contains the code of the request. The code may be the one of the following:
BPIO_OP_ENABLE | 1 | Requests that BypassIO be enabled for the given file, which means an application might not see all non-cached reads for that file. |
BPIO_OP_DISABLE | 2 | Informs that BypassIO is being disabled on the specified file. |
BPIO_OP_QUERY | 3 | Queries whether BypassIO can be enabled for the given file. |
BPIO_OP_VOLUME_STACK_PAUSE | 4 | Requests that BypassIO be paused on the specified volume/storage stack. |
BPIO_OP_VOLUME_STACK_RESUME | 5 | Requests that BypassIO processing be resumed on the given volume. |
BPIO_OP_STREAM_PAUSE | 6 | Requests that BypassIO processing be paused on a stream. |
BPIO_OP_STREAM_RESUME | 7 | Requests that BypassIO processing be resumed on a stream. |
BPIO_OP_GET_INFO | 8 | Requests information about the BypassIO state of the volume. |
When the request code is BPIO_OP_ENABLE, an application is able to block BypassIO by specifying a non-zero value for Status and a description of the reason in the Reason parameter. If the application does so, it should return the same status and reason in response to BPIO_OP_QUERY requests to let the caller know that enabling would not be possible. BPIO_OP_QUERY requests are used, in particular, by diagnostics tools. Other operations may not be denied, and when the event is fired for one of those other operations, the struct ignores the values returned in the Status and Reason parameters.
The Status value should be one of the NTStatus codes defined in Windows SDK (Windows 11 SDK defines a group of STATUS_NOT_SUPPORTED_WITH_* constants for this).
The Reason should be set to a human-readable text that explains why BypassIO was blocked.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_error Event (CBMonitor Struct)
This event fires if an unhandled error occurs during an event.
Syntax
// CBMonitorErrorEventArgs carries the CBMonitor Error event's parameters. pub struct CBMonitorErrorEventArgs { fn error_code(&self) -> i32 fn description(&self) -> &String } // CBMonitorErrorEvent defines the signature of the CBMonitor Error event's handler function. pub trait CBMonitorErrorEvent { fn on_error(&self, sender : CBMonitor, e : &mut CBMonitorErrorEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_error(&self) -> &'a dyn CBMonitorErrorEvent; pub fn set_on_error(&mut self, value : &'a dyn CBMonitorErrorEvent); ... }
Remarks
This event fires if an unhandled error occurs during another event. Developers can use this information to track down unhandled errors in an application's event handlers.
Note: Not everything is possible or allowed in the event handlers. For details, see the Recursive Calls topic.
on_filter_start Event (CBMonitor Struct)
This event fires once the filter has attached and filtering has started.
Syntax
// CBMonitorFilterStartEventArgs carries the CBMonitor FilterStart event's parameters. pub struct CBMonitorFilterStartEventArgs { fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorFilterStartEvent defines the signature of the CBMonitor FilterStart event's handler function. pub trait CBMonitorFilterStartEvent { fn on_filter_start(&self, sender : CBMonitor, e : &mut CBMonitorFilterStartEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_filter_start(&self) -> &'a dyn CBMonitorFilterStartEvent; pub fn set_on_filter_start(&mut self, value : &'a dyn CBMonitorFilterStartEvent); ... }
Remarks
This event fires once the filter has attached and filtering has started; please refer to the start_filter method for more information.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource is not available or security checks failed), set it to a nonzero value to report an appropriate error. Please see the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_filter_stop Event (CBMonitor Struct)
This event fires once filtering has stopped and the filter has detached.
Syntax
// CBMonitorFilterStopEventArgs carries the CBMonitor FilterStop event's parameters. pub struct CBMonitorFilterStopEventArgs { fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorFilterStopEvent defines the signature of the CBMonitor FilterStop event's handler function. pub trait CBMonitorFilterStopEvent { fn on_filter_stop(&self, sender : CBMonitor, e : &mut CBMonitorFilterStopEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_filter_stop(&self) -> &'a dyn CBMonitorFilterStopEvent; pub fn set_on_filter_stop(&mut self, value : &'a dyn CBMonitorFilterStopEvent); ... }
Remarks
This event fires once filtering has stopped and the filter has detached.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_notify_can_file_be_deleted Event (CBMonitor Struct)
This event fires when the OS marks a file or directory for deletion or removes such a mark.
Syntax
// CBMonitorNotifyCanFileBeDeletedEventArgs carries the CBMonitor NotifyCanFileBeDeleted event's parameters. pub struct CBMonitorNotifyCanFileBeDeletedEventArgs { fn file_name(&self) -> &String fn request_type(&self) -> i32 fn can_delete(&self) -> bool fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyCanFileBeDeletedEvent defines the signature of the CBMonitor NotifyCanFileBeDeleted event's handler function. pub trait CBMonitorNotifyCanFileBeDeletedEvent { fn on_notify_can_file_be_deleted(&self, sender : CBMonitor, e : &mut CBMonitorNotifyCanFileBeDeletedEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_can_file_be_deleted(&self) -> &'a dyn CBMonitorNotifyCanFileBeDeletedEvent; pub fn set_on_notify_can_file_be_deleted(&mut self, value : &'a dyn CBMonitorNotifyCanFileBeDeletedEvent); ... }
Remarks
This event fires when the OS marks the file or directory specified by FileName for deletion or removes such a mark. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic.
Files and directories can be deleted in two ways: (1) a file or directory can be opened with the FILE_FLAG_DELETE_ON_CLOSE flag, or (2) some process may call Windows API's NtSetInformationFile function with FILE_DISPOSITION_INFORMATION or FILE_DISPOSITION_INFORMATION_EX structure as a parameter. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
If the file or directory is created or opened with the FILE_FLAG_DELETE_ON_CLOSE flag, this event is fired shortly after the on_notify_create_file or on_notify_open_file event.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_CAN_DELETE flag.
The RequestType indicates which kind of system request resulted in firing this event. It can be one of the following:
DEL_REQ_OPEN_FLAG | 0x1 | The file or directory is opened with the FILE_FLAG_DELETE_ON_CLOSE flag |
DEL_REQ_SET_DISPOSITION | 0x2 | The system has sent the IRP_MJ_SET_INFORMATION request with SetFileDisposition structure as a parameter.
This request usually is sent using the NtSetInformationFile() Windows native API function. |
The CanDelete parameter reflects whether or not the file or directory can be deleted.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_cleanup_file Event (CBMonitor Struct)
This event fires when a file or directory handle has been closed.
Syntax
// CBMonitorNotifyCleanupFileEventArgs carries the CBMonitor NotifyCleanupFile event's parameters. pub struct CBMonitorNotifyCleanupFileEventArgs { fn file_name(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyCleanupFileEvent defines the signature of the CBMonitor NotifyCleanupFile event's handler function. pub trait CBMonitorNotifyCleanupFileEvent { fn on_notify_cleanup_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyCleanupFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_cleanup_file(&self) -> &'a dyn CBMonitorNotifyCleanupFileEvent; pub fn set_on_notify_cleanup_file(&mut self, value : &'a dyn CBMonitorNotifyCleanupFileEvent); ... }
Remarks
This event fires when a handle to the file or directory specified by FileName has been closed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. This event differs from on_notify_close_file in that on_notify_cleanup_file fires when an open handle to the specified file or directory is closed by a process, whereas on_notify_close_file may be fired much later when the OS itself decides that the file or directory can be formally closed.
Other events may fire for the file or directory in the time between when this event fires and when the on_notify_close_file event fires. For example, system components, such as the memory manager or cache manager, may cause the on_notify_read_file and on_notify_write_file events to fire.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_CLEANUP flag.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_close_file Event (CBMonitor Struct)
This event fires when a file or directory has been closed.
Syntax
// CBMonitorNotifyCloseFileEventArgs carries the CBMonitor NotifyCloseFile event's parameters. pub struct CBMonitorNotifyCloseFileEventArgs { fn file_name(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyCloseFileEvent defines the signature of the CBMonitor NotifyCloseFile event's handler function. pub trait CBMonitorNotifyCloseFileEvent { fn on_notify_close_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyCloseFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_close_file(&self) -> &'a dyn CBMonitorNotifyCloseFileEvent; pub fn set_on_notify_close_file(&mut self, value : &'a dyn CBMonitorNotifyCloseFileEvent); ... }
Remarks
This event fires when the file or directory specified by FileName has been closed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_CLOSE flag.
If the file or directory was marked for deletion earlier, the on_notify_delete_file will fire shortly before this event.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_create_file Event (CBMonitor Struct)
This event fires when a file or directory has been created.
Syntax
// CBMonitorNotifyCreateFileEventArgs carries the CBMonitor NotifyCreateFile event's parameters. pub struct CBMonitorNotifyCreateFileEventArgs { fn file_name(&self) -> &String fn existing_attributes(&self) -> i32 fn desired_access(&self) -> i32 fn attributes(&self) -> i32 fn share_mode(&self) -> i32 fn options(&self) -> i32 fn create_disposition(&self) -> i32 fn security_descriptor(&self) -> *mut u8 fn length(&self) -> i32 fn status(&self) -> i32 fn creation_status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyCreateFileEvent defines the signature of the CBMonitor NotifyCreateFile event's handler function. pub trait CBMonitorNotifyCreateFileEvent { fn on_notify_create_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyCreateFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_create_file(&self) -> &'a dyn CBMonitorNotifyCreateFileEvent; pub fn set_on_notify_create_file(&mut self, value : &'a dyn CBMonitorNotifyCreateFileEvent); ... }
Remarks
This event fires when the file or directory specified by FileName has been created. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. Please refer to the File Create/Open Events topic for more information about how the struct determines whether to fire this event or on_notify_open_file. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_CREATE flag.
Note: Applications must have the FilterOwnRequests configuration setting enabled if they wish to filter their own file/directory creation requests.
When extended rules are used or the AlwaysRequestAttributesOnOpen configuration setting is enabled, the driver requests attributes of the entity from the filesystem and passes them to ExistingAttributes. If the attributes are not requested, this parameter contains 0.
The DesiredAccess, Attributes, ShareMode, and CreateDisposition parameters reflect the values that were passed for the similarly named parameters of the Windows API's CreateFile function (or, more accurately, the values carried by the IRP_MJ_CREATE IRP).
DesiredAccess may contain one or more of the following access flags:
DESIRED_ACCESS_FILE_LIST_DIRECTORY | 0x00000001 | For a directory, the right to list the contents of the directory. |
DESIRED_ACCESS_FILE_READ_DATA | 0x00000001 | For a file object, the right to read the corresponding file data.
For a directory object, the right to read the corresponding directory data. |
DESIRED_ACCESS_FILE_ADD_FILE | 0x00000002 | For a directory, the right to create a file in the directory. |
DESIRED_ACCESS_FILE_WRITE_DATA | 0x00000002 | For a file object, the right to write data to the file.
For a directory object, the right to create a file in the directory |
DESIRED_ACCESS_FILE_ADD_SUBDIRECTORY | 0x00000004 | For a directory, the right to create a subdirectory. |
DESIRED_ACCESS_FILE_APPEND_DATA | 0x00000004 | For a file object, the right to append data to the file.
(For local files, write operations will not overwrite existing data if this flag is specified without FILE_WRITE_DATA.) For a directory object, the right to create a subdirectory (FILE_ADD_SUBDIRECTORY). |
DESIRED_ACCESS_FILE_READ_EA | 0x00000008 | The right to read extended file attributes. |
DESIRED_ACCESS_FILE_WRITE_EA | 0x00000010 | The right to write extended file attributes. |
DESIRED_ACCESS_FILE_EXECUTE | 0x00000020 | For a native code file, the right to execute the file.
This access right given to scripts may cause the script to be executable, depending on the script interpreter. |
DESIRED_ACCESS_FILE_DELETE_CHILD | 0x00000040 | For a directory, the right to delete a directory and all the files it contains, including read-only files. |
DESIRED_ACCESS_FILE_READ_ATTRIBUTES | 0x00000080 | The right to read file attributes. |
DESIRED_ACCESS_FILE_WRITE_ATTRIBUTES | 0x00000100 | The right to write file attributes. |
DESIRED_ACCESS_READ_CONTROL | 0x00020000 | The right to read the information in the file or directory object's security descriptor.
This does not include the information in the SACL. |
DESIRED_ACCESS_STANDARD_RIGHTS_READ | 0x00020000 | Includes READ_CONTROL, which is the right to read the information in the file or directory object's security descriptor.
This does not include the information in the SACL. |
DESIRED_ACCESS_STANDARD_RIGHTS_WRITE | 0x00020000 | Same as STANDARD_RIGHTS_READ |
DESIRED_ACCESS_STANDARD_RIGHTS_EXECUTE | 0x00020000 | Same as STANDARD_RIGHTS_READ |
DESIRED_ACCESS_SYNCHRONIZE | 0x00100000 | The right to use the object for synchronization.
This enables a thread to wait until the object is in the signaled state. Some object types do not support this access right. |
DESIRED_ACCESS_FILE_ALL_ACCESS | 0x001F01FF | All possible access rights for a file. |
DESIRED_ACCESS_FILE_GENERIC_READ | 0x00120089 | A combinarion of flags that allow reading of the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
DESIRED_ACCESS_FILE_GENERIC_WRITE | 0x00120116 | A combinarion of flags that allow modifications to the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
DESIRED_ACCESS_FILE_GENERIC_EXECUTE | 0x001200A0 | A combinarion of flags that allow execution of the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
Attributes may contain one or more of the following attributes:
FILE_SYS_ATTR_READ_ONLY | 0x00000001 | The file is read-only.
Applications can read the file, but cannot write to it or delete it. This attribute is not honored on directories. |
FILE_SYS_ATTR_HIDDEN | 0x00000002 | The file or directory is hidden.
The file is not included in an ordinary directory listing. |
FILE_SYS_ATTR_SYSTEM | 0x00000004 | A file or directory that the operating system uses a part of, or uses exclusively. |
FILE_SYS_ATTR_DIRECTORY | 0x00000010 | The entry is a directory. |
FILE_SYS_ATTR_ARCHIVE | 0x00000020 | The entry is an archive file or directory.
Applications typically use this attribute to mark files for backup or removal. |
FILE_SYS_ATTR_NORMAL | 0x00000080 | A file doesn't have other attributes set.
This attribute is valid only when used alone. |
FILE_SYS_ATTR_TEMPORARY | 0x00000100 | A file that is being used for temporary storage.
File systems avoid writing data back to mass storage if sufficient cache memory is available, because typically, an application deletes a temporary file after the handle is closed. In that scenario, the system can entirely avoid writing the data. Otherwise, the data are written after the handle is closed. |
FILE_SYS_ATTR_SPARSE_FILE | 0x00000200 | A file that is a sparse file. |
FILE_SYS_ATTR_REPARSE_POINT | 0x00000400 | A file that is a reparse point or a symbolic link. |
FILE_SYS_ATTR_COMPRESSED | 0x00000800 | A file or directory that is compressed.
For a file, all of the data in the file are compressed. For a directory, compression is the default for newly created files and subdirectories. A filesystem implementation can make use of this attribute by setting the support_compressed_attribute property to true and then properly handling the on_get_file_info, on_enumerate_directory, and on_set_file_attributes events. |
FILE_SYS_ATTR_OFFLINE | 0x00001000 | The data of a file are not available immediately.
This attribute indicates that the file data are physically moved to offline storage. |
FILE_SYS_ATTR_NOT_CONTENT_INDEXED | 0x00002000 | The file or directory is not to be indexed by the content indexing service. |
FILE_SYS_ATTR_ENCRYPTED | 0x00004000 | A file or directory that is encrypted.
For a file, all data streams in the file are encrypted. For a directory, encryption is the default for newly created files and subdirectories. Note: This flag is used by NTFS and the OS sends undocumented requests to the filesystem based on this flag. The flag should not be used for files in custom filesystem implementations. |
FILE_SYS_ATTR_VIRTUAL | 0x00010000 | Reserved.
Note: This flag is reserved by the OS and should not be used for files in custom filesystem implementations. |
FILE_SYS_ATTR_RECALL_ON_OPEN | 0x00040000 | The file or directory has no physical representation on the local system; the item is virtual.
Opening the item will be more expensive than normal (e.g., it will cause at least some of it to be fetched from a remote store). This flag is reported by filesystems during directory enumerations. |
ShareMode may contain zero or more of the following share mode flags:
FILESYS_SHARE_READ | 0x00000001 | Enables subsequent open operations on a file or device to request read access.
Enables subsequent open operations to request read access; otherwise, no process can open the file or device if it requests read access. If this flag is not specified, but the file or device has been opened for read access, the function fails. |
FILESYS_SHARE_WRITE | 0x00000002 | Enables subsequent open operations on a file or device to request write access.
Enables subsequent open operations to request write access; otherwise, no process can open the file or device if it requests write access. If this flag is not specified, but the file or device has been opened for write access or has a file mapping with write access, the function fails. |
FILESYS_SHARE_DELETE | 0x00000004 | Enables subsequent open operations on a file or device to request delete access.
Enables subsequent open operations to request delete access; otherwise, no process can open the file or device if it requests delete access. If this flag is not specified, but the file or device has been opened for delete access, the function fails. Note: Delete access allows both delete and rename operations. |
CreateDisposition may contain one of the following values:
FILE_DISPOSITION_CREATE_NEW | 0x00000001 | Creates a new file, only if it does not already exist.
If the specified file exists, the operation fails with an "already exists" error. |
FILE_DISPOSITION_CREATE_ALWAYS | 0x00000002 | Creates a new file, always.
If the specified file exists and is writable, the system overwrites the file. If the specified file does not exist and is a valid path, a new file is created. |
FILE_DISPOSITION_OPEN_EXISTING | 0x00000003 | Opens a file, only if it exists
If the specified file does not exist, opening fails. |
FILE_DISPOSITION_OPEN_ALWAYS | 0x00000004 | Opens a file, always.
If the specified file exists, the operation succeeds. If the specified file does not exist and is a valid path to a writable location, the a file is created. |
FILE_DISPOSITION_TRUNCATE_EXISTING | 0x00000005 | Opens a file and truncates it so that its size is zero bytes, only if it exists.
If the specified file does not exist, the operation fails with a "file not found" error. |
Options contains the flags that are described in the CreateOptions parameter of the native API's ZwCreateFile function. Most of those flags correspond to flags passed in the FlagsAndAttributes parameter of the Windows API's CreateFile function, but some flags are specific to the native API. If you need those flags, check both functions' descriptions.
Please refer to Microsoft's documentation for detailed information about these constants.
To determine whether the request was for a file or a directory, compare Attributes against the FILE_SYS_ATTR_DIRECTORY constant, as follows:
// Check whether the request is for a file or a directory.
bool isDirectory = Attributes & FILE_SYS_ATTR_DIRECTORY == FILE_SYS_ATTR_DIRECTORY;
FILE_SYS_ATTR_DIRECTORY will be present if it was specified by the calling process or if the existing filesystem entry is a directory.
To determine whether a file will be deleted when its last handle is closed, compare Options against the Windows API's FILE_FLAG_DELETE_ON_CLOSE constant, as follows:
// Check whether the file will be deleted on close.
bool deleteOnClose = Options & FILE_FLAG_DELETE_ON_CLOSE == FILE_FLAG_DELETE_ON_CLOSE;
Note: Because files can be deleted in different ways, do not use this check to take actions related to tracking file deletion operations. Instead, use the events related to file deletion.
When a file or directory is created using the CreateFile() Windows API function, a caller can specify the security descriptor with the security information. This security information should be applied to a newly created file or directory. The struct passes this security information in the SecurityInformation and SecurityDescriptor parameters, when the PassSecurityInFileOpenEvents configuration setting is enabled. If this configuration setting is omitted, the corresponding parameters are empty.
The SecurityInformation parameter reflects which pieces of security information, of those present in SecurityDescriptor, are valid and should have been applied. Please refer to Microsoft's SECURITY_INFORMATION data type documentation for more information about possible values.
The SecurityDescriptor parameter points to a memory buffer that contains the security information. The Length parameter reflects the length of this data, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The data are formatted as a SECURITY_DESCRIPTOR structure in self-relative format; please refer to the Microsoft's documentation for more information.
If the Options contains the FILE_FLAG_DELETE_ON_CLOSE flag, the on_notify_can_file_be_deleted event will fire after this event.
If the file is created with extended attributes passed in the request, the on_notify_set_ea event will fire after this event.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The CreationStatus parameter indicates whether the file was created or opened and can be one of the following values:
CREATION_STATUS_SUPERSEDED | 0x00000000 | An existing file was superseded by the new file.
The previous version of a file may still exist if it had hard links other than the name used in the operation. |
CREATION_STATUS_OPENED | 0x00000001 | The file existed before the operation and was opened. |
CREATION_STATUS_CREATED | 0x00000002 | The file didn't exist before the operation and was created. |
CREATION_STATUS_OVERWRITTEN | 0x00000003 | The file exists, and its contents have been replaced. |
CREATION_STATUS_EXISTS | 0x00000004 | The file existed before the operation, and no action was taken. |
CREATION_STATUS_DOES_NOT_EXIST | 0x000000055 | The file did not exist before the operation, and no action was taken. |
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_create_hard_link Event (CBMonitor Struct)
This event fires when a hard link has been created.
Syntax
// CBMonitorNotifyCreateHardLinkEventArgs carries the CBMonitor NotifyCreateHardLink event's parameters. pub struct CBMonitorNotifyCreateHardLinkEventArgs { fn file_name(&self) -> &String fn link_name(&self) -> &String fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyCreateHardLinkEvent defines the signature of the CBMonitor NotifyCreateHardLink event's handler function. pub trait CBMonitorNotifyCreateHardLinkEvent { fn on_notify_create_hard_link(&self, sender : CBMonitor, e : &mut CBMonitorNotifyCreateHardLinkEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_create_hard_link(&self) -> &'a dyn CBMonitorNotifyCreateHardLinkEvent; pub fn set_on_notify_create_hard_link(&mut self, value : &'a dyn CBMonitorNotifyCreateHardLinkEvent); ... }
Remarks
This event fires when a hard link to the file specified by FileName has been created. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. Please refer to Microsoft's Hard Links article for more information about hard links. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_CREATE_HARD_LINK flag.
The LinkName parameter reflects the name of the created hard link.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_delete_file Event (CBMonitor Struct)
This event fires when a file or directory has been deleted.
Syntax
// CBMonitorNotifyDeleteFileEventArgs carries the CBMonitor NotifyDeleteFile event's parameters. pub struct CBMonitorNotifyDeleteFileEventArgs { fn file_name(&self) -> &String fn request_type(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyDeleteFileEvent defines the signature of the CBMonitor NotifyDeleteFile event's handler function. pub trait CBMonitorNotifyDeleteFileEvent { fn on_notify_delete_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyDeleteFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_delete_file(&self) -> &'a dyn CBMonitorNotifyDeleteFileEvent; pub fn set_on_notify_delete_file(&mut self, value : &'a dyn CBMonitorNotifyDeleteFileEvent); ... }
Remarks
This event fires when the file or directory specified by FileName has been deleted. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. More specifically, this event is queued for delivery after the final IRP_MJ_CLOSE I/O request packet (IRP) has been processed by the filesystem (i.e., after the last handle to the file or directory is closed and the file or directory is gone) and before on_notify_close_file is queued.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_DELETE flag.
The RequestType indicates which kind of system request resulted in firing this event. It can be one of the following:
DEL_REQ_OPEN_FLAG | 0x1 | The file or directory is opened with the FILE_FLAG_DELETE_ON_CLOSE flag |
DEL_REQ_SET_DISPOSITION | 0x2 | The system has sent the IRP_MJ_SET_INFORMATION request with SetFileDisposition structure as a parameter.
This request usually is sent using the NtSetInformationFile() Windows native API function. |
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_delete_reparse_point Event (CBMonitor Struct)
This event fires when a file or directory's reparse point has been deleted.
Syntax
// CBMonitorNotifyDeleteReparsePointEventArgs carries the CBMonitor NotifyDeleteReparsePoint event's parameters. pub struct CBMonitorNotifyDeleteReparsePointEventArgs { fn file_name(&self) -> &String fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyDeleteReparsePointEvent defines the signature of the CBMonitor NotifyDeleteReparsePoint event's handler function. pub trait CBMonitorNotifyDeleteReparsePointEvent { fn on_notify_delete_reparse_point(&self, sender : CBMonitor, e : &mut CBMonitorNotifyDeleteReparsePointEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_delete_reparse_point(&self) -> &'a dyn CBMonitorNotifyDeleteReparsePointEvent; pub fn set_on_notify_delete_reparse_point(&mut self, value : &'a dyn CBMonitorNotifyDeleteReparsePointEvent); ... }
Remarks
This event fires when a reparse point has been deleted from the file or directory specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Note: The file or directory was not deleted, only a reparse point was.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_DELETE_REPARSE_POINT flag.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_enumerate_directory Event (CBMonitor Struct)
This event fires when a directory entry has been returned during directory enumeration.
Syntax
// CBMonitorNotifyEnumerateDirectoryEventArgs carries the CBMonitor NotifyEnumerateDirectory event's parameters. pub struct CBMonitorNotifyEnumerateDirectoryEventArgs { fn directory_name(&self) -> &String fn flags(&self) -> i32 fn index(&self) -> i32 fn file_name(&self) -> &String fn creation_time(&self) -> &chrono::DateTime<Utc> fn last_access_time(&self) -> &chrono::DateTime<Utc> fn last_write_time(&self) -> &chrono::DateTime<Utc> fn change_time(&self) -> &chrono::DateTime<Utc> fn size(&self) -> i64 fn allocation_size(&self) -> i64 fn file_id(&self) -> i64 fn attributes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyEnumerateDirectoryEvent defines the signature of the CBMonitor NotifyEnumerateDirectory event's handler function. pub trait CBMonitorNotifyEnumerateDirectoryEvent { fn on_notify_enumerate_directory(&self, sender : CBMonitor, e : &mut CBMonitorNotifyEnumerateDirectoryEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_enumerate_directory(&self) -> &'a dyn CBMonitorNotifyEnumerateDirectoryEvent; pub fn set_on_notify_enumerate_directory(&mut self, value : &'a dyn CBMonitorNotifyEnumerateDirectoryEvent); ... }
Remarks
This event fires when a directory entry (i.e., file or subdirectory) has been returned during enumeration of the directory specified by DirectoryName. For more information about the DirectoryName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_ENUMERATE_DIRECTORY flag.
The Flags parameter specifies supplementary information about enumeration. It is a combination of zero or more values:
FS_ENUM_RESTART_SCAN | 1 | The requestor specified that directory enumeration must be restarted. |
FS_ENUM_RETURN_SINGLE_ENTRY | 2 | One entry should be returned. |
FS_ENUM_INDEX_SPECIFIED | 4 | The requestor specified the index to start enumeration from. |
If the Flags parameter contains FS_ENUM_INDEX_SPECIFIED, the Index parameter contains the index as provided by the OS.
The FileName parameter reflects the name of the directory entry.
The CreationTime, LastAccessTime, LastWriteTime, and ChangeTime parameters reflect the entry's time values, specified in UTC.
The Size parameter reflects the size of the file, in bytes; it is always 0 for subdirectories.
The AllocationSize parameter reflects the amount of space allocated for the file, in bytes; it is always 0 for subdirectories.
The FileId parameter reflects the unique Id of the entry, as reported by the filesystem. This Id is used by the network redirector, and some third-party applications, to open files and directories by Id instead of by name. The root directory always uses the predefined Id 0x7FFFFFFFFFFFFFFF.
The Attributes parameter reflects the entry's attributes; please refer to Microsoft's File Attribute Constants article for attribute descriptions.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_filter_attach_to_volume Event (CBMonitor Struct)
This event fires when the filter has been attached to a newly mounted filesystem volume.
Syntax
// CBMonitorNotifyFilterAttachToVolumeEventArgs carries the CBMonitor NotifyFilterAttachToVolume event's parameters. pub struct CBMonitorNotifyFilterAttachToVolumeEventArgs { fn volume_name(&self) -> &String fn volume_name_nt(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyFilterAttachToVolumeEvent defines the signature of the CBMonitor NotifyFilterAttachToVolume event's handler function. pub trait CBMonitorNotifyFilterAttachToVolumeEvent { fn on_notify_filter_attach_to_volume(&self, sender : CBMonitor, e : &mut CBMonitorNotifyFilterAttachToVolumeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_filter_attach_to_volume(&self) -> &'a dyn CBMonitorNotifyFilterAttachToVolumeEvent; pub fn set_on_notify_filter_attach_to_volume(&mut self, value : &'a dyn CBMonitorNotifyFilterAttachToVolumeEvent); ... }
Remarks
This event fires when the filter has been attached to the newly mounted filesystem volume specified by VolumeNameNT and, when possible, VolumeName. Please refer to the fire_volume_events property for more information.
Applications need to handle this event only if the fire_volume_events property includes the FS_MOUNT_NOTIFY flag.
Note: This event won't fire for any volumes skipped during the on_before_filter_attach_to_volume event; please refer to its documentation for more information.
VolumeNameNT contains the name of the volume in the NT-native format, as received from the system. If the ResolveNtDeviceToDriveLetter configuration setting is enabled, and if it was possible to convert the NT name to the DOS format with a drive letter, VolumeName will contain the name in this format; otherwise, it will be empty.
Applications that use volume-specific rules should typically add such rules during the on_after_filter_attach_to_volume event, which is fired synchronously, rather than this one.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
Applications must be aware that this event fires as a direct response to a filesystem state change (mount or unmount). Various system components or third-party actors can perform supplementary filesystem mounting and unmounting during main unmount operations (e.g., Volume Service is one such component). This can cause seemingly excessive events to be fired, and sometimes they can be fired out of order (such as two *Attach or *Detach events fired in a row).
on_notify_filter_detach_from_volume Event (CBMonitor Struct)
This event fires when the filter has been detached from a filesystem volume.
Syntax
// CBMonitorNotifyFilterDetachFromVolumeEventArgs carries the CBMonitor NotifyFilterDetachFromVolume event's parameters. pub struct CBMonitorNotifyFilterDetachFromVolumeEventArgs { fn volume_name(&self) -> &String fn volume_name_nt(&self) -> &String fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyFilterDetachFromVolumeEvent defines the signature of the CBMonitor NotifyFilterDetachFromVolume event's handler function. pub trait CBMonitorNotifyFilterDetachFromVolumeEvent { fn on_notify_filter_detach_from_volume(&self, sender : CBMonitor, e : &mut CBMonitorNotifyFilterDetachFromVolumeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_filter_detach_from_volume(&self) -> &'a dyn CBMonitorNotifyFilterDetachFromVolumeEvent; pub fn set_on_notify_filter_detach_from_volume(&mut self, value : &'a dyn CBMonitorNotifyFilterDetachFromVolumeEvent); ... }
Remarks
This event fires when the filter has been detached from the filesystem volume specified by VolumeNameNT and, when possible, VolumeName, typically as a result of the volume being unmounted. Please refer to the fire_volume_events property for more information.
Applications need to handle this event only if the fire_volume_events property includes the FS_MOUNT_NOTIFY flag.
Note: This event won't fire for any volumes skipped during the on_before_filter_attach_to_volume event; please refer to its documentation for more information.
VolumeNameNT contains the name of the volume in the NT-native format, as received from the system. If the ResolveNtDeviceToDriveLetter configuration setting is enabled, and if it was possible to convert the NT name to the DOS format with a drive letter, VolumeName will contain the name in this format; otherwise, it will be empty.
Applications that use volume-specific rules typically should remove such rules during the on_after_filter_detach_from_volume event, which is fired synchronously, rather than this one.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
Applications must be aware that this event fires as a direct response to a filesystem state change (mount or unmount). Various system components or third-party actors can perform supplementary filesystem mounting and unmounting during main unmount operations (e.g., Volume Service is one such component). This can cause seemingly excessive events to be fired, and sometimes they can be fired out of order (such as two *Attach or *Detach events fired in a row).
on_notify_fsctl Event (CBMonitor Struct)
This event fires when an IRP_MJ_FILE_SYSTEM_CONTROL operation has occurred.
Syntax
// CBMonitorNotifyFsctlEventArgs carries the CBMonitor NotifyFsctl event's parameters. pub struct CBMonitorNotifyFsctlEventArgs { fn file_name(&self) -> &String fn fs_control_code(&self) -> i32 fn in_buffer(&self) -> *mut u8 fn in_buffer_length(&self) -> i32 fn in_buffer_valid_bytes(&self) -> i32 fn out_buffer(&self) -> *mut u8 fn out_buffer_length(&self) -> i32 fn out_buffer_valid_bytes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyFsctlEvent defines the signature of the CBMonitor NotifyFsctl event's handler function. pub trait CBMonitorNotifyFsctlEvent { fn on_notify_fsctl(&self, sender : CBMonitor, e : &mut CBMonitorNotifyFsctlEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_fsctl(&self) -> &'a dyn CBMonitorNotifyFsctlEvent; pub fn set_on_notify_fsctl(&mut self, value : &'a dyn CBMonitorNotifyFsctlEvent); ... }
Remarks
This event fires when an IRP_MJ_FILE_SYSTEM_CONTROL (FSCTL) operation has occurred. Such requests are sent using the Windows API's DeviceIoControl function (user mode), or ZwFsControlFile function (kernel mode); please refer to Microsoft's documentation for more information. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_FSCTL flag.
The FileName parameter reflects the file, directory, or volume targeted by the request.
The FsControlCode parameter reflects the requested filesystem control code (FSCTL).
The InBuffer parameter points to a memory buffer that contains the data required to perform the operation. The InBufferLength and InBufferValidBytes parameters reflect the capacity of InBuffer and the length of the data it contains (respectively), in bytes; InBufferValidBytes may be less than InBufferLength (unless the request did not include data, in which case both will be 0).
The OutBuffer parameter points to a memory buffer that contains the data returned by the operation. The OutBufferLength and OutBufferValidBytes parameters reflect the capacity of OutBuffer and the length of the data it contains (respectively), in bytes; OutBufferValidBytes may be less than OutBufferLength (unless the operation did not return data, in which case both will be 0).
Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_get_file_security Event (CBMonitor Struct)
This event fires when a file or directory's security attributes have been retrieved.
Syntax
// CBMonitorNotifyGetFileSecurityEventArgs carries the CBMonitor NotifyGetFileSecurity event's parameters. pub struct CBMonitorNotifyGetFileSecurityEventArgs { fn file_name(&self) -> &String fn security_information(&self) -> i32 fn security_descriptor(&self) -> *mut u8 fn length(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyGetFileSecurityEvent defines the signature of the CBMonitor NotifyGetFileSecurity event's handler function. pub trait CBMonitorNotifyGetFileSecurityEvent { fn on_notify_get_file_security(&self, sender : CBMonitor, e : &mut CBMonitorNotifyGetFileSecurityEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_get_file_security(&self) -> &'a dyn CBMonitorNotifyGetFileSecurityEvent; pub fn set_on_notify_get_file_security(&mut self, value : &'a dyn CBMonitorNotifyGetFileSecurityEvent); ... }
Remarks
This event fires when security attributes have been retrieved for the file or directory specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Note: This event will not fire every time a file or directory is accessed. To check file security upon each access to a file or directory, implement the file create and open events and perform the necessary checks there instead.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_GET_SECURITY flag.
The SecurityInformation parameter indicates which pieces of security information were requested. Please refer to Microsoft's SECURITY_INFORMATION data-type documentation for more information about possible values.
The SecurityDescriptor parameter points to a memory buffer that, if the request was successful, contains the requested security information. The Length parameter reflects the length of this data, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The data are formatted as a SECURITY_DESCRIPTOR structure in self-relative format; please refer to the Microsoft's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_get_file_sizes Event (CBMonitor Struct)
This event fires when a file's size information has been retrieved.
Syntax
// CBMonitorNotifyGetFileSizesEventArgs carries the CBMonitor NotifyGetFileSizes event's parameters. pub struct CBMonitorNotifyGetFileSizesEventArgs { fn file_name(&self) -> &String fn size(&self) -> i64 fn allocation_size(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyGetFileSizesEvent defines the signature of the CBMonitor NotifyGetFileSizes event's handler function. pub trait CBMonitorNotifyGetFileSizesEvent { fn on_notify_get_file_sizes(&self, sender : CBMonitor, e : &mut CBMonitorNotifyGetFileSizesEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_get_file_sizes(&self) -> &'a dyn CBMonitorNotifyGetFileSizesEvent; pub fn set_on_notify_get_file_sizes(&mut self, value : &'a dyn CBMonitorNotifyGetFileSizesEvent); ... }
Remarks
This event fires when size information has been retrieved for the file specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_GET_SIZES flag.
The Size parameter reflects the actual size of the file, in bytes.
The AllocationSize parameter reflects the amount of space allocated for the file, in bytes.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_get_reparse_point Event (CBMonitor Struct)
This event fires when a file or directory's reparse point information has been retrieved.
Syntax
// CBMonitorNotifyGetReparsePointEventArgs carries the CBMonitor NotifyGetReparsePoint event's parameters. pub struct CBMonitorNotifyGetReparsePointEventArgs { fn file_name(&self) -> &String fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyGetReparsePointEvent defines the signature of the CBMonitor NotifyGetReparsePoint event's handler function. pub trait CBMonitorNotifyGetReparsePointEvent { fn on_notify_get_reparse_point(&self, sender : CBMonitor, e : &mut CBMonitorNotifyGetReparsePointEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_get_reparse_point(&self) -> &'a dyn CBMonitorNotifyGetReparsePointEvent; pub fn set_on_notify_get_reparse_point(&mut self, value : &'a dyn CBMonitorNotifyGetReparsePointEvent); ... }
Remarks
This event fires when reparse point information has been retrieved for the file or directory specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_GET_REPARSE_POINT flag.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_ioctl Event (CBMonitor Struct)
This event fires when an IRP_MJ_DEVICE_CONTROL operation has occurred.
Syntax
// CBMonitorNotifyIoctlEventArgs carries the CBMonitor NotifyIoctl event's parameters. pub struct CBMonitorNotifyIoctlEventArgs { fn file_name(&self) -> &String fn io_control_code(&self) -> i32 fn in_buffer(&self) -> *mut u8 fn in_buffer_length(&self) -> i32 fn in_buffer_valid_bytes(&self) -> i32 fn out_buffer(&self) -> *mut u8 fn out_buffer_length(&self) -> i32 fn out_buffer_valid_bytes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyIoctlEvent defines the signature of the CBMonitor NotifyIoctl event's handler function. pub trait CBMonitorNotifyIoctlEvent { fn on_notify_ioctl(&self, sender : CBMonitor, e : &mut CBMonitorNotifyIoctlEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_ioctl(&self) -> &'a dyn CBMonitorNotifyIoctlEvent; pub fn set_on_notify_ioctl(&mut self, value : &'a dyn CBMonitorNotifyIoctlEvent); ... }
Remarks
This event fires when an IRP_MJ_DEVICE_CONTROL (IOCTL) operation has occurred. Such requests are sent using the Windows API's DeviceIoControl function (user mode), or ZwDeviceIoControlFile function (kernel mode). Please refer to Microsoft's documentation for more information. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_IOCTL flag.
The FileName parameter reflects the file, directory, or volume targeted by the request.
The IoControlCode parameter reflects the requested I/O control code (IOCTL).
The InBuffer parameter points to a memory buffer that contains the data required to perform the operation. The InBufferLength and InBufferValidBytes parameters reflect the capacity of InBuffer and the length of the data it contains (respectively), in bytes; InBufferValidBytes may be less than InBufferLength (unless the request did not include data, in which case both will be 0).
The OutBuffer parameter points to a memory buffer that contains the data returned by the operation. The OutBufferLength and OutBufferValidBytes parameters reflect the capacity of OutBuffer and the length of the data it contains (respectively), in bytes; OutBufferValidBytes may be less than OutBufferLength (unless the operation did not return data, in which case both will be 0).
Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_lock Event (CBMonitor Struct)
This event fires when a range of bytes in a file has been locked.
Syntax
// CBMonitorNotifyLockEventArgs carries the CBMonitor NotifyLock event's parameters. pub struct CBMonitorNotifyLockEventArgs { fn file_name(&self) -> &String fn offset(&self) -> i64 fn length(&self) -> i64 fn key(&self) -> i64 fn fail_immediately(&self) -> bool fn exclusive_lock(&self) -> bool fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyLockEvent defines the signature of the CBMonitor NotifyLock event's handler function. pub trait CBMonitorNotifyLockEvent { fn on_notify_lock(&self, sender : CBMonitor, e : &mut CBMonitorNotifyLockEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_lock(&self) -> &'a dyn CBMonitorNotifyLockEvent; pub fn set_on_notify_lock(&mut self, value : &'a dyn CBMonitorNotifyLockEvent); ... }
Remarks
This event fires when a range of bytes in the file specified by FileName has been locked. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. This request is made either by the OS, or on behalf of a user mode application that called the Windows API's LockFile or LockFileEx function. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_LOCK_CONTROL flag.
The Offset parameter reflects the byte offset where the byte range lock starts.
The Length parameter reflects the length of the byte range lock.
The Key parameter reflects the key that the byte range lock is associated with. This key is used to identify the byte range lock in later unlock-by-key requests.
The FailImmediately parameter indicates whether the request was to fail if the lock could not be granted immediately.
The ExclusiveLock parameter indicates whether the byte range lock was to be exclusive (true) or shared (false).
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_open_file Event (CBMonitor Struct)
This event fires when a file or directory has been opened.
Syntax
// CBMonitorNotifyOpenFileEventArgs carries the CBMonitor NotifyOpenFile event's parameters. pub struct CBMonitorNotifyOpenFileEventArgs { fn file_name(&self) -> &String fn existing_attributes(&self) -> i32 fn desired_access(&self) -> i32 fn attributes(&self) -> i32 fn share_mode(&self) -> i32 fn options(&self) -> i32 fn create_disposition(&self) -> i32 fn security_descriptor(&self) -> *mut u8 fn length(&self) -> i32 fn status(&self) -> i32 fn creation_status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyOpenFileEvent defines the signature of the CBMonitor NotifyOpenFile event's handler function. pub trait CBMonitorNotifyOpenFileEvent { fn on_notify_open_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyOpenFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_open_file(&self) -> &'a dyn CBMonitorNotifyOpenFileEvent; pub fn set_on_notify_open_file(&mut self, value : &'a dyn CBMonitorNotifyOpenFileEvent); ... }
Remarks
This event fires when the file or directory specified by FileName has been opened. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. Please refer to the File Create/Open Events topic for more information about how the struct determines whether to fire this event or on_notify_create_file. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_OPEN flag.
Note: Applications must have the FilterOwnRequests configuration setting enabled if they wish to filter their own file/directory open requests.
When extended rules are used or the AlwaysRequestAttributesOnOpen configuration setting is enabled, the driver requests attributes of the entity from the filesystem and passes them to ExistingAttributes. If the attributes are not requested, this parameter contains 0.
The DesiredAccess, Attributes, ShareMode, and CreateDisposition parameters reflect the values that were passed for the similarly named parameters of the Windows API's CreateFile function (or, more accurately, the values carried by the IRP_MJ_CREATE IRP).
DesiredAccess may contain one or more of the following access flags:
DESIRED_ACCESS_FILE_LIST_DIRECTORY | 0x00000001 | For a directory, the right to list the contents of the directory. |
DESIRED_ACCESS_FILE_READ_DATA | 0x00000001 | For a file object, the right to read the corresponding file data.
For a directory object, the right to read the corresponding directory data. |
DESIRED_ACCESS_FILE_ADD_FILE | 0x00000002 | For a directory, the right to create a file in the directory. |
DESIRED_ACCESS_FILE_WRITE_DATA | 0x00000002 | For a file object, the right to write data to the file.
For a directory object, the right to create a file in the directory |
DESIRED_ACCESS_FILE_ADD_SUBDIRECTORY | 0x00000004 | For a directory, the right to create a subdirectory. |
DESIRED_ACCESS_FILE_APPEND_DATA | 0x00000004 | For a file object, the right to append data to the file.
(For local files, write operations will not overwrite existing data if this flag is specified without FILE_WRITE_DATA.) For a directory object, the right to create a subdirectory (FILE_ADD_SUBDIRECTORY). |
DESIRED_ACCESS_FILE_READ_EA | 0x00000008 | The right to read extended file attributes. |
DESIRED_ACCESS_FILE_WRITE_EA | 0x00000010 | The right to write extended file attributes. |
DESIRED_ACCESS_FILE_EXECUTE | 0x00000020 | For a native code file, the right to execute the file.
This access right given to scripts may cause the script to be executable, depending on the script interpreter. |
DESIRED_ACCESS_FILE_DELETE_CHILD | 0x00000040 | For a directory, the right to delete a directory and all the files it contains, including read-only files. |
DESIRED_ACCESS_FILE_READ_ATTRIBUTES | 0x00000080 | The right to read file attributes. |
DESIRED_ACCESS_FILE_WRITE_ATTRIBUTES | 0x00000100 | The right to write file attributes. |
DESIRED_ACCESS_READ_CONTROL | 0x00020000 | The right to read the information in the file or directory object's security descriptor.
This does not include the information in the SACL. |
DESIRED_ACCESS_STANDARD_RIGHTS_READ | 0x00020000 | Includes READ_CONTROL, which is the right to read the information in the file or directory object's security descriptor.
This does not include the information in the SACL. |
DESIRED_ACCESS_STANDARD_RIGHTS_WRITE | 0x00020000 | Same as STANDARD_RIGHTS_READ |
DESIRED_ACCESS_STANDARD_RIGHTS_EXECUTE | 0x00020000 | Same as STANDARD_RIGHTS_READ |
DESIRED_ACCESS_SYNCHRONIZE | 0x00100000 | The right to use the object for synchronization.
This enables a thread to wait until the object is in the signaled state. Some object types do not support this access right. |
DESIRED_ACCESS_FILE_ALL_ACCESS | 0x001F01FF | All possible access rights for a file. |
DESIRED_ACCESS_FILE_GENERIC_READ | 0x00120089 | A combinarion of flags that allow reading of the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
DESIRED_ACCESS_FILE_GENERIC_WRITE | 0x00120116 | A combinarion of flags that allow modifications to the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
DESIRED_ACCESS_FILE_GENERIC_EXECUTE | 0x001200A0 | A combinarion of flags that allow execution of the file.
Note: Don't match received values against this flag. Instead, use flags that specify the rights that you want to verify or add/remove. |
Attributes may contain one or more of the following attributes:
FILE_SYS_ATTR_READ_ONLY | 0x00000001 | The file is read-only.
Applications can read the file, but cannot write to it or delete it. This attribute is not honored on directories. |
FILE_SYS_ATTR_HIDDEN | 0x00000002 | The file or directory is hidden.
The file is not included in an ordinary directory listing. |
FILE_SYS_ATTR_SYSTEM | 0x00000004 | A file or directory that the operating system uses a part of, or uses exclusively. |
FILE_SYS_ATTR_DIRECTORY | 0x00000010 | The entry is a directory. |
FILE_SYS_ATTR_ARCHIVE | 0x00000020 | The entry is an archive file or directory.
Applications typically use this attribute to mark files for backup or removal. |
FILE_SYS_ATTR_NORMAL | 0x00000080 | A file doesn't have other attributes set.
This attribute is valid only when used alone. |
FILE_SYS_ATTR_TEMPORARY | 0x00000100 | A file that is being used for temporary storage.
File systems avoid writing data back to mass storage if sufficient cache memory is available, because typically, an application deletes a temporary file after the handle is closed. In that scenario, the system can entirely avoid writing the data. Otherwise, the data are written after the handle is closed. |
FILE_SYS_ATTR_SPARSE_FILE | 0x00000200 | A file that is a sparse file. |
FILE_SYS_ATTR_REPARSE_POINT | 0x00000400 | A file that is a reparse point or a symbolic link. |
FILE_SYS_ATTR_COMPRESSED | 0x00000800 | A file or directory that is compressed.
For a file, all of the data in the file are compressed. For a directory, compression is the default for newly created files and subdirectories. A filesystem implementation can make use of this attribute by setting the support_compressed_attribute property to true and then properly handling the on_get_file_info, on_enumerate_directory, and on_set_file_attributes events. |
FILE_SYS_ATTR_OFFLINE | 0x00001000 | The data of a file are not available immediately.
This attribute indicates that the file data are physically moved to offline storage. |
FILE_SYS_ATTR_NOT_CONTENT_INDEXED | 0x00002000 | The file or directory is not to be indexed by the content indexing service. |
FILE_SYS_ATTR_ENCRYPTED | 0x00004000 | A file or directory that is encrypted.
For a file, all data streams in the file are encrypted. For a directory, encryption is the default for newly created files and subdirectories. Note: This flag is used by NTFS and the OS sends undocumented requests to the filesystem based on this flag. The flag should not be used for files in custom filesystem implementations. |
FILE_SYS_ATTR_VIRTUAL | 0x00010000 | Reserved.
Note: This flag is reserved by the OS and should not be used for files in custom filesystem implementations. |
FILE_SYS_ATTR_RECALL_ON_OPEN | 0x00040000 | The file or directory has no physical representation on the local system; the item is virtual.
Opening the item will be more expensive than normal (e.g., it will cause at least some of it to be fetched from a remote store). This flag is reported by filesystems during directory enumerations. |
ShareMode may contain zero or more of the following share mode flags:
FILESYS_SHARE_READ | 0x00000001 | Enables subsequent open operations on a file or device to request read access.
Enables subsequent open operations to request read access; otherwise, no process can open the file or device if it requests read access. If this flag is not specified, but the file or device has been opened for read access, the function fails. |
FILESYS_SHARE_WRITE | 0x00000002 | Enables subsequent open operations on a file or device to request write access.
Enables subsequent open operations to request write access; otherwise, no process can open the file or device if it requests write access. If this flag is not specified, but the file or device has been opened for write access or has a file mapping with write access, the function fails. |
FILESYS_SHARE_DELETE | 0x00000004 | Enables subsequent open operations on a file or device to request delete access.
Enables subsequent open operations to request delete access; otherwise, no process can open the file or device if it requests delete access. If this flag is not specified, but the file or device has been opened for delete access, the function fails. Note: Delete access allows both delete and rename operations. |
CreateDisposition may contain one of the following values:
FILE_DISPOSITION_CREATE_NEW | 0x00000001 | Creates a new file, only if it does not already exist.
If the specified file exists, the operation fails with an "already exists" error. |
FILE_DISPOSITION_CREATE_ALWAYS | 0x00000002 | Creates a new file, always.
If the specified file exists and is writable, the system overwrites the file. If the specified file does not exist and is a valid path, a new file is created. |
FILE_DISPOSITION_OPEN_EXISTING | 0x00000003 | Opens a file, only if it exists
If the specified file does not exist, opening fails. |
FILE_DISPOSITION_OPEN_ALWAYS | 0x00000004 | Opens a file, always.
If the specified file exists, the operation succeeds. If the specified file does not exist and is a valid path to a writable location, the a file is created. |
FILE_DISPOSITION_TRUNCATE_EXISTING | 0x00000005 | Opens a file and truncates it so that its size is zero bytes, only if it exists.
If the specified file does not exist, the operation fails with a "file not found" error. |
Options contains the flags that are described in the CreateOptions parameter of the native API's ZwCreateFile function. Most of those flags correspond to flags passed in the FlagsAndAttributes parameter of the Windows API's CreateFile function, but some flags are specific to the native API. If you need those flags, check both functions' descriptions.
Please refer to Microsoft's documentation for detailed information about these constants.
To determine whether the request was for a file or a directory, compare Attributes against the FILE_SYS_ATTR_DIRECTORY constant, as follows:
// Check whether the request is for a file or a directory.
bool isDirectory = Attributes & FILE_SYS_ATTR_DIRECTORY == FILE_SYS_ATTR_DIRECTORY;
FILE_SYS_ATTR_DIRECTORY will be present if it was specified by the calling process or if the existing filesystem entry is a directory.
To determine whether a file will be deleted when its last handle is closed, compare Options against the Windows API's FILE_FLAG_DELETE_ON_CLOSE constant, as follows:
// Check whether the file will be deleted on close.
bool deleteOnClose = Options & FILE_FLAG_DELETE_ON_CLOSE == FILE_FLAG_DELETE_ON_CLOSE;
Note: Because files can be deleted in different ways, do not use this check to take actions related to tracking file deletion operations. Instead, use the events related to file deletion.
When a file or directory is created using the CreateFile() Windows API function, a caller can specify the security descriptor with the security information. This security information should be applied to a newly created file or directory. The struct passes this security information in the SecurityInformation and SecurityDescriptor parameters, when the PassSecurityInFileOpenEvents configuration setting is enabled. If this configuration setting is omitted, the corresponding parameters are empty.
The SecurityInformation parameter reflects which pieces of security information, of those present in SecurityDescriptor, are valid and should have been applied. Please refer to Microsoft's SECURITY_INFORMATION data type documentation for more information about possible values.
The SecurityDescriptor parameter points to a memory buffer that contains the security information. The Length parameter reflects the length of this data, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The data are formatted as a SECURITY_DESCRIPTOR structure in self-relative format; please refer to the Microsoft's documentation for more information.
If the Options contains the FILE_FLAG_DELETE_ON_CLOSE flag, the on_notify_can_file_be_deleted event will fire after this event.
If the file is opened with extended attributes passed in the request, the on_notify_set_ea event will fire after this event.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The CreationStatus parameter indicates whether the file was created or opened and can be one of the following values:
CREATION_STATUS_SUPERSEDED | 0x00000000 | An existing file was superseded by the new file.
The previous version of a file may still exist if it had hard links other than the name used in the operation. |
CREATION_STATUS_OPENED | 0x00000001 | The file existed before the operation and was opened. |
CREATION_STATUS_CREATED | 0x00000002 | The file didn't exist before the operation and was created. |
CREATION_STATUS_OVERWRITTEN | 0x00000003 | The file exists, and its contents have been replaced. |
CREATION_STATUS_EXISTS | 0x00000004 | The file existed before the operation, and no action was taken. |
CREATION_STATUS_DOES_NOT_EXIST | 0x000000055 | The file did not exist before the operation, and no action was taken. |
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_query_ea Event (CBMonitor Struct)
This event fires when information about the extended attributes of a file has been retrieved.
Syntax
// CBMonitorNotifyQueryEaEventArgs carries the CBMonitor NotifyQueryEa event's parameters. pub struct CBMonitorNotifyQueryEaEventArgs { fn file_name(&self) -> &String fn buffer(&self) -> *mut u8 fn buffer_length(&self) -> i32 fn return_single_entry(&self) -> bool fn ea_list(&self) -> *mut u8 fn ea_list_length(&self) -> i32 fn ea_index(&self) -> i32 fn restart_scan(&self) -> bool fn length_returned(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyQueryEaEvent defines the signature of the CBMonitor NotifyQueryEa event's handler function. pub trait CBMonitorNotifyQueryEaEvent { fn on_notify_query_ea(&self, sender : CBMonitor, e : &mut CBMonitorNotifyQueryEaEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_query_ea(&self) -> &'a dyn CBMonitorNotifyQueryEaEvent; pub fn set_on_notify_query_ea(&mut self, value : &'a dyn CBMonitorNotifyQueryEaEvent); ... }
Remarks
This event fires when information about the extended attributes of a file specified by FileName has been retrieved. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_QUERY_EA flag.
The Buffer parameter points to a memory buffer that, if the request was successful, contains the requested information. The data in the buffer are formatted as a FILE_FULL_EA_INFORMATION structure; please refer to the Microsoft's documentation for more information. The Length parameter reflects the length of this buffer, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
ReturnSingleEntry specifies that the filesystem had to return only the first entry it has found.
EaList is an optional parameter that points to a caller-supplied memory buffer specifying the extended attributes to be queried. The data in the buffer are formatted as a FILE_GET_EA_INFORMATION structure; please refer to the Microsoft's documentation for more information. The EaListLength parameter reflects the length of this data, in bytes. If the caller of the FltQueryEaFile function did not specify any value, it will contain 0.
EaIndex is an optional parameter that specifies the starting index of the attribute, information about which was requested. This parameter is ignored by the filesystem if EaList points to a nonempty list. If the caller of the FltQueryEaFile function did not specify any value, the parameter will contain -1.
The RestartScan parameter instructs the filesystem to restart enumeration of extended attributes from the first entry. If the parameter is false, retrieval of the extended attributes is resumed by the filesystem after a previous request.
LengthReturned is an optional parameter that contains the size, in bytes, of the information, returned in the Buffer.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_query_file_info Event (CBMonitor Struct)
This event fires when information about a file or directory has been retrieved.
Syntax
// CBMonitorNotifyQueryFileInfoEventArgs carries the CBMonitor NotifyQueryFileInfo event's parameters. pub struct CBMonitorNotifyQueryFileInfoEventArgs { fn file_name(&self) -> &String fn file_information_class(&self) -> i32 fn buffer(&self) -> *mut u8 fn buffer_length(&self) -> i32 fn valid_bytes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyQueryFileInfoEvent defines the signature of the CBMonitor NotifyQueryFileInfo event's handler function. pub trait CBMonitorNotifyQueryFileInfoEvent { fn on_notify_query_file_info(&self, sender : CBMonitor, e : &mut CBMonitorNotifyQueryFileInfoEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_query_file_info(&self) -> &'a dyn CBMonitorNotifyQueryFileInfoEvent; pub fn set_on_notify_query_file_info(&mut self, value : &'a dyn CBMonitorNotifyQueryFileInfoEvent); ... }
Remarks
This event fires when information about a file or directory specified by FileName has been retrieved. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. This event typically fires in response to the Windows API's NtQueryInformationFile function. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_QUERY_FILE_INFO flag.
The FileInformationClass parameter indicates what kind of file information was requested. Please refer to the NtQueryInformationFile function's documentation for more information about possible values.
The Buffer parameter points to a memory buffer that, if the request was successful, contains the requested file information. The BufferLength and ValidBytes parameters reflect the capacity of Buffer and the length of the data it contains (respectively), in bytes; ValidBytes may be less than BufferLength. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The format of the data is determined by the specified FileInformationClass; please refer to the NtQueryInformationFile function's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_read_file Event (CBMonitor Struct)
This event fires when data have been read from a file.
Syntax
// CBMonitorNotifyReadFileEventArgs carries the CBMonitor NotifyReadFile event's parameters. pub struct CBMonitorNotifyReadFileEventArgs { fn file_name(&self) -> &String fn position(&self) -> i64 fn bytes_to_read(&self) -> i32 fn direction(&self) -> i32 fn bytes_read(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyReadFileEvent defines the signature of the CBMonitor NotifyReadFile event's handler function. pub trait CBMonitorNotifyReadFileEvent { fn on_notify_read_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyReadFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_read_file(&self) -> &'a dyn CBMonitorNotifyReadFileEvent; pub fn set_on_notify_read_file(&mut self, value : &'a dyn CBMonitorNotifyReadFileEvent); ... }
Remarks
This event fires when data have been read from a file specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_READ flag.
The Position parameter reflects the byte offset in the file at which reading started.
The BytesToRead parameter reflects how many bytes were to be read from the file.
The Direction parameter indicates the request direction; please refer to the Cached and Non-Cached Requests topic for more information. Possible values are as follows:
FS_REQUEST_DIR_USER_NONCACHED | 0 | Operations performed in the user mode application <--> filesystem direction. |
FS_REQUEST_DIR_USER_CACHED | 1 | Operations performed in the user mode application <--> system cache direction. |
FS_REQUEST_DIR_SYSTEM_NONCACHED | 2 | Operations performed in the system cache <--> filesystem direction. |
FS_REQUEST_DIR_SYSTEM_CACHED | 3 | Operations performed in the system component <--> system cache direction. |
The BytesRead parameter reflects how many bytes were actually read from the file.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_rename_or_move_file Event (CBMonitor Struct)
This event fires when a file or directory has been renamed or moved.
Syntax
// CBMonitorNotifyRenameOrMoveFileEventArgs carries the CBMonitor NotifyRenameOrMoveFile event's parameters. pub struct CBMonitorNotifyRenameOrMoveFileEventArgs { fn file_name(&self) -> &String fn new_file_name(&self) -> &String fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyRenameOrMoveFileEvent defines the signature of the CBMonitor NotifyRenameOrMoveFile event's handler function. pub trait CBMonitorNotifyRenameOrMoveFileEvent { fn on_notify_rename_or_move_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyRenameOrMoveFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_rename_or_move_file(&self) -> &'a dyn CBMonitorNotifyRenameOrMoveFileEvent; pub fn set_on_notify_rename_or_move_file(&mut self, value : &'a dyn CBMonitorNotifyRenameOrMoveFileEvent); ... }
Remarks
This event fires when a file or directory specified by FileName has been renamed or moved to NewFileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_RENAME flag. A rule's mask is matched against both previous and new file names, and the event will fire when either of the names matches the mask.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_allocation_size Event (CBMonitor Struct)
This event fires when a file's allocation size has been changed.
Syntax
// CBMonitorNotifySetAllocationSizeEventArgs carries the CBMonitor NotifySetAllocationSize event's parameters. pub struct CBMonitorNotifySetAllocationSizeEventArgs { fn file_name(&self) -> &String fn allocation_size(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetAllocationSizeEvent defines the signature of the CBMonitor NotifySetAllocationSize event's handler function. pub trait CBMonitorNotifySetAllocationSizeEvent { fn on_notify_set_allocation_size(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetAllocationSizeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_allocation_size(&self) -> &'a dyn CBMonitorNotifySetAllocationSizeEvent; pub fn set_on_notify_set_allocation_size(&mut self, value : &'a dyn CBMonitorNotifySetAllocationSizeEvent); ... }
Remarks
This event fires when the allocation size of the file specified by FileName has been changed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_SIZES flag.
The AllocationSize parameter reflects the new allocation size, in bytes. A file's allocation size is typically larger than its actual size because filesystem operations often reserve space on disk before writing additional data to a file.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_ea Event (CBMonitor Struct)
This event fires when information about the extended attributes of a file has been changed.
Syntax
// CBMonitorNotifySetEaEventArgs carries the CBMonitor NotifySetEa event's parameters. pub struct CBMonitorNotifySetEaEventArgs { fn file_name(&self) -> &String fn buffer(&self) -> *mut u8 fn buffer_length(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetEaEvent defines the signature of the CBMonitor NotifySetEa event's handler function. pub trait CBMonitorNotifySetEaEvent { fn on_notify_set_ea(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetEaEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_ea(&self) -> &'a dyn CBMonitorNotifySetEaEvent; pub fn set_on_notify_set_ea(&mut self, value : &'a dyn CBMonitorNotifySetEaEvent); ... }
Remarks
This event fires when information about the extended attributes of a file specified by FileName has been changed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic.
If the file is created or opened with extended attributes passed in the request, this event will fire shortly after the on_notify_create_file or on_notify_open_file event.
The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_EA flag.
The Buffer parameter points to a memory buffer that specifies the extended attribute information. The Length parameter reflects the length of this buffer, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The data are formatted as a FILE_FULL_EA_INFORMATION structure; please refer to the Microsoft's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_file_attributes Event (CBMonitor Struct)
This event fires when a file or directory's attributes or times have been changed.
Syntax
// CBMonitorNotifySetFileAttributesEventArgs carries the CBMonitor NotifySetFileAttributes event's parameters. pub struct CBMonitorNotifySetFileAttributesEventArgs { fn file_name(&self) -> &String fn creation_time(&self) -> &chrono::DateTime<Utc> fn last_access_time(&self) -> &chrono::DateTime<Utc> fn last_write_time(&self) -> &chrono::DateTime<Utc> fn change_time(&self) -> &chrono::DateTime<Utc> fn attributes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetFileAttributesEvent defines the signature of the CBMonitor NotifySetFileAttributes event's handler function. pub trait CBMonitorNotifySetFileAttributesEvent { fn on_notify_set_file_attributes(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetFileAttributesEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_file_attributes(&self) -> &'a dyn CBMonitorNotifySetFileAttributesEvent; pub fn set_on_notify_set_file_attributes(&mut self, value : &'a dyn CBMonitorNotifySetFileAttributesEvent); ... }
Remarks
This event fires when the attributes or times of the file or directory specified by FileName have been changed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_ATTRIBUTES flag.
The CreationTime, LastAccessTime, LastWriteTime, and ChangeTime parameters reflect the new time values, specified in UTC. A value of January 1, 1601 00:00:00 UTC indicates that the corresponding time value was not included in the request.
The Attributes parameter reflects the new attributes; please refer to Microsoft's File Attribute Constants article for attribute descriptions. A value of 0 indicates that attributes were not included in the request.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_file_info Event (CBMonitor Struct)
This event fires when information about a file or directory has been changed.
Syntax
// CBMonitorNotifySetFileInfoEventArgs carries the CBMonitor NotifySetFileInfo event's parameters. pub struct CBMonitorNotifySetFileInfoEventArgs { fn file_name(&self) -> &String fn file_information_class(&self) -> i32 fn buffer(&self) -> *mut u8 fn buffer_length(&self) -> i32 fn valid_bytes(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetFileInfoEvent defines the signature of the CBMonitor NotifySetFileInfo event's handler function. pub trait CBMonitorNotifySetFileInfoEvent { fn on_notify_set_file_info(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetFileInfoEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_file_info(&self) -> &'a dyn CBMonitorNotifySetFileInfoEvent; pub fn set_on_notify_set_file_info(&mut self, value : &'a dyn CBMonitorNotifySetFileInfoEvent); ... }
Remarks
This event fires when information about a file or directory specified by FileName has been changed. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. This event typically fires in response to the Windows API's NtSetInformationFile function. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_QUERY_FILE_INFO flag.
The FileInformationClass parameter indicates what kind of file information was set. Please refer to the NtSetInformationFile function's documentation for more information about possible values.
The Buffer parameter points to a memory buffer that, if the request was successful, contains the new file information. The BufferLength and ValidBytes parameters reflect the capacity of Buffer and the length of the data it contains (respectively), in bytes; ValidBytes may be less than BufferLength. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The format of the data is determined by the specified FileInformationClass; please refer to the NtSetInformationFile function's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_file_security Event (CBMonitor Struct)
This event fires when a file or directory's security attributes have been changed.
Syntax
// CBMonitorNotifySetFileSecurityEventArgs carries the CBMonitor NotifySetFileSecurity event's parameters. pub struct CBMonitorNotifySetFileSecurityEventArgs { fn file_name(&self) -> &String fn security_information(&self) -> i32 fn security_descriptor(&self) -> *mut u8 fn length(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetFileSecurityEvent defines the signature of the CBMonitor NotifySetFileSecurity event's handler function. pub trait CBMonitorNotifySetFileSecurityEvent { fn on_notify_set_file_security(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetFileSecurityEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_file_security(&self) -> &'a dyn CBMonitorNotifySetFileSecurityEvent; pub fn set_on_notify_set_file_security(&mut self, value : &'a dyn CBMonitorNotifySetFileSecurityEvent); ... }
Remarks
This event fires when security attributes have been changed for a file or directory specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_SECURITY flag.
The SecurityInformation parameter reflects which pieces of security information, of those present in SecurityDescriptor, were to be set. Please refer to Microsoft's SECURITY_INFORMATION data-type documentation for more information about possible values.
The SecurityDescriptor parameter points to a memory buffer that contains the new security information. The Length parameter reflects the length of this data, in bytes. Please see the Buffer Parameters topic for more information on how to work with memory buffer event parameters.
The data are formatted as a SECURITY_DESCRIPTOR structure in self-relative format; please refer to the Microsoft's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_file_size Event (CBMonitor Struct)
This event fires when a file has been resized.
Syntax
// CBMonitorNotifySetFileSizeEventArgs carries the CBMonitor NotifySetFileSize event's parameters. pub struct CBMonitorNotifySetFileSizeEventArgs { fn file_name(&self) -> &String fn size(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetFileSizeEvent defines the signature of the CBMonitor NotifySetFileSize event's handler function. pub trait CBMonitorNotifySetFileSizeEvent { fn on_notify_set_file_size(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetFileSizeEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_file_size(&self) -> &'a dyn CBMonitorNotifySetFileSizeEvent; pub fn set_on_notify_set_file_size(&mut self, value : &'a dyn CBMonitorNotifySetFileSizeEvent); ... }
Remarks
This event fires when the file specified by FileName has been resized, whether explicitly (e.g., truncation) or implicitly (i.e., as data are appended). For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Note: to receive this event when the file size is increased implicitly (during writing of data), the application must enable the SetFileSizeOnWrite configuration setting.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_SIZES flag.
The Size parameter reflects the new file size, in bytes.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_set_reparse_point Event (CBMonitor Struct)
This event fires when a file or directory's reparse point has been created or updated.
Syntax
// CBMonitorNotifySetReparsePointEventArgs carries the CBMonitor NotifySetReparsePoint event's parameters. pub struct CBMonitorNotifySetReparsePointEventArgs { fn file_name(&self) -> &String fn reparse_tag(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifySetReparsePointEvent defines the signature of the CBMonitor NotifySetReparsePoint event's handler function. pub trait CBMonitorNotifySetReparsePointEvent { fn on_notify_set_reparse_point(&self, sender : CBMonitor, e : &mut CBMonitorNotifySetReparsePointEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_set_reparse_point(&self) -> &'a dyn CBMonitorNotifySetReparsePointEvent; pub fn set_on_notify_set_reparse_point(&mut self, value : &'a dyn CBMonitorNotifySetReparsePointEvent); ... }
Remarks
This event fires when a reparse point has been created or updated for a file or directory specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_SET_REPARSE_POINT flag.
The ReparseTag parameter contains the reparse tag, which is the value the system uses to identify the format of the reparse point data.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_unlock_all Event (CBMonitor Struct)
This event fires when all locked byte ranges in a file have been unlocked.
Syntax
// CBMonitorNotifyUnlockAllEventArgs carries the CBMonitor NotifyUnlockAll event's parameters. pub struct CBMonitorNotifyUnlockAllEventArgs { fn file_name(&self) -> &String fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyUnlockAllEvent defines the signature of the CBMonitor NotifyUnlockAll event's handler function. pub trait CBMonitorNotifyUnlockAllEvent { fn on_notify_unlock_all(&self, sender : CBMonitor, e : &mut CBMonitorNotifyUnlockAllEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_unlock_all(&self) -> &'a dyn CBMonitorNotifyUnlockAllEvent; pub fn set_on_notify_unlock_all(&mut self, value : &'a dyn CBMonitorNotifyUnlockAllEvent); ... }
Remarks
This event fires when all locked byte ranges in the file specified by FileName have been unlocked. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_LOCK_CONTROL flag.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_unlock_all_by_key Event (CBMonitor Struct)
This event fires when all locked byte ranges in a file, associated with a particular key, have been unlocked.
Syntax
// CBMonitorNotifyUnlockAllByKeyEventArgs carries the CBMonitor NotifyUnlockAllByKey event's parameters. pub struct CBMonitorNotifyUnlockAllByKeyEventArgs { fn file_name(&self) -> &String fn key(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyUnlockAllByKeyEvent defines the signature of the CBMonitor NotifyUnlockAllByKey event's handler function. pub trait CBMonitorNotifyUnlockAllByKeyEvent { fn on_notify_unlock_all_by_key(&self, sender : CBMonitor, e : &mut CBMonitorNotifyUnlockAllByKeyEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_unlock_all_by_key(&self) -> &'a dyn CBMonitorNotifyUnlockAllByKeyEvent; pub fn set_on_notify_unlock_all_by_key(&mut self, value : &'a dyn CBMonitorNotifyUnlockAllByKeyEvent); ... }
Remarks
This event fires when all locked byte ranges in the file specified by FileName, and associated with the specified Key, have been unlocked. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_LOCK_CONTROL flag.
The Key parameter contains the key value specified when the byte ranges were locked. Please refer to the on_notify_lock event's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_unlock_single Event (CBMonitor Struct)
This event fires when a particular locked byte range in a file has been unlocked.
Syntax
// CBMonitorNotifyUnlockSingleEventArgs carries the CBMonitor NotifyUnlockSingle event's parameters. pub struct CBMonitorNotifyUnlockSingleEventArgs { fn file_name(&self) -> &String fn offset(&self) -> i64 fn length(&self) -> i64 fn key(&self) -> i64 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyUnlockSingleEvent defines the signature of the CBMonitor NotifyUnlockSingle event's handler function. pub trait CBMonitorNotifyUnlockSingleEvent { fn on_notify_unlock_single(&self, sender : CBMonitor, e : &mut CBMonitorNotifyUnlockSingleEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_unlock_single(&self) -> &'a dyn CBMonitorNotifyUnlockSingleEvent; pub fn set_on_notify_unlock_single(&mut self, value : &'a dyn CBMonitorNotifyUnlockSingleEvent); ... }
Remarks
This event fires when a particular locked byte range in a file specified by FileName has been unlocked. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_LOCK_CONTROL flag.
The Offset, Length, and Key parameters contain the starting byte offset, length, and key values, respectively, specified when the byte range was locked. Please refer to the on_notify_lock event's documentation for more information.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_notify_write_file Event (CBMonitor Struct)
This event fires when data have been written to a file.
Syntax
// CBMonitorNotifyWriteFileEventArgs carries the CBMonitor NotifyWriteFile event's parameters. pub struct CBMonitorNotifyWriteFileEventArgs { fn file_name(&self) -> &String fn position(&self) -> i64 fn bytes_to_write(&self) -> i32 fn direction(&self) -> i32 fn bytes_written(&self) -> i32 fn status(&self) -> i32 fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorNotifyWriteFileEvent defines the signature of the CBMonitor NotifyWriteFile event's handler function. pub trait CBMonitorNotifyWriteFileEvent { fn on_notify_write_file(&self, sender : CBMonitor, e : &mut CBMonitorNotifyWriteFileEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_notify_write_file(&self) -> &'a dyn CBMonitorNotifyWriteFileEvent; pub fn set_on_notify_write_file(&mut self, value : &'a dyn CBMonitorNotifyWriteFileEvent); ... }
Remarks
This event fires when data have been written to the file specified by FileName. For more information about the FileName parameter and what it may contain, please refer to the Filenames In Events topic. The event fires after the request is handled by the filesystem successfully or, in the case of a different status, when the process_failed_requests property is set to true.
Applications need to handle this event only if they have added a standard filter rule that includes the FS_NE_WRITE flag.
The Position parameter reflects the byte offset in the file at which writing started. A value of -1 means "append to the end of the file".
The BytesToWrite parameter reflects how many bytes were to be written to the file.
The Direction parameter indicates the request direction; please refer to the Cached and Non-Cached Requests topic for more information. Possible values are as follows:
FS_REQUEST_DIR_USER_NONCACHED | 0 | Operations performed in the user mode application <--> filesystem direction. |
FS_REQUEST_DIR_USER_CACHED | 1 | Operations performed in the user mode application <--> system cache direction. |
FS_REQUEST_DIR_SYSTEM_NONCACHED | 2 | Operations performed in the system cache <--> filesystem direction. |
FS_REQUEST_DIR_SYSTEM_CACHED | 3 | Operations performed in the system component <--> system cache direction. |
The BytesWritten parameter reflects how many bytes were actually written to the file.
The Status parameter contains an NT status code that indicates the outcome of the operation; 0 indicates success. To convert this value to a Win32 error code, call the nt_status_to_win32_error method.
Note: This event will not fire for failed requests unless the process_failed_requests property is enabled.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason, set it to a non-zero value to report an appropriate error.
Note: This event fires after the operation has already completed, so reporting an error will not actually affect the operation itself. Please refer to the Error Handling topic for more information.
This event is fired asynchronously; please refer to the Event Types topic for more information.
on_worker_thread_creation Event (CBMonitor Struct)
Fires just after a new worker thread is created.
Syntax
// CBMonitorWorkerThreadCreationEventArgs carries the CBMonitor WorkerThreadCreation event's parameters. pub struct CBMonitorWorkerThreadCreationEventArgs { fn result_code(&self) -> i32 fn set_result_code(&self, value : i32) } // CBMonitorWorkerThreadCreationEvent defines the signature of the CBMonitor WorkerThreadCreation event's handler function. pub trait CBMonitorWorkerThreadCreationEvent { fn on_worker_thread_creation(&self, sender : CBMonitor, e : &mut CBMonitorWorkerThreadCreationEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_worker_thread_creation(&self) -> &'a dyn CBMonitorWorkerThreadCreationEvent; pub fn set_on_worker_thread_creation(&mut self, value : &'a dyn CBMonitorWorkerThreadCreationEvent); ... }
Remarks
This event fires just after a worker thread is created, in the context of that worker thread.
This event is optional; it is provided to give applications a chance to perform additional processing when a new worker thread is created, such as allocating per-thread objects.
The struct maintains a pool of worker threads and uses them to fire events; please refer to the Threading and Concurrency topic for more information.
The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource is not available or security checks failed), set it to a nonzero value to report an appropriate error. Please see the Error Handling topic for more information.
This event is fired synchronously; please refer to the Event Types topic for more information.
on_worker_thread_termination Event (CBMonitor Struct)
Fires just before a worker thread is terminated.
Syntax
// CBMonitorWorkerThreadTerminationEventArgs carries the CBMonitor WorkerThreadTermination event's parameters. pub struct CBMonitorWorkerThreadTerminationEventArgs { } // CBMonitorWorkerThreadTerminationEvent defines the signature of the CBMonitor WorkerThreadTermination event's handler function. pub trait CBMonitorWorkerThreadTerminationEvent { fn on_worker_thread_termination(&self, sender : CBMonitor, e : &mut CBMonitorWorkerThreadTerminationEventArgs); } impl <'a> CBMonitor<'a> { pub fn on_worker_thread_termination(&self) -> &'a dyn CBMonitorWorkerThreadTerminationEvent; pub fn set_on_worker_thread_termination(&mut self, value : &'a dyn CBMonitorWorkerThreadTerminationEvent); ... }
Remarks
This event fires just before a worker thread is terminated, in the context of that worker thread.
This event is optional; it is provided to give applications a chance to perform additional processing before a worker thread is terminated, such as deallocating per-thread objects.
The struct maintains a pool of worker threads and uses them to fire events; please refer to the Threading and Concurrency topic for more information.
Any errors that occur during this event are ignored.
This event is fired synchronously; please refer to the Event Types topic for more information.
Config Settings (CBMonitor Struct)
The struct accepts one or more of the following configuration settings. Configuration settings are similar in functionality to properties, but they are rarely used. In order to avoid "polluting" the property namespace of the struct, access to these internal properties is provided through the config method.CBMonitor Config Settings
Administrative rights are required to change this configuration setting after initialize is called. If the user account of the process that calls config does not have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD (0x0522) error.
Enable this setting to tell the driver to always request the existing attributes and pass them to the ExistingAttributes parameter of the events, as related to file creation and opening.
By default, this configuration setting is disabled. Enable it to use the get_remote_access_information method.
Normally, this setting should remain disabled (especially in production) to reduce the possibility of system deadlocks occurring. Certain situations, however, do require it to be enabled, such as for testing purposes (so that event handlers can be tested with single-process tests).
Administrative rights are required to change this configuration setting after initialize is called. If the user account of the process that calls config does not have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD (0x0522) error.
Administrative rights are required to change this configuration setting after initialize is called. If the user account of the process that calls config does not have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD (0x0522) error.
This setting's value is stored in the registry and is persistent; it requires administrative rights to be changed.
By default, this setting is set to 0, and the driver automatically chooses an optimal number of threads using this equation: 4 * number_of_processors where number_of_processors is the number of logical processors, which are virtual cores, i.e. physical processor cores of all available physical processors adjusted by Hyper-Threading (on Intel CPUs) or Simultaneous Multi-Threading (SMT) (on AMD CPUs) .
By default, this setting is set to 0, and the driver automatically chooses an optimal number of threads using this equation: max(number_of_processors, 4). If this setting's value exceeds the MaxWorkerThreadCount value, the latter is used instead.
- 0 - never: Do nothing in regard to the short file names.
- 1 - on local file systems: Causes the driver to attempt to resolve short file names, but only for local filesystems.
- 2 - always: Causes the driver to attempt to resolve short file names for files on all filesystems.
This setting is global and is stored in the HKEY_LOCAL_MACHINE key of the registry. To change it, an application must run with administrative or equivalent rights.
By default this setting is disabled.
Note: This setting cannot be changed when active is true, and it cannot be changed within events.
When this configuration setting is enabled, all known names (both current and old) are passed to event handlers as described in the Filenames In Events topic. By default, this setting is disabled.
Note: This setting cannot be changed within events.
When a file or directory is first opened, the struct's system driver determines which of the currently active rules it matches, if any. The results of this process are collected into a single preprocessed rule internally, which is then cached. These preprocessed rules can provide significant performance improvements, especially if many rules have been added, because they prevent the driver from having to recheck each rule every time an operation occurs.
- Such translation will be performed only if a device actually has a corresponding DOS-style drive letter; not all devices do.
- The on_before_filter_attach_to_volume event always uses NT native device names, because DOS-style drive letters are not assigned until after it fires.
This setting is enabled by default; it can be disabled to improve performance, or if the application needs the native device name.
Note: This setting cannot be changed when active is true, and it cannot be changed within events.
If an application performs path analysis in event handlers, it needs to enable the PassAllFileNames setting as well in order to receive all collected names.
The setting is disabled by default for performance reasons.
Note: hard links are supported only on some filesystems, but are enabled by default in regular NTFS.
Administrative rights are required to change this configuration setting after initialize is called. If the user account of the process that calls config does not have such rights, the call will fail with an ERROR_PRIVILEGE_NOT_HELD (0x0522) error.
By default, this setting is disabled.
Note: This setting cannot be changed when active is true, and it cannot be changed within events.
By default, this setting is set to 0, and the driver uses a default stack size (currently, 1 MB).
Note: This setting cannot be changed when active is true, and it cannot be changed within events.
Base Config Settings
- Product: The product the license is for.
- Product Key: The key the license was generated from.
- License Source: Where the license was found (e.g., RuntimeLicense, License File).
- License Type: The type of license installed (e.g., Royalty Free, Single Server).
Trappable Errors (CBMonitor Struct)
The struct uses Windows error codes during operation as necessary. Please refer to the Error Handling topic for more information.Special Use Errors
21 | ERROR_NOT_READY: Reported by the methods of the struct if initialize has not been called or did not succeed. |
191 | ERROR_INVALID_EXE_SIGNATURE: Reported by the install method when the CAB file signature cannot be validated. |
575 | ERROR_APP_INIT_FAILURE: Reported by the methods of the struct if initialize has not been called or did not succeed. Differs from ERROR_NOT_READY (21) in that it indicates a specific situation in the internal code. |
588 | ERROR_FS_DRIVER_REQUIRED: Reported if the required system module was not correctly installed for the given ProductGUID. |
614 | ERROR_NO_CALLBACK_ACTIVE: Reported by any method that can only be called within event handlers if it is called outside an event handler. |
1292 | ERROR_IMPLEMENTATION_LIMIT: Reported when the timeout value provided is less than 3 seconds. |
1314 | ERROR_PRIVILEGE_NOT_HELD: Reported by any method that requires elevated permissions if it is called without such permissions. |