#include "JsonRequest.h" #include "Profiler.h" #include "Poco/JSON/Object.h" #include "Poco/Net/HTTPSClientSession.h" #include "Poco/Net/HTTPRequest.h" #include "Poco/Net/HTTPResponse.h" #include "Poco/JSON/Parser.h" JsonRequest::JsonRequest(const std::string& serverHost, int serverPort) : mServerHost(serverHost), mServerPort(serverPort) { } JsonRequest::~JsonRequest() { } JsonRequestReturn JsonRequest::request(const char* methodName, const Poco::Net::NameValueCollection& payload) { static const char* functionName = "JsonRequest::request"; Poco::JSON::Object requestJson; requestJson.set("method", methodName); for(auto it = payload.begin(); it != payload.end(); it++) { requestJson.set(it->first, it->second); } //requestJson.set("user", std::string(mSessionUser->getPublicKeyHex())); // send post request via https // 443 = HTTPS Default // TODO: adding port into ServerConfig try { Profiler phpRequestTime; Poco::Net::HTTPSClientSession httpsClientSession(mServerHost, mServerPort); Poco::Net::HTTPRequest request(Poco::Net::HTTPRequest::HTTP_POST, "/TransactionJsonRequestHandler"); request.setChunkedTransferEncoding(true); std::ostream& requestStream = httpsClientSession.sendRequest(request); requestJson.stringify(requestStream); Poco::Net::HTTPResponse response; std::istream& request_stream = httpsClientSession.receiveResponse(response); // debugging answer std::stringstream responseStringStream; for (std::string line; std::getline(request_stream, line); ) { responseStringStream << line << std::endl; } Poco::Logger& speedLog = Poco::Logger::get("SpeedLog"); speedLog.information("[%s] php server time: %s", methodName, phpRequestTime.string()); // extract parameter from request Poco::JSON::Parser jsonParser; Poco::Dynamic::Var parsedJson; try { parsedJson = jsonParser.parse(responseStringStream.str()); } catch (Poco::Exception& ex) { addError(new ParamError(functionName, "error parsing request answer", ex.displayText().data())); std::string fileName = "response_"; fileName += methodName; fileName += ".html"; FILE* f = fopen(fileName.data(), "wt"); std::string responseString = responseStringStream.str(); fwrite(responseString.data(), 1, responseString.size(), f); fclose(f); // */ sendErrorsAsEmail(responseStringStream.str()); return JSON_REQUEST_RETURN_PARSE_ERROR; } Poco::JSON::Object object = *parsedJson.extract(); auto state = object.get("state"); std::string stateString = state.convert(); if (stateString == "error") { addError(new Error(functionName, "php server return error")); if (!object.isNull("msg")) { addError(new ParamError(functionName, "msg:", object.get("msg").convert().data())); } if (!object.isNull("details")) { addError(new ParamError(functionName, "details:", object.get("details").convert().data())); } sendErrorsAsEmail(); return JSON_REQUEST_RETURN_ERROR; } } catch (Poco::Exception& e) { addError(new ParamError(functionName, "connect error to php server", e.displayText().data())); sendErrorsAsEmail(); return JSON_REQUEST_CONNECT_ERROR; } return JSON_REQUEST_RETURN_OK; }