]> git.sur5r.net Git - openldap/blobdiff - servers/slapd/at.c
Clean up
[openldap] / servers / slapd / at.c
index 40964b217b67c9482ee1fa2fe407cfac6ad8d869..4859040aea85865a111f6ba51b1d72a6e8eb0342 100644 (file)
 #include "ldap_pvt.h"
 #include "slap.h"
 
-#ifndef SLAPD_SCHEMA_NOT_COMPAT
-char *
-at_canonical_name( const char * a_type )
-{
-       AttributeType   *atp;
-
-       atp=at_find(a_type);
-
-       if ( atp == NULL ) {
-               return (char *) a_type;
-
-       } else if ( atp->sat_names
-               && atp->sat_names[0] && (*(atp->sat_names[0]) != '\0') )
-       {
-               return atp->sat_names[0];
-
-       } else if (atp->sat_oid && (*atp->sat_oid != '\0')) {
-               return atp->sat_oid;
-       }
-
-       return (char *) a_type;
-}
 
-#define DEFAULT_SYNTAX SYNTAX_CIS
-
-/*
- * attr_syntax - return the syntax of attribute type
- */
-
-int
-attr_syntax( const char *type )
+int is_at_syntax(
+       AttributeType *at,
+       const char *oid )
 {
-       AttributeType   *sat;
-
-       sat = at_find(type);
-       if ( sat ) {
-               return( sat->sat_syntax_compat );
-       }
-
-       return( DEFAULT_SYNTAX );
-}
-
-/*
- * attr_syntax_config - process an attribute syntax config line
- */
-
-void
-at_config(
-    const char *fname,
-    int                lineno,
-    int                argc,
-    char       **argv
-)
-{
-       char                    *save;
-       LDAP_ATTRIBUTE_TYPE     *at;
-       int                     lasti;
-       int                     code;
-       const char              *err;
-
-       if ( argc < 2 ) {
-               Debug( LDAP_DEBUG_ANY,
-"%s: line %d: missing name in \"attribute <name>+ <syntax>\" (ignored)\n",
-                   fname, lineno, 0 );
-               return;
-       }
-
-       at = (LDAP_ATTRIBUTE_TYPE *)
-               ch_calloc( 1, sizeof(LDAP_ATTRIBUTE_TYPE) );
-
-#define SYNTAX_DS_OID  "1.3.6.1.4.1.1466.115.121.1.15"
-#define SYNTAX_DSCE_OID        "2.5.13.5"
-#define SYNTAX_IA5_OID "1.3.6.1.4.1.1466.115.121.1.26"
-#define SYNTAX_IA5CE_OID       "1.3.6.1.4.1.1466.109.114.1"
-#define SYNTAX_DN_OID  SLAPD_OID_DN_SYNTAX
-#define SYNTAX_TEL_OID "1.3.6.1.4.1.1466.115.121.1.50"
-#define SYNTAX_BIN_OID "1.3.6.1.4.1.1466.115.121.1.40" /* octetString */
-
-       lasti = argc - 1;
-       if ( strcasecmp( argv[lasti], "caseignorestring" ) == 0 ||
-           strcasecmp( argv[lasti], "cis" ) == 0 ) {
-               at->at_syntax_oid = SYNTAX_DS_OID;
-               at->at_equality_oid = "2.5.13.2";
-               at->at_ordering_oid = "2.5.13.3";
-               at->at_substr_oid = "2.5.13.4";
-
-       } else if ( strcasecmp( argv[lasti], "telephone" ) == 0 ||
-           strcasecmp( argv[lasti], "tel" ) == 0 ) {
-               at->at_syntax_oid = SYNTAX_TEL_OID;
-               at->at_equality_oid = "2.5.13.20";
-               at->at_substr_oid = "2.5.13.21";
-
-       } else if ( strcasecmp( argv[lasti], "dn" ) == 0 ) {
-               at->at_syntax_oid = SYNTAX_DN_OID;
-               at->at_equality_oid = "2.5.13.1";
-
-       } else if ( strcasecmp( argv[lasti], "caseexactstring" ) == 0 ||
-           strcasecmp( argv[lasti], "ces" ) == 0 ) {
-               at->at_syntax_oid = SYNTAX_DS_OID;
-               at->at_equality_oid = SYNTAX_DSCE_OID;
-               at->at_ordering_oid = "2.5.13.6";
-               at->at_substr_oid = "2.5.13.7";
-
-       } else if ( strcasecmp( argv[lasti], "binary" ) == 0 ||
-           strcasecmp( argv[lasti], "bin" ) == 0 ) {
-               /* bin -> octetString, not binary! */
-               at->at_syntax_oid = SYNTAX_BIN_OID;
-               at->at_equality_oid = "2.5.13.17";
-
-       } else {
-               Debug( LDAP_DEBUG_ANY,
-           "%s: line %d: unknown syntax \"%s\" in attribute line (ignored)\n",
-                   fname, lineno, argv[lasti] );
-               Debug( LDAP_DEBUG_ANY,
-    "possible syntaxes are \"cis\", \"ces\", \"tel\", \"dn\", or \"bin\"\n",
-                   0, 0, 0 );
-               free( (AttributeType *) at );
-               return;
-       }
-
-       save = argv[lasti];
-       argv[lasti] = NULL;
-       at->at_names = charray_dup( argv );
-       argv[lasti] = save;
-
-       code = at_add( at, &err );
-       if ( code ) {
-               fprintf( stderr, "%s: line %d: %s %s\n",
-                        fname, lineno, scherr2str(code), err);
-               exit( EXIT_FAILURE );
+       for( ; at != NULL; at = at->sat_sup ) {
+               if( at->sat_syntax_oid ) {
+                       return ( strcmp( at->sat_syntax_oid, oid ) == 0 );
+               }
        }
 
-       ldap_memfree(at);
-}
-
-int
-at_fake_if_needed(
-    const char *name
-)
-{
-       char *argv[3];
-
-       if ( at_find( name ) ) {
-               return 0;
-       } else {
-               argv[0] = (char*) name;
-               argv[1] = "cis";
-               argv[2] = NULL;
-               at_config( "implicit", 0, 2, argv );
-               return 0;
-       }
+       return 0;
 }
 
-#endif
-
 int is_at_subtype(
        AttributeType *sub,
        AttributeType *sup )
@@ -215,36 +74,12 @@ at_find(
     const char         *name
 )
 {
-       struct aindexrec        *air;
-       char                    *tmpname;
+       struct aindexrec *air;
 
-#ifndef SLAPD_SCHEMA_NOT_COMPAT
-       /*
-        * The name may actually be an AttributeDescription, i.e. it may
-        * contain options.
-        */
-       /* Treat any attribute type with option as an unknown attribute type */
-       char *p = strchr( name, ';' );
-       if ( p ) {
-               tmpname = ch_malloc( p-name+1 );
-               strncpy( tmpname, name, p-name );
-               tmpname[p-name] = '\0';
-       } else
-#endif
-       {
-               tmpname = (char *)name;
-       }
-
-       if ( (air = (struct aindexrec *) avl_find( attr_index, tmpname,
-            (AVL_CMP) attr_index_name_cmp )) != NULL ) {
-               if ( tmpname != name )
-                       ldap_memfree( tmpname );
-               return( air->air_at );
-       }
+       air = (struct aindexrec *) avl_find( attr_index, name,
+            (AVL_CMP) attr_index_name_cmp );
 
-       if ( tmpname != name )
-               ldap_memfree( tmpname );
-       return( NULL );
+       return air != NULL ? air->air_at : NULL;
 }
 
 int
@@ -393,7 +228,7 @@ at_insert(
 
 int
 at_add(
-    LDAP_ATTRIBUTE_TYPE        *at,
+    LDAPAttributeType  *at,
     const char         **err
 )
 {
@@ -402,22 +237,32 @@ at_add(
        Syntax          *syn;
        int             code;
        char                    *cname;
-       LDAP_SCHEMA_EXTENSION_ITEM      **ext;
 
        if ( at->at_names && at->at_names[0] ) {
+               int i;
+
+               for( i=0; at->at_names[i]; i++ ) {
+                       if( !slap_valid_descr( at->at_names[i] ) ) {
+                               return SLAP_SCHERR_BAD_DESCR;
+                       }
+               }
+
                cname = at->at_names[0];
+
        } else if ( at->at_oid ) {
                cname = at->at_oid;
        } else {
-               cname = "";
                return SLAP_SCHERR_ATTR_INCOMPLETE;
        }
+
+       if ( at->at_collective ) {
+               return SLAP_SCHERR_NOT_SUPPORTED;
+       }
+
        sat = (AttributeType *) ch_calloc( 1, sizeof(AttributeType) );
-       memcpy( &sat->sat_atype, at, sizeof(LDAP_ATTRIBUTE_TYPE));
+       AC_MEMCPY( &sat->sat_atype, at, sizeof(LDAPAttributeType));
 
-#ifdef SLAPD_SCHEMA_NOT_COMPAT
        sat->sat_cname = cname;
-#endif
 
        if ( at->at_sup_oid ) {
                AttributeType *supsat = at_find(at->at_sup_oid);
@@ -442,14 +287,10 @@ at_add(
         */
        if ( sat->sat_sup ) {
                sat->sat_syntax = sat->sat_sup->sat_syntax;
-#ifndef SLAPD_SCHEMA_NOT_COMPAT
-               sat->sat_syntax_compat = sat->sat_sup->sat_syntax_compat;
-#endif
                sat->sat_equality = sat->sat_sup->sat_equality;
+               sat->sat_approx = sat->sat_sup->sat_approx;
                sat->sat_ordering = sat->sat_sup->sat_ordering;
                sat->sat_substr = sat->sat_sup->sat_substr;
-               sat->sat_binary = sat->sat_sup->sat_binary;
-               sat->sat_not_h_r = sat->sat_sup->sat_not_h_r;
        }
 
        if ( at->at_syntax_oid ) {
@@ -460,38 +301,6 @@ at_add(
                        return SLAP_SCHERR_SYN_NOT_FOUND;
                }
 
-#ifndef SLAPD_SCHEMA_NOT_COMPAT
-               if ( !strcmp(at->at_syntax_oid, SYNTAX_DS_OID) ) {
-                       if ( at->at_equality_oid && (
-                               !strcmp(at->at_equality_oid, SYNTAX_DSCE_OID) ) )
-                       {
-                               sat->sat_syntax_compat = SYNTAX_CES;
-                       } else {
-                               sat->sat_syntax_compat = SYNTAX_CIS;
-                       }
-
-               } else if ( !strcmp(at->at_syntax_oid, SYNTAX_IA5_OID) ) {
-                       if ( at->at_equality_oid && (
-                               !strcmp(at->at_equality_oid, SYNTAX_IA5CE_OID) ) )
-                       {
-                               sat->sat_syntax_compat = SYNTAX_CES;
-                       } else {
-                               sat->sat_syntax_compat = SYNTAX_CIS;
-                       }
-
-               } else if ( !strcmp(at->at_syntax_oid, SYNTAX_DN_OID ) ) {
-                       sat->sat_syntax_compat = SYNTAX_CIS | SYNTAX_DN;
-
-               } else if ( !strcmp(at->at_syntax_oid, SYNTAX_TEL_OID ) ) {
-                       sat->sat_syntax_compat = SYNTAX_CIS | SYNTAX_TEL;
-
-               } else if ( !strcmp(at->at_syntax_oid, SYNTAX_BIN_OID ) ) {
-                       sat->sat_syntax_compat = SYNTAX_BIN;
-
-               } else {
-                       sat->sat_syntax_compat = DEFAULT_SYNTAX;
-               }
-#endif
 
        } else if ( sat->sat_syntax == NULL ) {
                return SLAP_SCHERR_ATTR_INCOMPLETE;
@@ -500,6 +309,7 @@ at_add(
        if ( sat->sat_equality_oid ) {
                if ( (mr = mr_find(sat->sat_equality_oid)) ) {
                        sat->sat_equality = mr;
+                       sat->sat_approx = mr->smr_associated;
                } else {
                        *err = sat->sat_equality_oid;
                        return SLAP_SCHERR_MR_NOT_FOUND;
@@ -525,22 +335,6 @@ at_add(
                }
        }
 
-       if ( sat->sat_extensions ) {
-               for ( ext = sat->sat_extensions; *ext; ext++ ) {
-                       if ( strcmp((*ext)->lsei_name, "X-BINARY-TRANSFER-REQUIRED") == 0 &&
-                            (*ext)->lsei_values &&
-                            (*ext)->lsei_values[0] &&
-                            strcasecmp((*ext)->lsei_values[0], "true") == 0 ) {
-                               sat->sat_binary = 1;
-                       } else if ( strcmp((*ext)->lsei_name, "X-NOT-HUMAN-READABLE") == 0 &&
-                            (*ext)->lsei_values &&
-                            (*ext)->lsei_values[0] &&
-                            strcasecmp((*ext)->lsei_values[0], "true") == 0 ) {
-                               sat->sat_not_h_r = 1;
-                       }  
-               }
-       }
-
        code = at_insert(sat,err);
        return code;
 }
@@ -573,11 +367,7 @@ at_schema_info( Entry *e )
        struct berval   *vals[2];
        AttributeType   *at;
 
-#ifdef SLAPD_SCHEMA_NOT_COMPAT
        AttributeDescription *ad_attributeTypes = slap_schema.si_ad_attributeTypes;
-#else
-       char *ad_attributeTypes = "attributeTypes";
-#endif
 
        vals[0] = &val;
        vals[1] = NULL;