5.1. 提供的功能

5.1.1. 基于文本的对话功能

#include <security/pam_misc.h> 
   int misc_conv( 
   num_msg,  
   msgm,  
   response,  
   appdata_ptr); 
 int num_msg; 
 const struct pam_message **msgm; 
 struct pam_response **response; 
 void *appdata_ptr; 

5.1.1.1. DESCRIPTION

misc_conv函数是 libpam_misc 的一部分,而不是标准 libpam 库的一部分。该功能将提示用户适当的 Comments,并按照身份验证模块的指示获取适当的 Importing。

除了简单地插入适当的 pam_conv(3)外,此函数还提供了一些超时功能。该函数导出五个变量,应用程序程序员可以使用这些变量来限制此对话函数 await 用户键入内容所花费的时间。这五个变量如下:

以下两个功能指针可用于支持对话功能中的二进制提示。它们已针对 libpamc 库的当前版本进行了优化,并且会随时更改。

5.1.2. 将环境复制到 PAM 的环境

#include <security/pam_misc.h> 
   int pam_misc_paste_env( 
   pamh,  
   user); 
 pam_handle_t *pamh; 
 const char * const *user; 

5.1.2.1. DESCRIPTION

此函数获取提供的环境指针列表,并将其内容“上载”到 PAM 环境。 PAM_SUCCESS 表示成功。

5.1.3. 解放本地保存的环境

#include <security/pam_misc.h> 
   int pam_misc_drop_env( 
   env); 
 char **env; 

5.1.3.1. DESCRIPTION

定义此函数是对 pam_getenvlist(3)函数的补充。它将与* env 关联的内存,与 0 overwrite * * free()释放之前的所有内存释放。

5.1.4. BSD 之类的 PAM 环境变量设置

#include <security/pam_misc.h> 
   int pam_misc_setenv( 
   pamh,  
   name,  
   value,  
   readonly); 
 pam_handle_t *pamh; 
 const char *name; 
 const char *value; 
 int readonly; 

5.1.4.1. DESCRIPTION

该函数执行与 pam_putenv(3)等效的任务,但是其语法更像是 BSD 样式函数。 setenv()。 * name value 与'='串联以形成 name = value 并传递给pam_putenv()。但是,如果已经设置了 PAM 变量,则仅当最后一个参数 readonly *为零时才应用替换。

上一章 首页 下一章