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
|
/*
Unix SMB/CIFS implementation.
Samba utility functions
Copyright (C) Andrew Tridgell 2010
Copyright (C) Andrew Bartlett <abartlet@samba.org> 2009
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 __DSDB_COMMON_UTIL_H__
#define __DSDB_COMMON_UTIL_H__
/*
flags for dsdb_request_add_controls(). For the module functions,
the upper 16 bits are in dsdb/samdb/ldb_modules/util.h
*/
#define DSDB_SEARCH_SEARCH_ALL_PARTITIONS 0x00001
#define DSDB_SEARCH_SHOW_DELETED 0x00002
#define DSDB_SEARCH_SHOW_DN_IN_STORAGE_FORMAT 0x00004
#define DSDB_SEARCH_REVEAL_INTERNALS 0x00008
#define DSDB_SEARCH_SHOW_EXTENDED_DN 0x00010
#define DSDB_MODIFY_RELAX 0x00020
#define DSDB_MODIFY_PERMISSIVE 0x00040
#define DSDB_FLAG_AS_SYSTEM 0x00080
#define DSDB_TREE_DELETE 0x00100
#define DSDB_SEARCH_ONE_ONLY 0x00200 /* give an error unless 1 record */
#define DSDB_SEARCH_SHOW_RECYCLED 0x00400
#define DSDB_PROVISION 0x00800
#define DSDB_BYPASS_PASSWORD_HASH 0x01000
#define DSDB_SEARCH_NO_GLOBAL_CATALOG 0x02000
#define DSDB_MODIFY_PARTIAL_REPLICA 0x04000
#define DSDB_PASSWORD_BYPASS_LAST_SET 0x08000
#define DSDB_REPLMD_VANISH_LINKS 0x10000
bool is_attr_in_list(const char * const * attrs, const char *attr);
#define DSDB_SECRET_ATTRIBUTES_EX(sep) \
"pekList" sep \
"msDS-ExecuteScriptPassword" sep \
"currentValue" sep \
"dBCSPwd" sep \
"initialAuthIncoming" sep \
"initialAuthOutgoing" sep \
"lmPwdHistory" sep \
"ntPwdHistory" sep \
"priorValue" sep \
"supplementalCredentials" sep \
"trustAuthIncoming" sep \
"trustAuthOutgoing" sep \
"unicodePwd" sep \
"clearTextPassword"
#define DSDB_SECRET_ATTRIBUTES_COMMA ,
#define DSDB_SECRET_ATTRIBUTES DSDB_SECRET_ATTRIBUTES_EX(DSDB_SECRET_ATTRIBUTES_COMMA)
#define DSDB_PASSWORD_ATTRIBUTES \
"userPassword", \
"clearTextPassword", \
"unicodePwd", \
"dBCSPwd"
/*
* ldb opaque values used to pass the user session information to ldb modules
*/
#define DSDB_SESSION_INFO "sessionInfo"
#define DSDB_NETWORK_SESSION_INFO "networkSessionInfo"
struct GUID;
char *NS_GUID_string(TALLOC_CTX *mem_ctx, const struct GUID *guid);
NTSTATUS NS_GUID_from_string(const char *s, struct GUID *guid);
struct ldb_context;
int dsdb_werror_at(struct ldb_context *ldb, int ldb_ecode, WERROR werr,
const char *location, const char *func,
const char *reason);
#define dsdb_module_werror(module, ldb_ecode, werr, reason) \
dsdb_werror_at(ldb_module_get_ctx(module), ldb_ecode, werr, \
__location__, __func__, reason)
struct dsdb_ldb_dn_list_node {
struct dsdb_ldb_dn_list_node *prev, *next;
/* the dn of the partition */
struct ldb_dn *dn;
};
#endif /* __DSDB_COMMON_UTIL_H__ */
|