|
|
|
@ -2,7 +2,7 @@
|
|
|
|
|
* This file is a part of Winix
|
|
|
|
|
* and is not publicly distributed
|
|
|
|
|
*
|
|
|
|
|
* Copyright (c) 2008-2010, Tomasz Sowa
|
|
|
|
|
* Copyright (c) 2008-2011, Tomasz Sowa
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
@ -17,6 +17,7 @@
|
|
|
|
|
#include "misc.h"
|
|
|
|
|
#include "utf8.h"
|
|
|
|
|
#include "log.h"
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -27,6 +28,8 @@ class PostParser : public HttpSimpleParser
|
|
|
|
|
PostTab * post_tab;
|
|
|
|
|
std::wstring temp_name, temp_value;
|
|
|
|
|
bool input_as_utf8;
|
|
|
|
|
size_t log_value_size;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
|
@ -37,6 +40,29 @@ protected:
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CreateLog(bool param_added)
|
|
|
|
|
{
|
|
|
|
|
log << log2 << "Method POST, name: \"" << temp_name << "\"";
|
|
|
|
|
|
|
|
|
|
if( log_value_size > 0 && !IsSubStringNoCase(L"pass", temp_name.c_str()) )
|
|
|
|
|
{
|
|
|
|
|
log << ", value: ";
|
|
|
|
|
|
|
|
|
|
if( temp_value.size() > log_value_size )
|
|
|
|
|
log << "(first " << log_value_size << " characters) ";
|
|
|
|
|
|
|
|
|
|
log << "\"";
|
|
|
|
|
log.LogString(temp_value, log_value_size);
|
|
|
|
|
log << "\" (size: " << temp_value.size() << ")";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if( param_added == false )
|
|
|
|
|
log << log2 << " (skipped)";
|
|
|
|
|
|
|
|
|
|
log << log2 << logend;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
virtual void Parameter(std::string & name, std::string & value)
|
|
|
|
|
{
|
|
|
|
|
if( input_as_utf8 )
|
|
|
|
@ -51,13 +77,7 @@ protected:
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
std::pair<PostTab::iterator, bool> res = post_tab->insert( std::make_pair(temp_name, temp_value) );
|
|
|
|
|
|
|
|
|
|
log << log2 << "Method POST, name: \"" << temp_name << "\", value: \"" << temp_value << "\"";
|
|
|
|
|
|
|
|
|
|
if( res.second == false )
|
|
|
|
|
log << log2 << " (skipped)";
|
|
|
|
|
|
|
|
|
|
log << log2 << logend;
|
|
|
|
|
CreateLog(res.second);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -65,7 +85,8 @@ public:
|
|
|
|
|
|
|
|
|
|
PostParser()
|
|
|
|
|
{
|
|
|
|
|
input_as_utf8 = false;
|
|
|
|
|
input_as_utf8 = false;
|
|
|
|
|
log_value_size = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -74,6 +95,10 @@ public:
|
|
|
|
|
input_as_utf8 = utf;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void LogValueSize(size_t s)
|
|
|
|
|
{
|
|
|
|
|
log_value_size = s;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void Parse(FCGX_Stream * in_, PostTab & post_tab_)
|
|
|
|
|
{
|
|
|
|
|