29 #ifndef WEBSOCKETPP_CLOSE_HPP 30 #define WEBSOCKETPP_CLOSE_HPP 185 return ((code >= rsv_start && code <= rsv_end) ||
200 return (code <= invalid_low || code >= invalid_high ||
201 code == no_status || code == abnormal_close ||
202 code == tls_handshake);
218 return (code == protocol_error || code == invalid_payload ||
219 code == policy_violation || code == message_too_big ||
220 code == internal_endpoint_error);
235 return "Normal close";
239 return "Protocol error";
241 return "Unsupported data";
243 return "No status set";
245 return "Abnormal close";
247 return "Invalid payload";
249 return "Policy violoation";
251 return "Message too big";
253 return "Extension required";
255 return "Internal endpoint error";
257 return "Service restart";
259 return "Try again later";
261 return "Bad gateway";
263 return "TLS handshake failure";
265 return "Generic subprotocol error";
267 return "Invalid subprotocol data";
297 ec = lib::error_code();
299 if (payload.size() == 0) {
301 }
else if (payload.size() == 1) {
308 val.
c[0] = payload[0];
309 val.
c[1] = payload[1];
337 ec = lib::error_code();
339 if (payload.size() > 2) {
340 reason.append(payload.begin()+2,payload.end());
353 #endif // WEBSOCKETPP_CLOSE_HPP static value const internal_endpoint_error
An endpoint encountered an unexpected condition that prevented it from fulfilling the request...
uint16_t value
The type of a close code value.
lib::error_code make_error_code(error::value e)
static value const invalid_payload
An endpoint received message data inconsistent with its type.
bool terminal(value code)
Determine if the code represents an unrecoverable error.
static value const extension_required
A client expected the server to accept a required extension request.
static value const try_again_later
Indicates that the service is experiencing overload.
static value const invalid_high
Last value in range that is always invalid on the wire.
bool reserved(value code)
Test whether a close code is in a reserved range.
static value const protocol_error
A protocol error occurred.
static value const normal
Normal closure, meaning that the purpose for which the connection was established has been fulfilled...
static value const invalid_low
First value in range that is always invalid on the wire.
static value const invalid_subprotocol_data
A invalid subprotocol data.
status::value extract_code(std::string const &payload, lib::error_code &ec)
Extract a close code value from a close payload.
static value const policy_violation
An endpoint received a message that violated its policy.
static value const subprotocol_error
A generic subprotocol error.
static value const tls_handshake
An endpoint failed to perform a TLS handshake.
bool invalid(value code)
Test whether a close code is invalid on the wire.
static value const bad_gateway
Indicates that the server was acting as a gateway or proxy and received an invalid response from the ...
Unable to parse close code.
static value const unsupported_data
The connection was terminated because an endpoint received a type of data it cannot accept...
bool validate(std::string const &s)
Validate a UTF8 string.
Close code is in a reserved range.
static value const rsv_start
First value in range reserved for future protocol use.
Namespace for the WebSocket++ project.
static value const going_away
The endpoint was "going away", such as a server going down or a browser navigating away from a page...
static value const service_restart
Indicates that the service is restarted.
void close(T *e, websocketpp::connection_hdl hdl)
static value const omit_handshake
Close the connection without a WebSocket close handshake.
static value const rsv_end
Last value in range reserved for future protocol use.
static value const no_status
A dummy value to indicate that no status code was received.
static value const message_too_big
An endpoint received a message too large to process.
static value const force_tcp_drop
Close the connection with a forced TCP drop.
std::string get_string(value code)
Return a human readable interpretation of a WebSocket close code.
static value const abnormal_close
A dummy value to indicate that the connection was closed abnormally.
Type used to convert close statuses between integer and wire representations.
std::string extract_reason(std::string const &payload, lib::error_code &ec)
Extract the reason string from a close payload.
static value const blank
A blank value for internal use.