summaryrefslogtreecommitdiff
path: root/source3/include/smb_acls.h
blob: 4b282481ff389d6364f83a4778774c960be7d39b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
/* 
   Unix SMB/Netbios implementation.
   Version 2.2.x
   Portable SMB ACL interface
   Copyright (C) Jeremy Allison 2000
   
   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 2 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, write to the Free Software
   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/

#ifndef _SMB_ACLS_H
#define _SMB_ACLS_H

#include "includes.h"

#if defined(HAVE_POSIX_ACLS)

/* This is an identity mapping (just remove the SMB_). */

#define SMB_ACL_TAG_T               acl_tag_t
#define SMB_ACL_TYPE_T				acl_type_t
#define SMB_ACL_PERMSET_T           acl_permset_t
#define SMB_ACL_PERM_T				acl_perm_t
#define SMB_ACL_READ                ACL_READ
#define SMB_ACL_WRITE               ACL_WRITE
#define SMB_ACL_EXECUTE             ACL_EXECUTE

/* Types of ACLs. */
#define SMB_ACL_USER                ACL_USER
#define SMB_ACL_USER_OBJ            ACL_USER_OBJ
#define SMB_ACL_GROUP               ACL_GROUP
#define SMB_ACL_GROUP_OBJ           ACL_GROUP_OBJ
#define SMB_ACL_OTHER               ACL_OTHER
#define SMB_ACL_MASK                ACL_MASK

#define SMB_ACL_T 					acl_t

#define SMB_ACL_ENTRY_T				acl_entry_t

#define SMB_ACL_FIRST_ENTRY         ACL_FIRST_ENTRY
#define SMB_ACL_NEXT_ENTRY          ACL_NEXT_ENTRY

#define SMB_ACL_TYPE_ACCESS         ACL_TYPE_ACCESS
#define SMB_ACL_TYPE_DEFAULT        ACL_TYPE_DEFAULT

#elif defined(HAVE_DRAFT13_POSIX_ACLS)

/* This is for DEC OSF/1 */

#define SMB_ACL_TAG_T               acl_tag_t
#define SMB_ACL_TYPE_T				acl_type_t
#define SMB_ACL_PERMSET_T           acl_permset_t
#define SMB_ACL_PERM_T				acl_perm_t
#define SMB_ACL_READ                ACL_READ
#define SMB_ACL_WRITE               ACL_WRITE
#define SMB_ACL_EXECUTE             ACL_EXECUTE

/* Types of ACLs. */
#define SMB_ACL_USER                ACL_USER
#define SMB_ACL_USER_OBJ            ACL_USER_OBJ
#define SMB_ACL_GROUP               ACL_GROUP
#define SMB_ACL_GROUP_OBJ           ACL_GROUP_OBJ
#define SMB_ACL_OTHER               ACL_OTHER
#define SMB_ACL_MASK                ACL_MASK

#define SMB_ACL_T 					acl_t

#define SMB_ACL_ENTRY_T				acl_entry_t

#define SMB_ACL_FIRST_ENTRY         0
#define SMB_ACL_NEXT_ENTRY          1

#define SMB_ACL_TYPE_ACCESS         ACL_TYPE_ACCESS
#define SMB_ACL_TYPE_DEFAULT        ACL_TYPE_DEFAULT

#elif defined(HAVE_UNIXWARE_ACLS) || defined(HAVE_SOLARIS_ACLS)
/*
 * Donated by Michael Davidson <md@sco.COM> for UnixWare / OpenUNIX.
 * Modified by Toomas Soome <tsoome@ut.ee> for Solaris.
 */

/* SVR4.2 ES/MP ACLs */
typedef int			SMB_ACL_TAG_T;
typedef int			SMB_ACL_TYPE_T;
typedef ushort		*SMB_ACL_PERMSET_T;
typedef ushort		SMB_ACL_PERM_T;
#define SMB_ACL_READ 				4
#define SMB_ACL_WRITE 				2
#define SMB_ACL_EXECUTE				1

/* Types of ACLs. */
#define SMB_ACL_USER				USER
#define SMB_ACL_USER_OBJ			USER_OBJ
#define SMB_ACL_GROUP				GROUP
#define SMB_ACL_GROUP_OBJ			GROUP_OBJ
#define SMB_ACL_OTHER				OTHER_OBJ
#define SMB_ACL_MASK				CLASS_OBJ

typedef struct SMB_ACL_T {
	int	size;
	int	count;
	int	next;
	struct acl	acl[1];
} *SMB_ACL_T;

typedef struct acl					*SMB_ACL_ENTRY_T;

