15c1eca55SDag-Erling Smørgrav /*- 2856bb440SDag-Erling Smørgrav * Copyright (c) 2002 Networks Associates Technology, Inc. 35c1eca55SDag-Erling Smørgrav * All rights reserved. 45c1eca55SDag-Erling Smørgrav * 55c1eca55SDag-Erling Smørgrav * This software was developed for the FreeBSD Project by ThinkSec AS and 6ee02aaa9SDag-Erling Smørgrav * Network Associates Laboratories, the Security Research Division of 7ee02aaa9SDag-Erling Smørgrav * Network Associates, Inc. under DARPA/SPAWAR contract N66001-01-C-8035 8ee02aaa9SDag-Erling Smørgrav * ("CBOSS"), as part of the DARPA CHATS research program. 95c1eca55SDag-Erling Smørgrav * 105c1eca55SDag-Erling Smørgrav * Redistribution and use in source and binary forms, with or without 115c1eca55SDag-Erling Smørgrav * modification, are permitted provided that the following conditions 125c1eca55SDag-Erling Smørgrav * are met: 135c1eca55SDag-Erling Smørgrav * 1. Redistributions of source code must retain the above copyright 145c1eca55SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer. 155c1eca55SDag-Erling Smørgrav * 2. Redistributions in binary form must reproduce the above copyright 165c1eca55SDag-Erling Smørgrav * notice, this list of conditions and the following disclaimer in the 175c1eca55SDag-Erling Smørgrav * documentation and/or other materials provided with the distribution. 185c1eca55SDag-Erling Smørgrav * 3. The name of the author may not be used to endorse or promote 195c1eca55SDag-Erling Smørgrav * products derived from this software without specific prior written 205c1eca55SDag-Erling Smørgrav * permission. 215c1eca55SDag-Erling Smørgrav * 225c1eca55SDag-Erling Smørgrav * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 235c1eca55SDag-Erling Smørgrav * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 245c1eca55SDag-Erling Smørgrav * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 255c1eca55SDag-Erling Smørgrav * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 265c1eca55SDag-Erling Smørgrav * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 275c1eca55SDag-Erling Smørgrav * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 285c1eca55SDag-Erling Smørgrav * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 295c1eca55SDag-Erling Smørgrav * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 305c1eca55SDag-Erling Smørgrav * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 315c1eca55SDag-Erling Smørgrav * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 325c1eca55SDag-Erling Smørgrav * SUCH DAMAGE. 335c1eca55SDag-Erling Smørgrav * 34ee02aaa9SDag-Erling Smørgrav * $P4: //depot/projects/openpam/include/security/pam_appl.h#10 $ 355c1eca55SDag-Erling Smørgrav */ 365c1eca55SDag-Erling Smørgrav 375c1eca55SDag-Erling Smørgrav #ifndef _PAM_APPL_H_INCLUDED 385c1eca55SDag-Erling Smørgrav #define _PAM_APPL_H_INCLUDED 395c1eca55SDag-Erling Smørgrav 405c1eca55SDag-Erling Smørgrav #include <security/pam_types.h> 415c1eca55SDag-Erling Smørgrav #include <security/pam_constants.h> 425c1eca55SDag-Erling Smørgrav 435c1eca55SDag-Erling Smørgrav #ifdef __cplusplus 445c1eca55SDag-Erling Smørgrav extern "C" { 455c1eca55SDag-Erling Smørgrav #endif 465c1eca55SDag-Erling Smørgrav 475c1eca55SDag-Erling Smørgrav /* 485c1eca55SDag-Erling Smørgrav * XSSO 4.2.1, 6 495c1eca55SDag-Erling Smørgrav */ 505c1eca55SDag-Erling Smørgrav 515c1eca55SDag-Erling Smørgrav int 525c1eca55SDag-Erling Smørgrav pam_acct_mgmt(pam_handle_t *_pamh, 535c1eca55SDag-Erling Smørgrav int _flags); 545c1eca55SDag-Erling Smørgrav 555c1eca55SDag-Erling Smørgrav int 565c1eca55SDag-Erling Smørgrav pam_authenticate(pam_handle_t *_pamh, 575c1eca55SDag-Erling Smørgrav int _flags); 585c1eca55SDag-Erling Smørgrav 595c1eca55SDag-Erling Smørgrav int 605c1eca55SDag-Erling Smørgrav pam_chauthtok(pam_handle_t *_pamh, 615c1eca55SDag-Erling Smørgrav int _flags); 625c1eca55SDag-Erling Smørgrav 635c1eca55SDag-Erling Smørgrav int 645c1eca55SDag-Erling Smørgrav pam_close_session(pam_handle_t *_pamh, 655c1eca55SDag-Erling Smørgrav int _flags); 665c1eca55SDag-Erling Smørgrav 675c1eca55SDag-Erling Smørgrav int 685c1eca55SDag-Erling Smørgrav pam_end(pam_handle_t *_pamh, 695c1eca55SDag-Erling Smørgrav int _status); 705c1eca55SDag-Erling Smørgrav 715c1eca55SDag-Erling Smørgrav int 725c1eca55SDag-Erling Smørgrav pam_get_data(pam_handle_t *_pamh, 735c1eca55SDag-Erling Smørgrav const char *_module_data_name, 74ac676a11SDag-Erling Smørgrav const void **_data); 755c1eca55SDag-Erling Smørgrav 765c1eca55SDag-Erling Smørgrav int 775c1eca55SDag-Erling Smørgrav pam_get_item(pam_handle_t *_pamh, 785c1eca55SDag-Erling Smørgrav int _item_type, 795c1eca55SDag-Erling Smørgrav const void **_item); 805c1eca55SDag-Erling Smørgrav 815c1eca55SDag-Erling Smørgrav int 825c1eca55SDag-Erling Smørgrav pam_get_user(pam_handle_t *_pamh, 835c1eca55SDag-Erling Smørgrav const char **_user, 845c1eca55SDag-Erling Smørgrav const char *_prompt); 855c1eca55SDag-Erling Smørgrav 865c1eca55SDag-Erling Smørgrav char * 875c1eca55SDag-Erling Smørgrav pam_getenv(pam_handle_t *_pamh, 885c1eca55SDag-Erling Smørgrav const char *_name); 895c1eca55SDag-Erling Smørgrav 905c1eca55SDag-Erling Smørgrav char ** 915c1eca55SDag-Erling Smørgrav pam_getenvlist(pam_handle_t *_pamh); 925c1eca55SDag-Erling Smørgrav 935c1eca55SDag-Erling Smørgrav int 945c1eca55SDag-Erling Smørgrav pam_open_session(pam_handle_t *_pamh, 955c1eca55SDag-Erling Smørgrav int _flags); 965c1eca55SDag-Erling Smørgrav 975c1eca55SDag-Erling Smørgrav int 985c1eca55SDag-Erling Smørgrav pam_putenv(pam_handle_t *_pamh, 995c1eca55SDag-Erling Smørgrav const char *_namevalue); 1005c1eca55SDag-Erling Smørgrav 1015c1eca55SDag-Erling Smørgrav int 1025c1eca55SDag-Erling Smørgrav pam_set_data(pam_handle_t *_pamh, 1035c1eca55SDag-Erling Smørgrav const char *_module_data_name, 1045c1eca55SDag-Erling Smørgrav void *_data, 1055c1eca55SDag-Erling Smørgrav void (*_cleanup)(pam_handle_t *_pamh, 1065c1eca55SDag-Erling Smørgrav void *_data, 1075c1eca55SDag-Erling Smørgrav int _pam_end_status)); 1085c1eca55SDag-Erling Smørgrav 1095c1eca55SDag-Erling Smørgrav int 1105c1eca55SDag-Erling Smørgrav pam_set_item(pam_handle_t *_pamh, 1115c1eca55SDag-Erling Smørgrav int _item_type, 1125c1eca55SDag-Erling Smørgrav const void *_item); 1135c1eca55SDag-Erling Smørgrav 1145c1eca55SDag-Erling Smørgrav int 1155c1eca55SDag-Erling Smørgrav pam_setcred(pam_handle_t *_pamh, 1165c1eca55SDag-Erling Smørgrav int _flags); 1175c1eca55SDag-Erling Smørgrav 1185c1eca55SDag-Erling Smørgrav int 1195c1eca55SDag-Erling Smørgrav pam_start(const char *_service, 1205c1eca55SDag-Erling Smørgrav const char *_user, 1215c1eca55SDag-Erling Smørgrav const struct pam_conv *_pam_conv, 1225c1eca55SDag-Erling Smørgrav pam_handle_t **_pamh); 1235c1eca55SDag-Erling Smørgrav 1245c1eca55SDag-Erling Smørgrav const char * 1255c1eca55SDag-Erling Smørgrav pam_strerror(pam_handle_t *_pamh, 1265c1eca55SDag-Erling Smørgrav int _error_number); 1275c1eca55SDag-Erling Smørgrav 1285c1eca55SDag-Erling Smørgrav /* 1295c1eca55SDag-Erling Smørgrav * Single Sign-On extensions 1305c1eca55SDag-Erling Smørgrav */ 1315c1eca55SDag-Erling Smørgrav #if 0 1325c1eca55SDag-Erling Smørgrav int 1335c1eca55SDag-Erling Smørgrav pam_authenticate_secondary(pam_handle_t *_pamh, 1345c1eca55SDag-Erling Smørgrav char *_target_username, 1355c1eca55SDag-Erling Smørgrav char *_target_module_type, 1365c1eca55SDag-Erling Smørgrav char *_target_authn_domain, 1375c1eca55SDag-Erling Smørgrav char *_target_supp_data, 1385c1eca55SDag-Erling Smørgrav char *_target_module_authtok, 1395c1eca55SDag-Erling Smørgrav int _flags); 1405c1eca55SDag-Erling Smørgrav 1415c1eca55SDag-Erling Smørgrav int 1425c1eca55SDag-Erling Smørgrav pam_get_mapped_authtok(pam_handle_t *_pamh, 1435c1eca55SDag-Erling Smørgrav const char *_target_module_username, 1445c1eca55SDag-Erling Smørgrav const char *_target_module_type, 1455c1eca55SDag-Erling Smørgrav const char *_target_authn_domain, 1465c1eca55SDag-Erling Smørgrav size_t *_target_authtok_len, 1475c1eca55SDag-Erling Smørgrav unsigned char **_target_module_authtok); 1485c1eca55SDag-Erling Smørgrav 1495c1eca55SDag-Erling Smørgrav int 1505c1eca55SDag-Erling Smørgrav pam_get_mapped_username(pam_handle_t *_pamh, 1515c1eca55SDag-Erling Smørgrav const char *_src_username, 1525c1eca55SDag-Erling Smørgrav const char *_src_module_type, 1535c1eca55SDag-Erling Smørgrav const char *_src_authn_domain, 1545c1eca55SDag-Erling Smørgrav const char *_target_module_type, 1555c1eca55SDag-Erling Smørgrav const char *_target_authn_domain, 1565c1eca55SDag-Erling Smørgrav char **_target_module_username); 1575c1eca55SDag-Erling Smørgrav 1585c1eca55SDag-Erling Smørgrav int 1595c1eca55SDag-Erling Smørgrav pam_set_mapped_authtok(pam_handle_t *_pamh, 1605c1eca55SDag-Erling Smørgrav const char *_target_module_username, 1615c1eca55SDag-Erling Smørgrav size_t _target_authtok_len, 1625c1eca55SDag-Erling Smørgrav unsigned char *_target_module_authtok, 1635c1eca55SDag-Erling Smørgrav const char *_target_module_type, 1645c1eca55SDag-Erling Smørgrav const char *_target_authn_domain); 1655c1eca55SDag-Erling Smørgrav 1665c1eca55SDag-Erling Smørgrav int 1675c1eca55SDag-Erling Smørgrav pam_set_mapped_username(pam_handle_t *_pamh, 1685c1eca55SDag-Erling Smørgrav char *_src_username, 1695c1eca55SDag-Erling Smørgrav char *_src_module_type, 1705c1eca55SDag-Erling Smørgrav char *_src_authn_domain, 1715c1eca55SDag-Erling Smørgrav char *_target_module_username, 1725c1eca55SDag-Erling Smørgrav char *_target_module_type, 1735c1eca55SDag-Erling Smørgrav char *_target_authn_domain); 1745c1eca55SDag-Erling Smørgrav #endif /* 0 */ 1755c1eca55SDag-Erling Smørgrav 1765c1eca55SDag-Erling Smørgrav #ifdef __cplusplus 1775c1eca55SDag-Erling Smørgrav } 1785c1eca55SDag-Erling Smørgrav #endif 1795c1eca55SDag-Erling Smørgrav 1805c1eca55SDag-Erling Smørgrav #endif 181