// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // A set of common constants that are needed for the WebSocket handshake. // In general, you should prefer using these constants to literal strings, // except in tests. // // These constants cannot be used in files that are compiled on iOS, because // this file is not compiled on iOS. #ifndef NET_WEBSOCKETS_WEBSOCKET_HANDSHAKE_CONSTANTS_H_ #define NET_WEBSOCKETS_WEBSOCKET_HANDSHAKE_CONSTANTS_H_ #include "base/basictypes.h" // This file plases constants inside the ::net::websockets namespace to avoid // risk of collisions with other symbols in libnet. namespace net { namespace websockets { // "HTTP/1.1" // RFC6455 only requires HTTP/1.1 "or better" but in practice an HTTP version // other than 1.1 should not occur in a WebSocket handshake. extern const char* const kHttpProtocolVersion; // The Sec-WebSockey-Key challenge is 16 random bytes, base64 encoded. extern const size_t kRawChallengeLength; // "Sec-WebSocket-Protocol" extern const char* const kSecWebSocketProtocol; // "Sec-WebSocket-Extensions" extern const char* const kSecWebSocketExtensions; // "Sec-WebSocket-Key" extern const char* const kSecWebSocketKey; // "Sec-WebSocket-Accept" extern const char* const kSecWebSocketAccept; // "Sec-WebSocket-Version" extern const char* const kSecWebSocketVersion; // This implementation only supports one version of the WebSocket protocol, // "13", as specified in RFC6455. If support for multiple versions is added in // future, it will probably no longer be worth having a constant for this. extern const char* const kSupportedVersion; // "Upgrade" extern const char* const kUpgrade; // "258EAFA5-E914-47DA-95CA-C5AB0DC85B11" as defined in section 4.1 of // RFC6455. extern const char* const kWebSocketGuid; // Colon-prefixed lowercase headers for SPDY3. // ":sec-websocket-protocol" extern const char* const kSecWebSocketProtocolSpdy3; // ":sec-websocket-extensions" extern const char* const kSecWebSocketExtensionsSpdy3; // Some parts of the code require lowercase versions of the header names in // order to do case-insensitive comparisons, or because of SPDY. // "sec-websocket-protocol" extern const char* const kSecWebSocketProtocolLowercase; // "sec-websocket-extensions" extern const char* const kSecWebSocketExtensionsLowercase; // "sec-webSocket-key" extern const char* const kSecWebSocketKeyLowercase; // "sec-websocket-version" extern const char* const kSecWebSocketVersionLowercase; // "upgrade" extern const char* const kUpgradeLowercase; // "websocket", as used in the "Upgrade:" header. This is always lowercase // (except in obsolete versions of the protocol). extern const char* const kWebSocketLowercase; } // namespace websockets } // namespace net #endif // NET_WEBSOCKETS_WEBSOCKET_HANDSHAKE_CONSTANTS_H_