- HTTP request
- Path parameters
- Query parameters
- Request body
- Response body
- Authorization scopes
- IAM Permissions
- Try it!
Retrieves a list of ForwardingRule resources available to the specified project and region.
HTTP request
GET https://compute.googleapis.com/compute/beta/projects/{project}/regions/{region}/forwardingRules
The URL uses gRPC Transcoding syntax. To know more about valid error responses that can be thrown by this HTTP request, please refer to the service error catalog
Path parameters
| Parameters | |
|---|---|
| project | 
 Project ID for this request. | 
| region | 
 Name of the region scoping this request. | 
Query parameters
| Parameters | |
|---|---|
| maxResults | 
 The maximum number of results per page that should be returned. If the number of available results is larger than  | 
| pageToken | 
 Specifies a page token to use. Set  | 
| filter | 
 A filter expression that filters resources listed in the response. Most Compute resources support two types of filter expressions: expressions that support regular expressions and expressions that follow API improvement proposal AIP-160. These two types of filter expressions cannot be mixed in one request. If you want to use AIP-160, your expression must specify the field name, an operator, and the value that you want to use for filtering. The value must be a string, a number, or a boolean. The operator must be either  For example, if you are filtering Compute Engine instances, you can exclude instances named  The  You can also filter nested fields. For example, you could specify  To filter on multiple expressions, provide each separate expression within parentheses. For example: By default, each expression is an  If you want to use a regular expression, use the  
 The literal value is interpreted as a regular expression using Google RE2 library syntax. The literal value must match the entire field. For example, to filter for instances that do not end with name "instance", you would use  You cannot combine constraints on multiple fields using regular expressions. | 
| orderBy | 
 Sorts list results by a certain order. By default, results are returned in alphanumerical order based on the resource name. You can also sort results in descending order based on the creation timestamp using  Currently, only sorting by  | 
| returnPartialSuccess | 
 Opt-in for partial success behavior which provides partial results in case of failure. The default value is false. For example, when partial success behavior is enabled, aggregatedList for a single zone scope either returns all resources in the zone or no resources, with an error code. | 
Request body
The request body must be empty.
Response body
Contains a list of ForwardingRule resources.
If successful, the response body contains data with the following structure:
| JSON representation | 
|---|
| { "kind": string, "id": string, "items": [ { "kind": string, "id": string, "creationTimestamp": string, "name": string, "description": string, "region": string, "IPAddress": string, "IPProtocol": enum, "portRange": string, "ports": [ string ], "target": string, "selfLink": string, "selfLinkWithId": string, "loadBalancingScheme": enum, "subnetwork": string, "network": string, "backendService": string, "serviceDirectoryRegistrations": [ { "namespace": string, "service": string, "serviceDirectoryRegion": string } ], "serviceLabel": string, "serviceName": string, "networkTier": enum, "labels": { string: string, ... }, "labelFingerprint": string, "ipVersion": enum, "fingerprint": string, "allPorts": boolean, "allowGlobalAccess": boolean, "metadataFilters": [ { "filterMatchCriteria": enum, "filterLabels": [ { "name": string, "value": string } ] } ], "isMirroringCollector": boolean, "sourceIpRanges": [ string ], "pscConnectionId": string, "pscConnectionStatus": enum, "baseForwardingRule": string, "allowPscGlobalAccess": boolean, "noAutomateDnsZone": boolean, "ipCollection": string, "allowPscPacketInjection": boolean, "externalManagedBackendBucketMigrationState": enum, "externalManagedBackendBucketMigrationTestingPercentage": number } ], "nextPageToken": string, "selfLink": string, "warning": { "code": enum, "message": string, "data": [ { "key": string, "value": string } ] } } | 
| Fields | |
|---|---|
| kind | 
 Type of resource. | 
| id | 
 [Output Only] Unique identifier for the resource; defined by the server. | 
| items[] | 
 A list of ForwardingRule resources. | 
| items[].kind | 
 [Output Only] Type of the resource. Always  | 
| items[].id | 
 [Output Only] The unique identifier for the resource. This identifier is defined by the server. | 
| items[].creationTimestamp | 
 [Output Only] Creation timestamp in RFC3339 text format. | 
| items[].name | 
 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  For Private Service Connect forwarding rules that forward traffic to Google APIs, the forwarding rule name must be a 1-20 characters string with lowercase letters and numbers and must start with a letter. | 
| items[].description | 
 An optional description of this resource. Provide this property when you create the resource. | 
| items[].region | 
 [Output Only] URL of the region where the regional forwarding rule resides. This field is not applicable to global forwarding rules. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body. | 
| items[].IPAddress | 
 IP address for which this forwarding rule accepts traffic. When a client sends traffic to this IP address, the forwarding rule directs the traffic to the referenced  
 Otherwise, you can optionally specify an IP address that references an existing static (reserved) IP address resource. When omitted, Google Cloud assigns an ephemeral IP address. Use one of the following formats to specify an IP address while creating a forwarding rule: 
 The forwarding rule's  When reading an  | 
