forked from lthn/blockchain
* stratum_server: resolve CID 210144 (UNINIT_CTOR) * stratum_server: resolve CID 210042/210085/210104 (UNCAUGHT_EXCEPT) The potential to throw exists within the logger, remove_blockchain_update_listener, and any paths involving the logger (including CATCH_ENTRY_*). * epee: misc_log_ex: create CATCH_ENTRY_NO_RETURN macro A temporary substition for what I hope will eventually be a full-fledged exception-dispatcher (class-based, not macro). * stratum_server: resolve CID 210080/210084/210089 (UNCAUGHT_EXCEPT) The potential to throw exists within the logger, remove_protocol_handler, and any paths involving the logger (including CATCH_ENTRY_*). * epee: levin_protocol_handler_async: resolve CID 210140/210182/210165 (UNCAUGHT_EXCEPT) The potential to throw exists within guarded_critical_region_t, and any paths involving the logger (including CATCH_ENTRY_*). * epee: levin_protocol_handler_async: resolve CID 210110/210119/210155 (UNCAUGHT_EXCEPT) The potential to throw exists within the logger, del_connection, and any paths involving the logger (including CATCH_ENTRY_*). * epee: misc_log_ex: move macros to *top* of file so they can be used *within* this file. * daemon: resolve CID 210069/210092/210166 (UNCAUGHT_EXCEPT) The potential to throw exists within log_space, and any paths involving the logger (including CATCH_ENTRY_*). * daemon: return cstdlib proper types in main * simplewallet: resolve 6 different CIDs (UNCAUGHT_EXCEPT) CID: 210082 CID: 210086 CID: 210096 CID: 210147 CID: 210149 CID: 210150 The potential to throw exists throughout various paths in main. * simplewallet: return cstdlib proper types in main * simplewallet: resolve CID 210128/210160 (UNCAUGHT_EXCEPT) The potential to throw exists within various paths, and any paths involving the logger (including CATCH_ENTRY_*). * conn_tool: resolve 5 different CIDs (UNCAUGHT_EXCEPT) CID: 210038 CID: 210047 CID: 210108 CID: 210122 CID: 210157 The potential to throw exists throughout various paths in main. * conn_tool: return cstdlib proper types in main * miniupnp_helper: resolve CID 210050 (UNCAUGHT_EXCEPT) The potential to throw exists within deinit, including any paths involving the logger (including CATCH_ENTRY_*). * epee: profile_tools: resolve CID 210055 (UNCAUGHT_EXCEPT) The potential to throw exists within boost microsec_clock::localtime(), and any paths involving the logger (including CATCH_ENTRY_*). * db_backend_lmdb: resolve CID 210056/210133 (UNCAUGHT_EXCEPT) The potential to throw exists within close(), including any paths involving the logger (including CATCH_ENTRY_*). * epee: misc_log_ex: resolve CID 210060/210124 (UNCAUGHT_EXCEPT) The potential to throw exists within several paths, including any paths involving the logger (including CATCH_ENTRY_*). * epee: misc_language: resolve 4 CIDs (UNCAUGHT_EXCEPT) CID: 210064 CID: 210093 CID: 210136 CID: 210139 The potential to throw exists within m_func(), including any paths involving the logger (including CATCH_ENTRY_*). * db_abstract_accessor: resolve 4 CIDs (UNCAUGHT_EXCEPT) CID: 210072 CID: 210094 CID: 210116 CID: 210141 The potential to throw exists within m_cache.clear(), including any paths involving the logger (including CATCH_ENTRY_*). * epee: net_helper: resolve CID 210100 (UNCAUGHT_EXCEPT) The potential to throw exists within shutdown(), including any paths involving the logger (including CATCH_ENTRY_*). * epee: syncobj: resolve CID 210123 (UNCAUGHT_EXCEPT) The potential to throw exists within unlock(), including any paths involving the logger (including CATCH_ENTRY_*). * epee: profile_tools: resolve CID 210145/210154 (UNCAUGHT_EXCEPT) The potential to throw exists within various paths, including any paths involving the logger (including CATCH_ENTRY_*). * epee: http_base: resolve CID 210176 (UNINIT_CTOR) * p2p: net_node: resolve CID 210173 (UNINIT_CTOR) * epee: net_helper: resolve CID 210138 (UNINIT_CTOR) * p2p: net_peerlist: resolve CID 210137 (UNINIT_CTOR) * currency_basic: resolve CID 210117 (UNINIT_CTOR) * epee: abstract_tcp_server2: resolve 3 CIDs (UNINIT_CTOR) CID: 210040 CID: 210090 CID: 210105 * simplewallet: resolve CID 210103 (UNINIT_CTOR) * epee: levin_protocol_handler_async: resolve CID 210091 (UNINIT_CTOR) * json_archive: resolve CID 210087 (UNINIT_CTOR) * epee: levin_protocol_handler_async: resolve CID 210073 (UNINIT_CTOR) * miniupnp_helper: resolve CID 210037 (UNINIT_CTOR) * crypto: ge_frombytes_vartime: resolve CID 210142 (CHECKED_RETURN) * wallet2: resolve CID 210041 (CHECKED_RETURN) * epee: misc_log_ex: resolve CID 210127 (DEADCODE) * epee: levin_protocol_handler_sync: resolve 3 CIDs (PASS_BY_VALUE) CID: 210167 CID: 210170 CID: 210180 * p2p: net_node: resolve CID 210065 (PASS_BY_VALUE) * epee: levin_abstract_invoke2: resolve CID 210049 (PASS_BY_VALUE) * epee: abstract_tcp_server2: resolve CID 210045 (PASS_BY_VALUE) * epee: misc_log_ex: add NESTED_*_ENTRY macros * simplewallet: use NESTED_*_ENTRY in message_writer dtor * stratum_protocol_handler_config: use NESTED_*_ENTRY in dtor * stratum_protocol_handler: use NESTED_*_ENTRY in dtor * lmdb_db_backend: use NESTED_*_ENTRY in dtor * epee: abstract_tcp_server2: resolve 4 CIDs (UNCAUGHT_EXCEPT) CID: 210088 CID: 210106 CID: 210164 CID: 210179 The potential to throw exists within various paths, including any paths involving the logger (including CATCH_ENTRY_*). * db_abstract_accessor: use NESTED_*_ENTRY in dtor * miniupnp_helper: use NESTED_*_ENTRY in dtor * epee: misc_log_ex: use NESTED_*_ENTRY in log_frame dtor * epee: levin_protocol_handler_async: use NESTED_*_ENTRY in dtors * epee: net_helper: use NESTED_*_ENTRY in dtor * epee: profile_tools: use NESTED_*_ENTRY in dtors * epee: misc_language: use NESTED_*_ENTRY in dtor * epee: syncobj: use NESTED_*_ENTRY in dtor * zano: license contact w/ zano.org email instead of sekreta.org email
186 lines
5.2 KiB
C++
186 lines
5.2 KiB
C++
// Copyright (c) 2019, anonimal, <anonimal@zano.org>
|
|
// Copyright (c) 2006-2013, Andrey N. Sabelnikov, www.sabelnikov.net
|
|
// All rights reserved.
|
|
//
|
|
// Redistribution and use in source and binary forms, with or without
|
|
// modification, are permitted provided that the following conditions are met:
|
|
// * Redistributions of source code must retain the above copyright
|
|
// notice, this list of conditions and the following disclaimer.
|
|
// * Redistributions in binary form must reproduce the above copyright
|
|
// notice, this list of conditions and the following disclaimer in the
|
|
// documentation and/or other materials provided with the distribution.
|
|
// * Neither the name of the Andrey N. Sabelnikov nor the
|
|
// names of its contributors may be used to endorse or promote products
|
|
// derived from this software without specific prior written permission.
|
|
//
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER BE LIABLE FOR ANY
|
|
// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
// ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
//
|
|
|
|
|
|
|
|
#pragma once
|
|
#include <boost/lexical_cast.hpp>
|
|
#include <boost/regex.hpp>
|
|
|
|
#include "string_tools.h"
|
|
namespace epee
|
|
{
|
|
namespace net_utils
|
|
{
|
|
namespace http
|
|
{
|
|
|
|
enum http_method{
|
|
http_method_get,
|
|
http_method_post,
|
|
http_method_put,
|
|
http_method_head,
|
|
http_method_etc,
|
|
http_method_unknown
|
|
};
|
|
|
|
enum http_content_type
|
|
{
|
|
http_content_type_text_html,
|
|
http_content_type_image_gif,
|
|
http_content_type_other,
|
|
http_content_type_not_set
|
|
};
|
|
|
|
typedef std::list<std::pair<std::string, std::string> > fields_list;
|
|
|
|
inline
|
|
std::string get_value_from_fields_list(const std::string& param_name, const net_utils::http::fields_list& fields)
|
|
{
|
|
fields_list::const_iterator it = fields.begin();
|
|
for(; it != fields.end(); it++)
|
|
if(!string_tools::compare_no_case(param_name, it->first))
|
|
break;
|
|
|
|
if(it==fields.end())
|
|
return std::string();
|
|
|
|
return it->second;
|
|
}
|
|
|
|
|
|
inline
|
|
std::string get_value_from_uri_line(const std::string& param_name, const std::string& uri)
|
|
{
|
|
std::string buff = "([\\?|&])";
|
|
buff += param_name + "=([^&]*)";
|
|
boost::regex match_param(buff.c_str(), boost::regex::icase | boost::regex::normal);
|
|
boost::smatch result;
|
|
if(boost::regex_search(uri, result, match_param, boost::match_default) && result[0].matched)
|
|
{
|
|
return result[2];
|
|
}
|
|
return std::string();
|
|
}
|
|
|
|
|
|
|
|
struct http_header_info
|
|
{
|
|
std::string m_connection; //"Connection:"
|
|
std::string m_referer; //"Referer:"
|
|
std::string m_content_length; //"Content-Length:"
|
|
std::string m_content_type; //"Content-Type:"
|
|
std::string m_transfer_encoding;//"Transfer-Encoding:"
|
|
std::string m_content_encoding; //"Content-Encoding:"
|
|
std::string m_host; //"Host:"
|
|
std::string m_cookie; //"Cookie:"
|
|
fields_list m_etc_fields;
|
|
|
|
void clear()
|
|
{
|
|
m_connection.clear();
|
|
m_referer.clear();
|
|
m_content_length.clear();
|
|
m_content_type.clear();
|
|
m_transfer_encoding.clear();
|
|
m_content_encoding.clear();
|
|
m_host.clear();
|
|
m_cookie.clear();
|
|
m_etc_fields.clear();
|
|
}
|
|
};
|
|
|
|
struct uri_content
|
|
{
|
|
std::string m_path;
|
|
std::string m_query;
|
|
std::string m_fragment;
|
|
std::list<std::pair<std::string, std::string> > m_query_params;
|
|
};
|
|
|
|
struct url_content
|
|
{
|
|
std::string schema;
|
|
std::string host;
|
|
std::string uri;
|
|
uint64_t port;
|
|
uri_content m_uri_content;
|
|
};
|
|
|
|
|
|
struct http_request_info
|
|
{
|
|
http_request_info():m_http_method(http_method_unknown),
|
|
m_http_ver_hi(0),
|
|
m_http_ver_lo(0),
|
|
m_have_to_block(false),
|
|
m_full_request_buf_size{}
|
|
{}
|
|
|
|
http_method m_http_method;
|
|
std::string m_URI;
|
|
std::string m_http_method_str;
|
|
std::string m_full_request_str;
|
|
std::string m_replace_html;
|
|
std::string m_request_head;
|
|
int m_http_ver_hi;
|
|
int m_http_ver_lo;
|
|
bool m_have_to_block;
|
|
http_header_info m_header_info;
|
|
uri_content m_uri_content;
|
|
size_t m_full_request_buf_size;
|
|
std::string m_body;
|
|
|
|
void clear()
|
|
{
|
|
this->~http_request_info();
|
|
new(this) http_request_info();
|
|
}
|
|
};
|
|
|
|
|
|
struct http_response_info
|
|
{
|
|
int m_response_code;
|
|
std::string m_response_comment;
|
|
fields_list m_additional_fields;
|
|
std::string m_body;
|
|
std::string m_mime_tipe;
|
|
http_header_info m_header_info;
|
|
int m_http_ver_hi;// OUT paramter only
|
|
int m_http_ver_lo;// OUT paramter only
|
|
|
|
void clear()
|
|
{
|
|
this->~http_response_info();
|
|
new(this) http_response_info();
|
|
}
|
|
};
|
|
}
|
|
}
|
|
}
|