diff options
author | Volker Lendecke <vl@samba.org> | 2017-08-18 14:41:57 +0200 |
---|---|---|
committer | Jeremy Allison <jra@samba.org> | 2017-08-24 01:46:07 +0200 |
commit | 48815f8c3ed54edc418018b991c222e317302602 (patch) | |
tree | d75dd98f02ab9544935d17f2873f56016bfdb4c4 /source3/modules/vfs_acl_common.h | |
parent | ce8a22d2963a989a9a0cf730c15a8f3cb6f0c3d7 (diff) | |
download | samba-48815f8c3ed54edc418018b991c222e317302602.tar.gz |
acl_common: Avoid "#include vfs_acl_common.c"
This makes vfs_acl_common.c a subsystem of its own that acl_xattr and acl_tdb
now link against, not #include it.
This patch is a bit on the large and clumsy side, but splitting it up would
(I believe) involve a separate intermediate copy of acl_common.c.
Signed-off-by: Volker Lendecke <vl@samba.org>
Reviewed-by: Jeremy Allison <jra@samba.org>
Diffstat (limited to 'source3/modules/vfs_acl_common.h')
-rw-r--r-- | source3/modules/vfs_acl_common.h | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/source3/modules/vfs_acl_common.h b/source3/modules/vfs_acl_common.h new file mode 100644 index 00000000000..c52fc5094c5 --- /dev/null +++ b/source3/modules/vfs_acl_common.h @@ -0,0 +1,79 @@ +/* + * Store Windows ACLs in data store - common functions. + * + * Copyright (C) Volker Lendecke, 2008 + * Copyright (C) Jeremy Allison, 2009 + * Copyright (C) Ralph Böhme, 2016 + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, see <http://www.gnu.org/licenses/>. + */ + +#ifndef __VFS_ACL_COMMON_H__ +#define __VFS_ACL_COMMON_H__ + +enum default_acl_style {DEFAULT_ACL_POSIX, DEFAULT_ACL_WINDOWS}; + +struct acl_common_config { + bool ignore_system_acls; + enum default_acl_style default_acl_style; +}; + +bool init_acl_common_config(vfs_handle_struct *handle, + const char *module_name); + +int rmdir_acl_common(struct vfs_handle_struct *handle, + const struct smb_filename *smb_fname); +int unlink_acl_common(struct vfs_handle_struct *handle, + const struct smb_filename *smb_fname); +int chmod_acl_module_common(struct vfs_handle_struct *handle, + const struct smb_filename *smb_fname, + mode_t mode); +int fchmod_acl_module_common(struct vfs_handle_struct *handle, + struct files_struct *fsp, mode_t mode); +int chmod_acl_acl_module_common(struct vfs_handle_struct *handle, + const struct smb_filename *smb_fname, + mode_t mode); +int fchmod_acl_acl_module_common(struct vfs_handle_struct *handle, + struct files_struct *fsp, mode_t mode); + +NTSTATUS get_nt_acl_common( + NTSTATUS (*get_acl_blob_fn)(TALLOC_CTX *ctx, + vfs_handle_struct *handle, + files_struct *fsp, + const struct smb_filename *smb_fname, + DATA_BLOB *pblob), + vfs_handle_struct *handle, + files_struct *fsp, + const struct smb_filename *smb_fname_in, + uint32_t security_info, + TALLOC_CTX *mem_ctx, + struct security_descriptor **ppdesc); + +NTSTATUS fset_nt_acl_common( + NTSTATUS (*get_acl_blob_fn)(TALLOC_CTX *ctx, + vfs_handle_struct *handle, + files_struct *fsp, + const struct smb_filename *smb_fname, + DATA_BLOB *pblob), + NTSTATUS (*store_acl_blob_fsp_fn)(vfs_handle_struct *handle, + files_struct *fsp, + DATA_BLOB *pblob), + const char *module_name, + vfs_handle_struct *handle, files_struct *fsp, + uint32_t security_info_sent, + const struct security_descriptor *orig_psd); + + + +#endif |