| items[].IPProtocol | 
 The IP protocol to which this rule applies. For protocol forwarding, valid options are  The valid IP protocols are different for different load balancing products as described in Load balancing features. | 
| items[].portRange | 
 The  The  
 For external forwarding rules, two or more forwarding rules cannot use the same  For internal forwarding rules within the same VPC network, two or more forwarding rules cannot use the same  @pattern: \d+(?:-\d+)? | 
| items[].ports[] | 
 The  The  
 For external forwarding rules, two or more forwarding rules cannot use the same  For internal forwarding rules within the same VPC network, two or more forwarding rules cannot use the same  @pattern: \d+(?:-\d+)? | 
| items[].target | 
 The URL of the target resource to receive the matched traffic. For regional forwarding rules, this target must be in the same region as the forwarding rule. For global forwarding rules, this target must be a global load balancing resource. The forwarded traffic must be of a type appropriate to the target object. 
 | 
| items[].selfLink | 
 [Output Only] Server-defined URL for the resource. | 
| items[].selfLinkWithId | 
 [Output Only] Server-defined URL for this resource with the resource id. | 
| items[].loadBalancingScheme | 
 Specifies the forwarding rule type. For more information about forwarding rules, refer to Forwarding rule concepts. | 
| items[].subnetwork | 
 This field identifies the subnetwork that the load balanced IP should belong to for this forwarding rule, used with internal load balancers and external passthrough Network Load Balancers with IPv6. If the network specified is in auto subnet mode, this field is optional. However, a subnetwork must be specified if the network is in custom subnet mode or when creating external forwarding rule with IPv6. | 
| items[].network | 
 This field is not used for global external load balancing. For internal passthrough Network Load Balancers, this field identifies the network that the load balanced IP should belong to for this forwarding rule. If the subnetwork is specified, the network of the subnetwork will be used. If neither subnetwork nor this field is specified, the default network will be used. For Private Service Connect forwarding rules that forward traffic to Google APIs, a network must be provided. | 
| items[].backendService | 
 Identifies the backend service to which the forwarding rule sends traffic. Required for internal and external passthrough Network Load Balancers; must be omitted for all other load balancer types. | 
| items[].serviceDirectoryRegistrations[] | 
 Service Directory resources to register this forwarding rule with. Currently, only supports a single Service Directory resource. | 
| items[].serviceDirectoryRegistrations[].namespace | 
 Service Directory namespace to register the forwarding rule under. | 
| items[].serviceDirectoryRegistrations[].service | 
 Service Directory service to register the forwarding rule under. | 
| items[].serviceDirectoryRegistrations[].serviceDirectoryRegion | 
 [Optional] Service Directory region to register this global forwarding rule under. Default to "us-central1". Only used for PSC for Google APIs. All PSC for Google APIs forwarding rules on the same network should use the same Service Directory region. | 
| items[].serviceLabel | 
 An optional prefix to the service name for this forwarding rule. If specified, the prefix is the first label of the fully qualified service name. The label must be 1-63 characters long, and comply with RFC1035. Specifically, the label must be 1-63 characters long and match the regular expression  This field is only used for internal load balancing. | 
| items[].serviceName | 
 [Output Only] The internal fully qualified service name for this forwarding rule. This field is only used for internal load balancing. | 
| items[].networkTier | 
 This signifies the networking tier used for configuring this load balancer and can only take the following values:  For regional ForwardingRule, the valid values are  If this field is not specified, it is assumed to be  | 
| items[].labels | 
 Labels for this resource. These can only be added or modified by the  | 
| items[].labelFingerprint | 
 A fingerprint for the labels being applied to this resource, which is essentially a hash of the labels set used for optimistic locking. The fingerprint is initially generated by Compute Engine and changes after every request to modify or update labels. You must always provide an up-to-date fingerprint hash in order to update or change labels, otherwise the request will fail with error  To see the latest fingerprint, make a  A base64-encoded string. | 
| items[].ipVersion | 
 The IP Version that will be used by this forwarding rule. Valid options are  | 
| items[].fingerprint | 
 Fingerprint of this resource. A hash of the contents stored in this object. This field is used in optimistic locking. This field will be ignored when inserting a ForwardingRule. Include the fingerprint in patch request to ensure that you do not overwrite changes that were applied from another concurrent request. To see the latest fingerprint, make a  A base64-encoded string. | 
| items[].allPorts | 
 The  The  
 | 
| items[].allowGlobalAccess | 
 If set to true, clients can access the internal passthrough Network Load Balancers, the regional internal Application Load Balancer, and the regional internal proxy Network Load Balancer from all regions. If false, only allows access from the local region the load balancer is located at. Note that for INTERNAL_MANAGED forwarding rules, this field cannot be changed after the forwarding rule is created. | 
