#include "gssapiP_eap.h"
-static int
-eapPeerRegisterMethods(void)
+static OM_uint32
+eapPeerRegisterMethods(OM_uint32 *minor)
{
- int ret = 0;
+ OM_uint32 ret = 0;
#ifdef EAP_MD5
if (ret == 0)
ret = eap_peer_tnc_register();
#endif /* EAP_TNC */
- return ret;
+ return ret ? GSS_S_FAILURE : GSS_S_COMPLETE;
}
-static int
-eapServerRegisterMethods(void)
+static OM_uint32
+eapServerRegisterMethods(OM_uint32 *minor)
{
- int ret = 0;
+ OM_uint32 ret = 0;
#ifdef EAP_SERVER_IDENTITY
if (ret == 0)
if (ret == 0)
ret = eap_server_tnc_register();
#endif /* EAP_SERVER_TNC */
+
+ return ret ? GSS_S_FAILURE : GSS_S_COMPLETE;
}
-static int
-gssEapInitLibEap(void)
+static OM_uint32
+gssEapInitLibEap(OM_uint32 *minor)
{
- return eapPeerRegisterMethods();
+ return eapPeerRegisterMethods(minor);
}
-static int
-gssEapInitLibRadSec(void)
+static OM_uint32
+gssEapInitLibRadius(OM_uint32 *minor)
{
- return 0;
+ return GSS_S_COMPLETE;
}
static void gssEapInit(void) __attribute__((constructor));
static void
gssEapInit(void)
{
- int ret;
+ OM_uint32 major, minor;
- ret = gssEapInitLibEap();
- if (ret == 0)
-#if 0
- ret = gssEapInitLibRadSec();
-#else
- ret = eapServerRegisterMethods();
+ major = gssEapInitLibEap(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+ major = gssEapInitLibRadius(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+ major = eapServerRegisterMethods(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+ major = gssEapRadiusAttrProviderInit(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+ major = gssEapSamlAttrProvidersInit(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+ major = gssEapLocalAttrProviderInit(&minor);
+ assert(major == GSS_S_COMPLETE);
+
+#ifdef GSSEAP_ENABLE_REAUTH
+ major = gssEapReauthInitialize(&minor);
+ assert(major == GSS_S_COMPLETE);
#endif
}
static void
gssEapFinalize(void)
{
+ OM_uint32 minor;
+
+ gssEapLocalAttrProviderFinalize(&minor);
+ gssEapSamlAttrProvidersFinalize(&minor);
+ gssEapRadiusAttrProviderFinalize(&minor);
+
eap_peer_unregister_methods();
-#if 1
eap_server_unregister_methods();
-#endif
}