mirror of
https://github.com/siderolabs/talos.git
synced 2025-10-20 20:11:13 +02:00
There's a cyclic dependency on siderolink library which imports talos machinery back. We will fix that after we get talos pushed under a new name. Signed-off-by: Andrey Smirnov <andrey.smirnov@talos-systems.com>
57 lines
1.1 KiB
Go
57 lines
1.1 KiB
Go
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
package httpdefaults
|
|
|
|
import (
|
|
"crypto/x509"
|
|
"io/fs"
|
|
"os"
|
|
"sync"
|
|
|
|
"github.com/siderolabs/talos/pkg/machinery/constants"
|
|
)
|
|
|
|
var (
|
|
cachedPool *x509.CertPool
|
|
cachedSt fs.FileInfo
|
|
cacheMu sync.Mutex
|
|
)
|
|
|
|
// RootCAs provides a cached, but refreshed, list of root CAs.
|
|
//
|
|
// If loading certificates fails for any reason, function returns nil.
|
|
func RootCAs() *x509.CertPool {
|
|
st, err := os.Stat(constants.DefaultTrustedCAFile)
|
|
if err != nil {
|
|
return nil
|
|
}
|
|
|
|
// check if the file hasn't changed
|
|
cacheMu.Lock()
|
|
defer cacheMu.Unlock()
|
|
|
|
if cachedPool != nil && cachedSt != nil {
|
|
if cachedSt.ModTime().Equal(st.ModTime()) && cachedSt.Size() == st.Size() {
|
|
return cachedPool
|
|
}
|
|
}
|
|
|
|
pool := x509.NewCertPool()
|
|
|
|
contents, err := os.ReadFile(constants.DefaultTrustedCAFile)
|
|
if err == nil {
|
|
if pool.AppendCertsFromPEM(contents) {
|
|
cachedPool = pool
|
|
cachedSt = st
|
|
}
|
|
}
|
|
|
|
if cachedPool == nil {
|
|
return nil
|
|
}
|
|
|
|
return cachedPool.Clone()
|
|
}
|