2 Samba share mode database library.
4 Copyright (C) Jeremy Allison 2005.
6 This library is free software; you can redistribute it and/or
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 3 of the License, or (at your option) any later version.
11 This library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
16 You should have received a copy of the GNU Lesser General Public
17 License along with this library; if not, see <http://www.gnu.org/licenses/>.
20 #ifndef _SMB_SHARE_MODES_H_
21 #define _SMB_STATE_MODES_H_
28 # include <inttypes.h>
35 /* Opaque database context handle. */
38 /* Share mode entry. */
40 We use 64 bit types for device and inode as
41 we don't know what size mode Samba has been
42 compiled in - dev/ino may be 32, may be 64
43 bits. This interface copes with either.
46 struct smb_share_mode_entry
{
50 uint32_t share_access
;
52 struct timeval open_time
;
58 * open/close sharemode database.
61 struct smbdb_ctx
*smb_share_mode_db_open(const char *db_path
);
62 int smb_share_mode_db_close(struct smbdb_ctx
*db_ctx
);
65 * lock/unlock entry in sharemode database.
68 int smb_lock_share_mode_entry(struct smbdb_ctx
*db_ctx
,
73 int smb_unlock_share_mode_entry(struct smbdb_ctx
*db_ctx
,
79 * Share mode database accessor functions.
82 int smb_get_share_mode_entries(struct smbdb_ctx
*db_ctx
,
86 struct smb_share_mode_entry
**pp_list
,
87 unsigned char *p_delete_on_close
);
89 int smb_create_share_mode_entry(struct smbdb_ctx
*db_ctx
,
93 const struct smb_share_mode_entry
*set_entry
,
96 int smb_delete_share_mode_entry(struct smbdb_ctx
*db_ctx
,
100 const struct smb_share_mode_entry
*set_entry
);
102 int smb_change_share_mode_entry(struct smbdb_ctx
*db_ctx
,
106 const struct smb_share_mode_entry
*set_entry
,
107 const struct smb_share_mode_entry
*new_entry
);