1*f3b0ac34SDag-Erling Smørgrav /*-
2*f3b0ac34SDag-Erling Smørgrav * Copyright (c) 2015 Dag-Erling Smørgrav
3*f3b0ac34SDag-Erling Smørgrav * All rights reserved.
4*f3b0ac34SDag-Erling Smørgrav *
5*f3b0ac34SDag-Erling Smørgrav * Redistribution and use in source and binary forms, with or without
6*f3b0ac34SDag-Erling Smørgrav * modification, are permitted provided that the following conditions
7*f3b0ac34SDag-Erling Smørgrav * are met:
8*f3b0ac34SDag-Erling Smørgrav * 1. Redistributions of source code must retain the above copyright
9*f3b0ac34SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer.
10*f3b0ac34SDag-Erling Smørgrav * 2. Redistributions in binary form must reproduce the above copyright
11*f3b0ac34SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer in the
12*f3b0ac34SDag-Erling Smørgrav * documentation and/or other materials provided with the distribution.
13*f3b0ac34SDag-Erling Smørgrav * 3. The name of the author may not be used to endorse or promote
14*f3b0ac34SDag-Erling Smørgrav * products derived from this software without specific prior written
15*f3b0ac34SDag-Erling Smørgrav * permission.
16*f3b0ac34SDag-Erling Smørgrav *
17*f3b0ac34SDag-Erling Smørgrav * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
18*f3b0ac34SDag-Erling Smørgrav * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19*f3b0ac34SDag-Erling Smørgrav * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20*f3b0ac34SDag-Erling Smørgrav * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
21*f3b0ac34SDag-Erling Smørgrav * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22*f3b0ac34SDag-Erling Smørgrav * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23*f3b0ac34SDag-Erling Smørgrav * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24*f3b0ac34SDag-Erling Smørgrav * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25*f3b0ac34SDag-Erling Smørgrav * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26*f3b0ac34SDag-Erling Smørgrav * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27*f3b0ac34SDag-Erling Smørgrav * SUCH DAMAGE.
28*f3b0ac34SDag-Erling Smørgrav */
29*f3b0ac34SDag-Erling Smørgrav
30*f3b0ac34SDag-Erling Smørgrav #ifdef HAVE_CONFIG_H
31*f3b0ac34SDag-Erling Smørgrav # include "config.h"
32*f3b0ac34SDag-Erling Smørgrav #endif
33*f3b0ac34SDag-Erling Smørgrav
34*f3b0ac34SDag-Erling Smørgrav #include <sys/param.h>
35*f3b0ac34SDag-Erling Smørgrav
36*f3b0ac34SDag-Erling Smørgrav #include <limits.h>
37*f3b0ac34SDag-Erling Smørgrav #include <stdlib.h>
38*f3b0ac34SDag-Erling Smørgrav #include <string.h>
39*f3b0ac34SDag-Erling Smørgrav
40*f3b0ac34SDag-Erling Smørgrav #include <security/pam_modules.h>
41*f3b0ac34SDag-Erling Smørgrav #include <security/openpam.h>
42*f3b0ac34SDag-Erling Smørgrav
43*f3b0ac34SDag-Erling Smørgrav #include "openpam_impl.h"
44*f3b0ac34SDag-Erling Smørgrav
45*f3b0ac34SDag-Erling Smørgrav static int
pam_return(pam_handle_t * pamh,int flags,int argc,const char * argv[])46*f3b0ac34SDag-Erling Smørgrav pam_return(pam_handle_t *pamh, int flags,
47*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
48*f3b0ac34SDag-Erling Smørgrav {
49*f3b0ac34SDag-Erling Smørgrav const char *errname;
50*f3b0ac34SDag-Erling Smørgrav char *e;
51*f3b0ac34SDag-Erling Smørgrav long errcode;
52*f3b0ac34SDag-Erling Smørgrav
53*f3b0ac34SDag-Erling Smørgrav (void)flags;
54*f3b0ac34SDag-Erling Smørgrav (void)argc;
55*f3b0ac34SDag-Erling Smørgrav (void)argv;
56*f3b0ac34SDag-Erling Smørgrav if ((errname = openpam_get_option(pamh, "error")) == NULL ||
57*f3b0ac34SDag-Erling Smørgrav errname[0] == '\0') {
58*f3b0ac34SDag-Erling Smørgrav openpam_log(PAM_LOG_ERROR, "missing error parameter");
59*f3b0ac34SDag-Erling Smørgrav return (PAM_SYSTEM_ERR);
60*f3b0ac34SDag-Erling Smørgrav }
61*f3b0ac34SDag-Erling Smørgrav /* is it a number? */
62*f3b0ac34SDag-Erling Smørgrav errcode = strtol(errname, &e, 10);
63*f3b0ac34SDag-Erling Smørgrav if (e != NULL && *e == '\0') {
64*f3b0ac34SDag-Erling Smørgrav /* yep, check range */
65*f3b0ac34SDag-Erling Smørgrav if (errcode >= INT_MIN && errcode <= INT_MAX)
66*f3b0ac34SDag-Erling Smørgrav return (errcode);
67*f3b0ac34SDag-Erling Smørgrav } else {
68*f3b0ac34SDag-Erling Smørgrav /* nope, look it up */
69*f3b0ac34SDag-Erling Smørgrav for (errcode = 0; errcode < PAM_NUM_ERRORS; ++errcode)
70*f3b0ac34SDag-Erling Smørgrav if (strcmp(errname, pam_err_name[errcode]) == 0)
71*f3b0ac34SDag-Erling Smørgrav return (errcode);
72*f3b0ac34SDag-Erling Smørgrav }
73*f3b0ac34SDag-Erling Smørgrav openpam_log(PAM_LOG_ERROR, "invalid error code '%s'", errname);
74*f3b0ac34SDag-Erling Smørgrav return (PAM_SYSTEM_ERR);
75*f3b0ac34SDag-Erling Smørgrav }
76*f3b0ac34SDag-Erling Smørgrav
77*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_authenticate(pam_handle_t * pamh,int flags,int argc,const char * argv[])78*f3b0ac34SDag-Erling Smørgrav pam_sm_authenticate(pam_handle_t *pamh, int flags,
79*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
80*f3b0ac34SDag-Erling Smørgrav {
81*f3b0ac34SDag-Erling Smørgrav
82*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
83*f3b0ac34SDag-Erling Smørgrav }
84*f3b0ac34SDag-Erling Smørgrav
85*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_setcred(pam_handle_t * pamh,int flags,int argc,const char * argv[])86*f3b0ac34SDag-Erling Smørgrav pam_sm_setcred(pam_handle_t *pamh, int flags,
87*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
88*f3b0ac34SDag-Erling Smørgrav {
89*f3b0ac34SDag-Erling Smørgrav
90*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
91*f3b0ac34SDag-Erling Smørgrav }
92*f3b0ac34SDag-Erling Smørgrav
93*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_acct_mgmt(pam_handle_t * pamh,int flags,int argc,const char * argv[])94*f3b0ac34SDag-Erling Smørgrav pam_sm_acct_mgmt(pam_handle_t *pamh, int flags,
95*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
96*f3b0ac34SDag-Erling Smørgrav {
97*f3b0ac34SDag-Erling Smørgrav
98*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
99*f3b0ac34SDag-Erling Smørgrav }
100*f3b0ac34SDag-Erling Smørgrav
101*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_open_session(pam_handle_t * pamh,int flags,int argc,const char * argv[])102*f3b0ac34SDag-Erling Smørgrav pam_sm_open_session(pam_handle_t *pamh, int flags,
103*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
104*f3b0ac34SDag-Erling Smørgrav {
105*f3b0ac34SDag-Erling Smørgrav
106*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
107*f3b0ac34SDag-Erling Smørgrav }
108*f3b0ac34SDag-Erling Smørgrav
109*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_close_session(pam_handle_t * pamh,int flags,int argc,const char * argv[])110*f3b0ac34SDag-Erling Smørgrav pam_sm_close_session(pam_handle_t *pamh, int flags,
111*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
112*f3b0ac34SDag-Erling Smørgrav {
113*f3b0ac34SDag-Erling Smørgrav
114*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
115*f3b0ac34SDag-Erling Smørgrav }
116*f3b0ac34SDag-Erling Smørgrav
117*f3b0ac34SDag-Erling Smørgrav PAM_EXTERN int
pam_sm_chauthtok(pam_handle_t * pamh,int flags,int argc,const char * argv[])118*f3b0ac34SDag-Erling Smørgrav pam_sm_chauthtok(pam_handle_t *pamh, int flags,
119*f3b0ac34SDag-Erling Smørgrav int argc, const char *argv[])
120*f3b0ac34SDag-Erling Smørgrav {
121*f3b0ac34SDag-Erling Smørgrav
122*f3b0ac34SDag-Erling Smørgrav return (pam_return(pamh, flags, argc, argv));
123*f3b0ac34SDag-Erling Smørgrav }
124*f3b0ac34SDag-Erling Smørgrav
125*f3b0ac34SDag-Erling Smørgrav PAM_MODULE_ENTRY("pam_return");
126