mirror of
https://github.com/siderolabs/talos.git
synced 2026-05-06 04:46:17 +02:00
When extending PCR or trying to seed entropy pool from TPM if the found device is a TPM1.2 device, skip it, since Talos only supports TPM2.0 Fixes: #10847 Signed-off-by: Noel Georgi <git@frezbo.dev>
67 lines
1.5 KiB
Go
67 lines
1.5 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 provision
|
|
|
|
import (
|
|
"net/netip"
|
|
|
|
"github.com/google/uuid"
|
|
|
|
"github.com/siderolabs/talos/pkg/machinery/config/machine"
|
|
)
|
|
|
|
// Cluster describes the provisioned Cluster.
|
|
type Cluster interface {
|
|
// Provisioner returns name of the provisioner used to build the cluster.
|
|
Provisioner() string
|
|
// StatePath returns path to the state directory of the cluster.
|
|
StatePath() (string, error)
|
|
// Info returns running cluster information.
|
|
Info() ClusterInfo
|
|
}
|
|
|
|
// ClusterInfo describes the cluster.
|
|
type ClusterInfo struct {
|
|
ClusterName string
|
|
|
|
Network NetworkInfo
|
|
Nodes []NodeInfo
|
|
|
|
// ExtraNodes are not part of the cluster.
|
|
ExtraNodes []NodeInfo
|
|
|
|
// KubernetesEndpoint is the endpoint of the Kubernetes API server.
|
|
KubernetesEndpoint string
|
|
}
|
|
|
|
// NetworkInfo describes cluster network.
|
|
type NetworkInfo struct {
|
|
Name string
|
|
CIDRs []netip.Prefix
|
|
GatewayAddrs []netip.Addr
|
|
MTU int
|
|
NoMasqueradeCIDRs []netip.Prefix
|
|
}
|
|
|
|
// NodeInfo describes a node.
|
|
type NodeInfo struct {
|
|
ID string
|
|
UUID uuid.UUID
|
|
Name string
|
|
Type machine.Type
|
|
|
|
// Share of CPUs, in 1e-9 fractions
|
|
NanoCPUs int64
|
|
// Memory limit in bytes
|
|
Memory int64
|
|
// Disk (volume) size in bytes, if applicable
|
|
DiskSize uint64
|
|
|
|
IPs []netip.Addr
|
|
|
|
APIPort int
|
|
TPMStateDir string
|
|
}
|