summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/server/http_server.cc7
-rw-r--r--net/server/web_socket.cc24
-rw-r--r--net/server/web_socket.h1
3 files changed, 27 insertions, 5 deletions
diff --git a/net/server/http_server.cc b/net/server/http_server.cc
index 42d5752..6f2a46b 100644
--- a/net/server/http_server.cc
+++ b/net/server/http_server.cc
@@ -80,7 +80,9 @@ void HttpServer::Close(int connection_id)
if (connection == NULL)
return;
- connection->DetachSocket();
+ // Initiating close from server-side does not lead to the DidClose call.
+ // Do it manually here.
+ DidClose(connection->socket_);
}
//
@@ -237,7 +239,8 @@ void HttpServer::DidRead(ListenSocket* socket,
if (result == WebSocket::FRAME_INCOMPLETE)
break;
- if (result == WebSocket::FRAME_ERROR) {
+ if (result == WebSocket::FRAME_CLOSE ||
+ result == WebSocket::FRAME_ERROR) {
Close(connection->id());
break;
}
diff --git a/net/server/web_socket.cc b/net/server/web_socket.cc
index de5e33a..2409e0c 100644
--- a/net/server/web_socket.cc
+++ b/net/server/web_socket.cc
@@ -223,7 +223,19 @@ class WebSocketHybi10 : public WebSocket {
op_code_ = first_byte & kOpCodeMask;
masked_ = second_byte & kMaskBit;
- CHECK_EQ(kOpCodeText, op_code_);
+ switch (op_code_) {
+ case kOpCodeClose:
+ closed_ = true;
+ break;
+ case kOpCodeText:
+ break;
+ case kOpCodeBinary: // We don't support binary frames yet.
+ case kOpCodeContinuation: // We don't support binary frames yet.
+ case kOpCodePing: // We don't support binary frames yet.
+ case kOpCodePong: // We don't support binary frames yet.
+ default:
+ return FRAME_ERROR;
+ }
uint64 payload_length64 = second_byte & kPayloadLengthMask;
if (payload_length64 > kMaxSingleBytePayloadLength) {
@@ -271,10 +283,14 @@ class WebSocketHybi10 : public WebSocket {
size_t pos = p + masking_key_length + payload_length_ -
connection_->recv_data().c_str();
connection_->Shift(pos);
- return FRAME_OK;
+
+ return closed_ ? FRAME_CLOSE : FRAME_OK;
}
virtual void Send(const std::string& message) {
+ if (closed_)
+ return;
+
std::vector<char> frame;
OpCode op_code = kOpCodeText;
size_t data_length = message.length();
@@ -331,7 +347,8 @@ class WebSocketHybi10 : public WebSocket {
masked_(false),
payload_(0),
payload_length_(0),
- frame_end_(0) {
+ frame_end_(0),
+ closed_(false) {
}
OpCode op_code_;
@@ -343,6 +360,7 @@ class WebSocketHybi10 : public WebSocket {
const char* payload_;
size_t payload_length_;
const char* frame_end_;
+ bool closed_;
DISALLOW_COPY_AND_ASSIGN(WebSocketHybi10);
};
diff --git a/net/server/web_socket.h b/net/server/web_socket.h
index baed07c..66ad789 100644
--- a/net/server/web_socket.h
+++ b/net/server/web_socket.h
@@ -21,6 +21,7 @@ class WebSocket {
enum ParseResult {
FRAME_OK,
FRAME_INCOMPLETE,
+ FRAME_CLOSE,
FRAME_ERROR
};