Rule

elbv2.services.k8s.aws/v1alpha1

TypeLink
GoDocelbv2-controller/apis/v1alpha1#Rule

Metadata

PropertyValue
ScopeNamespaced
KindRule
ListKindRuleList
Pluralrules
Singularrule

Information about a rule.

Spec

actions:
  authenticateCognitoConfig: 
    authenticationRequestExtraParams: {}
    onUnauthenticatedRequest: string
    scope: string
    sessionCookieName: string
    sessionTimeout: integer
    userPoolARN: string
    userPoolClientID: string
    userPoolDomain: string
  authenticateOIDCConfig: 
    authenticationRequestExtraParams: {}
    authorizationEndpoint: string
    clientID: string
    clientSecret: string
    issuer: string
    onUnauthenticatedRequest: string
    scope: string
    sessionCookieName: string
    sessionTimeout: integer
    tokenEndpoint: string
    useExistingClientSecret: boolean
    userInfoEndpoint: string
  fixedResponseConfig: 
    contentType: string
    messageBody: string
    statusCode: string
  forwardConfig: 
    targetGroupStickinessConfig: 
      durationSeconds: integer
      enabled: boolean
    targetGroups:
    - targetGroupARN: string
      targetGroupRef: 
        from: 
          name: string
          namespace: string
      weight: integer
  order: integer
  redirectConfig: 
    host: string
    path: string
    port: string
    protocol: string
    query: string
    statusCode: string
  targetGroupARN: string
  targetGroupRef: 
    from: 
      name: string
      namespace: string
  type: string
conditions:
- field: string
  hostHeaderConfig: 
    values:
    - string
  httpHeaderConfig: 
    httpHeaderName: string
    values:
    - string
  httpRequestMethodConfig: 
    values:
    - string
  pathPatternConfig: 
    values:
    - string
  queryStringConfig: 
    values:
    - key: string
      value: string
  sourceIPConfig: 
    values:
    - string
  values:
  - string
listenerARN: string
listenerRef: 
  from: 
    name: string
    namespace: string
priority: integer
tags:
- key: string
  value: string
FieldDescription
actions
Required
array
The actions.
actions.[]
Required
object
Information about an action.

Each rule must include exactly one of the following types of actions: forward, fixed-response, or redirect, and it must be the last action to be performed. || actions.[].authenticateCognitoConfig
Optional | object
Request parameters to use when integrating with Amazon Cognito to authenticate
users. | | actions.[].authenticateCognitoConfig.authenticationRequestExtraParams
Optional | object
| | actions.[].authenticateCognitoConfig.onUnauthenticatedRequest
Optional | string
| | actions.[].authenticateCognitoConfig.scope
Optional | string
| | actions.[].authenticateCognitoConfig.sessionCookieName
Optional | string
| | actions.[].authenticateCognitoConfig.sessionTimeout
Optional | integer
| | actions.[].authenticateCognitoConfig.userPoolARN
Optional | string
| | actions.[].authenticateCognitoConfig.userPoolClientID
Optional | string
| | actions.[].authenticateCognitoConfig.userPoolDomain
Optional | string
| | actions.[].authenticateOIDCConfig
Optional | object
Request parameters when using an identity provider (IdP) that is compliant
with OpenID Connect (OIDC) to authenticate users. | | actions.[].authenticateOIDCConfig.authenticationRequestExtraParams
Optional | object
| | actions.[].authenticateOIDCConfig.authorizationEndpoint
Optional | string
| | actions.[].authenticateOIDCConfig.clientID
Optional | string
| | actions.[].authenticateOIDCConfig.clientSecret
Optional | string
| | actions.[].authenticateOIDCConfig.issuer
Optional | string
| | actions.[].authenticateOIDCConfig.onUnauthenticatedRequest
Optional | string
| | actions.[].authenticateOIDCConfig.scope
Optional | string
| | actions.[].authenticateOIDCConfig.sessionCookieName
Optional | string
| | actions.[].authenticateOIDCConfig.sessionTimeout
Optional | integer
| | actions.[].authenticateOIDCConfig.tokenEndpoint
Optional | string
| | actions.[].authenticateOIDCConfig.useExistingClientSecret
Optional | boolean
| | actions.[].authenticateOIDCConfig.userInfoEndpoint
Optional | string
| | actions.[].fixedResponseConfig
Optional | object
Information about an action that returns a custom HTTP response. | | actions.[].fixedResponseConfig.contentType
Optional | string
| | actions.[].fixedResponseConfig.messageBody
Optional | string
| | actions.[].fixedResponseConfig.statusCode
Optional | string
| | actions.[].forwardConfig
Optional | object
Information about a forward action. | | actions.[].forwardConfig.targetGroupStickinessConfig
Optional | object
Information about the target group stickiness for a rule. | | actions.[].forwardConfig.targetGroupStickinessConfig.durationSeconds
Optional | integer
| | actions.[].forwardConfig.targetGroupStickinessConfig.enabled
Optional | boolean
| | actions.[].forwardConfig.targetGroups
Optional | array
| | actions.[].forwardConfig.targetGroups.[]
Required | object
Information about how traffic will be distributed between multiple target groups in a forward rule. || actions.[].forwardConfig.targetGroups.[].targetGroupARN
Optional | string
| | actions.[].forwardConfig.targetGroups.[].targetGroupRef
Optional | object
Reference field for TargetGroupARN | | actions.[].forwardConfig.targetGroups.[].targetGroupRef.from
Optional | object
AWSResourceReference provides all the values necessary to reference another
k8s resource for finding the identifier(Id/ARN/Name) | | actions.[].forwardConfig.targetGroups.[].targetGroupRef.from.name
Optional | string
| | actions.[].forwardConfig.targetGroups.[].targetGroupRef.from.namespace
Optional | string
| | actions.[].forwardConfig.targetGroups.[].weight
Optional | integer
| | actions.[].order
Optional | integer
| | actions.[].redirectConfig
Optional | object
Information about a redirect action.