| items[].metadataFilters[] | 
 Opaque filter criteria used by load balancer to restrict routing configuration to a limited set of xDS compliant clients. In their xDS requests to load balancer, xDS clients present node metadata. When there is a match, the relevant configuration is made available to those proxies. Otherwise, all the resources (e.g.  For each  | 
| items[].metadataFilters[].filterMatchCriteria | 
 Specifies how individual filter label matches within the list of  Supported values are: 
 | 
| items[].metadataFilters[].filterLabels[] | 
 The list of label value pairs that must match labels in the provided metadata based on  This list must not be empty and can have at the most 64 entries. | 
| items[].metadataFilters[].filterLabels[].name | 
 Name of metadata label. The name can have a maximum length of 1024 characters and must be at least 1 character long. | 
| items[].metadataFilters[].filterLabels[].value | 
 The value of the label must match the specified value. value can have a maximum length of 1024 characters. | 
| items[].isMirroringCollector | 
 Indicates whether or not this load balancer can be used as a collector for packet mirroring. To prevent mirroring loops, instances behind this load balancer will not have their traffic mirrored even if a  | 
| items[].sourceIpRanges[] | 
 If not empty, this forwarding rule will only forward the traffic when the source IP address matches one of the IP addresses or CIDR ranges set here. Note that a forwarding rule can only have up to 64 source IP ranges, and this field can only be used with a regional forwarding rule whose scheme is  | 
| items[].pscConnectionId | 
 [Output Only] The PSC connection id of the PSC forwarding rule. | 
| items[].pscConnectionStatus | 
 | 
| items[].baseForwardingRule | 
 [Output Only] The URL for the corresponding base forwarding rule. By base forwarding rule, we mean the forwarding rule that has the same IP address, protocol, and port settings with the current forwarding rule, but without sourceIPRanges specified. Always empty if the current forwarding rule does not have sourceIPRanges specified. | 
| items[].allowPscGlobalAccess | 
 This is used in PSC consumer ForwardingRule to control whether the PSC endpoint can be accessed from another region. | 
| items[].noAutomateDnsZone | 
 This is used in PSC consumer ForwardingRule to control whether it should try to auto-generate a DNS zone or not. Non-PSC forwarding rules do not use this field. Once set, this field is not mutable. | 
| items[].ipCollection | 
 Resource reference of a  Use one of the following formats to specify a sub-PDP when creating an IPv6 NetLB forwarding rule using BYOIP: Full resource URL, as in  
 | 
| items[].allowPscPacketInjection | 
 This is used in PSC consumer ForwardingRule to control whether the producer is allowed to inject packets into the consumer's network. If set to true, the target service attachment must have tunneling enabled and TunnelingConfig.RoutingMode set to PACKET_INJECTION Non-PSC forwarding rules should not use this field. This field was never released to any customers and is deprecated and will be removed in the future. | 
| items[].externalManagedBackendBucketMigrationState | 
 Specifies the canary migration state for the backend buckets attached to this forwarding rule. Possible values are PREPARE, TEST_BY_PERCENTAGE, and TEST_ALL_TRAFFIC. To begin the migration from EXTERNAL to EXTERNAL_MANAGED, the state must be changed to PREPARE. The state must be changed to TEST_ALL_TRAFFIC before the loadBalancingScheme can be changed to EXTERNAL_MANAGED. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate traffic to backend buckets attached to this forwarding rule by percentage using externalManagedBackendBucketMigrationTestingPercentage. Rolling back a migration requires the states to be set in reverse order. So changing the scheme from EXTERNAL_MANAGED to EXTERNAL requires the state to be set to TEST_ALL_TRAFFIC at the same time. Optionally, the TEST_BY_PERCENTAGE state can be used to migrate some traffic back to EXTERNAL or PREPARE can be used to migrate all traffic back to EXTERNAL. | 
| items[].externalManagedBackendBucketMigrationTestingPercentage | 
 Determines the fraction of requests to backend buckets that should be processed by the global external Application Load Balancer. The value of this field must be in the range [0, 100]. This value can only be set if the loadBalancingScheme in the BackendService is set to EXTERNAL (when using the classic Application Load Balancer) and the migration state is TEST_BY_PERCENTAGE. | 
| nextPageToken | 
 [Output Only] This token allows you to get the next page of results for list requests. If the number of results is larger than  | 
| selfLink | 
 [Output Only] Server-defined URL for this resource. | 
| warning | 
 [Output Only] Informational warning message. | 
| warning.code | 
 [Output Only] A warning code, if applicable. For example, Compute Engine returns  | 
| warning.message | 
 [Output Only] A human-readable description of the warning code. | 
| warning.data[] | 
 [Output Only] Metadata about this warning in  "data": [  {  "key": "scope",  "value": "zones/us-east1-d"  } | 
| warning.data[].key | 
 [Output Only] A key that provides more detail on the warning being returned. For example, for warnings where there are no results in a list request for a particular zone, this key might be  | 
| warning.data[].value | 
 [Output Only] A warning data value corresponding to the key. | 
Authorization scopes
Requires one of the following OAuth scopes:
- https://www.googleapis.com/auth/compute.readonly
- https://www.googleapis.com/auth/compute
- https://www.googleapis.com/auth/cloud-platform
For more information, see the Authentication Overview.
IAM Permissions
In addition to any permissions specified on the fields above, authorization requires one or more of the following IAM permissions:
- compute.forwardingRules.list
To find predefined roles that contain those permissions, see Compute Engine IAM Roles.