int *more)
{
OM_uint32 major, tmpMinor;
+ gss_buffer_desc prefix, suffix;
+ enum gss_eap_attribute_type type;
if (name == GSS_C_NO_NAME) {
*minor = EINVAL;
return GSS_S_CALL_INACCESSIBLE_READ | GSS_S_BAD_NAME;
}
+ *authenticated = 0;
+ *complete = 0;
+ value->length = 0;
+ value->value = NULL;
+ display_value->length = 0;
+ display_value->value = NULL;
+ *more = -1;
+
GSSEAP_MUTEX_LOCK(&name->mutex);
+ major = decomposeAttributeName(minor, attr, &prefix, &suffix);
+ if (GSS_ERROR(major))
+ goto cleanup;
+
+ type = gssEapAttributePrefixToType(&prefix);
+ switch (type) {
+ case ATTR_TYPE_SAML_AAA_ASSERTION:
+ major = samlExportAssertion(minor, name->assertion, value);
+ break;
+ case ATTR_TYPE_SAML_ATTR:
+ major = samlGetAttribute(minor, name->assertion, &suffix,
+ authenticated, complete,
+ value, display_value, more);
+ break;
+ case ATTR_TYPE_RADIUS_AVP:
+ major = radiusGetAVP(minor, name->avps, &suffix,
+ authenticated, complete,
+ value, display_value, more);
+ break;
+ default:
+ *minor = ENOENT;
+ major = GSS_S_UNAVAILABLE;
+ break;
+ }
+
cleanup:
GSSEAP_MUTEX_UNLOCK(&name->mutex);
gss_buffer_t attr,
gss_buffer_t value)
{
- GSSEAP_NOT_IMPLEMENTED;
-}
+ OM_uint32 major, tmpMinor;
+ gss_buffer_desc prefix, suffix;
+ enum gss_eap_attribute_type type;
+
+ if (name == GSS_C_NO_NAME) {
+ *minor = EINVAL;
+ return GSS_S_CALL_INACCESSIBLE_READ | GSS_S_BAD_NAME;
+ }
+
+ GSSEAP_MUTEX_LOCK(&name->mutex);
+
+ major = decomposeAttributeName(minor, attr, &prefix, &suffix);
+ if (GSS_ERROR(major))
+ goto cleanup;
+
+ type = gssEapAttributePrefixToType(&prefix);
+ switch (type) {
+ case ATTR_TYPE_SAML_ATTR:
+ major = samlSetAttribute(minor, name->assertion,
+ complete, &suffix, value);
+ break;
+ case ATTR_TYPE_RADIUS_AVP:
+ major = radiusSetAVP(minor, name->avps,
+ complete, &suffix, value);
+ break;
+ default:
+ *minor = ENOENT;
+ major = GSS_S_UNAVAILABLE;
+ break;
+ }
+
+cleanup:
+ GSSEAP_MUTEX_UNLOCK(&name->mutex);
+
+ return major;
+}
{
GSSEAP_FREE(avps);
}
+
+OM_uint32
+radiusGetAVP(OM_uint32 *minor,
+ struct eap_gss_avp_list *avps,
+ gss_buffer_t attr,
+ int *authenticated,
+ int *complete,
+ gss_buffer_t value,
+ gss_buffer_t display_value,
+ int *more)
+{
+ GSSEAP_NOT_IMPLEMENTED;
+}
+
+OM_uint32
+radiusSetAVP(OM_uint32 *minor,
+ struct eap_gss_avp_list *avps,
+ int complete,
+ gss_buffer_t attr,
+ gss_buffer_t value)
+{
+ GSSEAP_NOT_IMPLEMENTED;
+}
radiusFreeAVPs(OM_uint32 *minor,
struct eap_gss_avp_list *in);
+OM_uint32
+radiusGetAVP(OM_uint32 *minor,
+ struct eap_gss_avp_list *avps,
+ gss_buffer_t attr,
+ int *authenticated,
+ int *complete,
+ gss_buffer_t value,
+ gss_buffer_t display_value,
+ int *more);
+
+OM_uint32
+radiusSetAVP(OM_uint32 *minor,
+ struct eap_gss_avp_list *avps,
+ int complete,
+ gss_buffer_t attr,
+ gss_buffer_t value);
+
#endif /* _UTIL_RADIUS_H_ */
{
GSSEAP_NOT_IMPLEMENTED;
}
+
+OM_uint32
+samlExportAssertion(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ gss_buffer_t buffer)
+{
+ GSSEAP_NOT_IMPLEMENTED;
+}
+
+OM_uint32
+samlGetAttribute(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ gss_buffer_t attr,
+ int *authenticated,
+ int *complete,
+ gss_buffer_t value,
+ gss_buffer_t display_value,
+ int *more)
+{
+ GSSEAP_NOT_IMPLEMENTED;
+}
+
+OM_uint32
+samlSetAttribute(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ int complete,
+ gss_buffer_t attr,
+ gss_buffer_t value)
+{
+ GSSEAP_NOT_IMPLEMENTED;
+}
struct eap_gss_saml_assertion **out);
OM_uint32
+samlExportAssertion(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ gss_buffer_t buffer);
+
+OM_uint32
samlFreeAssertion(OM_uint32 *minor,
struct eap_gss_saml_assertion *assertion);
+OM_uint32
+samlGetAttribute(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ gss_buffer_t attr,
+ int *authenticated,
+ int *complete,
+ gss_buffer_t value,
+ gss_buffer_t display_value,
+ int *more);
+
+OM_uint32
+samlSetAttribute(OM_uint32 *minor,
+ struct eap_gss_saml_assertion *assertion,
+ int complete,
+ gss_buffer_t attr,
+ gss_buffer_t value);
+
#endif /* _UTIL_SAML_H_ */