--- parser3/src/classes/mail.C 2005/08/09 08:14:48 1.110 +++ parser3/src/classes/mail.C 2009/08/08 13:30:20 1.113 @@ -1,11 +1,11 @@ /** @file Parser: @b mail parser class. - Copyright (c) 2001-2005 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001-2009 ArtLebedev Group (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) */ -static const char * const IDENT_MAIL_C="$Date: 2005/08/09 08:14:48 $"; +static const char * const IDENT_MAIL_C="$Date: 2009/08/08 13:30:20 $"; #include "pa_config_includes.h" #include "pa_vmethod_frame.h" @@ -73,7 +73,7 @@ static void sendmail( options #endif ) { - const char* message_cstr=message.cstr(String::L_UNSPECIFIED); + const char* message_cstr=message.untaint_cstr(String::L_AS_IS); const char* exception_type="email.format"; if(!from) // we use in sendmail -f {from} && SMTP MAIL from: {from} @@ -98,7 +98,7 @@ static void sendmail( #if WIN32 // win32 without SMTP server configured - throw Exception("parser.runtime", + throw Exception(PARSER_RUNTIME, 0, "$"MAIN_CLASS_NAME":"MAIL_NAME".SMTP not defined"); #else @@ -109,7 +109,7 @@ static void sendmail( String* sendmail_command=new String; if(vmail_conf) { #ifdef PA_FORCED_SENDMAIL - throw Exception("parser.runtime", + throw Exception(PARSER_RUNTIME, 0, "Parser was configured with --with-sendmail="PA_FORCED_SENDMAIL " key, to change sendmail you should reconfigure and recompie it"); @@ -117,7 +117,7 @@ static void sendmail( if(Value* sendmail_value=vmail_conf->get_hash()->get(mail_sendmail_name)) *sendmail_command<as_string(); else - throw Exception("parser.runtime", + throw Exception(PARSER_RUNTIME, 0, "$"MAIN_CLASS_NAME":"MAIL_NAME"."SENDMAIL_NAME" not defined"); #endif @@ -196,7 +196,7 @@ static void _send(Request& r, MethodPara Value& vhash=params.as_no_junction(0, "message must not be code"); HashStringValue* hash=vhash.get_hash(); if(!hash) - throw Exception("parser.runtime", + throw Exception(PARSER_RUNTIME, 0, "message must be hash"); @@ -236,12 +236,12 @@ MMail::MMail(): Methoded(MAIL_CLASS_NAME void MMail::configure_user(Request& r) { // $MAIN:MAIL[$SMTP[mail.design.ru]] - if(Value* mail_element=r.main_class.get_element(mail_name, r.main_class, false)) + if(Value* mail_element=r.main_class.get_element(mail_name)) if(mail_element->get_hash()) r.classes_conf.put(name(), mail_element); else if( !mail_element->is_string() ) - throw Exception("parser.runtime", + throw Exception(PARSER_RUNTIME, 0, "$" MAIL_CLASS_NAME ":" MAIL_NAME " is not hash"); }