diff options
author | Paul Kehrer <paul.l.kehrer@gmail.com> | 2018-01-06 15:00:28 -0600 |
---|---|---|
committer | Alex Gaynor <alex.gaynor@gmail.com> | 2018-01-06 16:00:28 -0500 |
commit | 323f2ad66befb13ec3b31b5ab99c9448b9a6b067 (patch) | |
tree | ebf189232140ab50ae11d04229f45b03a5e7fa09 /docs/development/custom-vectors/hkdf/verify_hkdf.go | |
parent | f8327a977f31ef1d66c11555d65deb1c3f263bc5 (diff) | |
download | cryptography-323f2ad66befb13ec3b31b5ab99c9448b9a6b067.tar.gz cryptography-323f2ad66befb13ec3b31b5ab99c9448b9a6b067.tar.bz2 cryptography-323f2ad66befb13ec3b31b5ab99c9448b9a6b067.zip |
add 1200 byte HKDF test vector and a generator/verifier for it (#4074)
* add 1200 byte HKDF test vector and a generator/verifier for it
* exit non-zero when failing
* ugh
Diffstat (limited to 'docs/development/custom-vectors/hkdf/verify_hkdf.go')
-rw-r--r-- | docs/development/custom-vectors/hkdf/verify_hkdf.go | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/docs/development/custom-vectors/hkdf/verify_hkdf.go b/docs/development/custom-vectors/hkdf/verify_hkdf.go new file mode 100644 index 00000000..ddeb3d8e --- /dev/null +++ b/docs/development/custom-vectors/hkdf/verify_hkdf.go @@ -0,0 +1,69 @@ +package main + +import ( + "bufio" + "bytes" + "crypto/sha256" + "encoding/hex" + "fmt" + "golang.org/x/crypto/hkdf" + "io" + "os" + "strconv" + "strings" +) + +func unhexlify(s string) []byte { + bytes, err := hex.DecodeString(s) + if err != nil { + panic(err) + } + return bytes +} + +func verifier(l uint64, ikm, okm []byte) bool { + hash := sha256.New + hkdf := hkdf.New(hash, ikm, nil, nil) + okmComputed := make([]byte, l) + io.ReadFull(hkdf, okmComputed) + return bytes.Equal(okmComputed, okm) +} + +func validateVectors(filename string) bool { + vectors, err := os.Open(filename) + if err != nil { + panic(err) + } + defer vectors.Close() + + var segments []string + var l uint64 + var ikm, okm string + + scanner := bufio.NewScanner(vectors) + for scanner.Scan() { + segments = strings.Split(scanner.Text(), " = ") + + switch { + case strings.ToUpper(segments[0]) == "L": + l, err = strconv.ParseUint(segments[1], 10, 64) + if err != nil { + panic(err) + } + case strings.ToUpper(segments[0]) == "IKM": + ikm = segments[1] + case strings.ToUpper(segments[0]) == "OKM": + okm = segments[1] + } + } + return verifier(l, unhexlify(ikm), unhexlify(okm)) +} + +func main() { + if validateVectors("vectors/cryptography_vectors/KDF/hkdf-generated.txt") { + fmt.Println("HKDF OK.") + } else { + fmt.Println("HKDF failed.") + os.Exit(1) + } +} |