1 /* mr.c - routines to manage matching rule definitions */
4 * Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.
5 * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
13 #include <ac/string.h>
14 #include <ac/socket.h>
25 static Avlnode *mr_index = NULL;
26 static MatchingRule *mr_list = NULL;
30 struct mindexrec *mir1,
31 struct mindexrec *mir2
34 return (strcmp( mir1->mir_name, mir2->mir_name ));
43 return (strcmp( name, mir->mir_name ));
47 mr_find( const char *mrname )
49 struct mindexrec *mir = NULL;
51 if ( (mir = (struct mindexrec *) avl_find( mr_index, mrname,
52 (AVL_CMP) mr_index_name_cmp )) != NULL ) {
53 return( mir->mir_mr );
63 avl_free(mr_index, ldap_memfree);
64 for (m=mr_list; m; m=n) {
66 ldap_matchingrule_free((LDAPMatchingRule *)m);
77 struct mindexrec *mir;
81 while ( *mrp != NULL ) {
82 mrp = &(*mrp)->smr_next;
87 mir = (struct mindexrec *)
88 ch_calloc( 1, sizeof(struct mindexrec) );
89 mir->mir_name = smr->smr_oid;
91 if ( avl_insert( &mr_index, (caddr_t) mir,
92 (AVL_CMP) mr_index_cmp,
93 (AVL_DUP) avl_dup_error ) ) {
96 return SLAP_SCHERR_DUP_RULE;
98 /* FIX: temporal consistency check */
99 mr_find(mir->mir_name);
101 if ( (names = smr->smr_names) ) {
103 mir = (struct mindexrec *)
104 ch_calloc( 1, sizeof(struct mindexrec) );
105 mir->mir_name = *names;
107 if ( avl_insert( &mr_index, (caddr_t) mir,
108 (AVL_CMP) mr_index_cmp,
109 (AVL_DUP) avl_dup_error ) ) {
112 return SLAP_SCHERR_DUP_RULE;
114 /* FIX: temporal consistency check */
115 mr_find(mir->mir_name);
124 LDAPMatchingRule *mr,
126 slap_mr_convert_func *convert,
127 slap_mr_normalize_func *normalize,
128 slap_mr_match_func *match,
129 slap_mr_indexer_func *indexer,
130 slap_mr_filter_func *filter,
139 smr = (MatchingRule *) ch_calloc( 1, sizeof(MatchingRule) );
140 AC_MEMCPY( &smr->smr_mrule, mr, sizeof(LDAPMatchingRule));
142 smr->smr_oidlen = strlen( mr->mr_oid );
143 smr->smr_usage = usage;
144 smr->smr_convert = convert;
145 smr->smr_normalize = normalize;
146 smr->smr_match = match;
147 smr->smr_indexer = indexer;
148 smr->smr_filter = filter;
149 smr->smr_associated = amr;
151 if ( smr->smr_syntax_oid ) {
152 if ( (syn = syn_find(smr->smr_syntax_oid)) ) {
153 smr->smr_syntax = syn;
155 *err = smr->smr_syntax_oid;
156 return SLAP_SCHERR_SYN_NOT_FOUND;
160 return SLAP_SCHERR_MR_INCOMPLETE;
162 code = mr_insert(smr,err);
168 register_matching_rule(
171 slap_mr_convert_func *convert,
172 slap_mr_normalize_func *normalize,
173 slap_mr_match_func *match,
174 slap_mr_indexer_func *indexer,
175 slap_mr_filter_func *filter,
176 const char* associated )
178 LDAPMatchingRule *mr;
179 MatchingRule *amr = NULL;
183 if( usage == SLAP_MR_NONE ) {
185 LDAP_LOG(( "operation", LDAP_LEVEL_ERR,
186 "register_matching_rule: %s not usable\n", desc ));
188 Debug( LDAP_DEBUG_ANY, "register_matching_rule: not usable %s\n",
195 if( associated != NULL ) {
196 amr = mr_find( associated );
203 LDAP_LOG(( "operation", LDAP_LEVEL_ERR,
204 "register_matching_rule: could not locate associated matching rule %s for %s\n",
207 Debug( LDAP_DEBUG_ANY, "register_matching_rule: could not locate "
208 "associated matching rule %s for %s\n",
209 associated, desc, 0 );
218 mr = ldap_str2matchingrule( desc, &code, &err, LDAP_SCHEMA_ALLOW_ALL);
221 LDAP_LOG(( "operation", LDAP_LEVEL_ERR,
222 "register_matching_rule: %s before %s in %s.\n",
223 ldap_scherr2str(code), err, desc ));
225 Debug( LDAP_DEBUG_ANY, "Error in register_matching_rule: %s before %s in %s\n",
226 ldap_scherr2str(code), err, desc );
232 code = mr_add( mr, usage,
233 convert, normalize, match, indexer, filter, amr,
240 LDAP_LOG(( "operation", LDAP_LEVEL_ERR,
241 "register_matching_rule: %s for %s in %s.\n",
242 scherr2str(code), err, desc ));
244 Debug( LDAP_DEBUG_ANY, "Error in register_matching_rule: %s for %s in %s\n",
245 scherr2str(code), err, desc );
255 #if defined( SLAPD_SCHEMA_DN )
257 int mr_schema_info( Entry *e )
260 struct berval *vals[2];
263 AttributeDescription *ad_matchingRules = slap_schema.si_ad_matchingRules;
268 for ( mr = mr_list; mr; mr = mr->smr_next ) {
269 if ( ! mr->smr_match ) {
270 /* skip rules without matching functions */
274 if ( ldap_matchingrule2bv( &mr->smr_mrule, &val ) == NULL ) {
278 Debug( LDAP_DEBUG_TRACE, "Merging mr [%ld] %s\n",
279 (long) val.bv_len, val.bv_val, 0 );
281 attr_merge( e, ad_matchingRules, vals );
282 ldap_memfree( val.bv_val );