Documentation
¶
Overview ¶
Package spdy implements the SPDY protocol (currently SPDY/3), described in http://www.chromium.org/spdy/spdy-protocol/spdy-protocol-draft3.
Index ¶
- Constants
- type ControlFlags
- type ControlFrameHeader
- type ControlFrameType
- type DataFlags
- type DataFrame
- type Error
- type ErrorCode
- type Frame
- type Framer
- type GoAwayFrame
- type GoAwayStatus
- type HeadersFrame
- type PingFrame
- type RstStreamFrame
- type RstStreamStatus
- type SettingsFlag
- type SettingsFlagIdValue
- type SettingsFrame
- type SettingsId
- type StreamId
- type SynReplyFrame
- type SynStreamFrame
- type WindowUpdateFrame
Constants ¶
const (
TypeSynStream ControlFrameType = 0x0001
TypeSynReply = 0x0002
TypeRstStream = 0x0003
TypeSettings = 0x0004
TypePing = 0x0006
TypeGoAway = 0x0007
TypeHeaders = 0x0008
TypeWindowUpdate = 0x0009
)
const (
ControlFlagFin ControlFlags = 0x01
ControlFlagUnidirectional = 0x02
ControlFlagSettingsClearSettings = 0x01
)
const (
UnlowercasedHeaderName ErrorCode = "header was not lowercased"
DuplicateHeaders = "multiple headers with same name"
WrongCompressedPayloadSize = "compressed payload size was incorrect"
UnknownFrameType = "unknown frame type"
InvalidControlFrame = "invalid control frame"
InvalidDataFrame = "invalid data frame"
InvalidHeaderPresent = "frame contained invalid header"
ZeroStreamId = "stream id zero is disallowed"
)
const MaxDataLength = 1<<24 - 1
MaxDataLength is the maximum number of bytes that can be stored in one frame.
const Version = 3
Version is the protocol version number that this package implements.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ControlFlags ¶
type ControlFlags uint8
ControlFlags are the flags that can be set on a control frame.
type ControlFrameHeader ¶
type ControlFrameHeader struct {
Flags ControlFlags
// contains filtered or unexported fields
}
ControlFrameHeader contains all the fields in a control frame header, in its unpacked in-memory representation.
type ControlFrameType ¶
type ControlFrameType uint16
ControlFrameType stores the type field in a control frame header.
type DataFlags ¶
type DataFlags uint8
DataFlags are the flags that can be set on a data frame.
const (
DataFlagFin DataFlags = 0x01
)
type DataFrame ¶
type DataFrame struct {
// Note, high bit is the "Control" bit. Should be 0 for data frames.
StreamId StreamId
Flags DataFlags
Data []byte // payload data of this frame
}
DataFrame is the unpacked, in-memory representation of a DATA frame.
type Error ¶
type Error struct {
Err ErrorCode
StreamId StreamId
}
Error contains both the type of error and additional values. StreamId is 0 if Error is not associated with a stream.
type Frame ¶
type Frame interface {
// contains filtered or unexported methods
}
Frame is a single SPDY frame in its unpacked in-memory representation. Use Framer to read and write it.
type Framer ¶
type Framer struct {
// contains filtered or unexported fields
}
Framer handles serializing/deserializing SPDY frames, including compressing/ decompressing payloads.
func NewFramer ¶
func NewFramer(w io.Writer, r io.Reader) (*Framer, error)
NewFramer allocates a new Framer for a given SPDY connection, represented by a io.Writer and io.Reader. Note that Framer will read and write individual fields from/to the Reader and Writer, so the caller should pass in an appropriately buffered implementation to optimize performance.
func (*Framer) ReadFrame ¶
func (f *Framer) ReadFrame() (Frame, error)
ReadFrame reads SPDY encoded data and returns a decompressed Frame.
func (*Framer) WriteFrame ¶
func (f *Framer) WriteFrame(frame Frame) error
WriteFrame writes a frame.
type GoAwayFrame ¶
type GoAwayFrame struct {
CFHeader ControlFrameHeader
LastGoodStreamId StreamId // last stream id which was accepted by sender
Status GoAwayStatus
}
GoAwayFrame is the unpacked, in-memory representation of a GOAWAY frame.
type GoAwayStatus ¶
type GoAwayStatus uint32
GoAwayStatus represents the status in a GoAwayFrame.
const (
GoAwayOK GoAwayStatus = iota
GoAwayProtocolError
GoAwayInternalError
)
type HeadersFrame ¶
type HeadersFrame struct {
CFHeader ControlFrameHeader
StreamId StreamId
Headers http.Header
}
HeadersFrame is the unpacked, in-memory representation of a HEADERS frame.
type PingFrame ¶
type PingFrame struct {
CFHeader ControlFrameHeader
Id uint32 // unique id for this ping, from server is even, from client is odd.
}
PingFrame is the unpacked, in-memory representation of a PING frame.
type RstStreamFrame ¶
type RstStreamFrame struct {
CFHeader ControlFrameHeader
StreamId StreamId
Status RstStreamStatus
}
RstStreamFrame is the unpacked, in-memory representation of a RST_STREAM frame.
type RstStreamStatus ¶
type RstStreamStatus uint32
RstStreamStatus represents the status that led to a RST_STREAM.
const (
ProtocolError RstStreamStatus = iota + 1
InvalidStream
RefusedStream
UnsupportedVersion
Cancel
InternalError
FlowControlError
StreamInUse
StreamAlreadyClosed
InvalidCredentials
FrameTooLarge
)
type SettingsFlag ¶
type SettingsFlag uint8
SettingsFlag represents a flag in a SETTINGS frame.
const (
FlagSettingsPersistValue SettingsFlag = 0x1
FlagSettingsPersisted = 0x2
)
type SettingsFlagIdValue ¶
type SettingsFlagIdValue struct {
Flag SettingsFlag
Id SettingsId
Value uint32
}
SettingsFlagIdValue is the unpacked, in-memory representation of the combined flag/id/value for a setting in a SETTINGS frame.
type SettingsFrame ¶
type SettingsFrame struct {
CFHeader ControlFrameHeader
FlagIdValues []SettingsFlagIdValue
}
SettingsFrame is the unpacked, in-memory representation of a SPDY SETTINGS frame.
type SettingsId ¶
type SettingsId uint32
SettingsFlag represents the id of an id/value pair in a SETTINGS frame.
const (
SettingsUploadBandwidth SettingsId = iota + 1
SettingsDownloadBandwidth
SettingsRoundTripTime
SettingsMaxConcurrentStreams
SettingsCurrentCwnd
SettingsDownloadRetransRate
SettingsInitialWindowSize
SettingsClientCretificateVectorSize
)
type SynReplyFrame ¶
type SynReplyFrame struct {
CFHeader ControlFrameHeader
StreamId StreamId
Headers http.Header
}
SynReplyFrame is the unpacked, in-memory representation of a SYN_REPLY frame.
type SynStreamFrame ¶
type SynStreamFrame struct {
CFHeader ControlFrameHeader
StreamId StreamId
AssociatedToStreamId StreamId // stream id for a stream which this stream is associated to
Priority uint8 // priority of this frame (3-bit)
Slot uint8 // index in the server's credential vector of the client certificate
Headers http.Header
}
SynStreamFrame is the unpacked, in-memory representation of a SYN_STREAM frame.
type WindowUpdateFrame ¶
type WindowUpdateFrame struct {
CFHeader ControlFrameHeader
StreamId StreamId
DeltaWindowSize uint32 // additional number of bytes to existing window size
}
WindowUpdateFrame is the unpacked, in-memory representation of a WINDOW_UPDATE frame.