Add close handling

This commit is contained in:
flamingcow
2019-05-11 21:52:49 -07:00
parent 89876f5bd6
commit ec99454756
2 changed files with 20 additions and 0 deletions

View File

@@ -20,10 +20,21 @@ Request::Request(Connection* conn)
: conn_(conn), : conn_(conn),
out_buf_(64*1024) {} out_buf_(64*1024) {}
Request::~Request() {
if (on_close_) {
on_close_();
}
}
void Request::NewRequest(uint16_t request_id) { void Request::NewRequest(uint16_t request_id) {
if (on_close_) {
on_close_();
}
request_id_ = request_id; request_id_ = request_id;
params_.clear(); params_.clear();
body_ = {}; body_ = {};
on_close_ = nullptr;
out_buf_.Reset(); out_buf_.Reset();
body_written_ = false; body_written_ = false;
} }
@@ -53,6 +64,10 @@ const std::string_view& Request::GetBody() const {
return body_; return body_;
} }
void Request::OnClose(const std::function<void()>& on_close) {
on_close_ = on_close;
}
void Request::WriteHeader(const std::string_view& name, const std::string_view& value) { void Request::WriteHeader(const std::string_view& name, const std::string_view& value) {
std::lock_guard<std::recursive_mutex> l(output_mu_); std::lock_guard<std::recursive_mutex> l(output_mu_);

View File

@@ -15,6 +15,7 @@ class Connection;
class Request { class Request {
public: public:
Request(Connection *conn); Request(Connection *conn);
~Request();
void NewRequest(uint16_t request_id); void NewRequest(uint16_t request_id);
@@ -26,6 +27,8 @@ class Request {
const std::string_view& GetParam(const std::string_view& key) const; const std::string_view& GetParam(const std::string_view& key) const;
const std::string_view& GetBody() const; const std::string_view& GetBody() const;
void OnClose(const std::function<void()>& callback);
void WriteHeader(const std::string_view& name, const std::string_view& value); void WriteHeader(const std::string_view& name, const std::string_view& value);
void WriteBody(const std::string_view& body); void WriteBody(const std::string_view& body);
[[nodiscard]] bool Flush(); [[nodiscard]] bool Flush();
@@ -47,6 +50,8 @@ class Request {
std::unordered_map<std::string_view, std::string_view> params_; std::unordered_map<std::string_view, std::string_view> params_;
std::string_view body_; std::string_view body_;
std::function<void()> on_close_;
firebuf::Buffer out_buf_; firebuf::Buffer out_buf_;
bool body_written_; bool body_written_;
std::recursive_mutex output_mu_; std::recursive_mutex output_mu_;