Обновлены комментарии
This commit is contained in:
parent
97edc0d795
commit
88554fa0cb
1 changed files with 294 additions and 152 deletions
|
@ -1,250 +1,392 @@
|
||||||
|
// Low-level wrapper over the C API fanotify for D.
|
||||||
|
// All values are taken from uapi <linux/fanotify.h>
|
||||||
// Низкоуровневая обёртка над C API fanotify для D.
|
// Низкоуровневая обёртка над C API fanotify для D.
|
||||||
// Все значения взяты из uapi <linux/fanotify.h> (актуальная версия на основе предоставленного заголовка).
|
// Все значения взяты из uapi <linux/fanotify.h>
|
||||||
|
|
||||||
module fanotify;
|
module fanotify;
|
||||||
|
|
||||||
import core.stdc.stdint; // uint64_t и т.п.
|
import core.stdc.stdint; // uint64_t and similar // uint64_t и т.п.
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
// FLAGS FOR fanotify_init(flags, event_f_flags)
|
||||||
// ФЛАГИ ДЛЯ fanotify_init(flags, event_f_flags)
|
// ФЛАГИ ДЛЯ fanotify_init(flags, event_f_flags)
|
||||||
// ------------------------------------------------------------
|
|
||||||
|
// File descriptor group behavior
|
||||||
// Поведение файлового дескриптора группы
|
// Поведение файлового дескриптора группы
|
||||||
enum FAN_CLOEXEC = 0x0000_0001; // закрывать fd при exec()
|
// Close fd on exec()
|
||||||
enum FAN_NONBLOCK = 0x0000_0002; // неблокирующие read()
|
enum FAN_CLOEXEC = 0x0000_0001; // Закрывать fd при exec()
|
||||||
|
// Non-blocking read()
|
||||||
|
enum FAN_NONBLOCK = 0x0000_0002; // Неблокирующие read()
|
||||||
|
|
||||||
|
// Group class (defines the type of issued events)
|
||||||
// Класс группы (определяет тип выдаваемых событий)
|
// Класс группы (определяет тип выдаваемых событий)
|
||||||
enum FAN_CLASS_NOTIF = 0x0000_0000; // только уведомления (не PERM)
|
// Notifications only (not PERM)
|
||||||
enum FAN_CLASS_CONTENT = 0x0000_0004; // разрешения на доступ к СОДЕРЖИМОМУ (CONTENT)
|
enum FAN_CLASS_NOTIF = 0x0000_0000; // Только уведомления (не PERM)
|
||||||
enum FAN_CLASS_PRE_CONTENT = 0x0000_0008; // разрешения ДО доступа к содержимому (PRE_CONTENT)
|
// Permissions for access to CONTENT
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
enum FAN_CLASS_CONTENT = 0x0000_0004; // Разрешения на доступ к СОДЕРЖИМОМУ (CONTENT)
|
||||||
|
// Permissions BEFORE access to content (PRE_CONTENT)
|
||||||
|
enum FAN_CLASS_PRE_CONTENT = 0x0000_0008; // Разрешения ДО доступа к содержимому (PRE_CONTENT)
|
||||||
|
|
||||||
deprecated enum FAN_ALL_CLASS_BITS = (FAN_CLASS_NOTIF | FAN_CLASS_CONTENT | FAN_CLASS_PRE_CONTENT);
|
deprecated enum FAN_ALL_CLASS_BITS = (FAN_CLASS_NOTIF | FAN_CLASS_CONTENT | FAN_CLASS_PRE_CONTENT);
|
||||||
|
|
||||||
|
// Queue/mark limits
|
||||||
// Лимиты очереди/меток
|
// Лимиты очереди/меток
|
||||||
enum FAN_UNLIMITED_QUEUE = 0x0000_0010; // неограниченная очередь событий
|
// Unlimited event queue
|
||||||
enum FAN_UNLIMITED_MARKS = 0x0000_0020; // неограниченное число меток
|
enum FAN_UNLIMITED_QUEUE = 0x0000_0010; // Неограниченная очередь событий
|
||||||
enum FAN_ENABLE_AUDIT = 0x0000_0040; // включить аудит
|
// Unlimited number of marks
|
||||||
|
enum FAN_UNLIMITED_MARKS = 0x0000_0020; // Неограниченное число меток
|
||||||
|
// Enable audit
|
||||||
|
enum FAN_ENABLE_AUDIT = 0x0000_0040; // Включить аудит
|
||||||
|
|
||||||
|
// Reporting format in event metadata
|
||||||
// Формат отчётности в метаданных события
|
// Формат отчётности в метаданных события
|
||||||
enum FAN_REPORT_PIDFD = 0x0000_0080; // добавлять PIDFD (если поддерживается ядром)
|
// Add PIDFD (if supported by kernel)
|
||||||
enum FAN_REPORT_TID = 0x0000_0100; // сообщать TID вместо PID
|
enum FAN_REPORT_PIDFD = 0x0000_0080; // Добавлять PIDFD (если поддерживается ядром)
|
||||||
enum FAN_REPORT_FID = 0x0000_0200; // сообщать file-id (handle) вместо fd
|
// Report TID instead of PID
|
||||||
enum FAN_REPORT_DIR_FID = 0x0000_0400; // сообщать dir file-id
|
enum FAN_REPORT_TID = 0x0000_0100; // Сообщать TID вместо PID
|
||||||
enum FAN_REPORT_NAME = 0x0000_0800; // сообщать имя (ранее FAN_REPORT_DFID_NAME)
|
// Report file-id (handle) instead of fd
|
||||||
enum FAN_REPORT_TARGET_FID = 0x0000_1000; // сообщать target file-id
|
enum FAN_REPORT_FID = 0x0000_0200; // Сообщать file-id (handle) вместо fd
|
||||||
|
// Report dir file-id
|
||||||
|
enum FAN_REPORT_DIR_FID = 0x0000_0400; // Сообщать dir file-id
|
||||||
|
// Report name (previously FAN_REPORT_DFID_NAME)
|
||||||
|
enum FAN_REPORT_NAME = 0x0000_0800; // Сообщать имя (ранее FAN_REPORT_DFID_NAME)
|
||||||
|
// Report target file-id
|
||||||
|
enum FAN_REPORT_TARGET_FID = 0x0000_1000; // Сообщать target file-id
|
||||||
|
// event->fd can report errors
|
||||||
enum FAN_REPORT_FD_ERROR = 0x0000_2000; // event->fd может сообщать ошибки
|
enum FAN_REPORT_FD_ERROR = 0x0000_2000; // event->fd может сообщать ошибки
|
||||||
enum FAN_REPORT_MNT = 0x0000_4000; // сообщать события монтирования
|
// Report mount events
|
||||||
|
enum FAN_REPORT_MNT = 0x0000_4000; // Сообщать события монтирования
|
||||||
|
|
||||||
|
// Convenient summary macros
|
||||||
// Удобные сводные макросы
|
// Удобные сводные макросы
|
||||||
enum FAN_REPORT_DFID_NAME = (FAN_REPORT_DIR_FID | FAN_REPORT_NAME);
|
enum FAN_REPORT_DFID_NAME = (FAN_REPORT_DIR_FID | FAN_REPORT_NAME);
|
||||||
enum FAN_REPORT_DFID_NAME_TARGET = (FAN_REPORT_DFID_NAME | FAN_REPORT_FID | FAN_REPORT_TARGET_FID);
|
enum FAN_REPORT_DFID_NAME_TARGET = (FAN_REPORT_DFID_NAME | FAN_REPORT_FID | FAN_REPORT_TARGET_FID);
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
|
||||||
deprecated enum FAN_ALL_INIT_FLAGS =
|
deprecated enum FAN_ALL_INIT_FLAGS =
|
||||||
(FAN_CLOEXEC | FAN_NONBLOCK | FAN_ALL_CLASS_BITS | FAN_UNLIMITED_QUEUE |
|
(FAN_CLOEXEC | FAN_NONBLOCK | FAN_ALL_CLASS_BITS | FAN_UNLIMITED_QUEUE |
|
||||||
FAN_UNLIMITED_MARKS);
|
FAN_UNLIMITED_MARKS);
|
||||||
|
|
||||||
|
// The event_f_flags parameter for fanotify_init() — these are open(2) flags:
|
||||||
|
// O_RDONLY / O_WRONLY / O_RDWR | O_LARGEFILE etc. (from <fcntl.h>).
|
||||||
// Параметр event_f_flags для fanotify_init() — это флаги open(2):
|
// Параметр event_f_flags для fanotify_init() — это флаги open(2):
|
||||||
// O_RDONLY / O_WRONLY / O_RDWR | O_LARGEFILE и т.п. (из <fcntl.h>).
|
// O_RDONLY / O_WRONLY / O_RDWR | O_LARGEFILE и т.п. (из <fcntl.h>).
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
// FLAGS FOR fanotify_mark(fanfd, flags, mask, dirfd, path)
|
||||||
// ФЛАГИ ДЛЯ fanotify_mark(fanfd, flags, mask, dirfd, path)
|
// ФЛАГИ ДЛЯ fanotify_mark(fanfd, flags, mask, dirfd, path)
|
||||||
// ------------------------------------------------------------
|
|
||||||
enum FAN_MARK_ADD = 0x0000_0001; // добавить/обновить метку
|
// Add/update mark
|
||||||
enum FAN_MARK_REMOVE = 0x0000_0002; // удалить метку
|
enum FAN_MARK_ADD = 0x0000_0001; // Добавить/обновить метку
|
||||||
enum FAN_MARK_DONT_FOLLOW = 0x0000_0004; // не переходить по симлинкам (на path)
|
// Remove mark
|
||||||
enum FAN_MARK_ONLYDIR = 0x0000_0008; // path должен быть каталогом
|
enum FAN_MARK_REMOVE = 0x0000_0002; // Удалить метку
|
||||||
enum FAN_MARK_MOUNT = 0x0000_0010; // навесить на точку монтирования
|
// Do not follow symlinks (on path)
|
||||||
enum FAN_MARK_IGNORED_MASK = 0x0000_0020; // задать игнорируемые события
|
enum FAN_MARK_DONT_FOLLOW = 0x0000_0004; // Не переходить по симлинкам (на path)
|
||||||
enum FAN_MARK_IGNORED_SURV_MODIFY = 0x0000_0040; // игнор сохраняется при модификации
|
// Path must be a directory
|
||||||
enum FAN_MARK_FLUSH = 0x0000_0080; // снять все метки у группы
|
enum FAN_MARK_ONLYDIR = 0x0000_0008; // Path должен быть каталогом
|
||||||
enum FAN_MARK_FILESYSTEM = 0x0000_0100; // навесить на всю ФС
|
// Attach to mount point
|
||||||
enum FAN_MARK_EVICTABLE = 0x0000_0200; // метка может быть evicted
|
enum FAN_MARK_MOUNT = 0x0000_0010; // Навесить на точку монтирования
|
||||||
enum FAN_MARK_IGNORE = 0x0000_0400; // игнорировать (взаимоисключающе с IGNORED_MASK, новое)
|
// Set ignored events
|
||||||
|
enum FAN_MARK_IGNORED_MASK = 0x0000_0020; // Задать игнорируемые события
|
||||||
|
// Ignore survives modification
|
||||||
|
enum FAN_MARK_IGNORED_SURV_MODIFY = 0x0000_0040; // Игнор сохраняется при модификации
|
||||||
|
// Remove all marks from group
|
||||||
|
enum FAN_MARK_FLUSH = 0x0000_0080; // Снять все метки у группы
|
||||||
|
// Attach to entire filesystem
|
||||||
|
enum FAN_MARK_FILESYSTEM = 0x0000_0100; // Навесить на всю ФС
|
||||||
|
// Mark can be evicted
|
||||||
|
enum FAN_MARK_EVICTABLE = 0x0000_0200; // Метка может быть evicted
|
||||||
|
// Ignore (mutually exclusive with IGNORED_MASK, new)
|
||||||
|
enum FAN_MARK_IGNORE = 0x0000_0400; // Игнорировать (взаимоисключающе с IGNORED_MASK, новое)
|
||||||
|
|
||||||
// These are NOT bitwise flags. Both bits can be used together.
|
// These are NOT bitwise flags. Both bits can be used together.
|
||||||
enum FAN_MARK_INODE = 0x0000_0000; // на inode
|
// Это НЕ битовые флаги. Оба бита могут использоваться вместе.
|
||||||
enum FAN_MARK_MNTNS = 0x0000_0110; // на mount namespace
|
// On inode
|
||||||
|
enum FAN_MARK_INODE = 0x0000_0000; // На inode
|
||||||
|
// On mount namespace
|
||||||
|
enum FAN_MARK_MNTNS = 0x0000_0110; // На mount namespace
|
||||||
|
|
||||||
|
// Convenient macro
|
||||||
// Удобный макрос
|
// Удобный макрос
|
||||||
enum FAN_MARK_IGNORE_SURV = (FAN_MARK_IGNORE | FAN_MARK_IGNORED_SURV_MODIFY);
|
enum FAN_MARK_IGNORE_SURV = (FAN_MARK_IGNORE | FAN_MARK_IGNORED_SURV_MODIFY);
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
|
||||||
deprecated enum FAN_ALL_MARK_FLAGS =
|
|
||||||
(FAN_MARK_ADD | FAN_MARK_REMOVE | FAN_MARK_DONT_FOLLOW | FAN_MARK_ONLYDIR |
|
|
||||||
FAN_MARK_MOUNT | FAN_MARK_IGNORED_MASK | FAN_MARK_IGNORED_SURV_MODIFY |
|
|
||||||
FAN_MARK_FLUSH);
|
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
deprecated enum FAN_ALL_MARK_FLAGS =
|
||||||
|
(FAN_MARK_ADD | FAN_MARK_REMOVE | FAN_MARK_DONT_FOLLOW | FAN_MARK_ONLYDIR |
|
||||||
|
FAN_MARK_MOUNT | FAN_MARK_IGNORED_MASK | FAN_MARK_IGNORED_SURV_MODIFY |
|
||||||
|
FAN_MARK_FLUSH);
|
||||||
|
|
||||||
|
// EVENT MASK BITS (mask) FOR fanotify_mark()
|
||||||
// БИТЫ МАСКИ СОБЫТИЙ (mask) ДЛЯ fanotify_mark()
|
// БИТЫ МАСКИ СОБЫТИЙ (mask) ДЛЯ fanotify_mark()
|
||||||
// ------------------------------------------------------------
|
|
||||||
|
// "Regular" events
|
||||||
// «Обычные» события
|
// «Обычные» события
|
||||||
enum FAN_ACCESS = 0x0000_0001; // чтение (read)
|
// Read (read)
|
||||||
enum FAN_MODIFY = 0x0000_0002; // запись/изменение
|
enum FAN_ACCESS = 0x0000_0001; // Чтение (read)
|
||||||
enum FAN_ATTRIB = 0x0000_0004; // метаданные (chmod/chown/utime)
|
// Write/modify
|
||||||
enum FAN_CLOSE_WRITE = 0x0000_0008; // закрыт после записи
|
enum FAN_MODIFY = 0x0000_0002; // Запись/изменение
|
||||||
enum FAN_CLOSE_NOWRITE = 0x0000_0010; // закрыт без записи
|
// Metadata (chmod/chown/utime)
|
||||||
enum FAN_OPEN = 0x0000_0020; // открыт
|
enum FAN_ATTRIB = 0x0000_0004; // Метаданные (chmod/chown/utime)
|
||||||
enum FAN_MOVED_FROM = 0x0000_0040; // перемещён «из»
|
// Closed after write
|
||||||
enum FAN_MOVED_TO = 0x0000_0080; // перемещён «в»
|
enum FAN_CLOSE_WRITE = 0x0000_0008; // Закрыт после записи
|
||||||
enum FAN_CREATE = 0x0000_0100; // создан
|
// Closed without write
|
||||||
enum FAN_DELETE = 0x0000_0200; // удалён
|
enum FAN_CLOSE_NOWRITE = 0x0000_0010; // Закрыт без записи
|
||||||
enum FAN_DELETE_SELF = 0x0000_0400; // удалён сам наблюдаемый объект
|
// Opened
|
||||||
enum FAN_MOVE_SELF = 0x0000_0800; // перемещён сам наблюдаемый объект
|
enum FAN_OPEN = 0x0000_0020; // Открыт
|
||||||
enum FAN_OPEN_EXEC = 0x0000_1000; // открыт для исполнения
|
// Moved "from"
|
||||||
enum FAN_Q_OVERFLOW = 0x0000_4000; // переполнение очереди
|
enum FAN_MOVED_FROM = 0x0000_0040; // Перемещён «из»
|
||||||
enum FAN_FS_ERROR = 0x0000_8000; // ошибки ФС
|
// Moved "to"
|
||||||
// deprecated #define FAN_DIR_MODIFY 0x00080000 /* Deprecated (reserved) */
|
enum FAN_MOVED_TO = 0x0000_0080; // Перемещён «в»
|
||||||
|
// Created
|
||||||
|
enum FAN_CREATE = 0x0000_0100; // Создан
|
||||||
|
// Deleted
|
||||||
|
enum FAN_DELETE = 0x0000_0200; // Удалён
|
||||||
|
// Observed object deleted itself
|
||||||
|
enum FAN_DELETE_SELF = 0x0000_0400; // Удалён сам наблюдаемый объект
|
||||||
|
// Observed object moved itself
|
||||||
|
enum FAN_MOVE_SELF = 0x0000_0800; // Перемещён сам наблюдаемый объект
|
||||||
|
// Opened for execution
|
||||||
|
enum FAN_OPEN_EXEC = 0x0000_1000; // Открыт для исполнения
|
||||||
|
// Queue overflow
|
||||||
|
enum FAN_Q_OVERFLOW = 0x0000_4000; // Переполнение очереди
|
||||||
|
// Filesystem errors
|
||||||
|
enum FAN_FS_ERROR = 0x0000_8000; // Ошибки ФС
|
||||||
|
|
||||||
|
// Pre-content access hook
|
||||||
enum FAN_PRE_ACCESS = 0x0010_0000; // pre-content access hook
|
enum FAN_PRE_ACCESS = 0x0010_0000; // pre-content access hook
|
||||||
|
// Mount attached
|
||||||
enum FAN_MNT_ATTACH = 0x0100_0000; // mount attached
|
enum FAN_MNT_ATTACH = 0x0100_0000; // mount attached
|
||||||
|
// Mount detached
|
||||||
enum FAN_MNT_DETACH = 0x0200_0000; // mount detached
|
enum FAN_MNT_DETACH = 0x0200_0000; // mount detached
|
||||||
|
// File renamed
|
||||||
enum FAN_RENAME = 0x1000_0000; // file renamed
|
enum FAN_RENAME = 0x1000_0000; // file renamed
|
||||||
|
|
||||||
|
// "Permission" events (require CLASS_CONTENT/PRE_CONTENT)
|
||||||
// События «разрешения» (требуют CLASS_CONTENT/PRE_CONTENT)
|
// События «разрешения» (требуют CLASS_CONTENT/PRE_CONTENT)
|
||||||
enum FAN_OPEN_PERM = 0x0001_0000; // запрос на open() (исправлено имя/значение)
|
// Request for open() (fixed name/value)
|
||||||
enum FAN_ACCESS_PERM = 0x0002_0000; // запрос на доступ к содержимому (исправлено имя/значение)
|
enum FAN_OPEN_PERM = 0x0001_0000; // Запрос на open() (исправлено имя/значение)
|
||||||
enum FAN_OPEN_EXEC_PERM = 0x0004_0000; // запрос на open(O_EXEC)
|
// Request for content access (fixed name/value)
|
||||||
|
enum FAN_ACCESS_PERM = 0x0002_0000; // Запрос на доступ к содержимому (исправлено имя/значение)
|
||||||
|
// Request for open(O_EXEC)
|
||||||
|
enum FAN_OPEN_EXEC_PERM = 0x0004_0000; // Запрос на open(O_EXEC)
|
||||||
|
|
||||||
|
// Mask scope modifiers
|
||||||
// Модификаторы области действия маски
|
// Модификаторы области действия маски
|
||||||
enum FAN_EVENT_ON_CHILD = 0x0800_0000; // события на дочерние объекты каталога
|
// Events on child objects of directory
|
||||||
enum FAN_ONDIR = 0x4000_0000; // событие относится к каталогу
|
enum FAN_EVENT_ON_CHILD = 0x0800_0000; // События на дочерние объекты каталога
|
||||||
|
// Event relates to directory
|
||||||
|
enum FAN_ONDIR = 0x4000_0000; // Событие относится к каталогу
|
||||||
|
|
||||||
|
// Composite convenient masks
|
||||||
// Составные удобные маски
|
// Составные удобные маски
|
||||||
enum FAN_CLOSE = (FAN_CLOSE_WRITE | FAN_CLOSE_NOWRITE);
|
enum FAN_CLOSE = (FAN_CLOSE_WRITE | FAN_CLOSE_NOWRITE);
|
||||||
enum FAN_MOVE = (FAN_MOVED_FROM | FAN_MOVED_TO);
|
enum FAN_MOVE = (FAN_MOVED_FROM | FAN_MOVED_TO);
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
|
||||||
deprecated enum FAN_ALL_EVENTS =
|
|
||||||
(FAN_ACCESS | FAN_MODIFY | FAN_CLOSE | FAN_OPEN);
|
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
|
||||||
deprecated enum FAN_ALL_PERM_EVENTS =
|
|
||||||
(FAN_OPEN_PERM | FAN_ACCESS_PERM);
|
|
||||||
// Deprecated - do not use this in programs and do not add new flags here!
|
|
||||||
deprecated enum FAN_ALL_OUTGOING_EVENTS =
|
|
||||||
(FAN_ALL_EVENTS | FAN_ALL_PERM_EVENTS | FAN_Q_OVERFLOW);
|
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
deprecated enum FAN_ALL_EVENTS =
|
||||||
|
(FAN_ACCESS | FAN_MODIFY | FAN_CLOSE | FAN_OPEN);
|
||||||
|
|
||||||
|
deprecated enum FAN_ALL_PERM_EVENTS =
|
||||||
|
(FAN_OPEN_PERM | FAN_ACCESS_PERM);
|
||||||
|
|
||||||
|
deprecated enum FAN_ALL_OUTGOING_EVENTS =
|
||||||
|
(FAN_ALL_EVENTS | FAN_ALL_PERM_EVENTS | FAN_Q_OVERFLOW);
|
||||||
|
|
||||||
|
// EVENT METADATA
|
||||||
// МЕТАДАННЫЕ СОБЫТИЯ
|
// МЕТАДАННЫЕ СОБЫТИЯ
|
||||||
// ------------------------------------------------------------
|
|
||||||
struct fanotify_event_metadata {
|
struct fanotify_event_metadata
|
||||||
uint event_len; // общая длина записи
|
{
|
||||||
ubyte vers; // версия (FANOTIFY_METADATA_VERSION)
|
// Total record length
|
||||||
ubyte reserved; // зарезервировано
|
uint event_len; // Общая длина записи
|
||||||
ushort metadata_len; // длина этой структуры
|
// Version (FANOTIFY_METADATA_VERSION)
|
||||||
uint64_t mask; // __aligned_u64: биты события/модификаторов
|
ubyte vers; // Версия (FANOTIFY_METADATA_VERSION)
|
||||||
int fd; // файловый дескриптор (или FAN_NOFD)
|
// Reserved
|
||||||
int pid; // PID или TID (если FAN_REPORT_TID)
|
ubyte reserved; // Зарезервировано
|
||||||
|
// Length of this structure
|
||||||
|
ushort metadata_len; // Длина этой структуры
|
||||||
|
// __aligned_u64: Event/modifier bits
|
||||||
|
uint64_t mask; // __aligned_u64: Биты события/модификаторов
|
||||||
|
// File descriptor (or FAN_NOFD)
|
||||||
|
int fd; // Файловый дескриптор (или FAN_NOFD)
|
||||||
|
// PID or TID (if FAN_REPORT_TID)
|
||||||
|
int pid; // PID или TID (если FAN_REPORT_TID)
|
||||||
}
|
}
|
||||||
|
|
||||||
enum FANOTIFY_METADATA_VERSION = 3;
|
enum FANOTIFY_METADATA_VERSION = 3;
|
||||||
enum FAN_NOFD = -1;
|
enum FAN_NOFD = -1;
|
||||||
enum FAN_NOPIDFD = FAN_NOFD;
|
enum FAN_NOPIDFD = FAN_NOFD;
|
||||||
enum FAN_EPIDFD = -2;
|
enum FAN_EPIDFD = -2;
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
// ADDITIONAL INFO (FID / PIDFD / ERROR / etc.) IN EVENT TAIL
|
||||||
// ДОП. ИНФОРМАЦИЯ (FID / PIDFD / ERROR / etc.) В ХВОСТЕ СОБЫТИЯ
|
// ДОП. ИНФОРМАЦИЯ (FID / PIDFD / ERROR / etc.) В ХВОСТЕ СОБЫТИЯ
|
||||||
// ------------------------------------------------------------
|
|
||||||
struct fanotify_event_info_header {
|
struct fanotify_event_info_header
|
||||||
ubyte info_type; // тип записей ниже
|
{
|
||||||
ubyte pad; // выравнивание
|
// Type of records below
|
||||||
ushort len; // длина этой записи
|
ubyte info_type; // Тип записей ниже
|
||||||
|
// Alignment
|
||||||
|
ubyte pad; // Выравнивание
|
||||||
|
// Length of this record
|
||||||
|
ushort len; // Длина этой записи
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Info record types (follow metadata)
|
||||||
// Типы info-записей (идут после metadata)
|
// Типы info-записей (идут после metadata)
|
||||||
enum FAN_EVENT_INFO_TYPE_FID = 1; // только file handle
|
// File handle only
|
||||||
enum FAN_EVENT_INFO_TYPE_DFID_NAME = 2; // dir handle + имя объекта
|
enum FAN_EVENT_INFO_TYPE_FID = 1; // Только file handle
|
||||||
enum FAN_EVENT_INFO_TYPE_DFID = 3; // dir handle
|
// Dir handle + object name
|
||||||
|
enum FAN_EVENT_INFO_TYPE_DFID_NAME = 2; // Dir handle + имя объекта
|
||||||
|
// Dir handle
|
||||||
|
enum FAN_EVENT_INFO_TYPE_DFID = 3; // Dir handle
|
||||||
|
// PIDFD (if FAN_REPORT_PIDFD)
|
||||||
enum FAN_EVENT_INFO_TYPE_PIDFD = 4; // PIDFD (если FAN_REPORT_PIDFD)
|
enum FAN_EVENT_INFO_TYPE_PIDFD = 4; // PIDFD (если FAN_REPORT_PIDFD)
|
||||||
enum FAN_EVENT_INFO_TYPE_ERROR = 5; // error info
|
// Error info
|
||||||
enum FAN_EVENT_INFO_TYPE_RANGE = 6; // range info
|
enum FAN_EVENT_INFO_TYPE_ERROR = 5; // Error info
|
||||||
enum FAN_EVENT_INFO_TYPE_MNT = 7; // mount info
|
// Range info
|
||||||
|
enum FAN_EVENT_INFO_TYPE_RANGE = 6; // Range info
|
||||||
|
// Mount info
|
||||||
|
enum FAN_EVENT_INFO_TYPE_MNT = 7; // Mount info
|
||||||
|
|
||||||
// Special info types for FAN_RENAME
|
// Special info types for FAN_RENAME
|
||||||
enum FAN_EVENT_INFO_TYPE_OLD_DFID_NAME = 10;
|
enum FAN_EVENT_INFO_TYPE_OLD_DFID_NAME = 10;
|
||||||
enum FAN_EVENT_INFO_TYPE_NEW_DFID_NAME = 12;
|
enum FAN_EVENT_INFO_TYPE_NEW_DFID_NAME = 12;
|
||||||
// (Reserved: 11 и 13 для OLD_DFID и NEW_DFID)
|
|
||||||
|
|
||||||
struct __kernel_fsid_t { int[2] val; }
|
struct __kernel_fsid_t
|
||||||
|
{
|
||||||
|
int[2] val;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Common header for FID records
|
||||||
// Общий заголовок для FID-записей
|
// Общий заголовок для FID-записей
|
||||||
struct fanotify_event_info_fid {
|
struct fanotify_event_info_fid
|
||||||
fanotify_event_info_header hdr;
|
{
|
||||||
__kernel_fsid_t fsid; // файловая система
|
fanotify_event_info_header hdr;
|
||||||
// далее переменной длины: unsigned char handle[]; (opaque struct file_handle)
|
// Filesystem
|
||||||
|
__kernel_fsid_t fsid; // Файловая система
|
||||||
|
// Followed by variable length: unsigned char handle[]; (opaque struct file_handle)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Compatible with open_by_handle_at()
|
||||||
// Совместимо с open_by_handle_at()
|
// Совместимо с open_by_handle_at()
|
||||||
struct file_handle {
|
struct file_handle
|
||||||
uint handle_bytes; // длина f_handle
|
{
|
||||||
int handle_type; // тип handle
|
// Length of f_handle
|
||||||
ubyte[0] f_handle; // гибкий хвост (реальные байты handle идут сразу за структурой)
|
uint handle_bytes; // Длина f_handle
|
||||||
|
// Handle type
|
||||||
|
int handle_type; // Тип handle
|
||||||
|
// Flexible tail (actual handle bytes follow the structure)
|
||||||
|
ubyte[0] f_handle; // Гибкий хвост (реальные байты handle идут сразу за структурой)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Structure for PIDFD
|
||||||
// Структура для PIDFD
|
// Структура для PIDFD
|
||||||
struct fanotify_event_info_pidfd {
|
struct fanotify_event_info_pidfd
|
||||||
fanotify_event_info_header hdr;
|
{
|
||||||
int pidfd; // __s32
|
fanotify_event_info_header hdr;
|
||||||
|
// __s32
|
||||||
|
int pidfd; // __s32
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Structure for ERROR
|
||||||
// Структура для ERROR
|
// Структура для ERROR
|
||||||
struct fanotify_event_info_error {
|
struct fanotify_event_info_error
|
||||||
fanotify_event_info_header hdr;
|
{
|
||||||
int error; // __s32
|
fanotify_event_info_header hdr;
|
||||||
uint error_count; // __u32
|
// __s32
|
||||||
|
int error; // __s32
|
||||||
|
// __u32
|
||||||
|
uint error_count; // __u32
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Structure for RANGE
|
||||||
// Структура для RANGE
|
// Структура для RANGE
|
||||||
struct fanotify_event_info_range {
|
struct fanotify_event_info_range
|
||||||
fanotify_event_info_header hdr;
|
{
|
||||||
uint pad; // __u32
|
fanotify_event_info_header hdr;
|
||||||
uint64_t offset; // __u64
|
// __u32
|
||||||
uint64_t count; // __u64
|
uint pad; // __u32
|
||||||
|
// __u64
|
||||||
|
uint64_t offset; // __u64
|
||||||
|
// __u64
|
||||||
|
uint64_t count; // __u64
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Structure for MNT
|
||||||
// Структура для MNT
|
// Структура для MNT
|
||||||
struct fanotify_event_info_mnt {
|
struct fanotify_event_info_mnt
|
||||||
fanotify_event_info_header hdr;
|
{
|
||||||
uint64_t mnt_id; // __u64
|
fanotify_event_info_header hdr;
|
||||||
|
// __u64
|
||||||
|
uint64_t mnt_id; // __u64
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
// STRUCTURES FOR RESPONSE (for PERM events)
|
||||||
// СТРУКТУРЫ ДЛЯ RESPONSE (для PERM-событий)
|
// СТРУКТУРЫ ДЛЯ RESPONSE (для PERM-событий)
|
||||||
// ------------------------------------------------------------
|
|
||||||
struct fanotify_response {
|
struct fanotify_response
|
||||||
int fd; // __s32
|
{
|
||||||
uint response; // __u32
|
// __s32
|
||||||
|
int fd; // __s32
|
||||||
|
// __u32
|
||||||
|
uint response; // __u32
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Additional information in response
|
||||||
// Дополнительная информация в response
|
// Дополнительная информация в response
|
||||||
enum FAN_RESPONSE_INFO_NONE = 0;
|
enum FAN_RESPONSE_INFO_NONE = 0;
|
||||||
enum FAN_RESPONSE_INFO_AUDIT_RULE = 1;
|
enum FAN_RESPONSE_INFO_AUDIT_RULE = 1;
|
||||||
|
|
||||||
struct fanotify_response_info_header {
|
struct fanotify_response_info_header
|
||||||
ubyte type;
|
{
|
||||||
ubyte pad;
|
ubyte type;
|
||||||
ushort len;
|
ubyte pad;
|
||||||
|
ushort len;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct fanotify_response_info_audit_rule {
|
struct fanotify_response_info_audit_rule
|
||||||
fanotify_response_info_header hdr;
|
{
|
||||||
uint rule_number; // __u32
|
fanotify_response_info_header hdr;
|
||||||
uint subj_trust; // __u32
|
// __u32
|
||||||
uint obj_trust; // __u32
|
uint rule_number; // __u32
|
||||||
|
// __u32
|
||||||
|
uint subj_trust; // __u32
|
||||||
|
// __u32
|
||||||
|
uint obj_trust; // __u32
|
||||||
}
|
}
|
||||||
|
|
||||||
// Legit responses
|
// Legit responses
|
||||||
enum FAN_ALLOW = 0x01;
|
enum FAN_ALLOW = 0x01;
|
||||||
enum FAN_DENY = 0x02;
|
enum FAN_DENY = 0x02;
|
||||||
|
// Bitmask to create audit record
|
||||||
enum FAN_AUDIT = 0x10; // Bitmask to create audit record
|
enum FAN_AUDIT = 0x10; // Bitmask to create audit record
|
||||||
|
// Bitmask to indicate additional information
|
||||||
enum FAN_INFO = 0x20; // Bitmask to indicate additional information
|
enum FAN_INFO = 0x20; // Bitmask to indicate additional information
|
||||||
|
|
||||||
|
// For DENY with errno
|
||||||
// Для DENY с errno
|
// Для DENY с errno
|
||||||
enum FAN_ERRNO_BITS = 8;
|
enum FAN_ERRNO_BITS = 8;
|
||||||
enum FAN_ERRNO_SHIFT = (32 - FAN_ERRNO_BITS);
|
enum FAN_ERRNO_SHIFT = (32 - FAN_ERRNO_BITS);
|
||||||
enum FAN_ERRNO_MASK = ((1 << FAN_ERRNO_BITS) - 1);
|
enum FAN_ERRNO_MASK = ((1 << FAN_ERRNO_BITS) - 1);
|
||||||
// Макрос: FAN_DENY_ERRNO(err) = (FAN_DENY | ((((__u32)(err)) & FAN_ERRNO_MASK) << FAN_ERRNO_SHIFT))
|
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
// C API FUNCTION PROTOTYPES
|
||||||
// ПРОТОТИПЫ ФУНКЦИЙ C API
|
// ПРОТОТИПЫ ФУНКЦИЙ C API
|
||||||
// ------------------------------------------------------------
|
|
||||||
extern(C) int fanotify_init(uint flags, uint event_f_flags);
|
|
||||||
extern(C) int fanotify_mark(
|
|
||||||
int fanotify_fd,
|
|
||||||
uint flags,
|
|
||||||
uint64_t mask,
|
|
||||||
int dirfd, // AT_FDCWD или fd каталога
|
|
||||||
const(char)* pathname // путь или null при INODE/FILESYSTEM/MOUNT
|
|
||||||
);
|
|
||||||
// Для работы с FID: открыть объект по handle (требует CAP_DAC_READ_SEARCH)
|
|
||||||
extern(C) int open_by_handle_at(int mount_fd, const(file_handle)* handle, int flags);
|
|
||||||
|
|
||||||
// ------------------------------------------------------------
|
extern (C) int fanotify_init(uint flags, uint event_f_flags);
|
||||||
|
|
||||||
|
extern (C) int fanotify_mark(
|
||||||
|
int fanotify_fd,
|
||||||
|
uint flags,
|
||||||
|
uint64_t mask,// AT_FDCWD or directory fd
|
||||||
|
int dirfd, // AT_FDCWD или fd каталога
|
||||||
|
// Path or null for INODE/FILESYSTEM/MOUNT
|
||||||
|
const(char)* pathname // Путь или null при INODE/FILESYSTEM/MOUNT
|
||||||
|
|
||||||
|
);
|
||||||
|
|
||||||
|
// For working with FID: open object by handle (requires CAP_DAC_READ_SEARCH)
|
||||||
|
// Для работы с FID: открыть объект по handle (требует CAP_DAC_READ_SEARCH)
|
||||||
|
extern (C) int open_by_handle_at(int mount_fd, const(file_handle)* handle, int flags);
|
||||||
|
|
||||||
|
// HELPER FUNCTIONS (macros for working with metadata buffer)
|
||||||
// HELPER FUNCTIONS (макросы для работы с буфером metadata)
|
// HELPER FUNCTIONS (макросы для работы с буфером metadata)
|
||||||
// ------------------------------------------------------------
|
|
||||||
enum FAN_EVENT_METADATA_LEN = fanotify_event_metadata.sizeof;
|
enum FAN_EVENT_METADATA_LEN = fanotify_event_metadata.sizeof;
|
||||||
|
|
||||||
// Макросы в D-стиле (как функции или шаблоны, но для простоты как enum/комментарии)
|
|
||||||
// FAN_EVENT_NEXT(meta, len): len -= meta.event_len; return cast(fanotify_event_metadata*) (cast(char*) meta + meta.event_len);
|
// FAN_EVENT_NEXT(meta, len): len -= meta.event_len; return cast(fanotify_event_metadata*) (cast(char*) meta + meta.event_len);
|
||||||
// FAN_EVENT_OK(meta, len): (len >= FAN_EVENT_METADATA_LEN) && (meta.event_len >= FAN_EVENT_METADATA_LEN) && (meta.event_len <= len)
|
// FAN_EVENT_OK(meta, len): (len >= FAN_EVENT_METADATA_LEN) && (meta.event_len >= FAN_EVENT_METADATA_LEN) && (meta.event_len <= len)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue