Chinaunix首页 | 论坛 | 博客
  • 博客访问: 231476
  • 博文数量: 48
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 412
  • 用 户 组: 普通用户
  • 注册时间: 2013-04-24 10:27
个人简介

Continuous pursuit technical details

文章分类

全部博文(48)

文章存档

2014年(1)

2013年(47)

分类: LINUX

2013-12-04 09:49:59

/*
 * pam_appl.h
 * 
 * This header file documents the PAM API --- that is, public
 * interface between the PAM library and an application program that
 * wishes to use it.
 *
 * Last modified: 15-Jan-96 by TYT
 */

/*
 * Copyright Theodore Ts'o, 1996.  All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, and the entire permission notice in its entirety,
 *    including the disclaimer of warranties.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 * 3. The name of the author may not be used to endorse or promote
 *    products derived from this software without specific prior
 *    written permission.
 * 
 * ALTERNATIVELY, this product may be distributed under the terms of
 * the GNU Public License, in which case the provisions of the GPL are
 * required INSTEAD OF the above restrictions.  (This clause is
 * necessary due to a potential bad interaction between the GPL and
 * the restrictions contained in a BSD-style copyright.)
 * 
 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED
 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
 * OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef _SECURITY_PAM_APPL_H
#define _SECURITY_PAM_APPL_H

/*
 * Defined types
 */

/*
 * This is a blind structure; users aren't allowed to see inside a
 * pam_handle_t, so we don't define struct _pam_handle here.  This is
 * defined in a file private to the PAM library.  (i.e., it's private
 * to PAM service modules, too!)
 */
typedef struct _pam_handle pam_handle_t;

/*
 * The PAM conversation structures
 */

/*
 * Used to pass prompting text, error messages, or other informatory
 * text to the user.  This structure is allocated and freed by the PAM
 * library.
 */
struct pam_message {
     int msg_style;
     char *msg;
};

/*
 * Used to return the user's response to the PAM library.  This
 * structure is allocated by the application program, and freed by the
 * PAM library.
 */
struct pam_response {
     char     *resp;
     int     resp_retcode;     /* not used, must be zero */
};

/*
 * The actual conversation structure itself
 */
struct pam_conv {
     int (*conv)(int num_msg, const struct pam_message **msg,
              struct pam_response **resp, void *appdata_ptr);
     void *appdata_ptr;
};

/*
 * Message styles
 */
#define PAM_PROMPT_ECHO_OFF     1
#define PAM_PROMPT_ECHO_ON      2
#define PAM_ERROR_MSG           3
#define PAM_TEXT_INFO           4

/*
 * PAM Flags
 */
     /* Authentication service should not generate any messages */
#define PAM_SILENT               0x0001
     /* The authentication service should return PAM_AUTHTOKEN_REQD if */
     /* the user has a null authentication token */
#define PAM_DISALLOW_NULL_AUTHTOK     0x0002

/* Note: these flags are used for pam_setcred() */

     /* Set user credentials for an authentication service */
#define PAM_CRED_ESTABLISH          0x0004
     /* Delete user credentials associated with an authentication service */
#define PAM_CRED_DELETE               0x0008
     /* Reinitialize user credentials */
#define PAM_CRED_REINITIALIZE          0x0010
     /* Extend lifetime of user credentials */
#define PAM_CRED_REFRESH          0x0020

/* Note: these flags are used by pam_chauthtok */

     /* The password service should only update those passwords */
     /* that have aged.  If this flag is not passed, the password */
     /* service should update all passwords. */
#define PAM_CHANGE_EXPIRED_AUTHTOK     0x0040

     /* The password service should only perform preliminary */
     /* checks.  No passwords should be updated. */
#define PAM_PRELIM_CHECK          0x0080

     /* The password service should update passwords */
     /* Note: PAM_PRELIM_CHECK and PAM_UPDATE_AUTHTOK can not both */
     /* simultaneously be set! */
#define PAM_UPDATE_AUTHTOK          0x0100




/*
 * Return values
 */
#define PAM_SUCCESS 0          /* Successful function return */
#define PAM_OPEN_ERR 1          /* dlopen() failure when dynamically */
                    /* loading a service module */
