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 * $Id: t_openpam_dispatch.c 922 2017-02-19 19:28:30Z des $ 30*f3b0ac34SDag-Erling Smørgrav */ 31*f3b0ac34SDag-Erling Smørgrav 32*f3b0ac34SDag-Erling Smørgrav #ifdef HAVE_CONFIG_H 33*f3b0ac34SDag-Erling Smørgrav # include "config.h" 34*f3b0ac34SDag-Erling Smørgrav #endif 35*f3b0ac34SDag-Erling Smørgrav 36*f3b0ac34SDag-Erling Smørgrav #include <err.h> 37*f3b0ac34SDag-Erling Smørgrav #include <stdint.h> 38*f3b0ac34SDag-Erling Smørgrav #include <stdio.h> 39*f3b0ac34SDag-Erling Smørgrav #include <stdlib.h> 40*f3b0ac34SDag-Erling Smørgrav #include <string.h> 41*f3b0ac34SDag-Erling Smørgrav #include <unistd.h> 42*f3b0ac34SDag-Erling Smørgrav 43*f3b0ac34SDag-Erling Smørgrav #include <cryb/test.h> 44*f3b0ac34SDag-Erling Smørgrav 45*f3b0ac34SDag-Erling Smørgrav #include <security/pam_appl.h> 46*f3b0ac34SDag-Erling Smørgrav #include <security/openpam.h> 47*f3b0ac34SDag-Erling Smørgrav 48*f3b0ac34SDag-Erling Smørgrav #include "openpam_impl.h" 49*f3b0ac34SDag-Erling Smørgrav #include "t_pam_conv.h" 50*f3b0ac34SDag-Erling Smørgrav 51*f3b0ac34SDag-Erling Smørgrav #define T_FUNC(n, d) \ 52*f3b0ac34SDag-Erling Smørgrav static const char *t_ ## n ## _desc = d; \ 53*f3b0ac34SDag-Erling Smørgrav static int t_ ## n ## _func(OPENPAM_UNUSED(char **desc), \ 54*f3b0ac34SDag-Erling Smørgrav OPENPAM_UNUSED(void *arg)) 55*f3b0ac34SDag-Erling Smørgrav 56*f3b0ac34SDag-Erling Smørgrav #define T(n) \ 57*f3b0ac34SDag-Erling Smørgrav t_add_test(&t_ ## n ## _func, NULL, t_ ## n ## _desc) 58*f3b0ac34SDag-Erling Smørgrav 59*f3b0ac34SDag-Erling Smørgrav const char *pam_return_so; 60*f3b0ac34SDag-Erling Smørgrav 61*f3b0ac34SDag-Erling Smørgrav T_FUNC(empty_policy, "empty policy") 62*f3b0ac34SDag-Erling Smørgrav { 63*f3b0ac34SDag-Erling Smørgrav struct t_pam_conv_script script; 64*f3b0ac34SDag-Erling Smørgrav struct pam_conv pamc; 65*f3b0ac34SDag-Erling Smørgrav struct t_file *tf; 66*f3b0ac34SDag-Erling Smørgrav pam_handle_t *pamh; 67*f3b0ac34SDag-Erling Smørgrav int pam_err, ret; 68*f3b0ac34SDag-Erling Smørgrav 69*f3b0ac34SDag-Erling Smørgrav memset(&script, 0, sizeof script); 70*f3b0ac34SDag-Erling Smørgrav pamc.conv = &t_pam_conv; 71*f3b0ac34SDag-Erling Smørgrav pamc.appdata_ptr = &script; 72*f3b0ac34SDag-Erling Smørgrav tf = t_fopen(NULL); 73*f3b0ac34SDag-Erling Smørgrav t_fprintf(tf, "# empty policy\n"); 74*f3b0ac34SDag-Erling Smørgrav pam_err = pam_start(tf->name, "test", &pamc, &pamh); 75*f3b0ac34SDag-Erling Smørgrav if (pam_err != PAM_SUCCESS) { 76*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_start() returned %d\n", pam_err); 77*f3b0ac34SDag-Erling Smørgrav return (0); 78*f3b0ac34SDag-Erling Smørgrav } 79*f3b0ac34SDag-Erling Smørgrav /* 80*f3b0ac34SDag-Erling Smørgrav * Note: openpam_dispatch() currently returns PAM_SYSTEM_ERR when 81*f3b0ac34SDag-Erling Smørgrav * the chain is empty, it should possibly return PAM_SERVICE_ERR 82*f3b0ac34SDag-Erling Smørgrav * instead. 83*f3b0ac34SDag-Erling Smørgrav */ 84*f3b0ac34SDag-Erling Smørgrav pam_err = pam_authenticate(pamh, 0); 85*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_authenticate() returned %d\n", pam_err); 86*f3b0ac34SDag-Erling Smørgrav ret = (pam_err == PAM_SYSTEM_ERR); 87*f3b0ac34SDag-Erling Smørgrav pam_err = pam_setcred(pamh, 0); 88*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_setcred() returned %d\n", pam_err); 89*f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 90*f3b0ac34SDag-Erling Smørgrav pam_err = pam_acct_mgmt(pamh, 0); 91*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_acct_mgmt() returned %d\n", pam_err); 92*f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 93*f3b0ac34SDag-Erling Smørgrav pam_err = pam_chauthtok(pamh, 0); 94*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_chauthtok() returned %d\n", pam_err); 95*f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 96*f3b0ac34SDag-Erling Smørgrav pam_err = pam_open_session(pamh, 0); 97*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_open_session() returned %d\n", pam_err); 98*f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 99*f3b0ac34SDag-Erling Smørgrav pam_err = pam_close_session(pamh, 0); 100*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_close_session() returned %d\n", pam_err); 101*f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 102*f3b0ac34SDag-Erling Smørgrav pam_end(pamh, pam_err); 103*f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 104*f3b0ac34SDag-Erling Smørgrav return (ret); 105*f3b0ac34SDag-Erling Smørgrav } 106*f3b0ac34SDag-Erling Smørgrav 107*f3b0ac34SDag-Erling Smørgrav static struct t_pam_return_case { 108*f3b0ac34SDag-Erling Smørgrav int facility; 109*f3b0ac34SDag-Erling Smørgrav int primitive; 110*f3b0ac34SDag-Erling Smørgrav int flags; 111*f3b0ac34SDag-Erling Smørgrav struct { 112*f3b0ac34SDag-Erling Smørgrav int ctlflag; 113*f3b0ac34SDag-Erling Smørgrav int modret; 114*f3b0ac34SDag-Erling Smørgrav } mod[2]; 115*f3b0ac34SDag-Erling Smørgrav int result; 116*f3b0ac34SDag-Erling Smørgrav } t_pam_return_cases[] = { 117*f3b0ac34SDag-Erling Smørgrav { 118*f3b0ac34SDag-Erling Smørgrav PAM_AUTH, PAM_SM_AUTHENTICATE, 0, 119*f3b0ac34SDag-Erling Smørgrav { 120*f3b0ac34SDag-Erling Smørgrav { PAM_REQUIRED, PAM_SUCCESS }, 121*f3b0ac34SDag-Erling Smørgrav { PAM_REQUIRED, PAM_SUCCESS }, 122*f3b0ac34SDag-Erling Smørgrav }, 123*f3b0ac34SDag-Erling Smørgrav PAM_SUCCESS, 124*f3b0ac34SDag-Erling Smørgrav }, 125*f3b0ac34SDag-Erling Smørgrav }; 126*f3b0ac34SDag-Erling Smørgrav 127*f3b0ac34SDag-Erling Smørgrav T_FUNC(mod_return, "module return value") 128*f3b0ac34SDag-Erling Smørgrav { 129*f3b0ac34SDag-Erling Smørgrav struct t_pam_return_case *tc; 130*f3b0ac34SDag-Erling Smørgrav struct t_pam_conv_script script; 131*f3b0ac34SDag-Erling Smørgrav struct pam_conv pamc; 132*f3b0ac34SDag-Erling Smørgrav struct t_file *tf; 133*f3b0ac34SDag-Erling Smørgrav pam_handle_t *pamh; 134*f3b0ac34SDag-Erling Smørgrav unsigned int i, j, n; 135*f3b0ac34SDag-Erling Smørgrav int pam_err; 136*f3b0ac34SDag-Erling Smørgrav 137*f3b0ac34SDag-Erling Smørgrav memset(&script, 0, sizeof script); 138*f3b0ac34SDag-Erling Smørgrav pamc.conv = &t_pam_conv; 139*f3b0ac34SDag-Erling Smørgrav pamc.appdata_ptr = &script; 140*f3b0ac34SDag-Erling Smørgrav n = sizeof t_pam_return_cases / sizeof t_pam_return_cases[0]; 141*f3b0ac34SDag-Erling Smørgrav for (i = 0; i < n; ++i) { 142*f3b0ac34SDag-Erling Smørgrav tc = &t_pam_return_cases[i]; 143*f3b0ac34SDag-Erling Smørgrav tf = t_fopen(NULL); 144*f3b0ac34SDag-Erling Smørgrav for (j = 0; j < 2; ++j) { 145*f3b0ac34SDag-Erling Smørgrav t_fprintf(tf, "%s %s %s error=%s\n", 146*f3b0ac34SDag-Erling Smørgrav pam_facility_name[tc->facility], 147*f3b0ac34SDag-Erling Smørgrav pam_control_flag_name[tc->mod[j].ctlflag], 148*f3b0ac34SDag-Erling Smørgrav pam_return_so, 149*f3b0ac34SDag-Erling Smørgrav pam_err_name[tc->mod[j].modret]); 150*f3b0ac34SDag-Erling Smørgrav } 151*f3b0ac34SDag-Erling Smørgrav pam_err = pam_start(tf->name, "test", &pamc, &pamh); 152*f3b0ac34SDag-Erling Smørgrav if (pam_err != PAM_SUCCESS) { 153*f3b0ac34SDag-Erling Smørgrav t_verbose("pam_start() returned %d\n", pam_err); 154*f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 155*f3b0ac34SDag-Erling Smørgrav continue; 156*f3b0ac34SDag-Erling Smørgrav } 157*f3b0ac34SDag-Erling Smørgrav switch (tc->primitive) { 158*f3b0ac34SDag-Erling Smørgrav case PAM_SM_AUTHENTICATE: 159*f3b0ac34SDag-Erling Smørgrav pam_err = pam_authenticate(pamh, tc->flags); 160*f3b0ac34SDag-Erling Smørgrav break; 161*f3b0ac34SDag-Erling Smørgrav case PAM_SM_SETCRED: 162*f3b0ac34SDag-Erling Smørgrav pam_err = pam_setcred(pamh, tc->flags); 163*f3b0ac34SDag-Erling Smørgrav break; 164*f3b0ac34SDag-Erling Smørgrav case PAM_SM_ACCT_MGMT: 165*f3b0ac34SDag-Erling Smørgrav pam_err = pam_acct_mgmt(pamh, tc->flags); 166*f3b0ac34SDag-Erling Smørgrav break; 167*f3b0ac34SDag-Erling Smørgrav case PAM_SM_OPEN_SESSION: 168*f3b0ac34SDag-Erling Smørgrav pam_err = pam_open_session(pamh, tc->flags); 169*f3b0ac34SDag-Erling Smørgrav break; 170*f3b0ac34SDag-Erling Smørgrav case PAM_SM_CLOSE_SESSION: 171*f3b0ac34SDag-Erling Smørgrav pam_err = pam_close_session(pamh, tc->flags); 172*f3b0ac34SDag-Erling Smørgrav break; 173*f3b0ac34SDag-Erling Smørgrav case PAM_SM_CHAUTHTOK: 174*f3b0ac34SDag-Erling Smørgrav pam_err = pam_chauthtok(pamh, tc->flags); 175*f3b0ac34SDag-Erling Smørgrav break; 176*f3b0ac34SDag-Erling Smørgrav } 177*f3b0ac34SDag-Erling Smørgrav t_verbose("%s returned %d\n", 178*f3b0ac34SDag-Erling Smørgrav pam_func_name[tc->primitive], pam_err); 179*f3b0ac34SDag-Erling Smørgrav pam_end(pamh, pam_err); 180*f3b0ac34SDag-Erling Smørgrav t_verbose("here\n"); 181*f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 182*f3b0ac34SDag-Erling Smørgrav } 183*f3b0ac34SDag-Erling Smørgrav return (1); 184*f3b0ac34SDag-Erling Smørgrav } 185*f3b0ac34SDag-Erling Smørgrav 186*f3b0ac34SDag-Erling Smørgrav 187*f3b0ac34SDag-Erling Smørgrav /*************************************************************************** 188*f3b0ac34SDag-Erling Smørgrav * Boilerplate 189*f3b0ac34SDag-Erling Smørgrav */ 190*f3b0ac34SDag-Erling Smørgrav 191*f3b0ac34SDag-Erling Smørgrav static int 192*f3b0ac34SDag-Erling Smørgrav t_prepare(int argc, char *argv[]) 193*f3b0ac34SDag-Erling Smørgrav { 194*f3b0ac34SDag-Erling Smørgrav 195*f3b0ac34SDag-Erling Smørgrav (void)argc; 196*f3b0ac34SDag-Erling Smørgrav (void)argv; 197*f3b0ac34SDag-Erling Smørgrav 198*f3b0ac34SDag-Erling Smørgrav if ((pam_return_so = getenv("PAM_RETURN_SO")) == NULL) { 199*f3b0ac34SDag-Erling Smørgrav t_verbose("define PAM_RETURN_SO before running these tests\n"); 200*f3b0ac34SDag-Erling Smørgrav return (0); 201*f3b0ac34SDag-Erling Smørgrav } 202*f3b0ac34SDag-Erling Smørgrav 203*f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_RESTRICT_MODULE_NAME, 0); 204*f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_VERIFY_MODULE_FILE, 0); 205*f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_RESTRICT_SERVICE_NAME, 0); 206*f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_VERIFY_POLICY_FILE, 0); 207*f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_FALLBACK_TO_OTHER, 0); 208*f3b0ac34SDag-Erling Smørgrav 209*f3b0ac34SDag-Erling Smørgrav T(empty_policy); 210*f3b0ac34SDag-Erling Smørgrav T(mod_return); 211*f3b0ac34SDag-Erling Smørgrav 212*f3b0ac34SDag-Erling Smørgrav return (0); 213*f3b0ac34SDag-Erling Smørgrav } 214*f3b0ac34SDag-Erling Smørgrav 215*f3b0ac34SDag-Erling Smørgrav int 216*f3b0ac34SDag-Erling Smørgrav main(int argc, char *argv[]) 217*f3b0ac34SDag-Erling Smørgrav { 218*f3b0ac34SDag-Erling Smørgrav 219*f3b0ac34SDag-Erling Smørgrav t_main(t_prepare, NULL, argc, argv); 220*f3b0ac34SDag-Erling Smørgrav } 221