A URI consists of the following components: protocol://hostname:port/path?query.
You must modify at least one of the following components to avoid a redirect
loop: protocol, hostname, port, or path. Any components that you do not modify
retain their original values.


You can reuse URI components using the following reserved keywords:


* #{protocol}


* #{host}


* #{port}


* #{path} (the leading “/” is removed)


* #{query}


For example, you can change the path to “/new/#{path}”, the hostname to “example.#{host}”,
or the query to “#{query}&value=xyz”. | | actions.[].redirectConfig.host
Optional | string
| | actions.[].redirectConfig.path
Optional | string
| | actions.[].redirectConfig.port
Optional | string
| | actions.[].redirectConfig.protocol
Optional | string
| | actions.[].redirectConfig.query
Optional | string
| | actions.[].redirectConfig.statusCode
Optional | string
| | actions.[].targetGroupARN
Optional | string
| | actions.[].targetGroupRef
Optional | object
Reference field for TargetGroupARN | | actions.[].targetGroupRef.from
Optional | object
AWSResourceReference provides all the values necessary to reference another
k8s resource for finding the identifier(Id/ARN/Name) | | actions.[].targetGroupRef.from.name
Optional | string
| | actions.[].targetGroupRef.from.namespace
Optional | string
| | actions.[].type
Optional | string
| | conditions
Required | array
The conditions. | | conditions.[]
Required | object
Information about a condition for a rule.

Each rule can optionally include up to one of each of the following conditions: http-request-method, host-header, path-pattern, and source-ip. Each rule can also optionally include one or more of each of the following conditions: http-header and query-string. Note that the value for a condition cannot be empty.

