8a1e53754e
This config entry will be used to configure terminating gateways. It accepts the name of the gateway and a list of services the gateway will represent. For each service users will be able to specify: its name, namespace, and additional options for TLS origination. Co-authored-by: Kyle Havlovitz <kylehav@gmail.com> Co-authored-by: Chris Piraino <cpiraino@hashicorp.com>
149 lines
4.9 KiB
Go
149 lines
4.9 KiB
Go
package api
|
|
|
|
// IngressGatewayConfigEntry manages the configuration for an ingress service
|
|
// with the given name.
|
|
type IngressGatewayConfigEntry struct {
|
|
// Kind of the config entry. This should be set to api.IngressGateway.
|
|
Kind string
|
|
|
|
// Name is used to match the config entry with its associated ingress gateway
|
|
// service. This should match the name provided in the service definition.
|
|
Name string
|
|
|
|
// Namespace is the namespace the IngressGateway is associated with
|
|
// Namespacing is a Consul Enterprise feature.
|
|
Namespace string `json:",omitempty"`
|
|
|
|
// Listeners declares what ports the ingress gateway should listen on, and
|
|
// what services to associated to those ports.
|
|
Listeners []IngressListener
|
|
|
|
// CreateIndex is the Raft index this entry was created at. This is a
|
|
// read-only field.
|
|
CreateIndex uint64
|
|
|
|
// ModifyIndex is used for the Check-And-Set operations and can also be fed
|
|
// back into the WaitIndex of the QueryOptions in order to perform blocking
|
|
// queries.
|
|
ModifyIndex uint64
|
|
}
|
|
|
|
// IngressListener manages the configuration for a listener on a specific port.
|
|
type IngressListener struct {
|
|
// Port declares the port on which the ingress gateway should listen for traffic.
|
|
Port int
|
|
|
|
// Protocol declares what type of traffic this listener is expected to
|
|
// receive. Depending on the protocol, a listener might support multiplexing
|
|
// services over a single port, or additional discovery chain features. The
|
|
// current supported values are: (tcp | http).
|
|
Protocol string
|
|
|
|
// Services declares the set of services to which the listener forwards
|
|
// traffic.
|
|
//
|
|
// For "tcp" protocol listeners, only a single service is allowed.
|
|
// For "http" listeners, multiple services can be declared.
|
|
Services []IngressService
|
|
}
|
|
|
|
// IngressService manages configuration for services that are exposed to
|
|
// ingress traffic.
|
|
type IngressService struct {
|
|
// Name declares the service to which traffic should be forwarded.
|
|
//
|
|
// This can either be a specific service instance, or the wildcard specifier,
|
|
// "*". If the wildcard specifier is provided, the listener must be of "http"
|
|
// protocol and means that the listener will forward traffic to all services.
|
|
Name string
|
|
|
|
// Namespace is the namespace where the service is located.
|
|
// Namespacing is a Consul Enterprise feature.
|
|
Namespace string `json:",omitempty"`
|
|
|
|
// ServiceSubset declares the specific service subset to which traffic should
|
|
// be sent. This must match an existing service subset declared in a
|
|
// service-resolver config entry.
|
|
ServiceSubset string
|
|
}
|
|
|
|
func (i *IngressGatewayConfigEntry) GetKind() string {
|
|
return i.Kind
|
|
}
|
|
|
|
func (i *IngressGatewayConfigEntry) GetName() string {
|
|
return i.Name
|
|
}
|
|
|
|
func (i *IngressGatewayConfigEntry) GetCreateIndex() uint64 {
|
|
return i.CreateIndex
|
|
}
|
|
|
|
func (i *IngressGatewayConfigEntry) GetModifyIndex() uint64 {
|
|
return i.ModifyIndex
|
|
}
|
|
|
|
// TerminatingGatewayConfigEntry manages the configuration for a terminating gateway
|
|
// with the given name.
|
|
type TerminatingGatewayConfigEntry struct {
|
|
// Kind of the config entry. This should be set to api.TerminatingGateway.
|
|
Kind string
|
|
|
|
// Name is used to match the config entry with its associated terminating gateway
|
|
// service. This should match the name provided in the service definition.
|
|
Name string
|
|
|
|
// Services is a list of service names represented by the terminating gateway.
|
|
Services []LinkedService `json:",omitempty"`
|
|
|
|
// CreateIndex is the Raft index this entry was created at. This is a
|
|
// read-only field.
|
|
CreateIndex uint64
|
|
|
|
// ModifyIndex is used for the Check-And-Set operations and can also be fed
|
|
// back into the WaitIndex of the QueryOptions in order to perform blocking
|
|
// queries.
|
|
ModifyIndex uint64
|
|
|
|
// Namespace is the namespace the config entry is associated with
|
|
// Namespacing is a Consul Enterprise feature.
|
|
Namespace string `json:",omitempty"`
|
|
}
|
|
|
|
// A LinkedService is a service represented by a terminating gateway
|
|
type LinkedService struct {
|
|
// The namespace the service is registered in
|
|
Namespace string `json:",omitempty"`
|
|
|
|
// Name is the name of the service, as defined in Consul's catalog
|
|
Name string `json:",omitempty"`
|
|
|
|
// CAFile is the optional path to a CA certificate to use for TLS connections
|
|
// from the gateway to the linked service
|
|
CAFile string `json:",omitempty"`
|
|
|
|
// CertFile is the optional path to a client certificate to use for TLS connections
|
|
// from the gateway to the linked service
|
|
CertFile string `json:",omitempty"`
|
|
|
|
// KeyFile is the optional path to a private key to use for TLS connections
|
|
// from the gateway to the linked service
|
|
KeyFile string `json:",omitempty"`
|
|
}
|
|
|
|
func (g *TerminatingGatewayConfigEntry) GetKind() string {
|
|
return g.Kind
|
|
}
|
|
|
|
func (g *TerminatingGatewayConfigEntry) GetName() string {
|
|
return g.Name
|
|
}
|
|
|
|
func (g *TerminatingGatewayConfigEntry) GetCreateIndex() uint64 {
|
|
return g.CreateIndex
|
|
}
|
|
|
|
func (g *TerminatingGatewayConfigEntry) GetModifyIndex() uint64 {
|
|
return g.ModifyIndex
|
|
}
|