--- parser3/src/main/pa_request.C 2002/06/12 12:50:32 1.210 +++ parser3/src/main/pa_request.C 2002/08/06 07:59:36 1.221 @@ -3,10 +3,10 @@ Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) - - $Id: pa_request.C,v 1.210 2002/06/12 12:50:32 paf Exp $ */ +static const char* IDENT_REQUEST_C="$Date: 2002/08/06 07:59:36 $"; + #include "pa_sapi.h" #include "pa_common.h" #include "pa_request.h" @@ -47,6 +47,7 @@ Request::Request(Pool& apool, env(apool), status(apool), form(apool), + mail(apool), math(apool), request(apool, *this), response(apool), @@ -101,6 +102,8 @@ Request::Request(Pool& apool, /// bases used // form class classes().put(form.get_class()->base()->name(), &form); + // mail class + classes().put(mail.get_class()->base()->name(), &mail); // math class classes().put(math.get_class()->base()->name(), &math); } @@ -160,8 +163,7 @@ void Request::configure_admin(VStateless */ void Request::core( - const char *root_config_filespec, bool root_config_fail_on_read_problem, - const char *site_config_filespec, bool site_config_fail_on_read_problem, + const char *config_filespec, bool config_fail_on_read_problem, bool header_only) { #ifdef RESOURCES_DEBUG @@ -173,23 +175,13 @@ gettimeofday(&mt[0],NULL); try { char *auto_filespec=(char *)malloc(MAX_STRING); - // loading root config - if(root_config_filespec) { - String& filespec=*NEW String(pool()); - filespec.APPEND_CLEAN(root_config_filespec, 0, "root_config", 0); - main_class=use_file( - filespec, - true/*ignore class_path*/, root_config_fail_on_read_problem, - main_class_name, main_class); - } - - // loading site config - if(site_config_filespec) { + // loading config + if(config_filespec) { String& filespec=*NEW String(pool()); - filespec.APPEND_CLEAN(site_config_filespec, 0, "site_config", 0); + filespec.APPEND_CLEAN(config_filespec, 0, "config", 0); main_class=use_file( filespec, - true/*ignore class_path*/, site_config_fail_on_read_problem, + true/*ignore class_path*/, config_fail_on_read_problem, main_class_name, main_class); } @@ -229,6 +221,10 @@ gettimeofday(&mt[0],NULL); true/*ignore class_path*/, true/*don't ignore read problem*/, main_class_name, main_class); + // configure root options if not configured yet + if(!configure_admin_done) + configure_admin(*main_class, 0); + // configure not-root=user options OP.configure_user(*this); methoded_array->configure_user(*this); @@ -244,6 +240,9 @@ gettimeofday(&mt[0],NULL); // filling cookies cookie.fill_fields(*this); + // filling mail received + mail.fill_received(*this); + #ifdef RESOURCES_DEBUG //measure:after compile gettimeofday(&mt[1],NULL); @@ -284,7 +283,7 @@ gettimeofday(&mt[2],NULL); // extract response body Value *body_value=static_cast( response.fields().get(*body_name)); - if(body_value) // there is some $response.body + if(body_value) // there is some $response:body body_file=body_value->as_vfile(); else if(lorigins_mode) response.fields().put(*content_type_name, @@ -485,42 +484,50 @@ VStateless_class *Request::use_file(cons if(!source) return base_class; - return use_buf(source, file_spec->cstr(), 0/*new class*/, name, base_class); + return use_buf(source, *file_spec, file_spec->cstr(), 0/*new class*/, name, base_class); } -VStateless_class *Request::use_buf(const char *source, const char *file, +VStateless_class *Request::use_buf(const char *source, + const String& filespec, const char *filespec_cstr, VStateless_class *aclass, const String *name, VStateless_class *base_class) { // compile loaded class - VStateless_class& cclass=COMPILE(source, aclass, name, base_class, file); + VStateless_class& cclass=COMPILE(source, aclass, name, base_class, filespec_cstr); + + VString *vfilespec=NEW VString(filespec); // locate and execute possible @conf[] static const Method *method_called; - execute_nonvirtual_method(cclass, *rootconf_method_name, 0/*no result needed*/, - &method_called); - if(method_called) + execute_nonvirtual_method(cclass, + *conf_method_name, vfilespec, + 0/*no result needed*/, &method_called); + if(method_called) { + if(!main_class) + main_class=&cclass; // for root auto.p, when main_class not assigned yet configure_admin(cclass, &method_called->name); + } // locate and execute possible @auto[] static - execute_nonvirtual_method(cclass, *auto_method_name, 0/*no result needed*/); + execute_nonvirtual_method(cclass, + *auto_method_name, vfilespec, + 0/*no result needed*/); return &cclass; } const String& Request::relative(const char *apath, const String& relative_name) { - int lpath_buf_size=strlen(apath)+1; - char *lpath=(char *)malloc(lpath_buf_size); - memcpy(lpath, apath, lpath_buf_size); - if(!rsplit(lpath, '/')) - strcpy(lpath, "."); - String& result=*NEW String(pool(), lpath); - result << "/" << relative_name; + int hpath_buf_size=strlen(apath)+1; + char *hpath=(char *)malloc(hpath_buf_size); + memcpy(hpath, apath, hpath_buf_size); + String& result=*NEW String(pool()); + if(rsplit(hpath, '/')) // if something/splitted + result << hpath << "/"; + result << relative_name; return result; } const String& Request::absolute(const String& relative_name) { - char *relative_name_cstr=relative_name.cstr(); - if(relative_name_cstr[0]=='/') { + if(relative_name.first_char()=='/') { String& result=*NEW String(pool(), info.document_root); result << relative_name; return result; @@ -546,8 +553,9 @@ void Request::output_result(const VFile& // header: cookies cookie.output_result(); + VString *body_file_content_type; // set content-type - if(String *body_file_content_type=static_cast( + if(body_file_content_type=static_cast( body_file.fields().get(*vfile_mime_type_name))) { // body file content type response.fields().put(*content_type_name, body_file_content_type); @@ -569,13 +577,18 @@ void Request::output_result(const VFile& // prepare header: $response:fields without :body response.fields().for_each(add_header_attribute, this); - // transcode const void *client_body; size_t client_content_length; - Charset::transcode(pool(), - pool().get_source_charset(), body_file.value_ptr(), body_file.value_size(), - pool().get_client_charset(), client_body, client_content_length - ); + // transcode text body when "text/*" or simple result + if(!body_file_content_type/*vstring.as_vfile*/ || body_file_content_type->as_string().pos("text/")==0) { + Charset::transcode(pool(), + pool().get_source_charset(), body_file.value_ptr(), body_file.value_size(), + pool().get_client_charset(), client_body, client_content_length + ); + } else { + client_body=body_file.value_ptr(); + client_content_length=body_file.value_size(); + } // prepare header: content-length char content_length_cstr[MAX_NUMBER]; @@ -594,13 +607,13 @@ const String& Request::mime_type_of(cons if(mime_types) if(const char *cext=strrchr(user_file_name_cstr, '.')) { String sext(pool(), ++cext); - if(mime_types->locate(0, sext)) + if(mime_types->locate(0, sext.change_case(pool(), String::CC_LOWER))) if(const String *result=mime_types->item(1)) return *result; else throw Exception("parser.runtime", mime_types->origin_string(), - "MIME-TYPE table column elements must not be empty"); + MIME_TYPES_NAME " table column elements must not be empty"); } return *NEW String(pool(), "application/octet-stream"); }