From f856163f1e1dcc07e96e77c55140129a442a4b49 Mon Sep 17 00:00:00 2001 From: Marten Seemann Date: Sun, 3 Mar 2024 23:02:32 +1030 Subject: [PATCH] handshake: embed the mask as an array into the aesHeaderProtector (#4324) --- internal/handshake/header_protector.go | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/internal/handshake/header_protector.go b/internal/handshake/header_protector.go index 455f2507..2c5ee42f 100644 --- a/internal/handshake/header_protector.go +++ b/internal/handshake/header_protector.go @@ -37,7 +37,7 @@ func newHeaderProtector(suite *cipherSuite, trafficSecret []byte, isLongHeader b } type aesHeaderProtector struct { - mask []byte + mask [16]byte // AES always has a 16 byte block size block cipher.Block isLongHeader bool } @@ -52,7 +52,6 @@ func newAESHeaderProtector(suite *cipherSuite, trafficSecret []byte, isLongHeade } return &aesHeaderProtector{ block: block, - mask: make([]byte, block.BlockSize()), isLongHeader: isLongHeader, } } @@ -69,7 +68,7 @@ func (p *aesHeaderProtector) apply(sample []byte, firstByte *byte, hdrBytes []by if len(sample) != len(p.mask) { panic("invalid sample size") } - p.block.Encrypt(p.mask, sample) + p.block.Encrypt(p.mask[:], sample) if p.isLongHeader { *firstByte ^= p.mask[0] & 0xf } else {