| Index: net/http/http_stream_parser.h
|
| ===================================================================
|
| --- net/http/http_stream_parser.h (revision 0)
|
| +++ net/http/http_stream_parser.h (revision 0)
|
| @@ -0,0 +1,167 @@
|
| +// Copyright (c) 2009 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.
|
| +
|
| +#ifndef NET_HTTP_HTTP_STREAM_PARSER_H_
|
| +#define NET_HTTP_HTTP_STREAM_PARSER_H_
|
| +
|
| +#include <string>
|
| +
|
| +#include "base/basictypes.h"
|
| +#include "net/base/io_buffer.h"
|
| +#include "net/base/upload_data_stream.h"
|
| +#include "net/http/http_chunked_decoder.h"
|
| +#include "net/http/http_response_info.h"
|
| +#include "net/socket/client_socket_handle.h"
|
| +
|
| +namespace net {
|
| +
|
| +class ClientSocketHandle;
|
| +class HttpRequestInfo;
|
| +
|
| +class HttpStreamParser {
|
| + public:
|
| + // Any data in |read_buffer| will be used before reading from the socket
|
| + // and any data left over after parsing the stream will be put into
|
| + // |read_buffer|. The left over data will start at offset 0 and the
|
| + // buffer's offset will be set to the first free byte. |read_buffer| may
|
| + // have its capacity changed.
|
| + HttpStreamParser(ClientSocketHandle* connection,
|
| + GrowableIOBuffer* read_buffer);
|
| + ~HttpStreamParser() {}
|
| +
|
| + // These functions implement the interface described in HttpStream with
|
| + // some additional functionality
|
| + int SendRequest(const HttpRequestInfo* request, const std::string& headers,
|
| + UploadDataStream* request_body, CompletionCallback* callback);
|
| +
|
| + int ReadResponseHeaders(CompletionCallback* callback);
|
| +
|
| + int ReadResponseBody(IOBuffer* buf, int buf_len,
|
| + CompletionCallback* callback);
|
| +
|
| + uint64 GetUploadProgress() const;
|
| +
|
| + HttpResponseInfo* GetResponseInfo();
|
| +
|
| + bool IsResponseBodyComplete() const;
|
| +
|
| + bool CanFindEndOfResponse() const;
|
| +
|
| + bool IsMoreDataBuffered() const;
|
| +
|
| + private:
|
| + // FOO_COMPLETE states implement the second half of potentially asynchronous
|
| + // operations and don't necessarily mean that FOO is complete.
|
| + enum State {
|
| + STATE_NONE,
|
| + STATE_SENDING_HEADERS,
|
| + STATE_SENDING_BODY,
|
| + STATE_REQUEST_SENT,
|
| + STATE_READ_HEADERS,
|
| + STATE_READ_HEADERS_COMPLETE,
|
| + STATE_BODY_PENDING,
|
| + STATE_READ_BODY,
|
| + STATE_READ_BODY_COMPLETE,
|
| + STATE_DONE
|
| + };
|
| +
|
| + // The number of bytes by which the header buffer is grown when it reaches
|
| + // capacity.
|
| + enum { kHeaderBufInitialSize = 4096 };
|
| +
|
| + // |kMaxHeaderBufSize| is the number of bytes that the response headers can
|
| + // grow to. If the body start is not found within this range of the
|
| + // response, the transaction will fail with ERR_RESPONSE_HEADERS_TOO_BIG.
|
| + // Note: |kMaxHeaderBufSize| should be a multiple of |kHeaderBufInitialSize|.
|
| + enum { kMaxHeaderBufSize = 256 * 1024 }; // 256 kilobytes.
|
| +
|
| + // Handle callbacks.
|
| + void OnIOComplete(int result);
|
| +
|
| + // Try to make progress sending/receiving the request/response.
|
| + int DoLoop(int result);
|
| +
|
| + // The implementations of each state of the state machine.
|
| + int DoSendHeaders(int result);
|
| + int DoSendBody(int result);
|
| + int DoReadHeaders();
|
| + int DoReadHeadersComplete(int result);
|
| + int DoReadBody();
|
| + int DoReadBodyComplete(int result);
|
| +
|
| + // Examines |read_buf_| to find the start and end of the headers. Return
|
| + // the offset for the end of the headers, or -1 if the complete headers
|
| + // were not found. If they are are found, parse them with
|
| + // DoParseResponseHeaders().
|
| + int ParseResponseHeaders();
|
| +
|
| + // Parse the headers into response_.
|
| + void DoParseResponseHeaders(int end_of_header_offset);
|
| +
|
| + // Examine the parsed headers to try to determine the response body size.
|
| + void CalculateResponseBodySize();
|
| +
|
| + // Current state of the request.
|
| + State io_state_;
|
| +
|
| + // The request to send.
|
| + const HttpRequestInfo* request_;
|
| +
|
| + // The request header data.
|
| + scoped_refptr<DrainableIOBuffer> request_headers_;
|
| +
|
| + // The request body data.
|
| + scoped_ptr<UploadDataStream> request_body_;
|
| +
|
| + // Temporary buffer for reading.
|
| + scoped_refptr<GrowableIOBuffer> read_buf_;
|
| +
|
| + // Offset of the first unused byte in |read_buf_|. May be nonzero due to
|
| + // a 1xx header, or body data in the same packet as header data.
|
| + int read_buf_unused_offset_;
|
| +
|
| + // The amount beyond |read_buf_unused_offset_| where the status line starts;
|
| + // -1 if not found yet.
|
| + int response_header_start_offset_;
|
| +
|
| + // The parsed response headers.
|
| + HttpResponseInfo response_;
|
| +
|
| + // Indicates the content length. If this value is less than zero
|
| + // (and chunked_decoder_ is null), then we must read until the server
|
| + // closes the connection.
|
| + int64 response_body_length_;
|
| +
|
| + // Keep track of the number of response body bytes read so far.
|
| + int64 response_body_read_;
|
| +
|
| + // Helper if the data is chunked.
|
| + scoped_ptr<HttpChunkedDecoder> chunked_decoder_;
|
| +
|
| + // Where the caller wants the body data.
|
| + scoped_refptr<IOBuffer> user_read_buf_;
|
| + int user_read_buf_len_;
|
| +
|
| + // The callback to notify a user that their request or response is
|
| + // complete or there was an error
|
| + CompletionCallback* user_callback_;
|
| +
|
| + // In the client callback, the client can do anything, including
|
| + // destroying this class, so any pending callback must be issued
|
| + // after everything else is done. When it is time to issue the client
|
| + // callback, move it from |user_callback_| to |scheduled_callback_|.
|
| + CompletionCallback* scheduled_callback_;
|
| +
|
| + // The underlying socket.
|
| + ClientSocketHandle* const connection_;
|
| +
|
| + // Callback to be used when doing IO.
|
| + CompletionCallbackImpl<HttpStreamParser> io_callback_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(HttpStreamParser);
|
| +};
|
| +
|
| +} // namespace net
|
| +
|
| +#endif // NET_HTTP_HTTP_STREAM_PARSER_H_
|
|
|
| Property changes on: net/http/http_stream_parser.h
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|