summaryrefslogtreecommitdiffstats
path: root/net/websockets/websocket_handshake_constants.h
blob: 43d3efda0f860d4b64e928ac0f2e98cc5973eefc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
// 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_