cli.go 2.75 KB
Newer Older
1 2 3 4 5
// This file contains CLI and env TLS configurations that can be used by clients or servers
package tls

import (
	"errors"
6 7
	"fmt"
	"strings"
8

9
	"github.com/urfave/cli/v2"
10 11 12 13 14 15 16 17 18 19

	opservice "github.com/ethereum-optimism/optimism/op-service"
)

const (
	TLSCaCertFlagName = "tls.ca"
	TLSCertFlagName   = "tls.cert"
	TLSKeyFlagName    = "tls.key"
)

20 21
// CLIFlags returns flags with env var envPrefix
// This should be used for server TLS configs, or when client and server tls configs are the same
22
func CLIFlags(envPrefix string) []cli.Flag {
23 24 25 26 27 28 29 30 31
	return CLIFlagsWithFlagPrefix(envPrefix, "")
}

// CLIFlagsWithFlagPrefix returns flags with env var and cli flag prefixes
// Should be used for client TLS configs when different from server on the same process
func CLIFlagsWithFlagPrefix(envPrefix string, flagPrefix string) []cli.Flag {
	prefixFunc := func(flagName string) string {
		return strings.Trim(fmt.Sprintf("%s.%s", flagPrefix, flagName), ".")
	}
32
	prefixEnvVars := func(name string) []string {
33
		return opservice.PrefixEnvVar(envPrefix, name)
34
	}
35
	return []cli.Flag{
36 37 38 39 40
		&cli.StringFlag{
			Name:    prefixFunc(TLSCaCertFlagName),
			Usage:   "tls ca cert path",
			Value:   "tls/ca.crt",
			EnvVars: prefixEnvVars("TLS_CA"),
41
		},
42 43 44 45 46
		&cli.StringFlag{
			Name:    prefixFunc(TLSCertFlagName),
			Usage:   "tls cert path",
			Value:   "tls/tls.crt",
			EnvVars: prefixEnvVars("TLS_CERT"),
47
		},
48 49 50 51 52
		&cli.StringFlag{
			Name:    prefixFunc(TLSKeyFlagName),
			Usage:   "tls key",
			Value:   "tls/tls.key",
			EnvVars: prefixEnvVars("TLS_KEY"),
53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
		},
	}
}

type CLIConfig struct {
	TLSCaCert string
	TLSCert   string
	TLSKey    string
}

func (c CLIConfig) Check() error {
	if c.TLSEnabled() && (c.TLSCaCert == "" || c.TLSCert == "" || c.TLSKey == "") {
		return errors.New("all tls flags must be set if at least one is set")
	}

	return nil
}

func (c CLIConfig) TLSEnabled() bool {
	return !(c.TLSCaCert == "" && c.TLSCert == "" && c.TLSKey == "")
}

75 76
// ReadCLIConfig reads tls cli configs
// This should be used for server TLS configs, or when client and server tls configs are the same
77 78
func ReadCLIConfig(ctx *cli.Context) CLIConfig {
	return CLIConfig{
79 80 81
		TLSCaCert: ctx.String(TLSCaCertFlagName),
		TLSCert:   ctx.String(TLSCertFlagName),
		TLSKey:    ctx.String(TLSKeyFlagName),
82 83
	}
}
84 85 86 87 88 89 90 91

// ReadCLIConfigWithPrefix reads tls cli configs with flag prefix
// Should be used for client TLS configs when different from server on the same process
func ReadCLIConfigWithPrefix(ctx *cli.Context, flagPrefix string) CLIConfig {
	prefixFunc := func(flagName string) string {
		return strings.Trim(fmt.Sprintf("%s.%s", flagPrefix, flagName), ".")
	}
	return CLIConfig{
92 93 94
		TLSCaCert: ctx.String(prefixFunc(TLSCaCertFlagName)),
		TLSCert:   ctx.String(prefixFunc(TLSCertFlagName)),
		TLSKey:    ctx.String(prefixFunc(TLSKeyFlagName)),
95 96
	}
}