2011-11-24 13:01:57 +04:00
#include "idl_types.h"
import "server_id.idl";
import "security.idl";
import "file_id.idl";
2014-11-27 20:34:56 +03:00
import "smb2_lease_struct.idl";
import "misc.idl";
2011-11-24 13:01:57 +04:00
[
2011-12-13 15:45:11 +04:00
pointer_default(unique)
2011-11-24 13:01:57 +04:00
]
interface open_files
{
2011-12-13 15:45:11 +04:00
typedef [public] struct {
server_id pid;
hyper op_mid;
uint16 op_type;
2018-09-13 13:47:55 +03:00
GUID client_guid;
smb2_lease_key lease_key;
2011-12-13 15:45:11 +04:00
uint32 access_mask;
uint32 share_access;
uint32 private_options;
timeval time;
udlong share_file_id;
uint32 uid;
uint16 flags;
uint32 name_hash;
2013-08-30 16:49:43 +04:00
/*
* In-memory flag indicating a non-existing pid. We don't want
* to store this share_mode_entry on disk.
*/
[skip] boolean8 stale;
2011-12-13 15:45:11 +04:00
} share_mode_entry;
2011-11-24 13:01:57 +04:00
2011-12-13 15:45:11 +04:00
typedef [public] struct {
uint32 name_hash;
2012-04-05 01:54:02 +04:00
security_token *delete_nt_token;
2011-12-13 15:45:11 +04:00
security_unix_token *delete_token;
} delete_token;
2011-11-24 13:01:57 +04:00
2019-08-09 17:16:21 +03:00
typedef [public,bitmap16bit] bitmap {
2019-08-09 17:27:48 +03:00
SHARE_MODE_SHARE_DELETE = 0x100,
SHARE_MODE_SHARE_WRITE = 0x080,
SHARE_MODE_SHARE_READ = 0x040,
SHARE_MODE_ACCESS_DELETE = 0x020,
SHARE_MODE_ACCESS_WRITE = 0x010,
SHARE_MODE_ACCESS_READ = 0x008,
SHARE_MODE_LEASE_HANDLE = 0x004,
SHARE_MODE_LEASE_WRITE = 0x002,
SHARE_MODE_LEASE_READ = 0x001
2019-06-28 08:48:45 +03:00
} share_mode_flags;
2011-12-13 15:45:11 +04:00
typedef [public] struct {
2020-07-07 12:49:27 +03:00
hyper unique_content_epoch;
2019-06-28 08:48:45 +03:00
share_mode_flags flags;
2011-12-13 15:45:11 +04:00
[string,charset(UTF8)] char *servicepath;
[string,charset(UTF8)] char *base_name;
[string,charset(UTF8)] char *stream_name;
uint32 num_delete_tokens;
[size_is(num_delete_tokens)] delete_token delete_tokens[];
2019-12-02 18:30:50 +03:00
NTTIME old_write_time;
NTTIME changed_write_time;
2013-09-01 13:07:19 +04:00
[skip] boolean8 fresh;
[skip] boolean8 modified;
2015-04-15 20:36:00 +03:00
[ignore] file_id id; /* In memory key used to lookup cache. */
2012-01-10 16:56:37 +04:00
} share_mode_data;
2012-06-08 19:54:19 +04:00
/* these are 0x30 (48) characters */
const string VFS_DEFAULT_DURABLE_COOKIE_MAGIC =
"VFS_DEFAULT_DURABLE_COOKIE_MAGIC ";
const uint32 VFS_DEFAULT_DURABLE_COOKIE_VERSION = 0;
2012-10-19 17:57:24 +04:00
/* this corresponds to struct stat_ex (SMB_STRUCT_STAT) */
typedef struct {
hyper st_ex_dev;
hyper st_ex_ino;
hyper st_ex_mode;
hyper st_ex_nlink;
hyper st_ex_uid;
hyper st_ex_gid;
hyper st_ex_rdev;
hyper st_ex_size;
timespec st_ex_atime;
timespec st_ex_mtime;
timespec st_ex_ctime;
timespec st_ex_btime;
hyper st_ex_blksize;
hyper st_ex_blocks;
uint32 st_ex_flags;
2019-06-27 18:06:46 +03:00
uint32 st_ex_iflags;
2012-10-19 17:57:24 +04:00
} vfs_default_durable_stat;
2012-06-08 19:54:19 +04:00
typedef [public] struct {
[value(VFS_DEFAULT_DURABLE_COOKIE_MAGIC),charset(DOS)] uint8 magic[0x30];
[value(VFS_DEFAULT_DURABLE_COOKIE_VERSION)] uint32 version;
boolean8 allow_reconnect;
file_id id;
[string,charset(UTF8)] char *servicepath;
[string,charset(UTF8)] char *base_name;
hyper initial_allocation_size;
hyper position_information;
2012-10-19 13:12:05 +04:00
boolean8 update_write_time_triggered;
boolean8 update_write_time_on_close;
boolean8 write_time_forced;
2019-12-02 18:30:50 +03:00
NTTIME close_write_time;
2012-10-19 17:57:24 +04:00
vfs_default_durable_stat stat_info;
2012-06-08 19:54:19 +04:00
} vfs_default_durable_cookie;
2019-05-16 16:38:26 +03:00
typedef [public] struct {
file_id id;
udlong share_file_id;
uint8 break_to;
} oplock_break_message;
2019-05-17 11:41:25 +03:00
typedef [public] struct {
file_id id;
2019-05-17 11:44:23 +03:00
udlong share_file_id;
2019-05-17 11:41:25 +03:00
[string,charset(UTF8)] char *servicepath;
[string,charset(UTF8)] char *base_name;
[string,charset(UTF8)] char *stream_name;
} file_rename_message;
2011-11-24 13:01:57 +04:00
}