#define PAM_SYMBOL_ERR 2     /* Symbol not found */
#define PAM_SERVICE_ERR 3     /* Error in service module */
#define PAM_SYSTEM_ERR 4     /* System error */
#define PAM_BUF_ERR 5          /* Memory buffer error */
#define PAM_PERM_DENIED 6     /* Permission denied */
#define PAM_AUTH_ERR 7          /* Authentication failure */
#define PAM_CRED_INSUFFICIENT 8     /* Can not access authentication data */
                    /* due to insufficient credentials */
#define PAM_AUTHINFO_UNAVAIL 9     /* Underlying authentication service */
                    /* can not retrieve authenticaiton */
                    /* information  */
#define PAM_USER_UNKNOWN 10     /* User not known to the underlying */
                    /* authenticaiton module */
#define PAM_MAXTRIES 11          /* An authentication service has */
                    /* maintained a retry count which has */
                    /* been reached.  No further retries */
                    /* should be attempted */
#define PAM_AUTHTOKEN_REQD 12     /* New authentication token required. */
                    /* This is normally returned if the */
                    /* machine security policies require */
                    /* that the password should be changed */
                    /* beccause the password is NULL or it */
                    /* has aged */
#define PAM_ACCT_EXPIRED 13     /* User account has expired */
#define PAM_SESSION_ERR 14     /* Can not make/remove an entry for */
                    /* the specified session */
#define PAM_CRED_UNAVAIL 15     /* Underlying authentication service */
                    /* can not retrieve user credentials unavailable */
#define PAM_CRED_EXPIRED 16     /* User credentials expired */
#define PAM_CRED_ERR 17          /* Failure setting user credentials */
#define PAM_NO_MODULE_DATA 18     /* No module specific data is present */
#define PAM_CONV_ERR 19          /* Conversation error */
#define PAM_AUTHTOK_ERR 20     /* Authentication token manipulation error */
#define PAM_AUTHTOK_RECOVER_ERR 21 /* Authentication information */
                       /* cannot be recovered */
#define PAM_AUHTOK_LOCK_BUSY 22     /* Authentication token lock busy */
#define PAM_AUTHTOK_DISABLE_AGING 23 /* Authentication token aging disabled */
#define PAM_TRY_AGAIN 24     /* Preliminary check by password service */
#define PAM_IGNORE 25          /* Ingore underlying account module */
                    /* regardless of whether the control */
                    /* flag is required, optional, or sufficient */

/*
 * these defines are used by pam_set_data() and pam_get_data()
 */

#define PAM_SERVICE     1     /* The service name */
#define PAM_USER        2     /* The user name */
#define PAM_TTY         3     /* The tty name */
#define PAM_RHOST       4     /* The remote host name */
#define PAM_CONV        5     /* The pam_conv structure */
#define PAM_AUTHTOK     6     /* The authentication token (password) */
#define PAM_OLDAUTHTOK  7     /* The old authentication token */
#define PAM_RUSER       8     /* The remote user name */

/*
 * Framework layer API's
 */
extern int pam_start(char *service_name, char *user,
               struct pam_conv *pam_conversation, pam_handle_t **pamh);
extern int pam_end(pam_handle_t *pamh, int pam_status);
extern int pam_set_item(pam_handle_t *pamh, int item_type, void *item);
extern int pam_get_item(pam_handle_t *pamh, int item_type, void **item);
extern char *pam_strerror(int errnum);
extern int pam_set_data(pam_handle_t *pamh, char *module_data_name, char *data,
               int (*cleanup)(pam_handle_t *pamh, char *data,
                       int error_status));
extern int pam_get_data(pam_handle_t *pamh, char *module_data_name, void **datap);


/*
 * Authentication API's
 */
extern int pam_authenticate(pam_handle_t *pamh, int flags);
extern int pam_setcred(pam_handle_t *pamh, int flags);

/*
 * Account Management API's
 */
extern int pam_acct_mgmt(pam_handle_t *pamh, int flags);

/*
 * Session Management API's
 */
extern int pam_open_session(pam_handle_t *pamh, int flags);

extern int pam_close_session(pam_handle_t *pamh, int flags);

/*
 * Password Management API's
 */
extern int pam_chauthtok(pam_handle_t *pamh, int flags);

#endif /* _SECURITY_PAM_APPL_H */
阅读(1760) | 评论(0) | 转发(0) |
0

上一篇:App example using PAM

下一篇:TCPDUMP 原理 (Linux)

给主人留下些什么吧!~~