Implement GetOutKeystream()

This commit is contained in:
Sergey Frolov 2017-09-06 16:51:32 -06:00
parent 004572df2e
commit 08a039c453
2 changed files with 12 additions and 0 deletions

View file

@ -435,3 +435,14 @@ func (uconn *UConn) MarshalClientHello() error {
hello.Raw = helloBuffer.Bytes()
return nil
}
// get current state of cipher and encrypt zeros to get keystream
func (uconn *UConn) GetOutKeystream(length int) ([]byte, error) {
zeros := make([]byte, length)
if outCipher, ok := uconn.out.cipher.(cipher.AEAD); ok {
// AEAD.Seal() does not mutate internal state, other ciphers might
return outCipher.Seal(nil, uconn.out.seq[:], zeros, nil), nil
}
return nil, errors.New("Could not convert OutCipher to cipher.AEAD")
}