Skip to main content

target_vpn_gateways

Creates, updates, deletes, gets or lists a target_vpn_gateways resource.

Overview

Nametarget_vpn_gateways
TypeResource
Idgoogle.compute.target_vpn_gateways

Fields

The following fields are returned by SELECT queries:

Successful response

NameDatatypeDescription
idstring (uint64)[Output Only] The unique identifier for the resource. This identifier is defined by the server.
namestringName 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. (pattern: a-z?)
creationTimestampstring[Output Only] Creation timestamp in RFC3339 text format.
descriptionstringAn optional description of this resource. Provide this property when you create the resource.
forwardingRulesarray[Output Only] A list of URLs to the ForwardingRule resources. ForwardingRules are created using compute.forwardingRules.insert and associated with a VPN gateway.
kindstring[Output Only] Type of resource. Always compute#targetVpnGateway for target VPN gateways. (default: compute#targetVpnGateway)
labelFingerprintstring (byte)A fingerprint for the labels being applied to this TargetVpnGateway, 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 412 conditionNotMet. To see the latest fingerprint, make a get() request to retrieve a TargetVpnGateway.
labelsobjectLabels for this resource. These can only be added or modified by the setLabels method. Each label key/value pair must comply with RFC1035. Label values may be empty.
networkstringURL of the network to which this VPN gateway is attached. Provided by the client when the VPN gateway is created.
regionstring[Output Only] URL of the region where the target VPN gateway resides. You must specify this field as part of the HTTP request URL. It is not settable as a field in the request body.
selfLinkstring[Output Only] Server-defined URL for the resource.
statusstring[Output Only] The status of the VPN gateway, which can be one of the following: CREATING, READY, FAILED, or DELETING.
tunnelsarray[Output Only] A list of URLs to VpnTunnel resources. VpnTunnels are created using the compute.vpntunnels.insert method and associated with a VPN gateway.

Methods

The following methods are available for this resource:

NameAccessible byRequired ParamsOptional ParamsDescription
getselectproject, region, targetVpnGatewayReturns the specified target VPN gateway.
listselectproject, regionfilter, maxResults, orderBy, pageToken, returnPartialSuccessRetrieves a list of target VPN gateways available to the specified project and region.
aggregated_listselectprojectfilter, includeAllScopes, maxResults, orderBy, pageToken, returnPartialSuccess, serviceProjectNumberRetrieves an aggregated list of target VPN gateways. To prevent failure, Google recommends that you set the returnPartialSuccess parameter to true.
insertinsertproject, regionrequestIdCreates a target VPN gateway in the specified project and region using the data included in the request.
deletedeleteproject, region, targetVpnGatewayrequestIdDeletes the specified target VPN gateway.
set_labelsexecproject, region, resourcerequestIdSets the labels on a TargetVpnGateway. To learn more about labels, read the Labeling Resources documentation.

Parameters

Parameters can be passed in the WHERE clause of a query. Check the Methods section to see which parameters are required or optional for each operation.

NameDatatypeDescription
projectstring
regionstring
resourcestring
targetVpnGatewaystring
filterstring
includeAllScopesboolean
maxResultsinteger (uint32)
orderBystring
pageTokenstring
requestIdstring
returnPartialSuccessboolean
serviceProjectNumberstring (int64)

SELECT examples

Returns the specified target VPN gateway.

SELECT
id,
name,
creationTimestamp,
description,
forwardingRules,
kind,
labelFingerprint,
labels,
network,
region,
selfLink,
status,
tunnels
FROM google.compute.target_vpn_gateways
WHERE project = '{{ project }}' -- required
AND region = '{{ region }}' -- required
AND targetVpnGateway = '{{ targetVpnGateway }}' -- required;

INSERT examples

Creates a target VPN gateway in the specified project and region using the data included in the request.

INSERT INTO google.compute.target_vpn_gateways (
data__kind,
data__id,
data__creationTimestamp,
data__name,
data__description,
data__region,
data__network,
data__tunnels,
data__status,
data__selfLink,
data__forwardingRules,
data__labels,
data__labelFingerprint,
project,
region,
requestId
)
SELECT
'{{ kind }}',
'{{ id }}',
'{{ creationTimestamp }}',
'{{ name }}',
'{{ description }}',
'{{ region }}',
'{{ network }}',
'{{ tunnels }}',
'{{ status }}',
'{{ selfLink }}',
'{{ forwardingRules }}',
'{{ labels }}',
'{{ labelFingerprint }}',
'{{ project }}',
'{{ region }}',
'{{ requestId }}'
RETURNING
id,
name,
clientOperationId,
creationTimestamp,
description,
endTime,
error,
httpErrorMessage,
httpErrorStatusCode,
insertTime,
instancesBulkInsertOperationMetadata,
kind,
operationGroupId,
operationType,
progress,
region,
selfLink,
setCommonInstanceMetadataOperationMetadata,
startTime,
status,
statusMessage,
targetId,
targetLink,
user,
warnings,
zone
;

DELETE examples

Deletes the specified target VPN gateway.

DELETE FROM google.compute.target_vpn_gateways
WHERE project = '{{ project }}' --required
AND region = '{{ region }}' --required
AND targetVpnGateway = '{{ targetVpnGateway }}' --required
AND requestId = '{{ requestId }}';

Lifecycle Methods

Sets the labels on a TargetVpnGateway. To learn more about labels, read the Labeling Resources documentation.

EXEC google.compute.target_vpn_gateways.set_labels 
@project='{{ project }}' --required,
@region='{{ region }}' --required,
@resource='{{ resource }}' --required,
@requestId='{{ requestId }}'
@@json=
'{
"labels": "{{ labels }}",
"labelFingerprint": "{{ labelFingerprint }}"
}';