|
@@ -58,7 +58,7 @@ static int dn_assertion2keys_ava( Slapi_PBlock *pb, Slapi_Value *val,
|
|
static int dn_assertion2keys_sub( Slapi_PBlock *pb, char *initial, char **any,
|
|
static int dn_assertion2keys_sub( Slapi_PBlock *pb, char *initial, char **any,
|
|
char *final, Slapi_Value ***ivals );
|
|
char *final, Slapi_Value ***ivals );
|
|
static int dn_validate( struct berval *val );
|
|
static int dn_validate( struct berval *val );
|
|
-static int rdn_validate( char *begin, char *end, char **last );
|
|
|
|
|
|
+static int rdn_validate( const char *begin, const char *end, const char **last );
|
|
|
|
|
|
/* the first name is the official one from RFC 2252 */
|
|
/* the first name is the official one from RFC 2252 */
|
|
static char *names[] = { "DN", DN_SYNTAX_OID, 0 };
|
|
static char *names[] = { "DN", DN_SYNTAX_OID, 0 };
|
|
@@ -156,9 +156,9 @@ static int dn_validate( struct berval *val )
|
|
*/
|
|
*/
|
|
if (val->bv_len > 0) {
|
|
if (val->bv_len > 0) {
|
|
int strict = 0;
|
|
int strict = 0;
|
|
- char *p = val->bv_val;
|
|
|
|
- char *end = &(val->bv_val[val->bv_len - 1]);
|
|
|
|
- char *last = NULL;
|
|
|
|
|
|
+ const char *p = val->bv_val;
|
|
|
|
+ const char *end = &(val->bv_val[val->bv_len - 1]);
|
|
|
|
+ const char *last = NULL;
|
|
|
|
|
|
/* Check if we should be performing strict validation. */
|
|
/* Check if we should be performing strict validation. */
|
|
strict = config_get_dn_validate_strict();
|
|
strict = config_get_dn_validate_strict();
|
|
@@ -168,7 +168,7 @@ static int dn_validate( struct berval *val )
|
|
* stored in the backend unmodified. */
|
|
* stored in the backend unmodified. */
|
|
val_copy = PL_strndup(val->bv_val, val->bv_len);
|
|
val_copy = PL_strndup(val->bv_val, val->bv_len);
|
|
p = val_copy;
|
|
p = val_copy;
|
|
- end = slapi_dn_normalize_to_end(p, NULL) - 1;
|
|
|
|
|
|
+ end = slapi_dn_normalize_to_end(val_copy, NULL) - 1;
|
|
}
|
|
}
|
|
|
|
|
|
/* Validate one RDN at a time in a loop. */
|
|
/* Validate one RDN at a time in a loop. */
|
|
@@ -212,12 +212,12 @@ exit:
|
|
* will be set in the "last parameter. This will be the end of the RDN
|
|
* will be set in the "last parameter. This will be the end of the RDN
|
|
* in the valid case, and the illegal character in the invalid case.
|
|
* in the valid case, and the illegal character in the invalid case.
|
|
*/
|
|
*/
|
|
-static int rdn_validate( char *begin, char *end, char **last )
|
|
|
|
|
|
+static int rdn_validate( const char *begin, const char *end, const char **last )
|
|
{
|
|
{
|
|
int rc = 0; /* Assume RDN is valid */
|
|
int rc = 0; /* Assume RDN is valid */
|
|
int numericform = 0;
|
|
int numericform = 0;
|
|
char *separator = NULL;
|
|
char *separator = NULL;
|
|
- char *p = begin;
|
|
|
|
|
|
+ const char *p = begin;
|
|
|
|
|
|
/* Find the '=', then use the helpers for descr and numericoid */
|
|
/* Find the '=', then use the helpers for descr and numericoid */
|
|
if ((separator = PL_strnchr(p, '=', end - begin + 1)) == NULL) {
|
|
if ((separator = PL_strnchr(p, '=', end - begin + 1)) == NULL) {
|
|
@@ -228,13 +228,13 @@ static int rdn_validate( char *begin, char *end, char **last )
|
|
/* Process an attribute type. The 'descr'
|
|
/* Process an attribute type. The 'descr'
|
|
* form must start with a 'leadkeychar'. */
|
|
* form must start with a 'leadkeychar'. */
|
|
if (IS_LEADKEYCHAR(*p)) {
|
|
if (IS_LEADKEYCHAR(*p)) {
|
|
- if (rc = keystring_validate(p, separator - 1)) {
|
|
|
|
|
|
+ if ((rc = keystring_validate(p, separator - 1))) {
|
|
goto exit;
|
|
goto exit;
|
|
}
|
|
}
|
|
/* See if the 'numericoid' form is being used */
|
|
/* See if the 'numericoid' form is being used */
|
|
} else if (isdigit(*p)) {
|
|
} else if (isdigit(*p)) {
|
|
numericform = 1;
|
|
numericform = 1;
|
|
- if (rc = numericoid_validate(p, separator - 1)) {
|
|
|
|
|
|
+ if ((rc = numericoid_validate(p, separator - 1))) {
|
|
goto exit;
|
|
goto exit;
|
|
}
|
|
}
|
|
} else {
|
|
} else {
|