--- parser3/src/classes/form.C 2003/02/06 14:31:53 1.34.2.4 +++ parser3/src/classes/form.C 2016/03/31 21:46:19 1.47 @@ -1,24 +1,24 @@ /** @file Parser: @b form parser class. - Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001-2015 Art. Lebedev Studio (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) */ -static const char* IDENT_FORM_C="$Date: 2003/02/06 14:31:53 $"; - #include "classes.h" #include "pa_vmethod_frame.h" #include "pa_request.h" #include "pa_vform.h" +volatile const char * IDENT_FORM_C="$Id: form.C,v 1.47 2016/03/31 21:46:19 moko Exp $"; + /// $LIMITS.max_post_size default 10M const size_t MAX_POST_SIZE_DEFAULT=10*0x400*0x400; // class -class MForm: public Methoded { +class MForm : public Methoded { public: // Methoded bool used_directly() { return false; } @@ -26,13 +26,13 @@ public: // Methoded public: - MForm(): Methoded(0) {} + MForm(): Methoded("form") {} }; // global variable -MethodedPtr form_base_class(new MForm); +DECLARE_CLASS_VAR(form, new MForm); // defines for statics @@ -41,45 +41,44 @@ MethodedPtr form_base_class(new MForm); // statics -StringPtr max_post_size_name(new String(MAX_POST_SIZE_NAME)); -StringPtr limits_name(new String(LIMITS_NAME)); +static const String max_post_size_name(MAX_POST_SIZE_NAME); +static const String limits_name(LIMITS_NAME); // methods // constructor & configurator void MForm::configure_admin(Request& r) { - Pool& pool=r.pool(); - ValuePtr limits=r.main_class->get_element(limits_name, *r.main_class, false); - if(r.request_info.method && StrEqNc(r.request_info.method, "post", true)) { + Value* limits=r.main_class.get_element(limits_name); + if(r.request_info.can_have_body()){ // $limits.max_post_size default 10M - ValuePtr element=limits?limits->get_element(max_post_size_name, *limits, false) - :ValuePtr(0); + Value* element=limits?limits->get_element(max_post_size_name) + :0; size_t value=element?(size_t)element->as_double():0; size_t max_post_size=value?value:MAX_POST_SIZE_DEFAULT; if(r.request_info.content_length>max_post_size) - throw Exception("parser.runtime", - Exception::undefined_source, - "posted content_length(%u) > max_post_size(%u)", + throw Exception(PARSER_RUNTIME, + 0, + "posted content_length(%u) > $" LIMITS_NAME "." MAX_POST_SIZE_NAME "(%u)", r.request_info.content_length, max_post_size); - if(r.request_info.content_length<0) - throw Exception(Exception::undefined_type, - Exception::undefined_source, - "posted content_length(%u) < 0", - r.request_info.content_length); // read POST data if(r.request_info.content_length) { - char *post_data=new(pool) char[r.request_info.content_length]; - r.request_info.post_size=SAPI::read_post(r.sapi_info, + char *post_data=new(PointerFreeGC) char[r.request_info.content_length+1/*terminating zero*/]; + size_t post_size=SAPI::read_post(r.sapi_info, post_data, r.request_info.content_length); + post_data[post_size]=0; // terminating zero r.request_info.post_data=post_data; + r.request_info.post_size=post_size; + } else { + r.request_info.post_data=0; + r.request_info.post_size=0; } if(r.request_info.post_size!=r.request_info.content_length) - throw Exception(Exception::undefined_type, - Exception::undefined_source, + throw Exception(0, + 0, "post_size(%u) != content_length(%u)", r.request_info.post_size, r.request_info.content_length); }