2018-03-26 00:52:26 +00:00
|
|
|
package structs
|
|
|
|
|
2018-04-16 15:00:20 +00:00
|
|
|
import (
|
|
|
|
"github.com/mitchellh/mapstructure"
|
|
|
|
)
|
|
|
|
|
2018-03-26 00:52:26 +00:00
|
|
|
// ConnectAuthorizeRequest is the structure of a request to authorize
|
|
|
|
// a connection.
|
|
|
|
type ConnectAuthorizeRequest struct {
|
|
|
|
// Target is the name of the service that is being requested.
|
|
|
|
Target string
|
|
|
|
|
2018-03-28 21:29:35 +00:00
|
|
|
// ClientCertURI is a unique identifier for the requesting client. This
|
2018-03-26 00:52:26 +00:00
|
|
|
// is currently the URI SAN from the TLS client certificate.
|
|
|
|
//
|
|
|
|
// ClientCertSerial is a colon-hex-encoded of the serial number for
|
|
|
|
// the requesting client cert. This is used to check against revocation
|
|
|
|
// lists.
|
2018-03-28 21:29:35 +00:00
|
|
|
ClientCertURI string
|
2018-03-26 00:52:26 +00:00
|
|
|
ClientCertSerial string
|
|
|
|
}
|
2018-04-16 15:00:20 +00:00
|
|
|
|
|
|
|
// ProxyExecMode encodes the mode for running a managed connect proxy.
|
|
|
|
type ProxyExecMode int
|
|
|
|
|
|
|
|
const (
|
|
|
|
// ProxyExecModeDaemon executes a proxy process as a supervised daemon.
|
|
|
|
ProxyExecModeDaemon ProxyExecMode = iota
|
|
|
|
|
|
|
|
// ProxyExecModeScript executes a proxy config script on each change to it's
|
|
|
|
// config.
|
|
|
|
ProxyExecModeScript
|
|
|
|
)
|
|
|
|
|
|
|
|
// ConnectManagedProxy represents the agent-local state for a configured proxy
|
|
|
|
// instance. This is never stored or sent to the servers and is only used to
|
|
|
|
// store the config for the proxy that the agent needs to track. For now it's
|
|
|
|
// really generic with only the fields the agent needs to act on defined while
|
|
|
|
// the rest of the proxy config is passed as opaque bag of attributes to support
|
|
|
|
// arbitrary config params for third-party proxy integrations. "External"
|
|
|
|
// proxies by definition register themselves and manage their own config
|
|
|
|
// externally so are never represented in agent state.
|
|
|
|
type ConnectManagedProxy struct {
|
|
|
|
// ExecMode is one of daemon or script.
|
|
|
|
ExecMode ProxyExecMode
|
|
|
|
|
|
|
|
// Command is the command to execute. Empty defaults to self-invoking the same
|
|
|
|
// consul binary with proxy subcomand for ProxyExecModeDaemon and is an error
|
|
|
|
// for ProxyExecModeScript.
|
|
|
|
Command string
|
|
|
|
|
|
|
|
// Config is the arbitrary configuration data provided with the registration.
|
|
|
|
Config map[string]interface{}
|
|
|
|
|
|
|
|
// ProxyService is a pointer to the local proxy's service record for
|
|
|
|
// convenience. The proxies ID and name etc. can be read from there. It may be
|
|
|
|
// nil if the agent is starting up and hasn't registered the service yet.
|
|
|
|
ProxyService *NodeService
|
|
|
|
|
|
|
|
// TargetServiceID is the ID of the target service on the localhost. It may
|
|
|
|
// not exist yet since bootstrapping is allowed to happen in either order.
|
|
|
|
TargetServiceID string
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConnectManagedProxyConfig represents the parts of the proxy config the agent
|
|
|
|
// needs to understand. It's bad UX to make the user specify these separately
|
|
|
|
// just to make parsing simpler for us so this encapsulates the fields in
|
|
|
|
// ConnectManagedProxy.Config that we care about. They are all optoinal anyway
|
|
|
|
// and this is used to decode them with mapstructure.
|
|
|
|
type ConnectManagedProxyConfig struct {
|
|
|
|
BindAddress string `mapstructure:"bind_address"`
|
|
|
|
BindPort int `mapstructure:"bind_port"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// ParseConfig attempts to read the fields we care about from the otherwise
|
|
|
|
// opaque config map. They are all optional but it may fail if one is specified
|
|
|
|
// but an invalid value.
|
|
|
|
func (p *ConnectManagedProxy) ParseConfig() (*ConnectManagedProxyConfig, error) {
|
|
|
|
var cfg ConnectManagedProxyConfig
|
|
|
|
d, err := mapstructure.NewDecoder(&mapstructure.DecoderConfig{
|
|
|
|
ErrorUnused: false,
|
|
|
|
WeaklyTypedInput: true, // allow string port etc.
|
|
|
|
Result: &cfg,
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
err = d.Decode(p.Config)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return &cfg, nil
|
|
|
|
}
|