10 #include "pam_private.h"
19 const char *service_name,
21 const struct pam_conv *pam_conversation,
24 D(("called pam_start: [%s] [%s] [%p] [%p]"
25 ,service_name, user, pam_conversation, pamh));
28 _pam_system_log(LOG_CRIT, "pam_start: invalid argument: pamh == NULL");
32 if ((*pamh = calloc(1, sizeof(**pamh))) == NULL) {
33 _pam_system_log(LOG_CRIT, "pam_start: calloc failed for *pamh");
37 /* All service names should be files below /etc/pam.d and nothing
38 else. Forbid paths. */
39 if (strrchr(service_name, '/') != NULL)
40 service_name = strrchr(service_name, '/') + 1;
42 /* Mark the caller as the application - permission to do certain
43 things is limited to a module or an application */
50 if (((*pamh)->service_name = _pam_strdup(service_name)) == NULL) {
51 _pam_system_log(LOG_CRIT,
52 "pam_start: _pam_strdup failed for service name");
56 for (tmp=(*pamh)->service_name; *tmp; ++tmp)
57 *tmp = tolower(*tmp); /* require lower case */
59 (*pamh)->service_name = NULL;
62 if (((*pamh)->user = _pam_strdup(user)) == NULL) {
63 _pam_system_log(LOG_CRIT,
64 "pam_start: _pam_strdup failed for user");
65 _pam_drop((*pamh)->service_name);
73 (*pamh)->prompt = NULL; /* prompt for pam_get_user() */
74 (*pamh)->ruser = NULL;
75 (*pamh)->rhost = NULL;
76 (*pamh)->authtok = NULL;
77 (*pamh)->oldauthtok = NULL;
78 (*pamh)->fail_delay.delay_fn_ptr = NULL;
79 (*pamh)->former.choice = PAM_NOT_STACKED;
81 if (pam_conversation == NULL
82 || ((*pamh)->pam_conversation = (struct pam_conv *)
83 malloc(sizeof(struct pam_conv))) == NULL) {
84 _pam_system_log(LOG_CRIT, "pam_start: malloc failed for pam_conv");
85 _pam_drop((*pamh)->service_name);
86 _pam_drop((*pamh)->user);
90 memcpy((*pamh)->pam_conversation, pam_conversation,
91 sizeof(struct pam_conv));
95 if ( _pam_make_env(*pamh) != PAM_SUCCESS ) {
96 _pam_system_log(LOG_ERR,"pam_start: failed to initialize environment");
97 _pam_drop((*pamh)->service_name);
98 _pam_drop((*pamh)->user);
103 _pam_reset_timer(*pamh); /* initialize timer support */
105 _pam_start_handlers(*pamh); /* cannot fail */
107 /* According to the SunOS man pages, loading modules and resolving
108 * symbols happens on the first call from the application. */
110 if ( _pam_init_handlers(*pamh) != PAM_SUCCESS ) {
111 _pam_system_log(LOG_ERR, "pam_start: failed to initialize handlers");
112 _pam_drop_env(*pamh); /* purge the environment */
113 _pam_drop((*pamh)->service_name);
114 _pam_drop((*pamh)->user);
119 D(("exiting pam_start successfully"));