±¾ÎĽéÉÜÈçºÎÈà qmail Ôö¼Ó smtpd-auth ¹¦ÄÜ£®
1. °²×° qmail-smtpd
ÏÂÔØ qmail-smptd.patch http://www.elysium.pl/members/brush/
ÔÚ /usr/ports/mail/qmail Ŀ¼ÏÂÃæ£¬patch ÖØÐ±àÒë qmail£¬²¢¿½±´ qmail-smtpd µ½ /var/qmail/bin
2. °²×° vpopmail
ʹÓÃmysqlÊý¾Ý¿âµÄ£¬ÐèҪעÒâµÄÊÇÒ»¶¨Òª¸Ä¶¯ vmysql.h ÎļþÖÐµÄ mysqlÃÜÂëΪÄãµÄ vpopmail Óû§ÃÜÂ룻
È»ºó¸Ä¶¯ vchkpw.c ÎļþÖУºÏÂÃæµÄÄÚÈÝ£¬·Ö±ðÔÚÏàÓ¦µÄλÖüÓÉÏ #ifdef AUTHVCHKPW ºÍ¡¡#endif
/* Since the vpopmail system runs under a uid/gid * file system security, and since qmail-pop3d * is required to run as the pop users uid/gid * change to the vpasswds uid and gid */
#ifdef AUTHVCHKPW
if (setgid(pwent->pw_gid) == -1) { log_exit(LOG_NOTICE, 4, "vchkpw: setgid() failed"); }
/* captn' changing group permissions, Eye Eye! */ if (setuid(pwent->pw_uid) == -1) { log_exit(LOG_NOTICE, 5, "vchkpw: setuid() failed"); }
/* hop into thier email directory */ if (chdir(pwent->pw_dir) == -1) {
/* if the dir does not exist, create it */ if (vmake_maildir(pwent->pw_dir, pwent->pw_uid, pwent->pw_gid)==-1) { log_exit(LOG_NOTICE, 5, "vchkpw: make user dir failed"); } } /* set up some environment variables */ scopy(envbuf1, VCHKPW_USER, MAX_ENV_BUF); scat(envbuf1, pwent->pw_name, MAX_ENV_BUF); if (putenv(envbuf1) == -1) log_exit(LOG_NOTICE,7,"vchkpw: putenv(USER) failed");
/* now HOME */ scopy(envbuf2, VCHKPW_HOME, MAX_ENV_BUF); scat(envbuf2, pwent->pw_dir, MAX_ENV_BUF); if (putenv(envbuf2) == -1) log_exit(LOG_NOTICE, 8, "vchkpw: putenv(HOME) failed");
/* Now shell */ scopy(envbuf3, VCHKPW_SHELL, MAX_ENV_BUF); if (putenv(envbuf3) == -1) log_exit(LOG_NOTICE, 9, "vchkpw: putenv(SHELL) failed");
/* and a vpopuser */ scopy(envbuf4, VCHKPW_VPOPUSER, MAX_ENV_BUF); scat(envbuf4, name, MAX_ENV_BUF); if (putenv(envbuf4) == -1) log_exit(LOG_NOTICE, 9, "vchkpw: putenv(VPOPUSER) failed");
/* close the auth module connection */
/* kick off the next program and exit */ execvp(argv[1],argv+1);
/* yikes! the exec failed, log error */ log_exit(LOG_NOTICE, 10, "vchkpw: execvp() failed");
#endif /* exit code of 0 */ return(0);
È»ºóÖØÐ±àÒë make
cd work/vpopmail* Ŀ¼£¬cp vchkpw /home/vpopmail/bin/authvchkpw
chmod a+s /home/vpopmail/bin/authvchkpw
ÒÔÏÂports°²×°ÊÇÔÚvpopmailÀϵİ汾ÉÏͨ¹ý£¬Ðİ汾ûÓвâÊÔ£¬Òò´Ë²»½¨Òé²ÉÓà ports °²×°¡£
ÔÚ /usr/ports/mail/vpopmail/ÏÂÃæÔö¼Ó files Ŀ¼£¬²¢½¨Á¢ÏÂÃæÁ½¸ö patch Îļþ
Îļþpatch-aa£¬ÄÚÈÝÈçÏ£º
+++ vmysql.h 27c27 < #define MYSQL_PASSWD "gipgap" --- > #define MYSQL_PASSWD "mypassword"
Îļþ patch-bb£¬ÄÚÈÝÈçÏ£º +++ vchkpw.c 310a311 > 311a313 > 313a316,317 > #ifdef AUTH_VCHKPW > 359a364,365 > > #endif
È»ºómake -D WITHOUT_ROAMING -D WITH_MYSQL DEFAULT_DOMAIN=sczg.net£¬ÖØÐ±àÒë
cd work/vpopmail* Ŀ¼£¬cp vchkpw /home/vpopmail/bin/authvchkpw
chmod a+s /home/vpopmail/bin/authvchkpw
3. °Ñ smtp µÄ tcpserver ÃüÃû¸ÄΪ£º
/usr/local/bin/tcpserver -u 82 -g 81 0 smtp /var/qmail/bin/qmail-smtpd \ /usr/local/vpopmail/bin/authvchkpw \ 2>%26amp;1 | /var/qmail/bin/splogger smtpd 3 %26amp;
ÖØÐÂÆô¶¯ÏàÓ¦µÄ tcpserver¼´¿É£®
|