class HTTPParser(LineReceiver): (source)
Known subclasses: twisted.web._newclient.HTTPClientParser
HTTPParser
handles the parsing side of HTTP processing. With a suitable subclass, it can parse either the client side or the server side of the connection.
Method | all |
Callback invoked after the last header is passed to headerReceived. Override this to change to the BODY or DONE state. |
Method | connection |
Called when a connection is made. |
Method | header |
Store the given header in self.headers. |
Method | is |
Return True if the given lower-cased name is the name of a connection control header (rather than an entity header). |
Method | line |
Handle one line from a response. |
Method | raw |
Pass data from the message body to the body decoder object. |
Method | status |
Callback invoked whenever the first line of a new message is received. Override this. |
Method | switch |
Switch to body parsing mode - interpret any more bytes delivered as part of the message body and deliver them to the given decoder. |
Constant | CONNECTION |
Undocumented |
Class Variable | delimiter |
Undocumented |
Instance Variable | body |
Undocumented |
Instance Variable | conn |
All of the connection control message headers yet received. See CONNECTION_CONTROL_HEADERS and isConnectionControlHeader . |
Instance Variable | headers |
All of the non-connection control message headers yet received. |
Instance Variable | state |
State indicator for the response parsing state machine. One of STATUS, HEADER, BODY, DONE. |
Instance Variable | _partial |
None or a list of the lines of a multiline header while that header is being received. |
Inherited from LineReceiver
:
Method | clear |
Clear buffered data. |
Method | data |
Protocol.dataReceived. Translates bytes into lines, and calls lineReceived (or rawDataReceived, depending on mode.) |
Method | line |
Called when the maximum line length has been reached. Override if it needs to be dealt with in some special way. |
Method | send |
Sends a line to the other end of the connection. |
Method | set |
Sets the line-mode of this receiver. |
Method | set |
Sets the raw mode of this receiver. Further data received will be sent to rawDataReceived rather than lineReceived. |
Constant | MAX |
The maximum length of a line to allow (If a sent line is longer than this, the connection is dropped). Default is 16384. |
Instance Variable | line |
Undocumented |
Instance Variable | _buffer |
Undocumented |
Instance Variable | _busy |
Undocumented |
Inherited from Protocol
(via LineReceiver
):
Method | connection |
Called when the connection is shut down. |
Method | log |
Return a prefix matching the class name, to identify log messages related to this protocol instance. |
Class Variable | factory |
Undocumented |
Inherited from BaseProtocol
(via LineReceiver
, Protocol
):
Method | make |
Make a connection to a transport and a server. |
Instance Variable | connected |
Undocumented |
Instance Variable | transport |
Undocumented |
Inherited from _PauseableMixin
(via LineReceiver
, Protocol
, BaseProtocol
):
Method | pause |
Undocumented |
Method | resume |
Undocumented |
Method | stop |
Undocumented |
Instance Variable | paused |
Undocumented |
twisted.web._newclient.HTTPClientParser
Callback invoked after the last header is passed to headerReceived. Override this to change to the BODY or DONE state.
Called when a connection is made.
This may be considered the initializer of the protocol, because it is called when the connection is completed. For clients, this is called once the connection to the server has been established; for servers, this is called after an accept() call stops blocking and a socket has been received. If you need to send any greeting or initial message, do it here.
twisted.web._newclient.HTTPClientParser
Return True if the given lower-cased name is the name of a connection control header (rather than an entity header).
According to RFC 2616, section 14.10, the tokens in the Connection header are probably relevant here. However, I am not sure what the practical consequences of either implementing or ignoring that are. So I leave it unimplemented for the time being.
twisted.web._newclient.HTTPClientParser
Callback invoked whenever the first line of a new message is received. Override this.
Parameters | |
status:bytes | The first line of an HTTP request or response message without trailing CR LF. |
Switch to body parsing mode - interpret any more bytes delivered as part of the message body and deliver them to the given decoder.
Undocumented
Value |
|
All of the connection control message headers yet received. See CONNECTION_CONTROL_HEADERS
and isConnectionControlHeader
.
twisted.web._newclient.HTTPClientParser
State indicator for the response parsing state machine. One of STATUS, HEADER, BODY, DONE.