Skip to main content

vpn_gateways

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

Overview

Namevpn_gateways
TypeResource
Idgoogle.compute.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.
gatewayIpVersionstringThe IP family of the gateway IPs for the HA-VPN gateway interfaces. If not specified, IPV4 will be used.
kindstring[Output Only] Type of resource. Always compute#vpnGateway for VPN gateways. (default: compute#vpnGateway)
labelFingerprintstring (byte)A fingerprint for the labels being applied to this VpnGateway, 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 VpnGateway.
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 VPN gateway resides.
selfLinkstring[Output Only] Server-defined URL for the resource.
stackTypestringThe stack type for this VPN gateway to identify the IP protocols that are enabled. Possible values are: IPV4_ONLY, IPV4_IPV6, IPV6_ONLY. If not specified, IPV4_ONLY is used if the gateway IP version is IPV4, or IPV4_IPV6 if the gateway IP version is IPV6.
vpnInterfacesarrayThe list of VPN interfaces associated with this VPN gateway.

Methods

The following methods are available for this resource:

NameAccessible byRequired ParamsOptional ParamsDescription
getselectproject, region, vpnGatewayReturns the specified VPN gateway.
listselectproject, regionfilter, maxResults, orderBy, pageToken, returnPartialSuccessRetrieves a list of VPN gateways available to the specified project and region.
aggregated_listselectprojectfilter, includeAllScopes, maxResults, orderBy, pageToken, returnPartialSuccess, serviceProjectNumberRetrieves an aggregated list of VPN gateways. To prevent failure, Google recommends that you set the returnPartialSuccess parameter to true.
insertinsertproject, regionrequestIdCreates a VPN gateway in the specified project and region using the data included in the request.
deletedeleteproject, region, vpnGatewayrequestIdDeletes the specified VPN gateway.
set_labelsexecproject, region, resourcerequestIdSets the labels on a VpnGateway. 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
vpnGatewaystring
filterstring
includeAllScopesboolean
maxResultsinteger (uint32)
orderBystring
pageTokenstring
requestIdstring
returnPartialSuccessboolean
serviceProjectNumberstring (int64)

SELECT examples

Returns the specified VPN gateway.

SELECT
id,
name,
creationTimestamp,
description,
gatewayIpVersion,
kind,
labelFingerprint,
labels,
network,
region,
selfLink,
stackType,
vpnInterfaces
FROM google.compute.vpn_gateways
WHERE project = '{{ project }}' -- required
AND region = '{{ region }}' -- required
AND vpnGateway = '{{ vpnGateway }}' -- required;

INSERT examples

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

INSERT INTO google.compute.vpn_gateways (
data__kind,
data__id,
data__creationTimestamp,
data__name,
data__description,
data__region,
data__network,
data__selfLink,
data__labels,
data__labelFingerprint,
data__vpnInterfaces,
data__stackType,
data__gatewayIpVersion,
project,
region,
requestId
)
SELECT
'{{ kind }}',
'{{ id }}',
'{{ creationTimestamp }}',
'{{ name }}',
'{{ description }}',
'{{ region }}',
'{{ network }}',
'{{ selfLink }}',
'{{ labels }}',
'{{ labelFingerprint }}',
'{{ vpnInterfaces }}',
'{{ stackType }}',
'{{ gatewayIpVersion }}',
'{{ 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 VPN gateway.

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

Lifecycle Methods

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

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