source: trunk/server/source4/dsdb/samdb/samdb.h

Last change on this file was 745, checked in by Silvan Scherrer, 13 years ago

Samba Server: updated trunk to 3.6.0

File size: 5.7 KB
Line 
1/*
2 Unix SMB/CIFS implementation.
3
4 interface functions for the sam database
5
6 Copyright (C) Andrew Tridgell 2004
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
20*/
21
22#ifndef __SAMDB_H__
23#define __SAMDB_H__
24
25struct auth_session_info;
26struct dsdb_control_current_partition;
27struct dsdb_extended_replicated_object;
28struct dsdb_extended_replicated_objects;
29struct loadparm_context;
30struct tevent_context;
31
32#include "librpc/gen_ndr/security.h"
33#include <ldb.h>
34#include "lib/ldb-samba/ldif_handlers.h"
35#include "librpc/gen_ndr/samr.h"
36#include "librpc/gen_ndr/drsuapi.h"
37#include "librpc/gen_ndr/drsblobs.h"
38#include "dsdb/schema/schema.h"
39#include "dsdb/samdb/samdb_proto.h"
40#include "dsdb/common/dsdb_dn.h"
41#include "dsdb/common/proto.h"
42#include "../libds/common/flags.h"
43
44#define DSDB_CONTROL_CURRENT_PARTITION_OID "1.3.6.1.4.1.7165.4.3.2"
45struct dsdb_control_current_partition {
46 /*
47 * this is the version of the dsdb_control_current_partition
48 * version 0: initial implementation
49 * version 1: got rid of backend and module fields
50 */
51#define DSDB_CONTROL_CURRENT_PARTITION_VERSION 1
52 uint32_t version;
53 struct ldb_dn *dn;
54};
55
56#define DSDB_CONTROL_REPLICATED_UPDATE_OID "1.3.6.1.4.1.7165.4.3.3"
57/* DSDB_CONTROL_REPLICATED_UPDATE_OID has NULL data */
58
59#define DSDB_CONTROL_DN_STORAGE_FORMAT_OID "1.3.6.1.4.1.7165.4.3.4"
60/* DSDB_CONTROL_DN_STORAGE_FORMAT_OID has NULL data and behaves very
61 * much like LDB_CONTROL_EXTENDED_DN_OID when the DB stores an
62 * extended DN, and otherwise returns normal DNs */
63
64#define DSDB_CONTROL_PASSWORD_CHANGE_STATUS_OID "1.3.6.1.4.1.7165.4.3.8"
65
66struct dsdb_control_password_change_status {
67 struct {
68 uint32_t pwdProperties;
69 uint32_t pwdHistoryLength;
70 int64_t maxPwdAge;
71 int64_t minPwdAge;
72 uint32_t minPwdLength;
73 bool store_cleartext;
74 const char *netbios_domain;
75 const char *dns_domain;
76 const char *realm;
77 } domain_data;
78 enum samPwdChangeReason reject_reason;
79};
80
81#define DSDB_CONTROL_PASSWORD_HASH_VALUES_OID "1.3.6.1.4.1.7165.4.3.9"
82
83#define DSDB_CONTROL_PASSWORD_CHANGE_OID "1.3.6.1.4.1.7165.4.3.10"
84
85struct dsdb_control_password_change {
86 const struct samr_Password *old_nt_pwd_hash;
87 const struct samr_Password *old_lm_pwd_hash;
88};
89
90/**
91 DSDB_CONTROL_APPLY_LINKS is internal to Samba4 - a token passed between repl_meta_data and linked_attributes modules
92*/
93#define DSDB_CONTROL_APPLY_LINKS "1.3.6.1.4.1.7165.4.3.11"
94
95/*
96 * this should only be used for importing users from Samba3
97 */
98#define DSDB_CONTROL_BYPASS_PASSWORD_HASH_OID "1.3.6.1.4.1.7165.4.3.12"
99
100/**
101 OID used to allow the replacement of replPropertyMetaData.
102 It is used when the current replmetadata needs to be edited.
103*/
104#define DSDB_CONTROL_CHANGEREPLMETADATA_OID "1.3.6.1.4.1.7165.4.3.14"
105
106#define DSDB_EXTENDED_REPLICATED_OBJECTS_OID "1.3.6.1.4.1.7165.4.4.1"
107struct dsdb_extended_replicated_object {
108 struct ldb_message *msg;
109 struct ldb_val guid_value;
110 const char *when_changed;
111 struct replPropertyMetaDataBlob *meta_data;
112};
113
114struct dsdb_extended_replicated_objects {
115 /*
116 * this is the version of the dsdb_extended_replicated_objects
117 * version 0: initial implementation
118 */
119#define DSDB_EXTENDED_REPLICATED_OBJECTS_VERSION 1
120 uint32_t version;
121
122 struct ldb_dn *partition_dn;
123
124 const struct repsFromTo1 *source_dsa;
125 const struct drsuapi_DsReplicaCursor2CtrEx *uptodateness_vector;
126
127 uint32_t num_objects;
128 struct dsdb_extended_replicated_object *objects;
129
130 uint32_t linked_attributes_count;
131 const struct drsuapi_DsReplicaLinkedAttribute *linked_attributes;
132};
133
134struct dsdb_naming_fsmo {
135 bool we_are_master;
136 struct ldb_dn *master_dn;
137};
138
139struct dsdb_pdc_fsmo {
140 bool we_are_master;
141 struct ldb_dn *master_dn;
142};
143
144#define DSDB_EXTENDED_CREATE_PARTITION_OID "1.3.6.1.4.1.7165.4.4.4"
145struct dsdb_create_partition_exop {
146 struct ldb_dn *new_dn;
147};
148
149/*
150 * the schema_dn is passed as struct ldb_dn in
151 * req->op.extended.data
152 */
153#define DSDB_EXTENDED_SCHEMA_UPDATE_NOW_OID "1.3.6.1.4.1.7165.4.4.2"
154
155#define DSDB_OPENLDAP_DEREFERENCE_CONTROL "1.3.6.1.4.1.4203.666.5.16"
156
157struct dsdb_openldap_dereference {
158 const char *source_attribute;
159 const char **dereference_attribute;
160};
161
162struct dsdb_openldap_dereference_control {
163 struct dsdb_openldap_dereference **dereference;
164};
165
166struct dsdb_openldap_dereference_result {
167 const char *source_attribute;
168 const char *dereferenced_dn;
169 int num_attributes;
170 struct ldb_message_element *attributes;
171};
172
173struct dsdb_openldap_dereference_result_control {
174 struct dsdb_openldap_dereference_result **attributes;
175};
176
177#define DSDB_PARTITION_DN "@PARTITION"
178#define DSDB_PARTITION_ATTR "partition"
179
180#define DSDB_EXTENDED_DN_STORE_FORMAT_OPAQUE_NAME "dsdb_extended_dn_store_format"
181struct dsdb_extended_dn_store_format {
182 bool store_extended_dn_in_ldb;
183};
184
185#define DSDB_OPAQUE_PARTITION_MODULE_MSG_OPAQUE_NAME "DSDB_OPAQUE_PARTITION_MODULE_MSG"
186
187/* this takes a struct dsdb_fsmo_extended_op */
188#define DSDB_EXTENDED_ALLOCATE_RID_POOL "1.3.6.1.4.1.7165.4.4.5"
189
190struct dsdb_fsmo_extended_op {
191 uint64_t fsmo_info;
192 struct GUID destination_dsa_guid;
193};
194
195#endif /* __SAMDB_H__ */
Note: See TracBrowser for help on using the repository browser.