delowan.googlecloud.gcp_compute_global_forwarding_rule (1.0.2) — module

Creates a GCP GlobalForwardingRule

Authors: Google Inc. (@googlecloudplatform)

preview | supported by community

Install collection

Install with ansible-galaxy collection install delowan.googlecloud:==1.0.2


Add to requirements.yml

  collections:
    - name: delowan.googlecloud
      version: 1.0.2

Description

Represents a GlobalForwardingRule resource. Global forwarding rules are used to forward traffic to the correct load balancer for HTTP load balancing. Global forwarding rules can only be used for HTTP load balancing.

For more information, see U(https://cloud.google.com/compute/docs/load-balancing/http/) .


Requirements

Usage examples

  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a global address
  google.cloud.gcp_compute_global_address:
    name: globaladdress-globalforwardingrule
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: globaladdress
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a instance group
  google.cloud.gcp_compute_instance_group:
    name: instancegroup-globalforwardingrule
    zone: us-central1-a
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: instancegroup
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a HTTP health check
  google.cloud.gcp_compute_http_health_check:
    name: httphealthcheck-globalforwardingrule
    healthy_threshold: 10
    port: 8080
    timeout_sec: 2
    unhealthy_threshold: 5
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: healthcheck
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a backend service
  google.cloud.gcp_compute_backend_service:
    name: backendservice-globalforwardingrule
    backends:
    - group: "{{ instancegroup.selfLink }}"
    health_checks:
    - "{{ healthcheck.selfLink }}"
    enable_cdn: 'true'
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: backendservice
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a URL map
  google.cloud.gcp_compute_url_map:
    name: urlmap-globalforwardingrule
    default_service: "{{ backendservice }}"
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: urlmap
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a target HTTP proxy
  google.cloud.gcp_compute_target_http_proxy:
    name: targethttpproxy-globalforwardingrule
    url_map: "{{ urlmap }}"
    project: "{{ gcp_project }}"
    auth_kind: "{{ gcp_cred_kind }}"
    service_account_file: "{{ gcp_cred_file }}"
    state: present
  register: httpproxy
  • Success
    Steampunk Spotter scan finished with no errors, warnings or hints.
- name: create a global forwarding rule
  google.cloud.gcp_compute_global_forwarding_rule:
    name: test_object
    ip_address: "{{ globaladdress.address }}"
    ip_protocol: TCP
    port_range: 80-80
    target: "{{ httpproxy.selfLink }}"
    project: test_project
    auth_kind: serviceaccount
    service_account_file: "/tmp/auth.pem"
    state: present

Inputs

    
name:
    description:
    - Name of the resource; provided by the client when the resource is created. The name
      must be 1-63 characters long, and comply with RFC1035. Specifically, the name must
      be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`
      which means the first character must be a lowercase letter, and all following characters
      must be a dash, lowercase letter, or digit, except the last character, which cannot
      be a dash.
    required: true
    type: str

state:
    choices:
    - present
    - absent
    default: present
    description:
    - Whether the given object should exist in GCP
    type: str

scopes:
    description:
    - Array of scopes to be used
    elements: str
    type: list

target:
    description:
    - The URL of the target resource to receive the matched traffic.
    - The forwarded traffic must be of a type appropriate to the target object.
    - For INTERNAL_SELF_MANAGED load balancing, only HTTP and HTTPS targets are valid.
    - ([Beta](U(https://terraform.io/docs/providers/google/guides/provider_versions.html))
      only) For global address with a purpose of PRIVATE_SERVICE_CONNECT and addressType
      of INTERNAL, only "all-apis" and "vpc-sc" are valid.
    required: true
    type: str

network:
    description:
    - This field is not used for external load balancing.
    - For INTERNAL_SELF_MANAGED load balancing, this field identifies the network that
      the load balanced IP should belong to for this global forwarding rule. If this field
      is not specified, the default network will be used.
    - 'This field represents a link to a Network resource in GCP. It can be specified
      in two ways. First, you can place a dictionary with key ''selfLink'' and value of
      your resource''s selfLink Alternatively, you can add `register: name-of-resource`
      to a gcp_compute_network task and then set this network field to "{{ name-of-resource
      }}"'
    required: false
    type: dict

project:
    description:
    - The Google Cloud Platform project to use.
    type: str

env_type:
    description:
    - Specifies which Ansible environment you're running this module within.
    - This should not be set unless you know what you're doing.
    - This only alters the User Agent string for any API requests.
    type: str

auth_kind:
    choices:
    - application
    - machineaccount
    - serviceaccount
    description:
    - The type of credential used.
    required: true
    type: str

ip_address:
    description:
    - The IP address that this forwarding rule is serving on behalf of.
    - Addresses are restricted based on the forwarding rule's load balancing scheme (EXTERNAL
      or INTERNAL) and scope (global or regional).
    - When the load balancing scheme is EXTERNAL, for global forwarding rules, the address
      must be a global IP, and for regional forwarding rules, the address must live in
      the same region as the forwarding rule. If this field is empty, an ephemeral IPv4
      address from the same scope (global or regional) will be assigned. A regional forwarding
      rule supports IPv4 only. A global forwarding rule supports either IPv4 or IPv6.
    - When the load balancing scheme is INTERNAL, this can only be an RFC 1918 IP address
      belonging to the network/subnet configured for the forwarding rule. By default,
      if this field is empty, an ephemeral internal IP address will be automatically allocated
      from the IP range of the subnet or network configured for this forwarding rule.
    - 'An address can be specified either by a literal IP address or a URL reference to
      an existing Address resource. The following examples are all valid: * 100.1.2.3
      * U(https://www.googleapis.com/compute/v1/projects/project/regions/region/addresses/address)
      * projects/project/regions/region/addresses/address * regions/region/addresses/address
      * global/addresses/address * address .'
    required: false
    type: str

ip_version:
    description:
    - The IP Version that will be used by this global forwarding rule.
    - 'Some valid choices include: "IPV4", "IPV6"'
    required: false
    type: str

port_range:
    description:
    - This field is used along with the target field for TargetHttpProxy, TargetHttpsProxy,
      TargetSslProxy, TargetTcpProxy, TargetVpnGateway, TargetPool, TargetInstance.
    - Applicable only when IPProtocol is TCP, UDP, or SCTP, only packets addressed to
      ports in the specified range will be forwarded to target.
    - Forwarding rules with the same [IPAddress, IPProtocol] pair must have disjoint port
      ranges.
    - 'Some types of forwarding target have constraints on the acceptable ports: * TargetHttpProxy:
      80, 8080 * TargetHttpsProxy: 443 * TargetTcpProxy: 25, 43, 110, 143, 195, 443, 465,
      587, 700, 993, 995, 1883, 5222 * TargetSslProxy: 25, 43, 110, 143, 195, 443, 465,
      587, 700, 993, 995, 1883, 5222 * TargetVpnGateway: 500, 4500 .'
    required: false
    type: str

description:
    description:
    - An optional description of this resource. Provide this property when you create
      the resource.
    required: false
    type: str

ip_protocol:
    description:
    - The IP protocol to which this rule applies. When the load balancing scheme is INTERNAL_SELF_MANAGED,
      only TCP is valid. This field must not be set if the global address is configured
      as a purpose of PRIVATE_SERVICE_CONNECT and addressType of INTERNAL .
    - 'Some valid choices include: "TCP", "UDP", "ESP", "AH", "SCTP", "ICMP"'
    required: false
    type: str

metadata_filters:
    description:
    - Opaque filter criteria used by Loadbalancer to restrict routing configuration to
      a limited set xDS compliant clients. In their xDS requests to Loadbalancer, xDS
      clients present node metadata. If a match takes place, the relevant routing configuration
      is made available to those proxies.
    - For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY,
      at least one of the filterLabels must match the corresponding label provided in
      the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its filterLabels
      must match with corresponding labels in the provided metadata.
    - metadataFilters specified here can be overridden by those specified in the UrlMap
      that this ForwardingRule references.
    - metadataFilters only applies to Loadbalancers that have their loadBalancingScheme
      set to INTERNAL_SELF_MANAGED.
    elements: dict
    required: false
    suboptions:
      filter_labels:
        description:
        - The list of label value pairs that must match labels in the provided metadata
          based on filterMatchCriteria This list must not be empty and can have at the
          most 64 entries.
        elements: dict
        required: true
        suboptions:
          name:
            description:
            - Name of the metadata label. The length must be between 1 and 1024 characters,
              inclusive.
            required: true
            type: str
          value:
            description:
            - The value that the label must match. The value has a maximum length of 1024
              characters.
            required: true
            type: str
        type: list
      filter_match_criteria:
        description:
        - Specifies how individual filterLabel matches within the list of filterLabels
          contribute towards the overall metadataFilter match.
        - MATCH_ANY - At least one of the filterLabels must have a matching label in the
          provided metadata.
        - MATCH_ALL - All filterLabels must have matching labels in the provided metadata.
        - 'Some valid choices include: "MATCH_ANY", "MATCH_ALL"'
        required: true
        type: str
    type: list

service_account_file:
    description:
    - The path of a Service Account JSON file if serviceaccount is selected as type.
    type: path

load_balancing_scheme:
    default: EXTERNAL
    description:
    - This signifies what the GlobalForwardingRule will be used for.
    - 'The value of INTERNAL_SELF_MANAGED means that this will be used for Internal Global
      HTTP(S) LB. The value of EXTERNAL means that this will be used for External Global
      Load Balancing (HTTP(S) LB, External TCP/UDP LB, SSL Proxy) ([Beta](U(https://terraform.io/docs/providers/google/guides/provider_versions.html))
      only) Note: This field must be set "" if the global address is configured as a purpose
      of PRIVATE_SERVICE_CONNECT and addressType of INTERNAL.'
    - 'Some valid choices include: "EXTERNAL", "INTERNAL_SELF_MANAGED"'
    required: false
    type: str

service_account_email:
    description:
    - An optional service account email address if machineaccount is selected and the
      user does not wish to use the default email.
    type: str

service_account_contents:
    description:
    - The contents of a Service Account JSON file, either in a dictionary or as a JSON
      string that represents it.
    type: jsonarg

Outputs

IPAddress:
  description:
  - The IP address that this forwarding rule is serving on behalf of.
  - Addresses are restricted based on the forwarding rule's load balancing scheme
    (EXTERNAL or INTERNAL) and scope (global or regional).
  - When the load balancing scheme is EXTERNAL, for global forwarding rules, the address
    must be a global IP, and for regional forwarding rules, the address must live
    in the same region as the forwarding rule. If this field is empty, an ephemeral
    IPv4 address from the same scope (global or regional) will be assigned. A regional
    forwarding rule supports IPv4 only. A global forwarding rule supports either IPv4
    or IPv6.
  - When the load balancing scheme is INTERNAL, this can only be an RFC 1918 IP address
    belonging to the network/subnet configured for the forwarding rule. By default,
    if this field is empty, an ephemeral internal IP address will be automatically
    allocated from the IP range of the subnet or network configured for this forwarding
    rule.
  - 'An address can be specified either by a literal IP address or a URL reference
    to an existing Address resource. The following examples are all valid: * 100.1.2.3
    * U(https://www.googleapis.com/compute/v1/projects/project/regions/region/addresses/address)
    * projects/project/regions/region/addresses/address * regions/region/addresses/address
    * global/addresses/address * address .'
  returned: success
  type: str
IPProtocol:
  description:
  - The IP protocol to which this rule applies. When the load balancing scheme is
    INTERNAL_SELF_MANAGED, only TCP is valid. This field must not be set if the global
    address is configured as a purpose of PRIVATE_SERVICE_CONNECT and addressType
    of INTERNAL .
  returned: success
  type: str
creationTimestamp:
  description:
  - Creation timestamp in RFC3339 text format.
  returned: success
  type: str
description:
  description:
  - An optional description of this resource. Provide this property when you create
    the resource.
  returned: success
  type: str
id:
  description:
  - The unique identifier for the resource.
  returned: success
  type: int
ipVersion:
  description:
  - The IP Version that will be used by this global forwarding rule.
  returned: success
  type: str
loadBalancingScheme:
  description:
  - This signifies what the GlobalForwardingRule will be used for.
  - 'The value of INTERNAL_SELF_MANAGED means that this will be used for Internal
    Global HTTP(S) LB. The value of EXTERNAL means that this will be used for External
    Global Load Balancing (HTTP(S) LB, External TCP/UDP LB, SSL Proxy) ([Beta](U(https://terraform.io/docs/providers/google/guides/provider_versions.html))
    only) Note: This field must be set "" if the global address is configured as a
    purpose of PRIVATE_SERVICE_CONNECT and addressType of INTERNAL.'
  returned: success
  type: str
metadataFilters:
  contains:
    filterLabels:
      contains:
        name:
          description:
          - Name of the metadata label. The length must be between 1 and 1024 characters,
            inclusive.
          returned: success
          type: str
        value:
          description:
          - The value that the label must match. The value has a maximum length of
            1024 characters.
          returned: success
          type: str
      description:
      - The list of label value pairs that must match labels in the provided metadata
        based on filterMatchCriteria This list must not be empty and can have at the
        most 64 entries.
      returned: success
      type: complex
    filterMatchCriteria:
      description:
      - Specifies how individual filterLabel matches within the list of filterLabels
        contribute towards the overall metadataFilter match.
      - MATCH_ANY - At least one of the filterLabels must have a matching label in
        the provided metadata.
      - MATCH_ALL - All filterLabels must have matching labels in the provided metadata.
      returned: success
      type: str
  description:
  - Opaque filter criteria used by Loadbalancer to restrict routing configuration
    to a limited set xDS compliant clients. In their xDS requests to Loadbalancer,
    xDS clients present node metadata. If a match takes place, the relevant routing
    configuration is made available to those proxies.
  - For each metadataFilter in this list, if its filterMatchCriteria is set to MATCH_ANY,
    at least one of the filterLabels must match the corresponding label provided in
    the metadata. If its filterMatchCriteria is set to MATCH_ALL, then all of its
    filterLabels must match with corresponding labels in the provided metadata.
  - metadataFilters specified here can be overridden by those specified in the UrlMap
    that this ForwardingRule references.
  - metadataFilters only applies to Loadbalancers that have their loadBalancingScheme
    set to INTERNAL_SELF_MANAGED.
  returned: success
  type: complex
name:
  description:
  - Name of the resource; provided by the client when the resource is created. The
    name must be 1-63 characters long, and comply with RFC1035. Specifically, the
    name must be 1-63 characters long and match the regular expression `[a-z]([-a-z0-9]*[a-z0-9])?`
    which means the first character must be a lowercase letter, and all following
    characters must be a dash, lowercase letter, or digit, except the last character,
    which cannot be a dash.
  returned: success
  type: str
network:
  description:
  - This field is not used for external load balancing.
  - For INTERNAL_SELF_MANAGED load balancing, this field identifies the network that
    the load balanced IP should belong to for this global forwarding rule. If this
    field is not specified, the default network will be used.
  returned: success
  type: dict
portRange:
  description:
  - This field is used along with the target field for TargetHttpProxy, TargetHttpsProxy,
    TargetSslProxy, TargetTcpProxy, TargetVpnGateway, TargetPool, TargetInstance.
  - Applicable only when IPProtocol is TCP, UDP, or SCTP, only packets addressed to
    ports in the specified range will be forwarded to target.
  - Forwarding rules with the same [IPAddress, IPProtocol] pair must have disjoint
    port ranges.
  - 'Some types of forwarding target have constraints on the acceptable ports: * TargetHttpProxy:
    80, 8080 * TargetHttpsProxy: 443 * TargetTcpProxy: 25, 43, 110, 143, 195, 443,
    465, 587, 700, 993, 995, 1883, 5222 * TargetSslProxy: 25, 43, 110, 143, 195, 443,
    465, 587, 700, 993, 995, 1883, 5222 * TargetVpnGateway: 500, 4500 .'
  returned: success
  type: str
target:
  description:
  - The URL of the target resource to receive the matched traffic.
  - The forwarded traffic must be of a type appropriate to the target object.
  - For INTERNAL_SELF_MANAGED load balancing, only HTTP and HTTPS targets are valid.
  - ([Beta](U(https://terraform.io/docs/providers/google/guides/provider_versions.html))
    only) For global address with a purpose of PRIVATE_SERVICE_CONNECT and addressType
    of INTERNAL, only "all-apis" and "vpc-sc" are valid.
  returned: success
  type: str