OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef NET_WEBSOCKETS_WEBSOCKET_FRAME_PARSER_H_ | |
6 #define NET_WEBSOCKETS_WEBSOCKET_FRAME_PARSER_H_ | |
7 #pragma once | |
8 | |
9 #include <vector> | |
10 | |
11 #include "base/memory/ref_counted.h" | |
12 #include "base/memory/scoped_ptr.h" | |
13 #include "base/memory/scoped_vector.h" | |
14 #include "net/base/net_export.h" | |
15 #include "net/websockets/websocket_frame.h" | |
16 | |
17 namespace net { | |
18 | |
19 // Parses WebSocket frames from byte stream. | |
20 // | |
21 // Specification of WebSocket frame format is available at | |
22 // <http://tools.ietf.org/html/rfc6455#section-5>. | |
23 | |
24 class NET_EXPORT_PRIVATE WebSocketFrameParser { | |
25 public: | |
26 WebSocketFrameParser(); | |
27 ~WebSocketFrameParser(); | |
28 | |
29 // Decodes the given byte stream and stores parsed WebSocket frames in | |
30 // |frames|. | |
31 // | |
32 // If the parser encounters invalid payload length format, Decode() fails | |
33 // and returns false. Once Decode() has failed, the parser refuses to decode | |
34 // any more data and future invocations of Decode() will simply return false. | |
35 // | |
36 // Payload data of parsed WebSocket frames may be incomplete; see comments in | |
37 // websocket_frame.h for more details. | |
38 bool Decode(const char* data, | |
39 size_t length, | |
40 ScopedVector<WebSocketFrameChunk>* frame_chunks); | |
41 | |
42 // Returns true if the parser has ever failed to decode a WebSocket frame. | |
43 // TODO(yutak): Provide human-readable description of failure. | |
44 bool failed() const { return failed_; } | |
45 | |
46 private: | |
47 // Tries to decode a frame header from |current_read_pos_|. | |
48 // If successful, this function updates |current_read_pos_|, | |
49 // |current_frame_header_|, and |masking_key_| (if available). | |
50 // This function may set |failed_| to true if it observes a corrupt frame. | |
51 // If there is not enough data in the remaining buffer to parse a frame | |
52 // header, this function returns without doing anything. | |
53 void DecodeFrameHeader(); | |
54 | |
55 // Decodes frame payload and creates a WebSocketFrameChunk object. | |
56 // This function updates |current_read_pos_| and |frame_offset_| after | |
57 // parsing. This function returns a frame object even if no payload data is | |
58 // available at this moment, so the receiver could make use of frame header | |
59 // information. If the end of frame is reached, this function clears | |
60 // |current_frame_header_|, |frame_offset_| and |masking_key_|. | |
61 scoped_ptr<WebSocketFrameChunk> DecodeFramePayload(bool first_chunk); | |
62 | |
63 // Internal buffer to store the data to parse. | |
64 std::vector<char> buffer_; | |
65 | |
66 // Position in |buffer_| where the next round of parsing starts. | |
67 size_t current_read_pos_; | |
68 | |
69 // Frame header and masking key of the current frame. | |
70 // |masking_key_| is filled with zeros if the current frame is not masked. | |
71 scoped_ptr<WebSocketFrameHeader> current_frame_header_; | |
72 char masking_key_[WebSocketFrameHeader::kMaskingKeyLength]; | |
73 | |
74 // Amount of payload data read so far for the current frame. | |
75 uint64 frame_offset_; | |
76 | |
77 bool failed_; | |
78 }; | |
willchan no longer on Chromium
2012/05/09 08:00:11
DISALLOW_COPY_AND_ASSIGN
Yuta Kitamura
2012/05/09 08:24:10
Done.
| |
79 | |
80 } // namespace net | |
81 | |
82 #endif // NET_WEBSOCKETS_WEBSOCKET_FRAME_PARSER_H_ | |
OLD | NEW |