Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Route ¶
type Route struct { kapi.TypeMeta `json:",inline"` kapi.ObjectMeta `json:"metadata,omitempty"` Spec RouteSpec `json:"spec"` Status RouteStatus `json:"status"` }
Route encapsulates the inputs needed to connect an alias to endpoints.
func (*Route) IsAnAPIObject ¶
func (*Route) IsAnAPIObject()
type RouteList ¶
type RouteList struct { kapi.TypeMeta `json:",inline"` kapi.ListMeta `json:"metadata,omitempty"` Items []Route `json:"items"` }
RouteList is a collection of Routes.
func (*RouteList) IsAnAPIObject ¶
func (*RouteList) IsAnAPIObject()
type RouteSpec ¶
type RouteSpec struct { // Host is an alias/DNS that points to the service. Optional // Must follow DNS952 subdomain conventions. Host string `json:"host"` // Optional: Path that the router watches for, to route traffic for to the service Path string `json:"path,omitempty"` // An object the route points to. Only the Service kind is allowed, and it will // be defaulted to Service. To kapi.ObjectReference `json:"to"` // TLS provides the ability to configure certificates and termination for the route TLS *TLSConfig `json:"tls,omitempty"` }
RouteSpec describes the route the user wishes to exist.
type RouteStatus ¶
type RouteStatus struct { }
RouteStatus provides relevant info about the status of a route, including which routers acknowledge it.
type RouterShard ¶
type RouterShard struct { // Shard name uniquely identifies a router shard in the "set" of // routers used for routing traffic to the services. ShardName string `json:"shardName"` // The DNS suffix for the shard ala: shard-1.v3.openshift.com DNSSuffix string `json:"dnsSuffix"` }
RouterShard has information of a routing shard and is used to generate host names and routing table entries when a routing shard is allocated for a specific route. Caveat: This is WIP and will likely undergo modifications when sharding
support is added.
type TLSConfig ¶
type TLSConfig struct { // Termination indicates termination type. If termination type is not set, any termination config will be ignored Termination TLSTerminationType `json:"termination,omitempty"` // Certificate provides certificate contents Certificate string `json:"certificate,omitempty"` // Key provides key file contents Key string `json:"key,omitempty"` // CACertificate provides the cert authority certificate contents CACertificate string `json:"caCertificate,omitempty"` // DestinationCACertificate provides the contents of the ca certificate of the final destination. When using reencrypt // termination this file should be provided in order to have routers use it for health checks on the secure connection DestinationCACertificate string `json:"destinationCACertificate,omitempty"` }
TLSConfig defines config used to secure a route and provide termination
type TLSTerminationType ¶
type TLSTerminationType string
TLSTerminationType dictates where the secure communication will stop
const ( // TLSTerminationEdge terminate encryption at the edge router. TLSTerminationEdge TLSTerminationType = "edge" // TLSTerminationPassthrough terminate encryption at the destination, the destination is responsible for decrypting traffic TLSTerminationPassthrough TLSTerminationType = "passthrough" // TLSTerminationReencrypt terminate encryption at the edge router and re-encrypt it with a new certificate supplied by the destination TLSTerminationReencrypt TLSTerminationType = "reencrypt" )