2022-03-29 23:58:41 +00:00
|
|
|
// Copyright 2022 the Pinniped contributors. All Rights Reserved.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
// The configurations here override the usual ptls.Secure, ptls.Default, and ptls.DefaultLDAP
|
|
|
|
// configs when Pinniped is built in fips-only mode.
|
|
|
|
// All of these are the same because FIPs is already so limited.
|
|
|
|
//go:build fips_strict
|
|
|
|
// +build fips_strict
|
|
|
|
|
|
|
|
package ptls
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/tls"
|
|
|
|
"crypto/x509"
|
|
|
|
"runtime"
|
|
|
|
|
2022-03-31 18:48:52 +00:00
|
|
|
"C" // explicitly import cgo so that runtime/cgo gets linked into the kube-cert-agent
|
|
|
|
_ "crypto/tls/fipsonly" // restricts all TLS configuration to FIPS-approved settings.
|
|
|
|
|
2022-03-31 21:07:47 +00:00
|
|
|
"k8s.io/apiserver/pkg/server/options"
|
2022-04-12 18:27:07 +00:00
|
|
|
"k8s.io/klog/v2"
|
2022-03-29 23:58:41 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// Always use TLS 1.2 for FIPs
|
|
|
|
const secureServingOptionsMinTLSVersion = "VersionTLS12"
|
|
|
|
const SecureTLSConfigMinTLSVersion = tls.VersionTLS12
|
|
|
|
|
|
|
|
func init() {
|
2022-04-12 18:27:07 +00:00
|
|
|
// this init runs before we have parsed our config to determine our log level
|
|
|
|
// thus we must use a log statement that will always print instead of conditionally print
|
|
|
|
// for plog, that is only error and warning logs, neither of which seem appropriate here
|
|
|
|
// therefore, just use klog directly with no V level requirement
|
|
|
|
klog.InfoS("using boring crypto in fips only mode", "go version", runtime.Version())
|
2022-03-29 23:58:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func Default(rootCAs *x509.CertPool) *tls.Config {
|
|
|
|
return &tls.Config{
|
|
|
|
// goboring requires TLS 1.2 and only TLS 1.2
|
|
|
|
MinVersion: SecureTLSConfigMinTLSVersion,
|
|
|
|
MaxVersion: SecureTLSConfigMinTLSVersion,
|
|
|
|
|
|
|
|
// enable HTTP2 for go's 1.7 HTTP Server
|
|
|
|
// setting this explicitly is only required in very specific circumstances
|
|
|
|
// it is simpler to just set it here than to try and determine if we need to
|
|
|
|
NextProtos: []string{"h2", "http/1.1"},
|
|
|
|
|
|
|
|
// optional root CAs, nil means use the host's root CA set
|
|
|
|
RootCAs: rootCAs,
|
|
|
|
|
|
|
|
// This is all of the fips-approved ciphers.
|
|
|
|
// The list is hard-coded for convenience of testing.
|
2022-03-31 18:48:52 +00:00
|
|
|
// This is kept in sync with the boring crypto compiler via TestFIPSCipherSuites.
|
2022-03-29 23:58:41 +00:00
|
|
|
CipherSuites: []uint16{
|
|
|
|
tls.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
tls.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
tls.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
tls.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
tls.TLS_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
tls.TLS_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Secure(rootCAs *x509.CertPool) *tls.Config {
|
|
|
|
return Default(rootCAs)
|
|
|
|
}
|
|
|
|
|
|
|
|
func DefaultLDAP(rootCAs *x509.CertPool) *tls.Config {
|
|
|
|
return Default(rootCAs)
|
|
|
|
}
|
2022-03-31 21:07:47 +00:00
|
|
|
|
|
|
|
func secureServing(opts *options.SecureServingOptionsWithLoopback) {
|
|
|
|
defaultServing(opts)
|
|
|
|
}
|