]> git.sur5r.net Git - openldap/blob - servers/slapd/oidm.c
89895ad6c3b3e0d1d5c9c3278bdbbab495214617
[openldap] / servers / slapd / oidm.c
1 /* schemaparse.c - routines to parse config file objectclass definitions */
2 /* $OpenLDAP$ */
3 /*
4  * Copyright 1998-2003 The OpenLDAP Foundation, All Rights Reserved.
5  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
6  */
7
8 #include "portable.h"
9
10 #include <stdio.h>
11
12 #include <ac/ctype.h>
13 #include <ac/string.h>
14 #include <ac/socket.h>
15
16 #include "slap.h"
17
18 static LDAP_SLIST_HEAD(OidMacroList, slap_oid_macro) om_list
19         = LDAP_SLIST_HEAD_INITIALIZER(om_list);
20
21 /* Replace an OID Macro invocation with its full numeric OID.
22  * If the macro is used with "macroname:suffix" append ".suffix"
23  * to the expansion.
24  */
25 char *
26 oidm_find(char *oid)
27 {
28         OidMacro *om;
29
30         /* OID macros must start alpha */
31         if ( OID_LEADCHAR( *oid ) )     {
32                 return oid;
33         }
34
35         LDAP_SLIST_FOREACH( om, &om_list, som_next ) {
36                 char **names = om->som_names;
37
38                 if( names == NULL ) {
39                         continue;
40                 }
41
42                 for( ; *names != NULL ; names++ ) {
43                         int pos = dscompare(*names, oid, ':');
44
45                         if( pos ) {
46                                 int suflen = strlen(oid + pos);
47                                 char *tmp = SLAP_MALLOC( om->som_oid.bv_len
48                                         + suflen + 1);
49                                 if( tmp == NULL ) {
50 #ifdef NEW_LOGGING
51                                         LDAP_LOG( OPERATION, ERR,
52                                                 "oidm_find: SLAP_MALLOC failed", 0, 0, 0 );
53 #else
54                                         Debug( LDAP_DEBUG_ANY,
55                                                 "oidm_find: SLAP_MALLOC failed", 0, 0, 0 );
56 #endif
57                                         return NULL;
58                                 }
59                                 strcpy(tmp, om->som_oid.bv_val);
60                                 if( suflen ) {
61                                         suflen = om->som_oid.bv_len;
62                                         tmp[suflen++] = '.';
63                                         strcpy(tmp+suflen, oid+pos+1);
64                                 }
65                                 return tmp;
66                         }
67                 }
68         }
69         return NULL;
70 }
71
72 void
73 oidm_destroy()
74 {
75         OidMacro *om;
76
77         while( !LDAP_SLIST_EMPTY( &om_list )) {
78                 om = LDAP_SLIST_FIRST( &om_list );
79
80                 ldap_charray_free(om->som_names);
81                 free(om->som_oid.bv_val);
82                 free(om);
83                 
84                 LDAP_SLIST_REMOVE_HEAD( &om_list, som_next );
85         }
86 }
87
88 int
89 parse_oidm(
90     const char  *fname,
91     int         lineno,
92     int         argc,
93     char        **argv
94 )
95 {
96         char *oid;
97         OidMacro *om;
98
99         if (argc != 3) {
100                 fprintf( stderr, "%s: line %d: too many arguments\n",
101                         fname, lineno );
102 usage:  fprintf( stderr, "\tObjectIdentifier <name> <oid>\n");
103                 return 1;
104         }
105
106         oid = oidm_find( argv[1] );
107         if( oid != NULL ) {
108                 fprintf( stderr,
109                         "%s: line %d: "
110                         "ObjectIdentifier \"%s\" previously defined \"%s\"",
111                         fname, lineno, argv[1], oid );
112                 return 1;
113         }
114
115         om = (OidMacro *) SLAP_MALLOC( sizeof(OidMacro) );
116         if( om == NULL ) {
117 #ifdef NEW_LOGGING
118                 LDAP_LOG( OPERATION, ERR, "parse_oidm: SLAP_MALLOC failed", 0, 0, 0 );
119 #else
120                 Debug( LDAP_DEBUG_ANY, "parse_oidm: SLAP_MALLOC failed", 0, 0, 0 );
121 #endif
122                 return 1;
123         }
124
125         om->som_names = NULL;
126         ldap_charray_add( &om->som_names, argv[1] );
127         om->som_oid.bv_val = oidm_find( argv[2] );
128
129         if (!om->som_oid.bv_val) {
130                 fprintf( stderr, "%s: line %d: OID %s not recognized\n",
131                         fname, lineno, argv[2] );
132                 goto usage;
133         }
134
135         if (om->som_oid.bv_val == argv[2]) {
136                 om->som_oid.bv_val = ch_strdup( argv[2] );
137         }
138
139         om->som_oid.bv_len = strlen( om->som_oid.bv_val );
140
141         LDAP_SLIST_INSERT_HEAD( &om_list, om, som_next );
142
143         return 0;
144 }