1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-18 06:04:06 +03:00
Jo Sutton 002e01963d s4:dsdb: Add dsdb_werror() macro
This works like dsdb_module_werror(), but does not require an ldb module
to work.

Signed-off-by: Jo Sutton <josutton@catalyst.net.nz>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
2024-02-16 02:41:36 +00:00

108 lines
3.4 KiB
C

/*
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__
#include "libcli/util/werror.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
#define DSDB_MARK_REQ_UNTRUSTED 0x20000
#define DSDB_SEARCH_UPDATE_MANAGED_PASSWORDS 0x40000
#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;
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_werror(ldb, ldb_ecode, werr, reason) \
dsdb_werror_at(ldb, ldb_ecode, werr, __location__, __func__, 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__ */