mirror of
https://github.com/minio/minio.git
synced 2025-01-12 15:33:22 -05:00
4af89543cf
With following changes - Add SSE and refactor encryption API (#942) <Andreas Auernhammer> - add copyObject test changing metadata and preserving etag (#944) <Harshavardhana> - Add SSE-C tests for multipart, copy, get range operations (#941) <Harshavardhana> - Removing conditional check for notificationInfoCh in api-notication (#940) <Matthew Magaldi> - Honor prefix parameter in ListBucketPolicies API (#929) <kannappanr> - test for empty objects uploaded with SSE-C headers (#927) <kannappanr> - Encryption headers should also be set during initMultipart (#930) <Harshavardhana> - Add support for Content-Language metadata header (#928) <kannappanr> - Fix check for duplicate notification configuration entries (#917) <kannappanr> - allow OS to cleanup sockets in TIME_WAIT (#925) <Harshavardhana> - Sign V2: Fix signature calculation in virtual host style (#921) <A. Elleuch> - bucket policy: Support json string in Principal field (#919) <A. Elleuch> - Fix copyobject failure for empty files (#918) <kannappanr> - Add new constructor NewWithOptions to SDK (#915) <poornas> - Support redirect headers to sign again with new Host header. (#829) <Harshavardhana> - Fail in PutObject if invalid user metadata is passed <Harshavadhana> - PutObjectOptions Header: Don't include invalid header <Isaac Hess> - increase max retry count to 10 (#913) <poornas> - Add new regions for Paris and China west. (#905) <Harshavardhana> - fix s3signer to use req.Host header (#899) <Bartłomiej Nogaś>
54 lines
1.1 KiB
Go
54 lines
1.1 KiB
Go
// Copyright 2017 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package argon2
|
|
|
|
import (
|
|
"encoding/binary"
|
|
"hash"
|
|
|
|
"golang.org/x/crypto/blake2b"
|
|
)
|
|
|
|
// blake2bHash computes an arbitrary long hash value of in
|
|
// and writes the hash to out.
|
|
func blake2bHash(out []byte, in []byte) {
|
|
var b2 hash.Hash
|
|
if n := len(out); n < blake2b.Size {
|
|
b2, _ = blake2b.New(n, nil)
|
|
} else {
|
|
b2, _ = blake2b.New512(nil)
|
|
}
|
|
|
|
var buffer [blake2b.Size]byte
|
|
binary.LittleEndian.PutUint32(buffer[:4], uint32(len(out)))
|
|
b2.Write(buffer[:4])
|
|
b2.Write(in)
|
|
|
|
if len(out) <= blake2b.Size {
|
|
b2.Sum(out[:0])
|
|
return
|
|
}
|
|
|
|
outLen := len(out)
|
|
b2.Sum(buffer[:0])
|
|
b2.Reset()
|
|
copy(out, buffer[:32])
|
|
out = out[32:]
|
|
for len(out) > blake2b.Size {
|
|
b2.Write(buffer[:])
|
|
b2.Sum(buffer[:0])
|
|
copy(out, buffer[:32])
|
|
out = out[32:]
|
|
b2.Reset()
|
|
}
|
|
|
|
if outLen%blake2b.Size > 0 { // outLen > 64
|
|
r := ((outLen + 31) / 32) - 2 // ⌈τ /32⌉-2
|
|
b2, _ = blake2b.New(outLen-32*r, nil)
|
|
}
|
|
b2.Write(buffer[:])
|
|
b2.Sum(out[:0])
|
|
}
|