--- parser3/src/classes/mail.C 2004/02/24 11:26:29 1.103 +++ parser3/src/classes/mail.C 2004/12/08 08:45:13 1.108 @@ -5,7 +5,7 @@ Author: Alexandr Petrosian (http://paf.design.ru) */ -static const char * const IDENT_MAIL_C="$Date: 2004/02/24 11:26:29 $"; +static const char * const IDENT_MAIL_C="$Date: 2004/12/08 08:45:13 $"; #include "pa_config_includes.h" #include "pa_vmethod_frame.h" @@ -21,6 +21,10 @@ static const char * const IDENT_MAIL_C=" #include "smtp.h" +// debug switches + +#define DEBUG_JUST_SEE_MESSAGE + // defines #define MAIL_CLASS_NAME "mail" @@ -56,7 +60,12 @@ static const String mail_sendmail_name(S // helpers -static void sendmail(Request& r, +static void sendmail( + Value* +#ifndef WIN32 + vmail_conf +#endif + , Value* smtp_server_port, const String& message, const String* from, const String* to, const String* @@ -65,24 +74,18 @@ static void sendmail(Request& r, #endif ) { const char* message_cstr=message.cstr(String::L_UNSPECIFIED); - Value* vmail_conf=static_cast(r.classes_conf.get(mail_base_class->name())); const char* exception_type="email.format"; if(!from) // we use in sendmail -f {from} && SMTP MAIL from: {from} throw Exception(exception_type, 0, "parameter does not specify 'from' header field"); - if(!to) // we use only in SMTP RCPT to: {to} - throw Exception(exception_type, - 0, - "parameter does not specify 'to' header field"); - - Value* smtp_server_port=0; - if(vmail_conf) { - // $MAIN:MAIL.SMTP[mail.yourdomain.ru[:port]] - smtp_server_port=vmail_conf->get_hash()->get(String::Body("SMTP")); - } if(smtp_server_port) { + if(!to) // we use only in SMTP RCPT to: {to} + throw Exception(exception_type, + 0, + "parameter does not specify 'to' header field"); + SMTP smtp; char* server=smtp_server_port->as_string().cstrm(); const char* port=rsplit(server, ':'); @@ -201,13 +204,26 @@ static void _send(Request& r, MethodPara if(Value* voptions=hash->get(MAIL_OPTIONS_NAME)) soptions=&voptions->as_string(); + Value* vmail_conf=static_cast(r.classes_conf.get(mail_base_class->name())); + Value* smtp_server_port=0; + if(vmail_conf) { + // $MAIN:MAIL.SMTP[mail.yourdomain.ru[:port]] + smtp_server_port=vmail_conf->get_hash()->get(String::Body("SMTP")); + } + + const String* from=0; String* to=0; const String& message= - GET_SELF(r, VMail).message_hash_to_string(r, hash, 0, from, to); + GET_SELF(r, VMail).message_hash_to_string(r, hash, 0, from, + smtp_server_port?true:false /*send by SMTP=strip to?*/, to); - //r.write_pass_lang(message); - sendmail(r, message, from, to, soptions); +#ifdef DEBUG_JUST_SEE_MESSAGE + r.write_pass_lang(message); +#else + sendmail(vmail_conf, smtp_server_port, + message, from, to, soptions); +#endif } // constructor & configurator