Skip to content

Commit

Permalink
Fix a race condition that could allow same IV to be used more than on…
Browse files Browse the repository at this point in the history
…ce if timed correctly
  • Loading branch information
xiaokangwang committed Mar 12, 2021
1 parent 956d345 commit cc36917
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 7 deletions.
24 changes: 23 additions & 1 deletion internal/bloomring.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ func (r *BloomRing) Add(b []byte) {
}
r.mutex.Lock()
defer r.mutex.Unlock()
r.add(b)
}

func (r *BloomRing) add(b []byte) {
slot := r.slots[r.slotPosition]
if r.entryCounter > r.slotCapacity {
// Move to next slot and reset
Expand All @@ -64,10 +68,28 @@ func (r *BloomRing) Test(b []byte) bool {
}
r.mutex.RLock()
defer r.mutex.RUnlock()
b2, done := r.test(b)
if done {
return b2
}
return false
}

func (r *BloomRing) test(b []byte) (bool, bool) {
for _, s := range r.slots {
if s.Test(b) {
return true
return true, true
}
}
return false, false
}

func (r *BloomRing) Check(b []byte) bool {
r.mutex.Lock()
defer r.mutex.Unlock()
if r.Test(b) {
return true
}
r.Add(b)
return false
}
4 changes: 4 additions & 0 deletions internal/saltfilter.go
Original file line number Diff line number Diff line change
Expand Up @@ -79,3 +79,7 @@ func TestSalt(b []byte) bool {
func AddSalt(b []byte) {
getSaltFilterSingleton().Add(b)
}

func CheckSalt(b []byte) bool {
return getSaltFilterSingleton().Test(b)
}
7 changes: 3 additions & 4 deletions shadowaead/packet.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,14 +46,13 @@ func Unpack(dst, pkt []byte, ciph Cipher) ([]byte, error) {
return nil, ErrShortPacket
}
salt := pkt[:saltSize]
if internal.TestSalt(salt) {
return nil, ErrRepeatedSalt
}
aead, err := ciph.Decrypter(salt)
if err != nil {
return nil, err
}
internal.AddSalt(salt)
if internal.CheckSalt(salt) {
return nil, ErrRepeatedSalt
}
if len(pkt) < saltSize+aead.Overhead() {
return nil, ErrShortPacket
}
Expand Down
7 changes: 5 additions & 2 deletions shadowaead/stream.go
Original file line number Diff line number Diff line change
Expand Up @@ -205,14 +205,17 @@ func (c *streamConn) initReader() error {
if _, err := io.ReadFull(c.Conn, salt); err != nil {
return err
}
if internal.TestSalt(salt) {
if internal.CheckSalt(salt) {
return ErrRepeatedSalt
}
aead, err := c.Decrypter(salt)
if err != nil {
return err
}
internal.AddSalt(salt)

if internal.CheckSalt(salt) {
return ErrRepeatedSalt
}

c.r = newReader(c.Conn, aead)
return nil
Expand Down

0 comments on commit cc36917

Please sign in to comment.