mirror of
https://github.com/minio/minio.git
synced 2025-01-11 23:13:23 -05:00
config: enforce AES-GCM in FIPS mode (#12265)
This commit enforces the usage of AES-256 for config and IAM data en/decryption in FIPS mode. Further, it improves the implementation of `fips.Enabled` by making it a compile time constant. Now, the compiler is able to evaluate the any `if fips.Enabled { ... }` at compile time and eliminate unused code. Signed-off-by: Andreas Auernhammer <aead@mail.de>
This commit is contained in:
parent
2d79d6d847
commit
c03a06cca8
@ -26,6 +26,7 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
|
||||||
|
"github.com/minio/minio/pkg/fips"
|
||||||
"github.com/minio/minio/pkg/kms"
|
"github.com/minio/minio/pkg/kms"
|
||||||
"github.com/secure-io/sio-go"
|
"github.com/secure-io/sio-go"
|
||||||
"github.com/secure-io/sio-go/sioutil"
|
"github.com/secure-io/sio-go/sioutil"
|
||||||
@ -62,7 +63,7 @@ func DecryptBytes(KMS kms.KMS, ciphertext []byte, context kms.Context) ([]byte,
|
|||||||
// ciphertext.
|
// ciphertext.
|
||||||
func Encrypt(KMS kms.KMS, plaintext io.Reader, context kms.Context) (io.Reader, error) {
|
func Encrypt(KMS kms.KMS, plaintext io.Reader, context kms.Context) (io.Reader, error) {
|
||||||
var algorithm = sio.AES_256_GCM
|
var algorithm = sio.AES_256_GCM
|
||||||
if !sioutil.NativeAES() {
|
if !fips.Enabled && !sioutil.NativeAES() {
|
||||||
algorithm = sio.ChaCha20Poly1305
|
algorithm = sio.ChaCha20Poly1305
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,6 +142,9 @@ func Decrypt(KMS kms.KMS, ciphertext io.Reader, context kms.Context) (io.Reader,
|
|||||||
if err := json.Unmarshal(metadataBuffer, &metadata); err != nil {
|
if err := json.Unmarshal(metadataBuffer, &metadata); err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
if fips.Enabled && metadata.Algorithm != sio.AES_256_GCM {
|
||||||
|
return nil, fmt.Errorf("config: unsupported encryption algorithm: %q is not supported in FIPS mode", metadata.Algorithm)
|
||||||
|
}
|
||||||
|
|
||||||
key, err := KMS.DecryptKey(metadata.KeyID, metadata.KMSKey, context)
|
key, err := KMS.DecryptKey(metadata.KeyID, metadata.KMSKey, context)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -173,7 +173,7 @@ func NewServer(addrs []string, handler http.Handler, getCert certs.GetCertificat
|
|||||||
NextProtos: []string{"http/1.1", "h2"},
|
NextProtos: []string{"http/1.1", "h2"},
|
||||||
GetCertificate: getCert,
|
GetCertificate: getCert,
|
||||||
}
|
}
|
||||||
if secureCiphers || fips.Enabled() {
|
if secureCiphers || fips.Enabled {
|
||||||
tlsConfig.CipherSuites = fips.CipherSuitesTLS()
|
tlsConfig.CipherSuites = fips.CipherSuitesTLS()
|
||||||
tlsConfig.CurvePreferences = fips.EllipticCurvesTLS()
|
tlsConfig.CurvePreferences = fips.EllipticCurvesTLS()
|
||||||
}
|
}
|
||||||
|
@ -34,14 +34,13 @@ package fips
|
|||||||
|
|
||||||
import "crypto/tls"
|
import "crypto/tls"
|
||||||
|
|
||||||
// Enabled returns true if and only if FIPS 140-2 support
|
// Enabled indicates whether cryptographic primitives,
|
||||||
// is enabled.
|
// like AES or SHA-256, are implemented using a FIPS 140
|
||||||
|
// certified module.
|
||||||
//
|
//
|
||||||
// FIPS 140-2 requires that only specifc cryptographic
|
// If FIPS-140 is enabled no non-NIST/FIPS approved
|
||||||
// primitives, like AES or SHA-256, are used and that
|
// primitives must be used.
|
||||||
// those primitives are implemented by a FIPS 140-2
|
const Enabled = enabled
|
||||||
// certified cryptographic module.
|
|
||||||
func Enabled() bool { return enabled }
|
|
||||||
|
|
||||||
// CipherSuitesDARE returns the supported cipher suites
|
// CipherSuitesDARE returns the supported cipher suites
|
||||||
// for the DARE object encryption.
|
// for the DARE object encryption.
|
||||||
|
@ -1,5 +1,3 @@
|
|||||||
// +build fips
|
|
||||||
|
|
||||||
// Copyright (c) 2015-2021 MinIO, Inc.
|
// Copyright (c) 2015-2021 MinIO, Inc.
|
||||||
//
|
//
|
||||||
// This file is part of MinIO Object Storage stack
|
// This file is part of MinIO Object Storage stack
|
||||||
@ -17,6 +15,8 @@
|
|||||||
// You should have received a copy of the GNU Affero General Public License
|
// You should have received a copy of the GNU Affero General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
// +build fips,linux,amd64
|
||||||
|
|
||||||
package fips
|
package fips
|
||||||
|
|
||||||
import (
|
import (
|
||||||
@ -25,7 +25,7 @@ import (
|
|||||||
"github.com/minio/sio"
|
"github.com/minio/sio"
|
||||||
)
|
)
|
||||||
|
|
||||||
var enabled = true
|
const enabled = true
|
||||||
|
|
||||||
func cipherSuitesDARE() []byte {
|
func cipherSuitesDARE() []byte {
|
||||||
return []byte{sio.AES_256_GCM}
|
return []byte{sio.AES_256_GCM}
|
||||||
|
@ -15,6 +15,8 @@
|
|||||||
// You should have received a copy of the GNU Affero General Public License
|
// You should have received a copy of the GNU Affero General Public License
|
||||||
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
// +build !fips
|
||||||
|
|
||||||
package fips
|
package fips
|
||||||
|
|
||||||
import (
|
import (
|
||||||
@ -23,7 +25,7 @@ import (
|
|||||||
"github.com/minio/sio"
|
"github.com/minio/sio"
|
||||||
)
|
)
|
||||||
|
|
||||||
var enabled = false
|
const enabled = false
|
||||||
|
|
||||||
func cipherSuitesDARE() []byte {
|
func cipherSuitesDARE() []byte {
|
||||||
return []byte{sio.AES_256_GCM, sio.CHACHA20_POLY1305}
|
return []byte{sio.AES_256_GCM, sio.CHACHA20_POLY1305}
|
||||||
|
Loading…
Reference in New Issue
Block a user