Hi, I compiled the milter sapi, the example in the distribution works well. BUT when I try to get the values of the sendmail macros with the smfi_getsymval function, i desperately get a blank string. I used strace and I do see the "i" sendmail macro in a red system call but I can no red its value in the PHP milter. Any ideas? Is this worth logging a bug? Thanks ------- HERE is the code I used. It is just the distribution example with the milter_envfrom function modified by including two function calls: milter_log(smfi_getsymval("i")); milter_log(smfi_getsymval("{i}")); Example was retrieved from CVS: http://cvs.php.net/viewvc.cgi/php-src/sapi/milter/milter.php?revision=1.2&view=markup <?php /** * example milter script * * run: php-milter -D -p /path/to/sock milter.php * * for details on how to set up sendmail and configure the milter see * http://www.sendmail.com/partner/resources/development/milter_api/ * * for api details see * http://www.sendmail.com/partner/resources/development/milter_api/api.html * * below is a list of all callbacks, that are available through the milter sapi, * if you leave one or more out they simply won't get called (e.g. if you secify an * empty php file, the milter would do nothing :) */ /** * this function is called once on sapi startup, * here you can specify the actions the filter may take * * see http://www.sendmail.com/partner/resources/development/milter_api/smfi_register.html#flags */ function milter_log($msg) { $GLOBALS['log'] = fopen("/tmp/milter.log", "a"); fwrite($GLOBALS['log'], date("[H:i:s d.m.Y]") . "\t{$msg}\n"); fclose($GLOBALS['log']); } function milter_init() { milter_log("-- startup --"); milter_log("milter_init()"); smfi_setflags(SMFIF_ADDHDRS); } /** * is called once, at the start of each SMTP connection */ function milter_connect($connect) { milter_log("milter_connect('$connect')"); } /** * is called whenever the client sends a HELO/EHLO command. * It may therefore be called between zero and three times. */ function milter_helo($helo) { milter_log("milter_helo('$helo')"); } /** * is called once at the beginning of each message, * before milter_envrcpt. */ function milter_envfrom($args) { milter_log("milter_envfrom(args[])"); foreach ($args as $ix => $arg) { milter_log("\targs[$ix] = $arg"); } milter_log(smfi_getsymval("i")); milter_log(smfi_getsymval("{i}")); } /** * is called once per recipient, hence one or more times per message, * immediately after milter_envfrom */ function milter_envrcpt($args) { milter_log("milter_envrcpt(args[])"); foreach ($args as $ix => $arg) { milter_log("\targs[$ix] = $arg"); } } /** * is called zero or more times between milter_envrcpt and milter_eoh, * once per message header */ function milter_header($header, $value) { milter_log("milter_header('$header', '$value')"); } /** * is called once after all headers have been sent and processed. */ function milter_eoh() { milter_log("milter_eoh()"); } /** * is called zero or more times between milter_eoh and milter_eom. */ function milter_body($bodypart) { milter_log("milter_body('$bodypart')"); } /** * is called once after all calls to milter_body for a given message. * most of the api functions, that alter the message can only be called * within this callback. */ function milter_eom() { milter_log("milter_eom()"); /* add PHP header to the message */ smfi_addheader("X-PHP", phpversion()); } /** * may be called at any time during message processing * (i.e. between some message-oriented routine and milter_eom). */ function milter_abort() { milter_log("milter_abort()"); } /** * is always called once at the end of each connection. */ function milter_close() { milter_log("milter_close()"); } ?> Alex Madon http://atpic.com Webmaster -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php