| Tim Windelschmidt | 6d33a43 | 2025-02-04 14:34:25 +0100 | [diff] [blame^] | 1 | // Copyright The Monogon Project Authors. |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 2 | // SPDX-License-Identifier: Apache-2.0 |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 3 | |
| 4 | package kubernetes |
| 5 | |
| 6 | import ( |
| Lorenz Brun | 878f5f9 | 2020-05-12 16:15:39 +0200 | [diff] [blame] | 7 | "context" |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 8 | "encoding/pem" |
| 9 | "fmt" |
| 10 | "net" |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 11 | "os/exec" |
| 12 | |
| Serge Bazanski | 31370b0 | 2021-01-07 16:31:14 +0100 | [diff] [blame] | 13 | "source.monogon.dev/metropolis/node/kubernetes/pki" |
| Tim Windelschmidt | 9f21f53 | 2024-05-07 15:14:20 +0200 | [diff] [blame] | 14 | "source.monogon.dev/osbase/fileargs" |
| 15 | "source.monogon.dev/osbase/supervisor" |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 16 | ) |
| 17 | |
| 18 | type controllerManagerConfig struct { |
| 19 | clusterNet net.IPNet |
| Lorenz Brun | 6211e4d | 2023-11-14 19:09:40 +0100 | [diff] [blame] | 20 | serviceNet net.IPNet |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 21 | // All PKI-related things are in DER |
| 22 | kubeConfig []byte |
| 23 | rootCA []byte |
| 24 | serviceAccountPrivKey []byte // In PKCS#8 form |
| 25 | serverCert []byte |
| 26 | serverKey []byte |
| 27 | } |
| 28 | |
| Serge Bazanski | 9411f7c | 2021-03-10 13:12:53 +0100 | [diff] [blame] | 29 | func getPKIControllerManagerConfig(ctx context.Context, kpki *pki.PKI) (*controllerManagerConfig, error) { |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 30 | var config controllerManagerConfig |
| 31 | var err error |
| Serge Bazanski | c2c7ad9 | 2020-07-13 17:20:09 +0200 | [diff] [blame] | 32 | config.rootCA, _, err = kpki.Certificate(ctx, pki.IdCA) |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 33 | if err != nil { |
| 34 | return nil, fmt.Errorf("failed to get ID root CA: %w", err) |
| 35 | } |
| Serge Bazanski | c2c7ad9 | 2020-07-13 17:20:09 +0200 | [diff] [blame] | 36 | config.serverCert, config.serverKey, err = kpki.Certificate(ctx, pki.ControllerManager) |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 37 | if err != nil { |
| 38 | return nil, fmt.Errorf("failed to get controller-manager serving certificate: %w", err) |
| 39 | } |
| Serge Bazanski | c2c7ad9 | 2020-07-13 17:20:09 +0200 | [diff] [blame] | 40 | config.serviceAccountPrivKey, err = kpki.ServiceAccountKey(ctx) |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 41 | if err != nil { |
| 42 | return nil, fmt.Errorf("failed to get serviceaccount privkey: %w", err) |
| 43 | } |
| Serge Bazanski | e88ffe9 | 2023-03-21 13:38:46 +0100 | [diff] [blame] | 44 | config.kubeConfig, err = kpki.Kubeconfig(ctx, pki.ControllerManagerClient, pki.KubernetesAPIEndpointForController) |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 45 | if err != nil { |
| 46 | return nil, fmt.Errorf("failed to get controller-manager kubeconfig: %w", err) |
| 47 | } |
| 48 | return &config, nil |
| 49 | } |
| 50 | |
| Serge Bazanski | 967be21 | 2020-11-02 11:26:59 +0100 | [diff] [blame] | 51 | func runControllerManager(config controllerManagerConfig) supervisor.Runnable { |
| Lorenz Brun | 8e3b8fc | 2020-05-19 14:29:40 +0200 | [diff] [blame] | 52 | return func(ctx context.Context) error { |
| 53 | args, err := fileargs.New() |
| 54 | if err != nil { |
| 55 | panic(err) // If this fails, something is very wrong. Just crash. |
| 56 | } |
| 57 | defer args.Close() |
| 58 | |
| 59 | cmd := exec.CommandContext(ctx, "/kubernetes/bin/kube", "kube-controller-manager", |
| 60 | args.FileOpt("--kubeconfig", "kubeconfig", config.kubeConfig), |
| 61 | args.FileOpt("--service-account-private-key-file", "service-account-privkey.pem", |
| 62 | pem.EncodeToMemory(&pem.Block{Type: "PRIVATE KEY", Bytes: config.serviceAccountPrivKey})), |
| 63 | args.FileOpt("--root-ca-file", "root-ca.pem", |
| 64 | pem.EncodeToMemory(&pem.Block{Type: "CERTIFICATE", Bytes: config.rootCA})), |
| Tim Windelschmidt | 90613af | 2023-07-20 14:26:18 +0200 | [diff] [blame] | 65 | args.FileOpt("--client-ca-file", "root-ca.pem", |
| 66 | pem.EncodeToMemory(&pem.Block{Type: "CERTIFICATE", Bytes: config.rootCA})), |
| Jan Schär | d5d33ba | 2024-05-15 11:45:35 +0200 | [diff] [blame] | 67 | "--use-service-account-credentials=true", |
| Lorenz Brun | 8e3b8fc | 2020-05-19 14:29:40 +0200 | [diff] [blame] | 68 | fmt.Sprintf("--cluster-cidr=%v", config.clusterNet.String()), |
| Lorenz Brun | 6211e4d | 2023-11-14 19:09:40 +0100 | [diff] [blame] | 69 | fmt.Sprintf("--service-cluster-ip-range=%v", config.serviceNet.String()), |
| Lorenz Brun | 8e3b8fc | 2020-05-19 14:29:40 +0200 | [diff] [blame] | 70 | args.FileOpt("--tls-cert-file", "server-cert.pem", |
| 71 | pem.EncodeToMemory(&pem.Block{Type: "CERTIFICATE", Bytes: config.serverCert})), |
| 72 | args.FileOpt("--tls-private-key-file", "server-key.pem", |
| 73 | pem.EncodeToMemory(&pem.Block{Type: "PRIVATE KEY", Bytes: config.serverKey})), |
| Lorenz Brun | f042e6f | 2020-06-24 16:46:09 +0200 | [diff] [blame] | 74 | "--allocate-node-cidrs", |
| Lorenz Brun | 6211e4d | 2023-11-14 19:09:40 +0100 | [diff] [blame] | 75 | // Disables unused cloud control loops and prevents warnings. |
| 76 | "--cloud-provider=external", |
| 77 | "--controllers=*,-certificatesigningrequest-signing-controller", |
| 78 | // This is intentionally empty, but if unset it tries to mkdir it |
| 79 | // in the usual place, generating an error. |
| 80 | "--flex-volume-plugin-dir=/kubernetes/conf/flexvolume-plugins", |
| Lorenz Brun | d58edf4 | 2024-11-27 20:38:14 +0000 | [diff] [blame] | 81 | extraFeatureGates.AsFlag(), |
| Lorenz Brun | 8e3b8fc | 2020-05-19 14:29:40 +0200 | [diff] [blame] | 82 | ) |
| Lorenz Brun | f042e6f | 2020-06-24 16:46:09 +0200 | [diff] [blame] | 83 | |
| Lorenz Brun | 8e3b8fc | 2020-05-19 14:29:40 +0200 | [diff] [blame] | 84 | if args.Error() != nil { |
| 85 | return fmt.Errorf("failed to use fileargs: %w", err) |
| 86 | } |
| Serge Bazanski | 0560429 | 2021-03-12 17:47:21 +0100 | [diff] [blame] | 87 | return supervisor.RunCommand(ctx, cmd, supervisor.ParseKLog()) |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 88 | } |
| Lorenz Brun | 6e8f69c | 2019-11-18 10:44:24 +0100 | [diff] [blame] | 89 | } |