mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-12-04 21:42:39 +00:00
47 lines
1011 B
C++
47 lines
1011 B
C++
#pragma once
|
|
|
|
#include <Interpreters/Context_fwd.h>
|
|
#include <Server/HTTP/HTTPRequestHandler.h>
|
|
#include <Poco/Logger.h>
|
|
|
|
|
|
#include <mutex>
|
|
#include <unordered_map>
|
|
|
|
|
|
namespace DB
|
|
{
|
|
/** Main handler for requests to ODBC driver
|
|
* requires connection_string and columns in request params
|
|
* and also query in request body
|
|
* response in RowBinary format
|
|
*/
|
|
class ODBCHandler : public HTTPRequestHandler, WithContext
|
|
{
|
|
public:
|
|
ODBCHandler(
|
|
size_t keep_alive_timeout_,
|
|
ContextPtr context_,
|
|
const String & mode_)
|
|
: WithContext(context_)
|
|
, log(&Poco::Logger::get("ODBCHandler"))
|
|
, keep_alive_timeout(keep_alive_timeout_)
|
|
, mode(mode_)
|
|
{
|
|
}
|
|
|
|
void handleRequest(HTTPServerRequest & request, HTTPServerResponse & response) override;
|
|
|
|
private:
|
|
Poco::Logger * log;
|
|
|
|
size_t keep_alive_timeout;
|
|
String mode;
|
|
|
|
static inline std::mutex mutex;
|
|
|
|
void processError(HTTPServerResponse & response, const std::string & message);
|
|
};
|
|
|
|
}
|