Skip to content

Commit

Permalink
Merge pull request shadowsocks#201 from xiaokangwang/dev-ssivracecond
Browse files Browse the repository at this point in the history
Fix a race condition that could allow same Salt/IV to be reused
  • Loading branch information
riobard authored Mar 12, 2021
2 parents 3ab862d + 28b56ca commit 58f2b62
Show file tree
Hide file tree
Showing 4 changed files with 30 additions and 8 deletions.
19 changes: 19 additions & 0 deletions 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,25 @@ func (r *BloomRing) Test(b []byte) bool {
}
r.mutex.RLock()
defer r.mutex.RUnlock()
test := r.test(b)
return test
}

func (r *BloomRing) test(b []byte) bool {
for _, s := range r.slots {
if s.Test(b) {
return true
}
}
return 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
8 changes: 4 additions & 4 deletions shadowaead/stream.go
Original file line number Diff line number Diff line change
Expand Up @@ -205,14 +205,14 @@ func (c *streamConn) initReader() error {
if _, err := io.ReadFull(c.Conn, salt); err != nil {
return err
}
if internal.TestSalt(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 58f2b62

Please sign in to comment.