mirror of
https://github.com/siderolabs/talos.git
synced 2025-08-24 16:11:11 +02:00
Instead of passing around a struct, it is better if we pass around an interface that describes the behavior we want. The Runtime interface provides a common place to describe runtime specific parameters. This initial implementation offers the runtime mode, the platform specifics, and the config. Signed-off-by: Andrew Rynhard <andrew@andrewrynhard.com>
46 lines
1.5 KiB
Go
46 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 sysctls
|
|
|
|
import (
|
|
"github.com/hashicorp/go-multierror"
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/talos-systems/talos/internal/app/machined/internal/phase"
|
|
"github.com/talos-systems/talos/internal/pkg/runtime"
|
|
"github.com/talos-systems/talos/pkg/sysctl"
|
|
)
|
|
|
|
// Task represents the Task task.
|
|
type Task struct{}
|
|
|
|
// NewSysctlsTask initializes and returns a Task task.
|
|
func NewSysctlsTask() phase.Task {
|
|
return &Task{}
|
|
}
|
|
|
|
// TaskFunc returns the runtime function.
|
|
func (task *Task) TaskFunc(mode runtime.Mode) phase.TaskFunc {
|
|
return task.runtime
|
|
}
|
|
|
|
func (task *Task) runtime(r runtime.Runtime) error {
|
|
var multiErr *multierror.Error
|
|
|
|
if err := sysctl.WriteSystemProperty(&sysctl.SystemProperty{Key: "net.ipv4.ip_forward", Value: "1"}); err != nil {
|
|
multiErr = multierror.Append(multiErr, errors.Wrapf(err, "failed to set IPv4 forwarding"))
|
|
}
|
|
|
|
if err := sysctl.WriteSystemProperty(&sysctl.SystemProperty{Key: "net.ipv6.conf.default.forwarding", Value: "1"}); err != nil {
|
|
multiErr = multierror.Append(multiErr, errors.Wrap(err, "failed to set IPv6 forwarding"))
|
|
}
|
|
|
|
if err := sysctl.WriteSystemProperty(&sysctl.SystemProperty{Key: "kernel.pid_max", Value: "262144"}); err != nil {
|
|
multiErr = multierror.Append(multiErr, errors.Wrap(err, "failed to set pid_max"))
|
|
}
|
|
|
|
return multiErr.ErrorOrNil()
|
|
}
|