From 7c24af851a2e829cb1209347e0cab5a809dee6e8 Mon Sep 17 00:00:00 2001 From: Jim Norman Date: Fri, 28 Apr 2006 21:25:05 +0000 Subject: [PATCH] Account for length without null inclusion --- c_micasadk/sscs_ndk.c | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/c_micasadk/sscs_ndk.c b/c_micasadk/sscs_ndk.c index b15a865b..bb4bda63 100644 --- a/c_micasadk/sscs_ndk.c +++ b/c_micasadk/sscs_ndk.c @@ -20,8 +20,6 @@ * ***********************************************************************/ - - #include #include @@ -52,8 +50,6 @@ static SS_UTF8_T SSCS_OBITUARY_DELIMITED[] = {"SS_Obituary:"}; #define sscsshs_AddSHSBinaryEntry sscsshs_AddSHSEntry - - /* * NAME - sscsshs_AddSHSEntry * @@ -1578,8 +1574,18 @@ miCASAWriteKey { return(NSSCS_E_BUFFER_LEN); } - + // check to see if caller included the null in length, if not add one + if (sscs_Utf8Strlen(key) == keyLen) + { + keyLen += 1; + } + + if (strlen(val) == valLen) + { + valLen += 1; + } + if((escapedSHSName = (SS_UTF8_T *) malloc(NSSCS_MAX_SECRET_ID_LEN)) == NULL) { rc = NSSCS_E_SYSTEM_FAILURE; @@ -1598,7 +1604,6 @@ miCASAWriteKey goto errorLevel1; } - memset(secretID.id, 0, NSSCS_MAX_SECRET_ID_LEN); memset(escapedSHSName, 0, NSSCS_MAX_SECRET_ID_LEN); memset(escapedSHSKey, 0, NSSCS_MAX_SECRET_ID_LEN); @@ -3219,8 +3224,17 @@ miCASASetCredential return NSSCS_E_BUFFER_LEN; } + // check length to see if includes the null, add one if not + if ((sscs_Utf8Strlen(appSecretID->id) == appSecretID->len) + { + appSecretID += 1; + } - + if ((sharedSecretID) && (sscs_Utf8Strlen(sharedSecretID->id) == sharedSecretID->len) + { + sharedSecretID->len += 1; + } + // open secretStore sscs_Utf8Strncpy(store.ssName, SSCS_DEFAULT_SECRETSTORE_ID, SSCS_DEFAULT_SECRETSTORE_ID_LEN); store.version = 1; @@ -3265,6 +3279,7 @@ miCASASetCredential basicCred = (SSCS_BASIC_CREDENTIAL *)credential; } + // determine username key name, ie CN, LDAPDN, etc if(basicCred->unFlags & USERNAME_TYPE_NDS_DN_F) {