2017-05-27 13:30:11 -06:00
|
|
|
package handshake
|
|
|
|
|
|
|
|
import "github.com/lucas-clemente/quic-go/protocol"
|
|
|
|
|
|
|
|
// Sealer seals a packet
|
|
|
|
type Sealer func(dst, src []byte, packetNumber protocol.PacketNumber, associatedData []byte) []byte
|
|
|
|
|
|
|
|
// CryptoSetup is a crypto setup
|
|
|
|
type CryptoSetup interface {
|
|
|
|
Open(dst, src []byte, packetNumber protocol.PacketNumber, associatedData []byte) ([]byte, protocol.EncryptionLevel, error)
|
|
|
|
HandleCryptoStream() error
|
|
|
|
// TODO: clean up this interface
|
|
|
|
DiversificationNonce() []byte // only needed for cryptoSetupServer
|
|
|
|
SetDiversificationNonce([]byte) // only needed for cryptoSetupClient
|
|
|
|
|
|
|
|
GetSealer() (protocol.EncryptionLevel, Sealer)
|
|
|
|
GetSealerWithEncryptionLevel(protocol.EncryptionLevel) (Sealer, error)
|
2017-07-27 16:11:56 -06:00
|
|
|
GetSealerForCryptoStream() (protocol.EncryptionLevel, Sealer)
|
2017-05-27 13:30:11 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
// TransportParameters are parameters sent to the peer during the handshake
|
|
|
|
type TransportParameters struct {
|
|
|
|
RequestConnectionIDTruncation bool
|
|
|
|
}
|