56 lines
1.2 KiB
Go
56 lines
1.2 KiB
Go
|
// Copyright 2021 the Pinniped contributors. All Rights Reserved.
|
||
|
// SPDX-License-Identifier: Apache-2.0
|
||
|
|
||
|
// Package main is the combined entrypoint for the Pinniped "kube-cert-agent" component.
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"encoding/base64"
|
||
|
"encoding/json"
|
||
|
"io"
|
||
|
"io/ioutil"
|
||
|
"log"
|
||
|
"math"
|
||
|
"os"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
//nolint: gochecknoglobals // these are swapped during unit tests.
|
||
|
var (
|
||
|
getenv = os.Getenv
|
||
|
fail = log.Fatalf
|
||
|
sleep = time.Sleep
|
||
|
out = io.Writer(os.Stdout)
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
if len(os.Args) < 2 {
|
||
|
fail("missing subcommand")
|
||
|
}
|
||
|
|
||
|
switch os.Args[1] {
|
||
|
case "sleep":
|
||
|
sleep(math.MaxInt64)
|
||
|
case "print":
|
||
|
certBytes, err := ioutil.ReadFile(getenv("CERT_PATH"))
|
||
|
if err != nil {
|
||
|
fail("could not read CERT_PATH: %v", err)
|
||
|
}
|
||
|
keyBytes, err := ioutil.ReadFile(getenv("KEY_PATH"))
|
||
|
if err != nil {
|
||
|
fail("could not read KEY_PATH: %v", err)
|
||
|
}
|
||
|
if err := json.NewEncoder(out).Encode(&struct {
|
||
|
Cert string `json:"tls.crt"`
|
||
|
Key string `json:"tls.key"`
|
||
|
}{
|
||
|
Cert: base64.StdEncoding.EncodeToString(certBytes),
|
||
|
Key: base64.StdEncoding.EncodeToString(keyBytes),
|
||
|
}); err != nil {
|
||
|
fail("failed to write output: %v", err)
|
||
|
}
|
||
|
default:
|
||
|
fail("invalid subcommand %q", os.Args[1])
|
||
|
}
|
||
|
}
|