1
// This Source Code Form is subject to the terms of the Mozilla Public
2
// License, v. 2.0. If a copy of the MPL was not distributed with this
3
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
17
"github.com/siderolabs/talos/pkg/provision"
25
// CreateKMS creates KMS server.
26
func (p *Provisioner) CreateKMS(state *State, clusterReq provision.ClusterRequest, options provision.Options) error {
27
pidPath := state.GetRelativePath(kmsPid)
29
logFile, err := os.OpenFile(state.GetRelativePath(kmsLog), os.O_APPEND|os.O_CREATE|os.O_RDWR, 0o666)
34
defer logFile.Close() //nolint:errcheck
36
key := make([]byte, 32)
37
if _, err = io.ReadFull(rand.Reader, key); err != nil {
43
"--kms-addr", options.KMSEndpoint,
44
"--kms-key", base64.StdEncoding.EncodeToString(key),
47
cmd := exec.Command(clusterReq.SelfExecutable, args...)
50
cmd.SysProcAttr = &syscall.SysProcAttr{
51
Setsid: true, // daemonize
54
if err = cmd.Start(); err != nil {
58
if err = os.WriteFile(pidPath, []byte(strconv.Itoa(cmd.Process.Pid)), os.ModePerm); err != nil {
59
return fmt.Errorf("error writing LB PID file: %w", err)
65
// DestroyKMS destroys KMS server.
66
func (p *Provisioner) DestroyKMS(state *State) error {
67
pidPath := state.GetRelativePath(kmsPid)
69
return StopProcessByPidfile(pidPath)