| Tim Windelschmidt | 6d33a43 | 2025-02-04 14:34:25 +0100 | [diff] [blame] | 1 | // Copyright The Monogon Project Authors. |
| 2 | // SPDX-License-Identifier: Apache-2.0 |
| 3 | |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 4 | package main |
| 5 | |
| 6 | import ( |
| 7 | "crypto/x509" |
| 8 | "encoding/pem" |
| Tim Windelschmidt | d5f851b | 2024-04-23 14:59:37 +0200 | [diff] [blame] | 9 | "errors" |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 10 | "fmt" |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 11 | "log" |
| 12 | "os" |
| 13 | |
| 14 | "github.com/spf13/cobra" |
| 15 | |
| 16 | "source.monogon.dev/metropolis/cli/metroctl/core" |
| 17 | ) |
| 18 | |
| 19 | func init() { |
| 20 | certCmd.AddCommand(certExportCmd) |
| 21 | |
| 22 | rootCmd.AddCommand(certCmd) |
| 23 | } |
| 24 | |
| 25 | var certCmd = &cobra.Command{ |
| 26 | Short: "Certificate utilities", |
| 27 | Use: "cert", |
| 28 | } |
| 29 | |
| 30 | var certExportCmd = &cobra.Command{ |
| 31 | Short: "Exports certificates for use in other programs", |
| 32 | Use: "export", |
| 33 | Example: "metroctl cert export", |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 34 | RunE: func(cmd *cobra.Command, args []string) error { |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 35 | ocert, opkey, err := core.GetOwnerCredentials(flags.configPath) |
| Tim Windelschmidt | 513df18 | 2024-04-18 23:44:50 +0200 | [diff] [blame] | 36 | if errors.Is(err, core.ErrNoCredentials) { |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 37 | return fmt.Errorf("you have to take ownership of the cluster first: %w", err) |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 38 | } |
| 39 | |
| 40 | pkcs8Key, err := x509.MarshalPKCS8PrivateKey(opkey) |
| 41 | if err != nil { |
| 42 | // We explicitly pass an Ed25519 private key in, so this can't happen |
| 43 | panic(err) |
| 44 | } |
| 45 | |
| 46 | if err := os.WriteFile("owner.crt", pem.EncodeToMemory(&pem.Block{Type: "CERTIFICATE", Bytes: ocert.Raw}), 0755); err != nil { |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 47 | return err |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | if err := os.WriteFile("owner.key", pem.EncodeToMemory(&pem.Block{Type: "PRIVATE KEY", Bytes: pkcs8Key}), 0755); err != nil { |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 51 | return err |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 52 | } |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 53 | |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 54 | log.Println("Wrote files to current dir: cert.pem, key.pem") |
| Tim Windelschmidt | 0b4fb8c | 2024-09-18 17:34:23 +0200 | [diff] [blame] | 55 | return nil |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 56 | }, |
| Tim Windelschmidt | fc6e1cf | 2024-09-18 17:34:07 +0200 | [diff] [blame] | 57 | Args: PrintUsageOnWrongArgs(cobra.NoArgs), |
| Tim Windelschmidt | f0ec0f6 | 2023-07-17 13:43:38 +0200 | [diff] [blame] | 58 | } |