For more information, see Quotas for your Application Load Balancers (https://docs.aws.amazon.com/elasticloadbalancing/latest/application/load-balancer-limits.html). || conditions.[].field
Optional | string
| | conditions.[].hostHeaderConfig
Optional | object
Information about a host header condition. | | conditions.[].hostHeaderConfig.values
Optional | array
| | conditions.[].hostHeaderConfig.values.[]
Required | string
|| conditions.[].httpHeaderConfig
Optional | object
Information about an HTTP header condition.


There is a set of standard HTTP header fields. You can also define custom
HTTP header fields. | | conditions.[].httpHeaderConfig.httpHeaderName
Optional | string
| | conditions.[].httpHeaderConfig.values
Optional | array
| | conditions.[].httpHeaderConfig.values.[]
Required | string
|| conditions.[].httpRequestMethodConfig
Optional | object
Information about an HTTP method condition.


HTTP defines a set of request methods, also referred to as HTTP verbs. For
more information, see the HTTP Method Registry (https://www.iana.org/assignments/http-methods/http-methods.xhtml).
You can also define custom HTTP methods. | | conditions.[].httpRequestMethodConfig.values
Optional | array
| | conditions.[].httpRequestMethodConfig.values.[]
Required | string
|| conditions.[].pathPatternConfig
Optional | object
Information about a path pattern condition. | | conditions.[].pathPatternConfig.values
Optional | array
| | conditions.[].pathPatternConfig.values.[]
Required | string
|| conditions.[].queryStringConfig
Optional | object
Information about a query string condition.


The query string component of a URI starts after the first ‘?’ character
and is terminated by either a ‘#’ character or the end of the URI. A typical
query string contains key/value pairs separated by ‘&’ characters. The allowed
characters are specified by RFC 3986. Any character can be percentage encoded. | | conditions.[].queryStringConfig.values
Optional | array
| | conditions.[].queryStringConfig.values.[]
Required | object
Information about a key/value pair. || conditions.[].queryStringConfig.values.[].key
Optional | string
| | conditions.[].queryStringConfig.values.[].value
Optional | string
| | conditions.[].sourceIPConfig
Optional | object
Information about a source IP condition.


You can use this condition to route based on the IP address of the source
that connects to the load balancer. If a client is behind a proxy, this is
the IP address of the proxy not the IP address of the client. | | conditions.[].sourceIPConfig.values
Optional | array
| | conditions.[].sourceIPConfig.values.[]
Required | string
|| conditions.[].values
Optional | array
| | conditions.[].values.[]
Required | string
|| listenerARN
Optional | string
The Amazon Resource Name (ARN) of the listener. | | listenerRef
Optional | object
AWSResourceReferenceWrapper provides a wrapper around *AWSResourceReference
type to provide more user friendly syntax for references using ‘from’ field
Ex:
APIIDRef:


from:
name: my-api | | listenerRef.from
Optional | object
AWSResourceReference provides all the values necessary to reference another
k8s resource for finding the identifier(Id/ARN/Name) | | listenerRef.from.name
Optional | string
| | listenerRef.from.namespace
Optional | string
| | priority
Required | integer
The rule priority. A listener can’t have multiple rules with the same priority. | | tags
Optional | array
The tags to assign to the rule. | | tags.[]
Required | object
Information about a tag. || tags.[].key
Optional | string
| | tags.[].value
Optional | string
|

Status

ackResourceMetadata: 
  arn: string
  ownerAccountID: string
  region: string
conditions:
- lastTransitionTime: string
  message: string
  reason: string
  status: string
  type: string
isDefault: boolean
FieldDescription
ackResourceMetadata
Optional
object
All CRs managed by ACK have a common Status.ACKResourceMetadata member
that is used to contain resource sync state, account ownership,
constructed ARN for the resource
ackResourceMetadata.arn
Optional
string
ARN is the Amazon Resource Name for the resource. This is a
globally-unique identifier and is set only by the ACK service controller
once the controller has orchestrated the creation of the resource OR
when it has verified that an “adopted” resource (a resource where the
ARN annotation was set by the Kubernetes user on the CR) exists and
matches the supplied CR’s Spec field values.
TODO(vijat@): Find a better strategy for resources that do not have ARN in CreateOutputResponse
https://github.com/aws/aws-controllers-k8s/issues/270
ackResourceMetadata.ownerAccountID
Required
string
OwnerAccountID is the AWS Account ID of the account that owns the
backend AWS service API resource.
ackResourceMetadata.region
Required
string
Region is the AWS region in which the resource exists or will exist.
conditions
Optional
array
All CRS managed by ACK have a common Status.Conditions member that
contains a collection of ackv1alpha1.Condition objects that describe
the various terminal states of the CR and its backend AWS service API
resource
conditions.[]
Required
object
Condition is the common struct used by all CRDs managed by ACK service
controllers to indicate terminal states of the CR and its backend AWS
service API resource
conditions.[].message
Optional
string
A human readable message indicating details about the transition.
conditions.[].reason
Optional
string
The reason for the condition’s last transition.
conditions.[].status
Optional
string
Status of the condition, one of True, False, Unknown.
conditions.[].type
Optional
string
Type is the type of the Condition
isDefault
Optional
boolean
Indicates whether this is the default rule.