mirror of
https://github.com/siderolabs/talos.git
synced 2025-10-21 12:31:24 +02:00
This is a rewrite of machined. It addresses some of the limitations and complexity in the implementation. This introduces the idea of a controller. A controller is responsible for managing the runtime, the sequencer, and a new state type introduced in this PR. A few highlights are: - no more event bus - functional approach to tasks (no more types defined for each task) - the task function definition now offers a lot more context, like access to raw API requests, the current sequence, a logger, the new state interface, and the runtime interface. - no more panics to handle reboots - additional initialize and reboot sequences - graceful gRPC server shutdown on critical errors - config is now stored at install time to avoid having to download it at install time and at boot time - upgrades now use the local config instead of downloading it - the upgrade API's preserve option takes precedence over the config's install force option Additionally, this pulls various packes in under machined to make the code easier to navigate. Signed-off-by: Andrew Rynhard <andrew@andrewrynhard.com>
75 lines
1.9 KiB
Go
75 lines
1.9 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 access
|
|
|
|
import (
|
|
"github.com/talos-systems/talos/internal/app/machined/pkg/runtime"
|
|
"github.com/talos-systems/talos/internal/pkg/cluster"
|
|
"github.com/talos-systems/talos/internal/pkg/provision"
|
|
)
|
|
|
|
// Adapter provides cluster access via provision.Cluster.
|
|
type Adapter struct {
|
|
cluster.ConfigClientProvider
|
|
cluster.KubernetesClient
|
|
cluster.APICrashDumper
|
|
cluster.Info
|
|
}
|
|
|
|
type infoWrapper struct {
|
|
clusterInfo provision.ClusterInfo
|
|
}
|
|
|
|
func (wrapper *infoWrapper) Nodes() []string {
|
|
nodes := make([]string, len(wrapper.clusterInfo.Nodes))
|
|
|
|
for i := range nodes {
|
|
nodes[i] = wrapper.clusterInfo.Nodes[i].PrivateIP.String()
|
|
}
|
|
|
|
return nodes
|
|
}
|
|
|
|
func (wrapper *infoWrapper) NodesByType(t runtime.MachineType) []string {
|
|
var nodes []string
|
|
|
|
for _, node := range wrapper.clusterInfo.Nodes {
|
|
if node.Type == t {
|
|
nodes = append(nodes, node.PrivateIP.String())
|
|
}
|
|
}
|
|
|
|
return nodes
|
|
}
|
|
|
|
// NewAdapter returns ClusterAccess object from Cluster.
|
|
func NewAdapter(clusterInfo provision.Cluster, opts ...provision.Option) *Adapter {
|
|
options := provision.DefaultOptions()
|
|
|
|
for _, opt := range opts {
|
|
if err := opt(&options); err != nil {
|
|
panic(err)
|
|
}
|
|
}
|
|
|
|
configProvider := cluster.ConfigClientProvider{
|
|
DefaultClient: options.TalosClient,
|
|
TalosConfig: options.TalosConfig,
|
|
}
|
|
|
|
return &Adapter{
|
|
ConfigClientProvider: configProvider,
|
|
KubernetesClient: cluster.KubernetesClient{
|
|
ClientProvider: &configProvider,
|
|
ForceEndpoint: options.ForceEndpoint,
|
|
},
|
|
APICrashDumper: cluster.APICrashDumper{
|
|
ClientProvider: &configProvider,
|
|
Info: &infoWrapper{clusterInfo: clusterInfo.Info()},
|
|
},
|
|
Info: &infoWrapper{clusterInfo: clusterInfo.Info()},
|
|
}
|
|
}
|