forked from quic-go/quic-go
move ErrorCode type to errorcodes package
This commit is contained in:
@@ -1,12 +1,15 @@
|
|||||||
|
// Package errorcodes defines the error codes in QUIC.
|
||||||
|
//
|
||||||
package errorcodes
|
package errorcodes
|
||||||
|
|
||||||
import "github.com/lucas-clemente/quic-go/protocol"
|
// An ErrorCode in QUIC
|
||||||
|
type ErrorCode uint32
|
||||||
|
|
||||||
// The error codes defined by QUIC
|
// The error codes defined by QUIC
|
||||||
const (
|
const (
|
||||||
InternalError protocol.ErrorCode = 1
|
InternalError ErrorCode = 1
|
||||||
InvalidFrameData protocol.ErrorCode = 4
|
InvalidFrameData ErrorCode = 4
|
||||||
DecryptionFailure protocol.ErrorCode = 12
|
DecryptionFailure ErrorCode = 12
|
||||||
PeerGoingAway protocol.ErrorCode = 16
|
PeerGoingAway ErrorCode = 16
|
||||||
NetworkIdleTimeout protocol.ErrorCode = 25
|
NetworkIdleTimeout ErrorCode = 25
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -6,13 +6,14 @@ import (
|
|||||||
"io"
|
"io"
|
||||||
"math"
|
"math"
|
||||||
|
|
||||||
|
"github.com/lucas-clemente/quic-go/errorcodes"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
"github.com/lucas-clemente/quic-go/utils"
|
"github.com/lucas-clemente/quic-go/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
// A ConnectionCloseFrame in QUIC
|
// A ConnectionCloseFrame in QUIC
|
||||||
type ConnectionCloseFrame struct {
|
type ConnectionCloseFrame struct {
|
||||||
ErrorCode protocol.ErrorCode
|
ErrorCode errorcodes.ErrorCode
|
||||||
ReasonPhrase string
|
ReasonPhrase string
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -30,7 +31,7 @@ func ParseConnectionCloseFrame(r *bytes.Reader) (*ConnectionCloseFrame, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
frame.ErrorCode = protocol.ErrorCode(errorCode)
|
frame.ErrorCode = errorcodes.ErrorCode(errorCode)
|
||||||
|
|
||||||
reasonPhraseLen, err := utils.ReadUint16(r)
|
reasonPhraseLen, err := utils.ReadUint16(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package frames
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
|
||||||
|
"github.com/lucas-clemente/quic-go/errorcodes"
|
||||||
"github.com/lucas-clemente/quic-go/protocol"
|
"github.com/lucas-clemente/quic-go/protocol"
|
||||||
. "github.com/onsi/ginkgo"
|
. "github.com/onsi/ginkgo"
|
||||||
. "github.com/onsi/gomega"
|
. "github.com/onsi/gomega"
|
||||||
@@ -14,7 +15,7 @@ var _ = Describe("ConnectionCloseFrame", func() {
|
|||||||
b := bytes.NewReader([]byte{0x40, 0x19, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x4e, 0x6f, 0x20, 0x72, 0x65, 0x63, 0x65, 0x6e, 0x74, 0x20, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x20, 0x61, 0x63, 0x74, 0x69, 0x76, 0x69, 0x74, 0x79, 0x2e})
|
b := bytes.NewReader([]byte{0x40, 0x19, 0x00, 0x00, 0x00, 0x1B, 0x00, 0x4e, 0x6f, 0x20, 0x72, 0x65, 0x63, 0x65, 0x6e, 0x74, 0x20, 0x6e, 0x65, 0x74, 0x77, 0x6f, 0x72, 0x6b, 0x20, 0x61, 0x63, 0x74, 0x69, 0x76, 0x69, 0x74, 0x79, 0x2e})
|
||||||
frame, err := ParseConnectionCloseFrame(b)
|
frame, err := ParseConnectionCloseFrame(b)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(frame.ErrorCode).To(Equal(protocol.ErrorCode(0x19)))
|
Expect(frame.ErrorCode).To(Equal(errorcodes.ErrorCode(0x19)))
|
||||||
Expect(frame.ReasonPhrase).To(Equal("No recent network activity."))
|
Expect(frame.ReasonPhrase).To(Equal("No recent network activity."))
|
||||||
Expect(b.Len()).To(Equal(0))
|
Expect(b.Len()).To(Equal(0))
|
||||||
})
|
})
|
||||||
@@ -23,7 +24,7 @@ var _ = Describe("ConnectionCloseFrame", func() {
|
|||||||
b := bytes.NewReader([]byte{0x02, 0xAD, 0xFB, 0xCA, 0xDE, 0x00, 0x00})
|
b := bytes.NewReader([]byte{0x02, 0xAD, 0xFB, 0xCA, 0xDE, 0x00, 0x00})
|
||||||
frame, err := ParseConnectionCloseFrame(b)
|
frame, err := ParseConnectionCloseFrame(b)
|
||||||
Expect(err).ToNot(HaveOccurred())
|
Expect(err).ToNot(HaveOccurred())
|
||||||
Expect(frame.ErrorCode).To(Equal(protocol.ErrorCode(0xDECAFBAD)))
|
Expect(frame.ErrorCode).To(Equal(errorcodes.ErrorCode(0xDECAFBAD)))
|
||||||
Expect(frame.ReasonPhrase).To(BeEmpty())
|
Expect(frame.ReasonPhrase).To(BeEmpty())
|
||||||
Expect(b.Len()).To(Equal(0))
|
Expect(b.Len()).To(Equal(0))
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -1,16 +1,17 @@
|
|||||||
package protocol
|
package protocol
|
||||||
|
|
||||||
// An ErrorCode in QUIC
|
import (
|
||||||
type ErrorCode uint32
|
"github.com/lucas-clemente/quic-go/errorcodes"
|
||||||
|
)
|
||||||
|
|
||||||
// A QuicError is a QUIC error
|
// A QuicError is a QUIC error
|
||||||
type QuicError struct {
|
type QuicError struct {
|
||||||
ErrorCode ErrorCode
|
ErrorCode errorcodes.ErrorCode
|
||||||
ErrorMessage string
|
ErrorMessage string
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error creates a new Quic Error
|
// Error creates a new Quic Error
|
||||||
func Error(errorCode ErrorCode, errorMessage string) *QuicError {
|
func Error(errorCode errorcodes.ErrorCode, errorMessage string) *QuicError {
|
||||||
return &QuicError{
|
return &QuicError{
|
||||||
ErrorCode: errorCode,
|
ErrorCode: errorCode,
|
||||||
ErrorMessage: errorMessage,
|
ErrorMessage: errorMessage,
|
||||||
|
|||||||
@@ -369,7 +369,7 @@ func (s *Session) Close(e error, sendConnectionClose bool) error {
|
|||||||
|
|
||||||
// if e is a QUIC error, send it to the client
|
// if e is a QUIC error, send it to the client
|
||||||
// else, send the generic QUIC internal error
|
// else, send the generic QUIC internal error
|
||||||
var errorCode protocol.ErrorCode
|
var errorCode errorcodes.ErrorCode
|
||||||
var reasonPhrase string
|
var reasonPhrase string
|
||||||
quicError, ok := e.(*protocol.QuicError)
|
quicError, ok := e.(*protocol.QuicError)
|
||||||
if ok {
|
if ok {
|
||||||
|
|||||||
Reference in New Issue
Block a user