#define SMB_ACL_FIRST_ENTRY			0
#define SMB_ACL_NEXT_ENTRY			1

#define SMB_ACL_TYPE_ACCESS			0
#define SMB_ACL_TYPE_DEFAULT		1

#elif defined(HAVE_IRIX_ACLS)

#define SMB_ACL_TAG_T               acl_tag_t
#define SMB_ACL_TYPE_T		    acl_type_t
#define SMB_ACL_PERMSET_T           acl_permset_t
#define SMB_ACL_PERM_T		    acl_perm_t
#define SMB_ACL_READ                ACL_READ
#define SMB_ACL_WRITE               ACL_WRITE
#define SMB_ACL_EXECUTE             ACL_EXECUTE

/* Types of ACLs. */
#define SMB_ACL_USER                ACL_USER
#define SMB_ACL_USER_OBJ            ACL_USER_OBJ
#define SMB_ACL_GROUP               ACL_GROUP
#define SMB_ACL_GROUP_OBJ           ACL_GROUP_OBJ
#define SMB_ACL_OTHER               ACL_OTHER_OBJ
#define SMB_ACL_MASK                ACL_MASK

typedef struct SMB_ACL_T {
   int next;
   BOOL freeaclp;
   struct acl  *aclp;
} *SMB_ACL_T;

#define SMB_ACL_ENTRY_T		    acl_entry_t

#define SMB_ACL_FIRST_ENTRY         0
#define SMB_ACL_NEXT_ENTRY          1

#define SMB_ACL_TYPE_ACCESS         ACL_TYPE_ACCESS
#define SMB_ACL_TYPE_DEFAULT        ACL_TYPE_DEFAULT

#elif defined(HAVE_AIX_ACLS)

/* Donated by Medha Date, mdate@austin.ibm.com, for IBM */

#include "/usr/include/acl.h"

typedef uint                        *SMB_ACL_PERMSET_T;
 
struct acl_entry_link{
	struct acl_entry_link *prevp;
	struct new_acl_entry *entryp;
	struct acl_entry_link *nextp;
	int count;
};

struct new_acl_entry{
	unsigned short  ace_len;
	unsigned short  ace_type;
	unsigned int    ace_access;
	struct ace_id ace_id[1];
};

#define SMB_ACL_ENTRY_T             struct new_acl_entry*
#define SMB_ACL_T                   struct acl_entry_link*
 
#define SMB_ACL_TAG_T               unsigned short
#define SMB_ACL_TYPE_T              int
#define SMB_ACL_PERM_T              uint
#define SMB_ACL_READ                S_IRUSR
#define SMB_ACL_WRITE               S_IWUSR
#define SMB_ACL_EXECUTE             S_IXUSR

/* Types of ACLs. */
#define SMB_ACL_USER                ACEID_USER
#define SMB_ACL_USER_OBJ            3
#define SMB_ACL_GROUP               ACEID_GROUP
#define SMB_ACL_GROUP_OBJ           4
#define SMB_ACL_OTHER               5
#define SMB_ACL_MASK                6


#define SMB_ACL_FIRST_ENTRY         1
#define SMB_ACL_NEXT_ENTRY          2

#define SMB_ACL_TYPE_ACCESS         0
#define SMB_ACL_TYPE_DEFAULT        1

#else /* No ACLs. */

/* No ACLS - fake it. */
#define SMB_ACL_TAG_T 				int
#define SMB_ACL_TYPE_T              int
#define SMB_ACL_PERMSET_T 			mode_t
#define SMB_ACL_PERM_T				mode_t
#define SMB_ACL_READ 				S_IRUSR
#define SMB_ACL_WRITE 				S_IWUSR
#define SMB_ACL_EXECUTE				S_IXUSR

/* Types of ACLs. */
#define SMB_ACL_USER				0
#define SMB_ACL_USER_OBJ			1
#define SMB_ACL_GROUP				2
#define SMB_ACL_GROUP_OBJ			3
#define SMB_ACL_OTHER				4
#define SMB_ACL_MASK				5

typedef struct SMB_ACL_T {
	int dummy;
} *SMB_ACL_T;

typedef struct SMB_ACL_ENTRY_T {
	int dummy;
} *SMB_ACL_ENTRY_T;

#define SMB_ACL_FIRST_ENTRY			0
#define SMB_ACL_NEXT_ENTRY			1

#define SMB_ACL_TYPE_ACCESS			0
#define SMB_ACL_TYPE_DEFAULT		1

#endif /* No ACLs. */
#endif /* _SMB_ACLS_H */