2006-03-14 15:03:25 +00:00
/*
Unix SMB / CIFS implementation .
interface functions for the sam database
Copyright ( C ) Andrew Tridgell 2004
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
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2006-03-14 15:03:25 +00:00
( 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
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2006-03-14 15:03:25 +00:00
*/
# ifndef __SAMDB_H__
# define __SAMDB_H__
struct auth_session_info ;
2007-01-16 10:57:55 +00:00
struct dsdb_control_current_partition ;
2007-01-11 10:21:38 +00:00
struct dsdb_extended_replicated_object ;
struct dsdb_extended_replicated_objects ;
2007-12-02 17:09:52 +01:00
struct loadparm_context ;
2008-12-29 20:24:57 +01:00
struct tevent_context ;
2007-01-11 10:21:38 +00:00
# include "librpc/gen_ndr/security.h"
# include "lib/ldb/include/ldb.h"
2008-08-18 20:30:27 +10:00
# include "lib/ldb-samba/ldif_handlers.h"
2007-01-11 10:21:38 +00:00
# include "librpc/gen_ndr/samr.h"
# include "librpc/gen_ndr/drsuapi.h"
# include "librpc/gen_ndr/drsblobs.h"
# include "dsdb/schema/schema.h"
# include "dsdb/samdb/samdb_proto.h"
2007-12-17 04:22:44 +01:00
# include "dsdb/common/proto.h"
2009-11-05 16:57:20 +11:00
# include "dsdb/common/dsdb_dn.h"
2009-06-12 14:27:19 +02:00
# include "../libds/common/flags.h"
2006-03-14 15:03:25 +00:00
2007-01-16 10:57:55 +00:00
# define DSDB_CONTROL_CURRENT_PARTITION_OID "1.3.6.1.4.1.7165.4.3.2"
struct dsdb_control_current_partition {
/*
* this is the version of the dsdb_control_current_partition
* version 0 : initial implementation
2009-09-02 13:36:54 +10:00
* version 1 : got rid of backend and module fields
2007-01-16 10:57:55 +00:00
*/
2009-09-02 13:36:54 +10:00
# define DSDB_CONTROL_CURRENT_PARTITION_VERSION 1
2007-01-16 10:57:55 +00:00
uint32_t version ;
struct ldb_dn * dn ;
} ;
2008-09-27 02:27:54 +02:00
# define DSDB_CONTROL_REPLICATED_UPDATE_OID "1.3.6.1.4.1.7165.4.3.3"
/* DSDB_CONTROL_REPLICATED_UPDATE_OID has NULL data */
2008-12-16 09:21:55 +01:00
# define DSDB_CONTROL_DN_STORAGE_FORMAT_OID "1.3.6.1.4.1.7165.4.3.4"
/* DSDB_CONTROL_DN_STORAGE_FORMAT_OID has NULL data and behaves very
* much like LDB_CONTROL_EXTENDED_DN_OID when the DB stores an
* extended DN , and otherwise returns normal DNs */
2010-06-13 18:19:37 +02:00
# define DSDB_CONTROL_PASSWORD_CHANGE_STATUS_OID "1.3.6.1.4.1.7165.4.3.8"
2009-09-23 19:25:54 +02:00
struct dsdb_control_password_change_status {
struct {
uint32_t pwdProperties ;
uint32_t pwdHistoryLength ;
int64_t maxPwdAge ;
int64_t minPwdAge ;
uint32_t minPwdLength ;
bool store_cleartext ;
const char * netbios_domain ;
const char * dns_domain ;
const char * realm ;
} domain_data ;
enum samPwdChangeReason reject_reason ;
} ;
2010-06-13 18:19:37 +02:00
# define DSDB_CONTROL_PASSWORD_HASH_VALUES_OID "1.3.6.1.4.1.7165.4.3.9"
2009-09-23 19:25:54 +02:00
2010-06-13 18:19:37 +02:00
# define DSDB_CONTROL_PASSWORD_CHANGE_OLD_PW_CHECKED_OID "1.3.6.1.4.1.7165.4.3.10"
2009-09-23 19:25:54 +02:00
2010-06-14 15:30:36 +10:00
/**
DSDB_CONTROL_APPLY_LINKS is internal to Samba4 - a token passed between repl_meta_data and linked_attributes modules
*/
# define DSDB_CONTROL_APPLY_LINKS "1.3.6.1.4.1.7165.4.3.11"
2010-06-30 08:24:35 +02:00
/*
* this should only be used for importing users from Samba3
*/
# define DSDB_CONTROL_BYPASS_PASSWORD_HASH_OID "1.3.6.1.4.1.7165.4.3.12"
2007-01-06 10:15:02 +00:00
# define DSDB_EXTENDED_REPLICATED_OBJECTS_OID "1.3.6.1.4.1.7165.4.4.1"
2007-01-09 11:15:56 +00:00
struct dsdb_extended_replicated_object {
struct ldb_message * msg ;
2007-01-11 09:45:30 +00:00
struct ldb_val guid_value ;
2007-01-13 10:53:12 +00:00
const char * when_changed ;
2007-01-11 09:45:30 +00:00
struct replPropertyMetaDataBlob * meta_data ;
2007-01-09 11:15:56 +00:00
} ;
2007-01-06 10:15:02 +00:00
struct dsdb_extended_replicated_objects {
2007-01-13 11:37:13 +00:00
/*
* this is the version of the dsdb_extended_replicated_objects
* version 0 : initial implementation
*/
2009-09-03 12:52:31 +10:00
# define DSDB_EXTENDED_REPLICATED_OBJECTS_VERSION 1
2007-01-13 11:37:13 +00:00
uint32_t version ;
2007-01-07 19:11:27 +00:00
struct ldb_dn * partition_dn ;
2007-01-09 11:15:56 +00:00
2007-01-12 16:02:10 +00:00
const struct repsFromTo1 * source_dsa ;
2007-01-12 13:17:25 +00:00
const struct drsuapi_DsReplicaCursor2CtrEx * uptodateness_vector ;
2007-01-09 11:15:56 +00:00
uint32_t num_objects ;
struct dsdb_extended_replicated_object * objects ;
2009-09-03 12:52:31 +10:00
uint32_t linked_attributes_count ;
const struct drsuapi_DsReplicaLinkedAttribute * linked_attributes ;
2007-01-06 10:15:02 +00:00
} ;
2007-01-18 01:31:09 +00:00
struct dsdb_naming_fsmo {
bool we_are_master ;
struct ldb_dn * master_dn ;
} ;
struct dsdb_pdc_fsmo {
bool we_are_master ;
struct ldb_dn * master_dn ;
} ;
2009-10-02 10:28:29 +10:00
# define DSDB_EXTENDED_CREATE_PARTITION_OID "1.3.6.1.4.1.7165.4.4.4"
struct dsdb_create_partition_exop {
struct ldb_dn * new_dn ;
} ;
2008-07-24 10:00:20 +02:00
/*
* the schema_dn is passed as struct ldb_dn in
* req - > op . extended . data
*/
2008-07-23 09:59:17 +03:00
# define DSDB_EXTENDED_SCHEMA_UPDATE_NOW_OID "1.3.6.1.4.1.7165.4.4.2"
2008-12-16 08:28:55 +01:00
# define DSDB_OPENLDAP_DEREFERENCE_CONTROL "1.3.6.1.4.1.4203.666.5.16"
struct dsdb_openldap_dereference {
const char * source_attribute ;
const char * * dereference_attribute ;
} ;
struct dsdb_openldap_dereference_control {
struct dsdb_openldap_dereference * * dereference ;
} ;
struct dsdb_openldap_dereference_result {
const char * source_attribute ;
const char * dereferenced_dn ;
int num_attributes ;
struct ldb_message_element * attributes ;
} ;
struct dsdb_openldap_dereference_result_control {
struct dsdb_openldap_dereference_result * * attributes ;
} ;
2009-10-02 10:28:29 +10:00
# define DSDB_PARTITION_DN "@PARTITION"
# define DSDB_PARTITION_ATTR "partition"
2009-11-16 18:46:28 +11:00
# define DSDB_EXTENDED_DN_STORE_FORMAT_OPAQUE_NAME "dsdb_extended_dn_store_format"
struct dsdb_extended_dn_store_format {
bool store_extended_dn_in_ldb ;
} ;
2009-11-23 20:30:35 +11:00
# define DSDB_OPAQUE_PARTITION_MODULE_MSG_OPAQUE_NAME "DSDB_OPAQUE_PARTITION_MODULE_MSG"
2010-01-06 19:34:14 +11:00
/* this takes a struct dsdb_fsmo_extended_op */
# define DSDB_EXTENDED_ALLOCATE_RID_POOL "1.3.6.1.4.1.7165.4.4.5"
struct dsdb_fsmo_extended_op {
uint64_t fsmo_info ;
struct GUID destination_dsa_guid ;
} ;
2006-03-14 15:03:25 +00:00
# endif /* __SAMDB_H__ */