talos/pkg/provision/result.go
Utku Ozdemir 0821b9c50b
feat: add --non-masquerade-cidrs flag to talosctl cluster create
Allow skipping NAT for the given destinations from a cluster network. This option makes it possible to form an etcd cluster from clusters in different networks created by running `talosctl cluster create` command multiple times using different CIDRs: they simply should have the CIDR of the other clusters passed with `--non-masquerade-cidrs`.

Signed-off-by: Utku Ozdemir <utku.ozdemir@siderolabs.com>
2024-04-23 13:30:13 +02:00

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
TPM2StateDir string
}