diff options
| author | Simo Sorce <simo@redhat.com> | 2012-06-07 13:10:42 -0400 |
|---|---|---|
| committer | Simo Sorce <simo@redhat.com> | 2012-09-13 16:18:12 -0400 |
| commit | 80d1ac7c01973eda200cab55f54a6fb821d81dd0 (patch) | |
| tree | ce94b1956579d9f32780a32af38b4f75d7e75e93 /src | |
| parent | 893ad5da87c6dddaed4f4e510767ffacf7092edf (diff) | |
| download | krb5-80d1ac7c01973eda200cab55f54a6fb821d81dd0.tar.gz krb5-80d1ac7c01973eda200cab55f54a6fb821d81dd0.tar.xz krb5-80d1ac7c01973eda200cab55f54a6fb821d81dd0.zip | |
Never return interposers OIDs
This function is used to return te reply for gss_indicate_mechs(), and we do
not want applications to see interposer mechs, they should never be exposed
directly to apps.
Diffstat (limited to 'src')
| -rw-r--r-- | src/lib/gssapi/mechglue/g_initialize.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/lib/gssapi/mechglue/g_initialize.c b/src/lib/gssapi/mechglue/g_initialize.c index 8bdb2353c2..1ce87fa5bb 100644 --- a/src/lib/gssapi/mechglue/g_initialize.c +++ b/src/lib/gssapi/mechglue/g_initialize.c @@ -348,10 +348,14 @@ build_mechSet(void) count * sizeof (gss_OID_desc)); /* now copy each oid element */ - g_mechSet.count = count; count = 0; mList = g_mechList; while (mList != NULL) { + if (mList->is_interposer) { + /* skip interposers, we never expose them */ + mList = mList->next; + continue; + } curItem = &(g_mechSet.elements[count]); curItem->elements = (void*) malloc(mList->mech_type->length); @@ -375,6 +379,7 @@ build_mechSet(void) count++; mList = mList->next; } + g_mechSet.count = count; } #if 0 @@ -452,7 +457,7 @@ gssint_mech_to_oid(const char *mechStr, gss_OID* oid) /* no lock required - only looking at fields that are not updated */ while (aMech != NULL) { - if ((aMech->mechNameStr) && + if ((aMech->mechNameStr) && (!aMech->is_interposer) && strcmp(aMech->mechNameStr, mechStr) == 0) { *oid = aMech->mech_type; return (GSS_S_COMPLETE); @@ -519,7 +524,7 @@ gssint_get_mechanisms(char *mechArray[], int arrayLen) /* no lock required - only looking at fields that are not updated */ for (i = 1; i < arrayLen; i++) { - if (aMech != NULL) { + if (aMech != NULL && !aMech->is_interposer) { *mechArray = aMech->mechNameStr; mechArray++; aMech = aMech->next; |
