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
|
/*
Unix SMB/CIFS mplementation.
API for determining af an attribute belongs to the filtered set.
Copyright (C) Nadezhda Ivanova <nivanova@samba.org> 2010
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/>.
*/
#include "includes.h"
#include "dsdb/samdb/samdb.h"
#include "dsdb/common/util.h"
#include "lib/ldb/include/ldb_errors.h"
#include "../lib/util/dlinklist.h"
#include "param/param.h"
const char *never_in_filtered_attrs[] = { "accountExpires",
"codePage",
"creationTime",
"currentValue",
"dBCSPwd",
"dNSHostName",
"displayName",
"domainReplica",
"fSMORoleOwner",
"flatName",
"initialAuthIncoming",
"initialAuthOutgoing",
"isCriticalSystemObject",
"lmPwdHistory",
"lockOutObservationWindow",
"lockoutDuration",
"lockoutTime",
"logonHours",
"maxPwdAge",
"minPwdAge",
"minPwdLength",
"msDS-AdditionalDnsHostName",
"msDS-AdditionalSamAccountName",
"msDS-AllowedToDelegateTo",
"msDS-AuthenticatedAtDC",
"msDS-ExecuteScriptPassword",
"msDS-KrbTgtLink",
"msDS-SPNSuffixes",
"msDS-SupportedEncryptionTypes",
"msDS-TrustForestTrustInfo",
"nETBIOSName",
"nTMixedDomain",
"notFiltlockoutThreshold",
"ntPwdHistory",
"operatingSystem",
"operatingSystemServicePack",
"operatingSystemVersion",
"priorValue",
"pwdHistoryLength",
"pwdLastSet",
"pwdProperties",
"rid",
"sIDHistory",
"securityIdentifier",
"servicePrincipalName",
"supplementalCredentials",
"trustAttributes",
"trustAuthIncoming",
"trustAuthOutgoing",
"trustDirection",
"trustParent",
"trustPartner",
"trustPosixOffset",
"trustType",
"unicodePwd"
};
/* returns true if the attribute can be in a filtered replica */
bool dsdb_attribute_is_attr_in_filtered_replica(struct dsdb_attribute *attribute)
{
int i, size = sizeof(never_in_filtered_attrs)/sizeof(char *);
if (attribute->systemOnly ||
attribute->schemaFlagsEx & SCHEMA_FLAG_ATTR_IS_CRITICAL) {
return false;
}
if (attribute->systemFlags & (DS_FLAG_ATTR_NOT_REPLICATED |
DS_FLAG_ATTR_REQ_PARTIAL_SET_MEMBER |
DS_FLAG_ATTR_IS_CONSTRUCTED)) {
return false;
}
for (i=0; i < size; i++) {
if (strcmp(attribute->lDAPDisplayName, never_in_filtered_attrs[i]) == 0) {
return false;
}
}
if (attribute->searchFlags & SEARCH_FLAG_RODC_ATTRIBUTE) {
return false;
}
return true;
}
|