Made it a bit cleaner :)
This commit is contained in:
28
pkg/engine/kdf.go
Normal file
28
pkg/engine/kdf.go
Normal file
@@ -0,0 +1,28 @@
|
||||
package engine
|
||||
|
||||
import (
|
||||
"crypto/sha256"
|
||||
"fmt"
|
||||
"io"
|
||||
|
||||
"golang.org/x/crypto/hkdf"
|
||||
)
|
||||
|
||||
// deriveKey derives a symmetric key from two shared secrets using HKDF-SHA256
|
||||
func deriveKey(ss1, ss2, salt []byte) ([]byte, error) {
|
||||
ikm := append(ss1, ss2...)
|
||||
kdf := hkdf.New(sha256.New, ikm, salt, []byte(HKDFInfo))
|
||||
symmetricKey := make([]byte, KeySize)
|
||||
if _, err := io.ReadFull(kdf, symmetricKey); err != nil {
|
||||
return nil, fmt.Errorf("key derivation failed: %w", err)
|
||||
}
|
||||
return symmetricKey, nil
|
||||
}
|
||||
|
||||
// buildAAD constructs the associated authenticated data from public keys
|
||||
func buildAAD(ephemeralPubBytes, senderPubBytes []byte) []byte {
|
||||
aad := make([]byte, 0, len(ephemeralPubBytes)+len(senderPubBytes))
|
||||
aad = append(aad, ephemeralPubBytes...)
|
||||
aad = append(aad, senderPubBytes...)
|
||||
return aad
|
||||
}
|
||||
Reference in New Issue
Block a user