#define AUTH_RETURN \
{ \
- if (on(UNIX_LIKE_AUTH, ctrl)) { \
+ if (on(UNIX_LIKE_AUTH, ctrl) && ret_data) { \
D(("recording return code for next time [%d]", \
retval)); \
+ *ret_data = retval; \
pam_set_data(pamh, "unix_setcred_return", \
- (void *) &retval, NULL); \
+ (void *) ret_data, NULL); \
} \
D(("done. [%s]", pam_strerror(pamh, retval))); \
return retval; \
,int argc, const char **argv)
{
unsigned int ctrl;
- int retval;
+ int retval, *ret_data = NULL;
const char *name, *p;
D(("called."));
ctrl = _set_ctrl(flags, NULL, argc, argv);
+ /* Get a few bytes so we can pass our return value to
+ pam_sm_setcred(). */
+ ret_data = malloc(sizeof(int));
+
/* get the user'name' */
retval = pam_get_user(pamh, &name, "login: ");
retval = PAM_SUCCESS;
if (on(UNIX_LIKE_AUTH, ctrl)) {
- int *pretval = &retval;
+ int *pretval = NULL;
D(("recovering return code from auth call"));
pam_get_data(pamh, "unix_setcred_return", (const void **) &pretval);
pam_set_data(pamh, "unix_setcred_return", NULL, NULL);
- D(("recovered data indicates that old retval was %d", retval));
+ if(pretval) {
+ retval = *pretval;
+ free(pretval);
+ D(("recovered data indicates that old retval was %d", retval));
+ }
}
return retval;
}