1f3b0ac34SDag-Erling Smørgrav /*- 2*49e56509SDag-Erling Smørgrav * Copyright (c) 2015-2017 Dag-Erling Smørgrav 3f3b0ac34SDag-Erling Smørgrav * All rights reserved. 4f3b0ac34SDag-Erling Smørgrav * 5f3b0ac34SDag-Erling Smørgrav * Redistribution and use in source and binary forms, with or without 6f3b0ac34SDag-Erling Smørgrav * modification, are permitted provided that the following conditions 7f3b0ac34SDag-Erling Smørgrav * are met: 8f3b0ac34SDag-Erling Smørgrav * 1. Redistributions of source code must retain the above copyright 9f3b0ac34SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer. 10f3b0ac34SDag-Erling Smørgrav * 2. Redistributions in binary form must reproduce the above copyright 11f3b0ac34SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer in the 12f3b0ac34SDag-Erling Smørgrav * documentation and/or other materials provided with the distribution. 13f3b0ac34SDag-Erling Smørgrav * 3. The name of the author may not be used to endorse or promote 14f3b0ac34SDag-Erling Smørgrav * products derived from this software without specific prior written 15f3b0ac34SDag-Erling Smørgrav * permission. 16f3b0ac34SDag-Erling Smørgrav * 17f3b0ac34SDag-Erling Smørgrav * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 18f3b0ac34SDag-Erling Smørgrav * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 19f3b0ac34SDag-Erling Smørgrav * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 20f3b0ac34SDag-Erling Smørgrav * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 21f3b0ac34SDag-Erling Smørgrav * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 22f3b0ac34SDag-Erling Smørgrav * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 23f3b0ac34SDag-Erling Smørgrav * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 24f3b0ac34SDag-Erling Smørgrav * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 25f3b0ac34SDag-Erling Smørgrav * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 26f3b0ac34SDag-Erling Smørgrav * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 27f3b0ac34SDag-Erling Smørgrav * SUCH DAMAGE. 28f3b0ac34SDag-Erling Smørgrav * 29*49e56509SDag-Erling Smørgrav * $OpenPAM: t_openpam_dispatch.c 938 2017-04-30 21:34:42Z des $ 30f3b0ac34SDag-Erling Smørgrav */ 31f3b0ac34SDag-Erling Smørgrav 32f3b0ac34SDag-Erling Smørgrav #ifdef HAVE_CONFIG_H 33f3b0ac34SDag-Erling Smørgrav # include "config.h" 34f3b0ac34SDag-Erling Smørgrav #endif 35f3b0ac34SDag-Erling Smørgrav 36f3b0ac34SDag-Erling Smørgrav #include <err.h> 37f3b0ac34SDag-Erling Smørgrav #include <stdint.h> 38f3b0ac34SDag-Erling Smørgrav #include <stdio.h> 39f3b0ac34SDag-Erling Smørgrav #include <stdlib.h> 40f3b0ac34SDag-Erling Smørgrav #include <string.h> 41f3b0ac34SDag-Erling Smørgrav #include <unistd.h> 42f3b0ac34SDag-Erling Smørgrav 43f3b0ac34SDag-Erling Smørgrav #include <cryb/test.h> 44f3b0ac34SDag-Erling Smørgrav 45f3b0ac34SDag-Erling Smørgrav #include <security/pam_appl.h> 46f3b0ac34SDag-Erling Smørgrav #include <security/openpam.h> 47f3b0ac34SDag-Erling Smørgrav 48f3b0ac34SDag-Erling Smørgrav #include "openpam_impl.h" 49f3b0ac34SDag-Erling Smørgrav #include "t_pam_conv.h" 50f3b0ac34SDag-Erling Smørgrav 51f3b0ac34SDag-Erling Smørgrav #define T_FUNC(n, d) \ 52f3b0ac34SDag-Erling Smørgrav static const char *t_ ## n ## _desc = d; \ 53f3b0ac34SDag-Erling Smørgrav static int t_ ## n ## _func(OPENPAM_UNUSED(char **desc), \ 54f3b0ac34SDag-Erling Smørgrav OPENPAM_UNUSED(void *arg)) 55f3b0ac34SDag-Erling Smørgrav 56f3b0ac34SDag-Erling Smørgrav #define T(n) \ 57*49e56509SDag-Erling Smørgrav t_add_test(&t_ ## n ## _func, NULL, "%s", t_ ## n ## _desc) 58f3b0ac34SDag-Erling Smørgrav 59f3b0ac34SDag-Erling Smørgrav const char *pam_return_so; 60f3b0ac34SDag-Erling Smørgrav 61f3b0ac34SDag-Erling Smørgrav T_FUNC(empty_policy, "empty policy") 62f3b0ac34SDag-Erling Smørgrav { 63f3b0ac34SDag-Erling Smørgrav struct t_pam_conv_script script; 64f3b0ac34SDag-Erling Smørgrav struct pam_conv pamc; 65f3b0ac34SDag-Erling Smørgrav struct t_file *tf; 66f3b0ac34SDag-Erling Smørgrav pam_handle_t *pamh; 67f3b0ac34SDag-Erling Smørgrav int pam_err, ret; 68f3b0ac34SDag-Erling Smørgrav 69f3b0ac34SDag-Erling Smørgrav memset(&script, 0, sizeof script); 70f3b0ac34SDag-Erling Smørgrav pamc.conv = &t_pam_conv; 71f3b0ac34SDag-Erling Smørgrav pamc.appdata_ptr = &script; 72f3b0ac34SDag-Erling Smørgrav tf = t_fopen(NULL); 73f3b0ac34SDag-Erling Smørgrav t_fprintf(tf, "# empty policy\n"); 74f3b0ac34SDag-Erling Smørgrav pam_err = pam_start(tf->name, "test", &pamc, &pamh); 75f3b0ac34SDag-Erling Smørgrav if (pam_err != PAM_SUCCESS) { 76*49e56509SDag-Erling Smørgrav t_printv("pam_start() returned %d\n", pam_err); 77f3b0ac34SDag-Erling Smørgrav return (0); 78f3b0ac34SDag-Erling Smørgrav } 79f3b0ac34SDag-Erling Smørgrav /* 80f3b0ac34SDag-Erling Smørgrav * Note: openpam_dispatch() currently returns PAM_SYSTEM_ERR when 81f3b0ac34SDag-Erling Smørgrav * the chain is empty, it should possibly return PAM_SERVICE_ERR 82f3b0ac34SDag-Erling Smørgrav * instead. 83f3b0ac34SDag-Erling Smørgrav */ 84f3b0ac34SDag-Erling Smørgrav pam_err = pam_authenticate(pamh, 0); 85*49e56509SDag-Erling Smørgrav t_printv("pam_authenticate() returned %d\n", pam_err); 86f3b0ac34SDag-Erling Smørgrav ret = (pam_err == PAM_SYSTEM_ERR); 87f3b0ac34SDag-Erling Smørgrav pam_err = pam_setcred(pamh, 0); 88*49e56509SDag-Erling Smørgrav t_printv("pam_setcred() returned %d\n", pam_err); 89f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 90f3b0ac34SDag-Erling Smørgrav pam_err = pam_acct_mgmt(pamh, 0); 91*49e56509SDag-Erling Smørgrav t_printv("pam_acct_mgmt() returned %d\n", pam_err); 92f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 93f3b0ac34SDag-Erling Smørgrav pam_err = pam_chauthtok(pamh, 0); 94*49e56509SDag-Erling Smørgrav t_printv("pam_chauthtok() returned %d\n", pam_err); 95f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 96f3b0ac34SDag-Erling Smørgrav pam_err = pam_open_session(pamh, 0); 97*49e56509SDag-Erling Smørgrav t_printv("pam_open_session() returned %d\n", pam_err); 98f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 99f3b0ac34SDag-Erling Smørgrav pam_err = pam_close_session(pamh, 0); 100*49e56509SDag-Erling Smørgrav t_printv("pam_close_session() returned %d\n", pam_err); 101f3b0ac34SDag-Erling Smørgrav ret &= (pam_err == PAM_SYSTEM_ERR); 102f3b0ac34SDag-Erling Smørgrav pam_end(pamh, pam_err); 103f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 104f3b0ac34SDag-Erling Smørgrav return (ret); 105f3b0ac34SDag-Erling Smørgrav } 106f3b0ac34SDag-Erling Smørgrav 107f3b0ac34SDag-Erling Smørgrav static struct t_pam_return_case { 108f3b0ac34SDag-Erling Smørgrav int facility; 109f3b0ac34SDag-Erling Smørgrav int primitive; 110f3b0ac34SDag-Erling Smørgrav int flags; 111f3b0ac34SDag-Erling Smørgrav struct { 112f3b0ac34SDag-Erling Smørgrav int ctlflag; 113f3b0ac34SDag-Erling Smørgrav int modret; 114f3b0ac34SDag-Erling Smørgrav } mod[2]; 115f3b0ac34SDag-Erling Smørgrav int result; 116f3b0ac34SDag-Erling Smørgrav } t_pam_return_cases[] = { 117f3b0ac34SDag-Erling Smørgrav { 118f3b0ac34SDag-Erling Smørgrav PAM_AUTH, PAM_SM_AUTHENTICATE, 0, 119f3b0ac34SDag-Erling Smørgrav { 120f3b0ac34SDag-Erling Smørgrav { PAM_REQUIRED, PAM_SUCCESS }, 121f3b0ac34SDag-Erling Smørgrav { PAM_REQUIRED, PAM_SUCCESS }, 122f3b0ac34SDag-Erling Smørgrav }, 123f3b0ac34SDag-Erling Smørgrav PAM_SUCCESS, 124f3b0ac34SDag-Erling Smørgrav }, 125f3b0ac34SDag-Erling Smørgrav }; 126f3b0ac34SDag-Erling Smørgrav 127f3b0ac34SDag-Erling Smørgrav T_FUNC(mod_return, "module return value") 128f3b0ac34SDag-Erling Smørgrav { 129f3b0ac34SDag-Erling Smørgrav struct t_pam_return_case *tc; 130f3b0ac34SDag-Erling Smørgrav struct t_pam_conv_script script; 131f3b0ac34SDag-Erling Smørgrav struct pam_conv pamc; 132f3b0ac34SDag-Erling Smørgrav struct t_file *tf; 133f3b0ac34SDag-Erling Smørgrav pam_handle_t *pamh; 134f3b0ac34SDag-Erling Smørgrav unsigned int i, j, n; 135f3b0ac34SDag-Erling Smørgrav int pam_err; 136f3b0ac34SDag-Erling Smørgrav 137f3b0ac34SDag-Erling Smørgrav memset(&script, 0, sizeof script); 138f3b0ac34SDag-Erling Smørgrav pamc.conv = &t_pam_conv; 139f3b0ac34SDag-Erling Smørgrav pamc.appdata_ptr = &script; 140f3b0ac34SDag-Erling Smørgrav n = sizeof t_pam_return_cases / sizeof t_pam_return_cases[0]; 141f3b0ac34SDag-Erling Smørgrav for (i = 0; i < n; ++i) { 142f3b0ac34SDag-Erling Smørgrav tc = &t_pam_return_cases[i]; 143f3b0ac34SDag-Erling Smørgrav tf = t_fopen(NULL); 144f3b0ac34SDag-Erling Smørgrav for (j = 0; j < 2; ++j) { 145f3b0ac34SDag-Erling Smørgrav t_fprintf(tf, "%s %s %s error=%s\n", 146f3b0ac34SDag-Erling Smørgrav pam_facility_name[tc->facility], 147f3b0ac34SDag-Erling Smørgrav pam_control_flag_name[tc->mod[j].ctlflag], 148f3b0ac34SDag-Erling Smørgrav pam_return_so, 149f3b0ac34SDag-Erling Smørgrav pam_err_name[tc->mod[j].modret]); 150f3b0ac34SDag-Erling Smørgrav } 151f3b0ac34SDag-Erling Smørgrav pam_err = pam_start(tf->name, "test", &pamc, &pamh); 152f3b0ac34SDag-Erling Smørgrav if (pam_err != PAM_SUCCESS) { 153*49e56509SDag-Erling Smørgrav t_printv("pam_start() returned %d\n", pam_err); 154f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 155f3b0ac34SDag-Erling Smørgrav continue; 156f3b0ac34SDag-Erling Smørgrav } 157f3b0ac34SDag-Erling Smørgrav switch (tc->primitive) { 158f3b0ac34SDag-Erling Smørgrav case PAM_SM_AUTHENTICATE: 159f3b0ac34SDag-Erling Smørgrav pam_err = pam_authenticate(pamh, tc->flags); 160f3b0ac34SDag-Erling Smørgrav break; 161f3b0ac34SDag-Erling Smørgrav case PAM_SM_SETCRED: 162f3b0ac34SDag-Erling Smørgrav pam_err = pam_setcred(pamh, tc->flags); 163f3b0ac34SDag-Erling Smørgrav break; 164f3b0ac34SDag-Erling Smørgrav case PAM_SM_ACCT_MGMT: 165f3b0ac34SDag-Erling Smørgrav pam_err = pam_acct_mgmt(pamh, tc->flags); 166f3b0ac34SDag-Erling Smørgrav break; 167f3b0ac34SDag-Erling Smørgrav case PAM_SM_OPEN_SESSION: 168f3b0ac34SDag-Erling Smørgrav pam_err = pam_open_session(pamh, tc->flags); 169f3b0ac34SDag-Erling Smørgrav break; 170f3b0ac34SDag-Erling Smørgrav case PAM_SM_CLOSE_SESSION: 171f3b0ac34SDag-Erling Smørgrav pam_err = pam_close_session(pamh, tc->flags); 172f3b0ac34SDag-Erling Smørgrav break; 173f3b0ac34SDag-Erling Smørgrav case PAM_SM_CHAUTHTOK: 174f3b0ac34SDag-Erling Smørgrav pam_err = pam_chauthtok(pamh, tc->flags); 175f3b0ac34SDag-Erling Smørgrav break; 176f3b0ac34SDag-Erling Smørgrav } 177*49e56509SDag-Erling Smørgrav t_printv("%s returned %d\n", 178f3b0ac34SDag-Erling Smørgrav pam_func_name[tc->primitive], pam_err); 179f3b0ac34SDag-Erling Smørgrav pam_end(pamh, pam_err); 180*49e56509SDag-Erling Smørgrav t_printv("here\n"); 181f3b0ac34SDag-Erling Smørgrav t_fclose(tf); 182f3b0ac34SDag-Erling Smørgrav } 183f3b0ac34SDag-Erling Smørgrav return (1); 184f3b0ac34SDag-Erling Smørgrav } 185f3b0ac34SDag-Erling Smørgrav 186f3b0ac34SDag-Erling Smørgrav 187f3b0ac34SDag-Erling Smørgrav /*************************************************************************** 188f3b0ac34SDag-Erling Smørgrav * Boilerplate 189f3b0ac34SDag-Erling Smørgrav */ 190f3b0ac34SDag-Erling Smørgrav 191f3b0ac34SDag-Erling Smørgrav static int 192f3b0ac34SDag-Erling Smørgrav t_prepare(int argc, char *argv[]) 193f3b0ac34SDag-Erling Smørgrav { 194f3b0ac34SDag-Erling Smørgrav 195f3b0ac34SDag-Erling Smørgrav (void)argc; 196f3b0ac34SDag-Erling Smørgrav (void)argv; 197f3b0ac34SDag-Erling Smørgrav 198f3b0ac34SDag-Erling Smørgrav if ((pam_return_so = getenv("PAM_RETURN_SO")) == NULL) { 199*49e56509SDag-Erling Smørgrav t_printv("define PAM_RETURN_SO before running these tests\n"); 200f3b0ac34SDag-Erling Smørgrav return (0); 201f3b0ac34SDag-Erling Smørgrav } 202f3b0ac34SDag-Erling Smørgrav 203f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_RESTRICT_MODULE_NAME, 0); 204f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_VERIFY_MODULE_FILE, 0); 205f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_RESTRICT_SERVICE_NAME, 0); 206f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_VERIFY_POLICY_FILE, 0); 207f3b0ac34SDag-Erling Smørgrav openpam_set_feature(OPENPAM_FALLBACK_TO_OTHER, 0); 208f3b0ac34SDag-Erling Smørgrav 209f3b0ac34SDag-Erling Smørgrav T(empty_policy); 210f3b0ac34SDag-Erling Smørgrav T(mod_return); 211f3b0ac34SDag-Erling Smørgrav 212f3b0ac34SDag-Erling Smørgrav return (0); 213f3b0ac34SDag-Erling Smørgrav } 214f3b0ac34SDag-Erling Smørgrav 215f3b0ac34SDag-Erling Smørgrav int 216f3b0ac34SDag-Erling Smørgrav main(int argc, char *argv[]) 217f3b0ac34SDag-Erling Smørgrav { 218f3b0ac34SDag-Erling Smørgrav 219f3b0ac34SDag-Erling Smørgrav t_main(t_prepare, NULL, argc, argv); 220f3b0ac34SDag-Erling Smørgrav } 221