kms: fix possible deadlock due to nested RLock calls. (#16136)

Signed-off-by: Andreas Auernhammer <hi@aead.dev>
This commit is contained in:
Andreas Auernhammer 2022-11-28 16:31:07 +01:00 committed by GitHub
parent 09d4f8cd0f
commit 9b1e70e4f9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -303,7 +303,11 @@ func (c *kesClient) DecryptAll(ctx context.Context, keyID string, ciphertexts []
plaintexts := make([][]byte, 0, len(ciphertexts)) plaintexts := make([][]byte, 0, len(ciphertexts))
for i := range ciphertexts { for i := range ciphertexts {
plaintext, err := c.DecryptKey(keyID, ciphertexts[i], contexts[i]) ctxBytes, err := contexts[i].MarshalText()
if err != nil {
return nil, err
}
plaintext, err := c.client.Decrypt(ctx, keyID, ciphertexts[i], ctxBytes)
if err != nil { if err != nil {
return nil, err return nil, err
} }