mirror of
https://github.com/siderolabs/talos.git
synced 2025-09-14 02:11:10 +02:00
The structure of the controllers is really similar to addresses and routes: * `LinkSpec` resource describes desired link state * `LinkConfig` controller generates `LinkSpecs` based on machine configuration and kernel cmdline * `LinkMerge` controller merges multiple configuration sources into a single `LinkSpec` paying attention to the config layer priority * `LinkSpec` controller applies the specs to the kernel state Controller `LinkStatus` (which was implemented before) watches the kernel state and publishes current link status. Signed-off-by: Andrey Smirnov <smirnov.andrey@gmail.com>
61 lines
1.4 KiB
Go
61 lines
1.4 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 cluster
|
|
|
|
import (
|
|
"context"
|
|
"crypto/tls"
|
|
"io"
|
|
"time"
|
|
|
|
"github.com/talos-systems/go-retry/retry"
|
|
|
|
machineapi "github.com/talos-systems/talos/pkg/machinery/api/machine"
|
|
"github.com/talos-systems/talos/pkg/machinery/client"
|
|
"github.com/talos-systems/talos/pkg/provision"
|
|
)
|
|
|
|
// ApplyConfigClient client to apply config.
|
|
type ApplyConfigClient struct {
|
|
ClientProvider
|
|
Info
|
|
}
|
|
|
|
// ApplyConfig on the node via the API using insecure mode.
|
|
func (s *APIBootstrapper) ApplyConfig(ctx context.Context, nodes []provision.NodeRequest, out io.Writer) error {
|
|
for _, node := range nodes {
|
|
n := node
|
|
|
|
configureNode := func() error {
|
|
c, err := client.New(ctx, client.WithTLSConfig(&tls.Config{
|
|
InsecureSkipVerify: true,
|
|
}), client.WithEndpoints(n.IPs[0].String()))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cfgBytes, err := n.Config.Bytes()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
_, err = c.ApplyConfiguration(ctx, &machineapi.ApplyConfigurationRequest{
|
|
Data: cfgBytes,
|
|
})
|
|
if err != nil {
|
|
return retry.ExpectedError(err)
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
if err := retry.Constant(2*time.Minute, retry.WithUnits(250*time.Millisecond), retry.WithJitter(50*time.Millisecond)).Retry(configureNode); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|