1 /* syslogging function for errors and other information */
2 extern void _log_err(int, const char *, ...);
4 /* set the control flags for the UNIX module. */
5 extern int set_ctrl(int, int, const char **);
7 /* generic function for freeing pam data segments */
8 extern void _cleanup(pam_handle_t
*, void *, int);
11 * Safe duplication of character strings. "Paranoid"; don't leave
12 * evidence of old token around for later stack analysis.
15 extern char *xstrdup(const char *);
17 /* ************************************************************** *
18 * Useful non-trivial functions *
19 * ************************************************************** */
21 extern void _cleanup_failures(pam_handle_t
*, void *, int);
23 /* compare 2 strings */
24 extern BOOL
strequal(const char *, const char *);
26 extern struct smb_passwd
*
27 _my_get_smbpwnam(FILE *, const char *, BOOL
*, BOOL
*, long *);
29 extern int _smb_verify_password( pam_handle_t
*pamh
, SAM_ACCOUNT
*sampass
,
30 const char *p
, unsigned int ctrl
);
33 * this function obtains the name of the current user and ensures
34 * that the PAM_USER item is set to this value
37 extern int _smb_get_user(pam_handle_t
*, unsigned int,
38 const char *, const char **);
40 /* _smb_blankpasswd() is a quick check for a blank password */
42 extern int _smb_blankpasswd(unsigned int, SAM_ACCOUNT
*sampass
);
45 /* obtain a password from the user */
46 extern int _smb_read_password( pam_handle_t
*, unsigned int, char*,
47 char *, char *, char *, char **);
49 extern int _pam_smb_approve_pass(pam_handle_t
*, unsigned int, const char *,