aboutsummaryrefslogtreecommitdiff
path: root/src/common/http_connection.h
diff options
context:
space:
mode:
authorThomas Winget <tewinget@gmail.com>2015-03-25 07:30:23 -0400
committerThomas Winget <tewinget@gmail.com>2015-03-25 07:30:23 -0400
commit874f48bc82a5d73695171287a8397d037b471547 (patch)
tree8db94233f02c113f2f0a91febfba55a3f6beeb79 /src/common/http_connection.h
parentBerkeleyDB implementation of BlockchainDB seems to be working! (diff)
parentMerge upstream updates into blockchain branch (diff)
downloadmonero-874f48bc82a5d73695171287a8397d037b471547.tar.xz
update berkeleydb branch to blockchain branch
Diffstat (limited to 'src/common/http_connection.h')
-rw-r--r--src/common/http_connection.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/src/common/http_connection.h b/src/common/http_connection.h
new file mode 100644
index 000000000..759145009
--- /dev/null
+++ b/src/common/http_connection.h
@@ -0,0 +1,42 @@
+#pragma once
+
+#include "string_tools.h"
+#include "net/http_client.h"
+
+namespace tools {
+
+class t_http_connection {
+private:
+ epee::net_utils::http::http_simple_client * mp_http_client;
+ bool m_ok;
+public:
+ static unsigned int const TIMEOUT = 200000;
+
+ t_http_connection(
+ epee::net_utils::http::http_simple_client * p_http_client
+ , uint32_t ip
+ , uint16_t port
+ )
+ : mp_http_client(p_http_client)
+ {
+ // TODO fix http client so that it accepts properly typed arguments
+ std::string ip_str = epee::string_tools::get_ip_string_from_int32(ip);
+ std::string port_str = boost::lexical_cast<std::string>(port);
+ m_ok = mp_http_client->connect(ip_str, port_str, TIMEOUT);
+ }
+
+ ~t_http_connection()
+ {
+ if (m_ok)
+ {
+ mp_http_client->disconnect();
+ }
+ }
+
+ bool is_open()
+ {
+ return m_ok;
+ }
+}; // class t_http_connection
+
+} // namespace tools