Add missing GSSEncRequest
This commit is contained in:
+8
-1
@@ -19,6 +19,7 @@ type Backend struct {
|
|||||||
describe Describe
|
describe Describe
|
||||||
execute Execute
|
execute Execute
|
||||||
flush Flush
|
flush Flush
|
||||||
|
gssEncRequest GSSEncRequest
|
||||||
parse Parse
|
parse Parse
|
||||||
passwordMessage PasswordMessage
|
passwordMessage PasswordMessage
|
||||||
query Query
|
query Query
|
||||||
@@ -45,7 +46,7 @@ func (b *Backend) Send(msg BackendMessage) error {
|
|||||||
|
|
||||||
// ReceiveStartupMessage receives the initial connection message. This method is used of the normal Receive method
|
// ReceiveStartupMessage receives the initial connection message. This method is used of the normal Receive method
|
||||||
// because the initial connection message is "special" and does not include the message type as the first byte. This
|
// because the initial connection message is "special" and does not include the message type as the first byte. This
|
||||||
// will return either a StartupMessage, SSLRequest, or CancelRequest.
|
// will return either a StartupMessage, SSLRequest, GSSEncRequest, or CancelRequest.
|
||||||
func (b *Backend) ReceiveStartupMessage() (FrontendMessage, error) {
|
func (b *Backend) ReceiveStartupMessage() (FrontendMessage, error) {
|
||||||
buf, err := b.cr.Next(4)
|
buf, err := b.cr.Next(4)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -79,6 +80,12 @@ func (b *Backend) ReceiveStartupMessage() (FrontendMessage, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &b.cancelRequest, nil
|
return &b.cancelRequest, nil
|
||||||
|
case gssEncReqNumber:
|
||||||
|
err = b.gssEncRequest.Decode(buf)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return &b.gssEncRequest, nil
|
||||||
default:
|
default:
|
||||||
return nil, fmt.Errorf("unknown startup message code: %d", code)
|
return nil, fmt.Errorf("unknown startup message code: %d", code)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,49 @@
|
|||||||
|
package pgproto3
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/binary"
|
||||||
|
"encoding/json"
|
||||||
|
"errors"
|
||||||
|
|
||||||
|
"github.com/jackc/pgio"
|
||||||
|
)
|
||||||
|
|
||||||
|
const gssEncReqNumber = 80877104
|
||||||
|
|
||||||
|
type GSSEncRequest struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
// Frontend identifies this message as sendable by a PostgreSQL frontend.
|
||||||
|
func (*GSSEncRequest) Frontend() {}
|
||||||
|
|
||||||
|
func (dst *GSSEncRequest) Decode(src []byte) error {
|
||||||
|
if len(src) < 4 {
|
||||||
|
return errors.New("gss encoding request too short")
|
||||||
|
}
|
||||||
|
|
||||||
|
requestCode := binary.BigEndian.Uint32(src)
|
||||||
|
|
||||||
|
if requestCode != gssEncReqNumber {
|
||||||
|
return errors.New("bad gss encoding request code")
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Encode encodes src into dst. dst will include the 4 byte message length.
|
||||||
|
func (src *GSSEncRequest) Encode(dst []byte) []byte {
|
||||||
|
dst = pgio.AppendInt32(dst, 8)
|
||||||
|
dst = pgio.AppendInt32(dst, gssEncReqNumber)
|
||||||
|
return dst
|
||||||
|
}
|
||||||
|
|
||||||
|
// MarshalJSON implements encoding/json.Marshaler.
|
||||||
|
func (src GSSEncRequest) MarshalJSON() ([]byte, error) {
|
||||||
|
return json.Marshal(struct {
|
||||||
|
Type string
|
||||||
|
ProtocolVersion uint32
|
||||||
|
Parameters map[string]string
|
||||||
|
}{
|
||||||
|
Type: "GSSEncRequest",
|
||||||
|
})
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user