2015-11-27 00:17:36 +00:00
|
|
|
package codec
|
|
|
|
|
2015-11-28 11:22:29 +00:00
|
|
|
import (
|
|
|
|
"io"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
Error MessageType = iota
|
|
|
|
Request
|
|
|
|
Response
|
|
|
|
Publication
|
|
|
|
)
|
|
|
|
|
|
|
|
type MessageType int
|
|
|
|
|
|
|
|
// Takes in a connection/buffer and returns a new Codec
|
|
|
|
type NewCodec func(io.ReadWriteCloser) Codec
|
|
|
|
|
|
|
|
// Codec encodes/decodes various types of
|
|
|
|
// messages used within go-micro
|
2015-11-27 00:17:36 +00:00
|
|
|
type Codec interface {
|
2015-11-28 11:22:29 +00:00
|
|
|
Encoder
|
|
|
|
Decoder
|
|
|
|
Close() error
|
2015-11-27 00:17:36 +00:00
|
|
|
String() string
|
|
|
|
}
|
2015-11-28 11:22:29 +00:00
|
|
|
|
|
|
|
type Encoder interface {
|
|
|
|
Write(*Message, interface{}) error
|
|
|
|
}
|
|
|
|
|
|
|
|
type Decoder interface {
|
|
|
|
ReadHeader(*Message, MessageType) error
|
|
|
|
ReadBody(interface{}) error
|
|
|
|
}
|
|
|
|
|
|
|
|
// Message represents detailed information about
|
|
|
|
// the communication, likely followed by the body.
|
|
|
|
// In the case of an error, body may be nil.
|
|
|
|
type Message struct {
|
|
|
|
Id uint64
|
|
|
|
Type MessageType
|
|
|
|
Target string
|
|
|
|
Method string
|
|
|
|
Error string
|
|
|
|
Headers map[string]string
|
|
|
|
}
|