workstation_configs
Creates, updates, deletes, gets or lists a workstation_configs
resource.
Overview
Name | workstation_configs |
Type | Resource |
Id | google.workstations.workstation_configs |
Fields
The following fields are returned by SELECT
queries:
- get
- list
Successful response
Name | Datatype | Description |
---|---|---|
name | string | Identifier. Full name of this workstation configuration. |
allowedPorts | array | Optional. A list of PortRanges specifying single ports or ranges of ports that are externally accessible in the workstation. Allowed ports must be one of 22, 80, or within range 1024-65535. If not specified defaults to ports 22, 80, and ports 1024-65535. |
annotations | object | Optional. Client-specified annotations. |
conditions | array | Output only. Status conditions describing the workstation configuration's current state. |
container | object | Optional. Container that runs upon startup for each workstation using this workstation configuration. (id: Container) |
createTime | string (google-datetime) | Output only. Time when this workstation configuration was created. |
degraded | boolean | Output only. Whether this workstation configuration is in degraded mode, in which case it may require user action to restore full functionality. The conditions field contains detailed information about the status of the configuration. |
deleteTime | string (google-datetime) | Output only. Time when this workstation configuration was soft-deleted. |
disableTcpConnections | boolean | Optional. Disables support for plain TCP connections in the workstation. By default the service supports TCP connections through a websocket relay. Setting this option to true disables that relay, which prevents the usage of services that require plain TCP connections, such as SSH. When enabled, all communication must occur over HTTPS or WSS. |
displayName | string | Optional. Human-readable name for this workstation configuration. |
enableAuditAgent | boolean | Optional. Whether to enable Linux auditd logging on the workstation. When enabled, a service_account must also be specified that has roles/logging.logWriter and roles/monitoring.metricWriter on the project. Operating system audit logging is distinct from Cloud Audit Logs and Container output logging. Operating system audit logs are available in the Cloud Logging console by querying: resource.type="gce_instance" log_name:"/logs/linux-auditd" |
encryptionKey | object | Immutable. Encrypts resources of this workstation configuration using a customer-managed encryption key (CMEK). If specified, the boot disk of the Compute Engine instance and the persistent disk are encrypted using this encryption key. If this field is not set, the disks are encrypted using a generated key. Customer-managed encryption keys do not protect disk metadata. If the customer-managed encryption key is rotated, when the workstation instance is stopped, the system attempts to recreate the persistent disk with the new version of the key. Be sure to keep older versions of the key until the persistent disk is recreated. Otherwise, data on the persistent disk might be lost. If the encryption key is revoked, the workstation session automatically stops within 7 hours. Immutable after the workstation configuration is created. (id: CustomerEncryptionKey) |
ephemeralDirectories | array | Optional. Ephemeral directories which won't persist across workstation sessions. |
etag | string | Optional. Checksum computed by the server. May be sent on update and delete requests to make sure that the client has an up-to-date value before proceeding. |
grantWorkstationAdminRoleOnCreate | boolean | Optional. Grant creator of a workstation roles/workstations.policyAdmin role along with roles/workstations.user role on the workstation created by them. This allows workstation users to share access to either their entire workstation, or individual ports. Defaults to false. |
host | object | Optional. Runtime host for the workstation. (id: Host) |
idleTimeout | string (google-duration) | Optional. Number of seconds to wait before automatically stopping a workstation after it last received user traffic. A value of "0s" indicates that Cloud Workstations VMs created with this configuration should never time out due to idleness. Provide duration terminated by s for seconds—for example, "7200s" (2 hours). The default is "1200s" (20 minutes). |
labels | object | Optional. Labels that are applied to the workstation configuration and that are also propagated to the underlying Compute Engine resources. |
maxUsableWorkstations | integer (int32) | Optional. Maximum number of workstations under this configuration a user can have workstations.workstation.use permission on. Only enforced on CreateWorkstation API calls on the user issuing the API request. Can be overridden by: - granting a user workstations.workstationConfigs.exemptMaxUsableWorkstationLimit permission, or - having a user with that permission create a workstation and granting another user workstations.workstation.use permission on that workstation. If not specified, defaults to 0 , which indicates unlimited. |
persistentDirectories | array | Optional. Directories to persist across workstation sessions. |
readinessChecks | array | Optional. Readiness checks to perform when starting a workstation using this workstation configuration. Mark a workstation as running only after all specified readiness checks return 200 status codes. |
reconciling | boolean | Output only. Indicates whether this workstation configuration is currently being updated to match its intended state. |
replicaZones | array | Optional. Immutable. Specifies the zones used to replicate the VM and disk resources within the region. If set, exactly two zones within the workstation cluster's region must be specified—for example, ['us-central1-a', 'us-central1-f'] . If this field is empty, two default zones within the region are used. Immutable after the workstation configuration is created. |
runningTimeout | string (google-duration) | Optional. Number of seconds that a workstation can run until it is automatically shut down. We recommend that workstations be shut down daily to reduce costs and so that security updates can be applied upon restart. The idle_timeout and running_timeout fields are independent of each other. Note that the running_timeout field shuts down VMs after the specified time, regardless of whether or not the VMs are idle. Provide duration terminated by s for seconds—for example, "54000s" (15 hours). Defaults to "43200s" (12 hours). A value of "0s" indicates that workstations using this configuration should never time out. If encryption_key is set, it must be greater than "0s" and less than "86400s" (24 hours). Warning: A value of "0s" indicates that Cloud Workstations VMs created with this configuration have no maximum running time. This is strongly discouraged because you incur costs and will not pick up security updates. |
uid | string | Output only. A system-assigned unique identifier for this workstation configuration. |
updateTime | string (google-datetime) | Output only. Time when this workstation configuration was most recently updated. |
Successful response
Name | Datatype | Description |
---|---|---|
name | string | Identifier. Full name of this workstation configuration. |
allowedPorts | array | Optional. A list of PortRanges specifying single ports or ranges of ports that are externally accessible in the workstation. Allowed ports must be one of 22, 80, or within range 1024-65535. If not specified defaults to ports 22, 80, and ports 1024-65535. |
annotations | object | Optional. Client-specified annotations. |
conditions | array | Output only. Status conditions describing the workstation configuration's current state. |
container | object | Optional. Container that runs upon startup for each workstation using this workstation configuration. (id: Container) |
createTime | string (google-datetime) | Output only. Time when this workstation configuration was created. |
degraded | boolean | Output only. Whether this workstation configuration is in degraded mode, in which case it may require user action to restore full functionality. The conditions field contains detailed information about the status of the configuration. |
deleteTime | string (google-datetime) | Output only. Time when this workstation configuration was soft-deleted. |
disableTcpConnections | boolean | Optional. Disables support for plain TCP connections in the workstation. By default the service supports TCP connections through a websocket relay. Setting this option to true disables that relay, which prevents the usage of services that require plain TCP connections, such as SSH. When enabled, all communication must occur over HTTPS or WSS. |
displayName | string | Optional. Human-readable name for this workstation configuration. |
enableAuditAgent | boolean | Optional. Whether to enable Linux auditd logging on the workstation. When enabled, a service_account must also be specified that has roles/logging.logWriter and roles/monitoring.metricWriter on the project. Operating system audit logging is distinct from Cloud Audit Logs and Container output logging. Operating system audit logs are available in the Cloud Logging console by querying: resource.type="gce_instance" log_name:"/logs/linux-auditd" |
encryptionKey | object | Immutable. Encrypts resources of this workstation configuration using a customer-managed encryption key (CMEK). If specified, the boot disk of the Compute Engine instance and the persistent disk are encrypted using this encryption key. If this field is not set, the disks are encrypted using a generated key. Customer-managed encryption keys do not protect disk metadata. If the customer-managed encryption key is rotated, when the workstation instance is stopped, the system attempts to recreate the persistent disk with the new version of the key. Be sure to keep older versions of the key until the persistent disk is recreated. Otherwise, data on the persistent disk might be lost. If the encryption key is revoked, the workstation session automatically stops within 7 hours. Immutable after the workstation configuration is created. (id: CustomerEncryptionKey) |
ephemeralDirectories | array | Optional. Ephemeral directories which won't persist across workstation sessions. |
etag | string | Optional. Checksum computed by the server. May be sent on update and delete requests to make sure that the client has an up-to-date value before proceeding. |
grantWorkstationAdminRoleOnCreate | boolean | Optional. Grant creator of a workstation roles/workstations.policyAdmin role along with roles/workstations.user role on the workstation created by them. This allows workstation users to share access to either their entire workstation, or individual ports. Defaults to false. |
host | object | Optional. Runtime host for the workstation. (id: Host) |
idleTimeout | string (google-duration) | Optional. Number of seconds to wait before automatically stopping a workstation after it last received user traffic. A value of "0s" indicates that Cloud Workstations VMs created with this configuration should never time out due to idleness. Provide duration terminated by s for seconds—for example, "7200s" (2 hours). The default is "1200s" (20 minutes). |
labels | object | Optional. Labels that are applied to the workstation configuration and that are also propagated to the underlying Compute Engine resources. |
maxUsableWorkstations | integer (int32) | Optional. Maximum number of workstations under this configuration a user can have workstations.workstation.use permission on. Only enforced on CreateWorkstation API calls on the user issuing the API request. Can be overridden by: - granting a user workstations.workstationConfigs.exemptMaxUsableWorkstationLimit permission, or - having a user with that permission create a workstation and granting another user workstations.workstation.use permission on that workstation. If not specified, defaults to 0 , which indicates unlimited. |
persistentDirectories | array | Optional. Directories to persist across workstation sessions. |
readinessChecks | array | Optional. Readiness checks to perform when starting a workstation using this workstation configuration. Mark a workstation as running only after all specified readiness checks return 200 status codes. |
reconciling | boolean | Output only. Indicates whether this workstation configuration is currently being updated to match its intended state. |
replicaZones | array | Optional. Immutable. Specifies the zones used to replicate the VM and disk resources within the region. If set, exactly two zones within the workstation cluster's region must be specified—for example, ['us-central1-a', 'us-central1-f'] . If this field is empty, two default zones within the region are used. Immutable after the workstation configuration is created. |
runningTimeout | string (google-duration) | Optional. Number of seconds that a workstation can run until it is automatically shut down. We recommend that workstations be shut down daily to reduce costs and so that security updates can be applied upon restart. The idle_timeout and running_timeout fields are independent of each other. Note that the running_timeout field shuts down VMs after the specified time, regardless of whether or not the VMs are idle. Provide duration terminated by s for seconds—for example, "54000s" (15 hours). Defaults to "43200s" (12 hours). A value of "0s" indicates that workstations using this configuration should never time out. If encryption_key is set, it must be greater than "0s" and less than "86400s" (24 hours). Warning: A value of "0s" indicates that Cloud Workstations VMs created with this configuration have no maximum running time. This is strongly discouraged because you incur costs and will not pick up security updates. |
uid | string | Output only. A system-assigned unique identifier for this workstation configuration. |
updateTime | string (google-datetime) | Output only. Time when this workstation configuration was most recently updated. |
Methods
The following methods are available for this resource:
Name | Accessible by | Required Params | Optional Params | Description |
---|---|---|---|---|
get | select | projectsId , locationsId , workstationClustersId , workstationConfigsId | Returns the requested workstation configuration. | |
list | select | projectsId , locationsId , workstationClustersId | pageSize , pageToken , filter | Returns all workstation configurations in the specified cluster. |
create | insert | projectsId , locationsId , workstationClustersId | workstationConfigId , validateOnly | Creates a new workstation configuration. |
patch | update | projectsId , locationsId , workstationClustersId , workstationConfigsId | updateMask , validateOnly , allowMissing | Updates an existing workstation configuration. |
delete | delete | projectsId , locationsId , workstationClustersId , workstationConfigsId | validateOnly , etag , force | Deletes the specified workstation configuration. |
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.
Name | Datatype | Description |
---|---|---|
locationsId | string | |
projectsId | string | |
workstationClustersId | string | |
workstationConfigsId | string | |
allowMissing | boolean | |
etag | string | |
filter | string | |
force | boolean | |
pageSize | integer (int32) | |
pageToken | string | |
updateMask | string (google-fieldmask) | |
validateOnly | boolean | |
workstationConfigId | string |
SELECT
examples
- get
- list
Returns the requested workstation configuration.
SELECT
name,
allowedPorts,
annotations,
conditions,
container,
createTime,
degraded,
deleteTime,
disableTcpConnections,
displayName,
enableAuditAgent,
encryptionKey,
ephemeralDirectories,
etag,
grantWorkstationAdminRoleOnCreate,
host,
idleTimeout,
labels,
maxUsableWorkstations,
persistentDirectories,
readinessChecks,
reconciling,
replicaZones,
runningTimeout,
uid,
updateTime
FROM google.workstations.workstation_configs
WHERE projectsId = '{{ projectsId }}' -- required
AND locationsId = '{{ locationsId }}' -- required
AND workstationClustersId = '{{ workstationClustersId }}' -- required
AND workstationConfigsId = '{{ workstationConfigsId }}' -- required;
Returns all workstation configurations in the specified cluster.
SELECT
name,
allowedPorts,
annotations,
conditions,
container,
createTime,
degraded,
deleteTime,
disableTcpConnections,
displayName,
enableAuditAgent,
encryptionKey,
ephemeralDirectories,
etag,
grantWorkstationAdminRoleOnCreate,
host,
idleTimeout,
labels,
maxUsableWorkstations,
persistentDirectories,
readinessChecks,
reconciling,
replicaZones,
runningTimeout,
uid,
updateTime
FROM google.workstations.workstation_configs
WHERE projectsId = '{{ projectsId }}' -- required
AND locationsId = '{{ locationsId }}' -- required
AND workstationClustersId = '{{ workstationClustersId }}' -- required
AND pageSize = '{{ pageSize }}'
AND pageToken = '{{ pageToken }}'
AND filter = '{{ filter }}';
INSERT
examples
- create
- Manifest
Creates a new workstation configuration.
INSERT INTO google.workstations.workstation_configs (
data__name,
data__displayName,
data__annotations,
data__labels,
data__etag,
data__idleTimeout,
data__runningTimeout,
data__maxUsableWorkstations,
data__host,
data__persistentDirectories,
data__ephemeralDirectories,
data__container,
data__encryptionKey,
data__readinessChecks,
data__replicaZones,
data__enableAuditAgent,
data__disableTcpConnections,
data__allowedPorts,
data__grantWorkstationAdminRoleOnCreate,
projectsId,
locationsId,
workstationClustersId,
workstationConfigId,
validateOnly
)
SELECT
'{{ name }}',
'{{ displayName }}',
'{{ annotations }}',
'{{ labels }}',
'{{ etag }}',
'{{ idleTimeout }}',
'{{ runningTimeout }}',
{{ maxUsableWorkstations }},
'{{ host }}',
'{{ persistentDirectories }}',
'{{ ephemeralDirectories }}',
'{{ container }}',
'{{ encryptionKey }}',
'{{ readinessChecks }}',
'{{ replicaZones }}',
{{ enableAuditAgent }},
{{ disableTcpConnections }},
'{{ allowedPorts }}',
{{ grantWorkstationAdminRoleOnCreate }},
'{{ projectsId }}',
'{{ locationsId }}',
'{{ workstationClustersId }}',
'{{ workstationConfigId }}',
'{{ validateOnly }}'
RETURNING
name,
done,
error,
metadata,
response
;
# Description fields are for documentation purposes
- name: workstation_configs
props:
- name: projectsId
value: string
description: Required parameter for the workstation_configs resource.
- name: locationsId
value: string
description: Required parameter for the workstation_configs resource.
- name: workstationClustersId
value: string
description: Required parameter for the workstation_configs resource.
- name: name
value: string
description: >
Identifier. Full name of this workstation configuration.
- name: displayName
value: string
description: >
Optional. Human-readable name for this workstation configuration.
- name: annotations
value: object
description: >
Optional. Client-specified annotations.
- name: labels
value: object
description: >
Optional. [Labels](https://cloud.google.com/workstations/docs/label-resources) that are applied to the workstation configuration and that are also propagated to the underlying Compute Engine resources.
- name: etag
value: string
description: >
Optional. Checksum computed by the server. May be sent on update and delete requests to make sure that the client has an up-to-date value before proceeding.
- name: idleTimeout
value: string
description: >
Optional. Number of seconds to wait before automatically stopping a workstation after it last received user traffic. A value of `"0s"` indicates that Cloud Workstations VMs created with this configuration should never time out due to idleness. Provide [duration](https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#duration) terminated by `s` for seconds—for example, `"7200s"` (2 hours). The default is `"1200s"` (20 minutes).
- name: runningTimeout
value: string
description: >
Optional. Number of seconds that a workstation can run until it is automatically shut down. We recommend that workstations be shut down daily to reduce costs and so that security updates can be applied upon restart. The idle_timeout and running_timeout fields are independent of each other. Note that the running_timeout field shuts down VMs after the specified time, regardless of whether or not the VMs are idle. Provide duration terminated by `s` for seconds—for example, `"54000s"` (15 hours). Defaults to `"43200s"` (12 hours). A value of `"0s"` indicates that workstations using this configuration should never time out. If encryption_key is set, it must be greater than `"0s"` and less than `"86400s"` (24 hours). Warning: A value of `"0s"` indicates that Cloud Workstations VMs created with this configuration have no maximum running time. This is strongly discouraged because you incur costs and will not pick up security updates.
- name: maxUsableWorkstations
value: integer
description: >
Optional. Maximum number of workstations under this configuration a user can have `workstations.workstation.use` permission on. Only enforced on CreateWorkstation API calls on the user issuing the API request. Can be overridden by: - granting a user workstations.workstationConfigs.exemptMaxUsableWorkstationLimit permission, or - having a user with that permission create a workstation and granting another user `workstations.workstation.use` permission on that workstation. If not specified, defaults to `0`, which indicates unlimited.
- name: host
value: object
description: >
Optional. Runtime host for the workstation.
- name: persistentDirectories
value: array
description: >
Optional. Directories to persist across workstation sessions.
- name: ephemeralDirectories
value: array
description: >
Optional. Ephemeral directories which won't persist across workstation sessions.
- name: container
value: object
description: >
Optional. Container that runs upon startup for each workstation using this workstation configuration.
- name: encryptionKey
value: object
description: >
Immutable. Encrypts resources of this workstation configuration using a customer-managed encryption key (CMEK). If specified, the boot disk of the Compute Engine instance and the persistent disk are encrypted using this encryption key. If this field is not set, the disks are encrypted using a generated key. Customer-managed encryption keys do not protect disk metadata. If the customer-managed encryption key is rotated, when the workstation instance is stopped, the system attempts to recreate the persistent disk with the new version of the key. Be sure to keep older versions of the key until the persistent disk is recreated. Otherwise, data on the persistent disk might be lost. If the encryption key is revoked, the workstation session automatically stops within 7 hours. Immutable after the workstation configuration is created.
- name: readinessChecks
value: array
description: >
Optional. Readiness checks to perform when starting a workstation using this workstation configuration. Mark a workstation as running only after all specified readiness checks return 200 status codes.
- name: replicaZones
value: array
description: >
Optional. Immutable. Specifies the zones used to replicate the VM and disk resources within the region. If set, exactly two zones within the workstation cluster's region must be specified—for example, `['us-central1-a', 'us-central1-f']`. If this field is empty, two default zones within the region are used. Immutable after the workstation configuration is created.
- name: enableAuditAgent
value: boolean
description: >
Optional. Whether to enable Linux `auditd` logging on the workstation. When enabled, a service_account must also be specified that has `roles/logging.logWriter` and `roles/monitoring.metricWriter` on the project. Operating system audit logging is distinct from [Cloud Audit Logs](https://cloud.google.com/workstations/docs/audit-logging) and [Container output logging](https://cloud.google.com/workstations/docs/container-output-logging#overview). Operating system audit logs are available in the [Cloud Logging](https://cloud.google.com/logging/docs) console by querying: resource.type="gce_instance" log_name:"/logs/linux-auditd"
- name: disableTcpConnections
value: boolean
description: >
Optional. Disables support for plain TCP connections in the workstation. By default the service supports TCP connections through a websocket relay. Setting this option to true disables that relay, which prevents the usage of services that require plain TCP connections, such as SSH. When enabled, all communication must occur over HTTPS or WSS.
- name: allowedPorts
value: array
description: >
Optional. A list of PortRanges specifying single ports or ranges of ports that are externally accessible in the workstation. Allowed ports must be one of 22, 80, or within range 1024-65535. If not specified defaults to ports 22, 80, and ports 1024-65535.
- name: grantWorkstationAdminRoleOnCreate
value: boolean
description: >
Optional. Grant creator of a workstation `roles/workstations.policyAdmin` role along with `roles/workstations.user` role on the workstation created by them. This allows workstation users to share access to either their entire workstation, or individual ports. Defaults to false.
- name: workstationConfigId
value: string
- name: validateOnly
value: boolean
UPDATE
examples
- patch
Updates an existing workstation configuration.
UPDATE google.workstations.workstation_configs
SET
data__name = '{{ name }}',
data__displayName = '{{ displayName }}',
data__annotations = '{{ annotations }}',
data__labels = '{{ labels }}',
data__etag = '{{ etag }}',
data__idleTimeout = '{{ idleTimeout }}',
data__runningTimeout = '{{ runningTimeout }}',
data__maxUsableWorkstations = {{ maxUsableWorkstations }},
data__host = '{{ host }}',
data__persistentDirectories = '{{ persistentDirectories }}',
data__ephemeralDirectories = '{{ ephemeralDirectories }}',
data__container = '{{ container }}',
data__encryptionKey = '{{ encryptionKey }}',
data__readinessChecks = '{{ readinessChecks }}',
data__replicaZones = '{{ replicaZones }}',
data__enableAuditAgent = {{ enableAuditAgent }},
data__disableTcpConnections = {{ disableTcpConnections }},
data__allowedPorts = '{{ allowedPorts }}',
data__grantWorkstationAdminRoleOnCreate = {{ grantWorkstationAdminRoleOnCreate }}
WHERE
projectsId = '{{ projectsId }}' --required
AND locationsId = '{{ locationsId }}' --required
AND workstationClustersId = '{{ workstationClustersId }}' --required
AND workstationConfigsId = '{{ workstationConfigsId }}' --required
AND updateMask = '{{ updateMask}}'
AND validateOnly = {{ validateOnly}}
AND allowMissing = {{ allowMissing}}
RETURNING
name,
done,
error,
metadata,
response;
DELETE
examples
- delete
Deletes the specified workstation configuration.
DELETE FROM google.workstations.workstation_configs
WHERE projectsId = '{{ projectsId }}' --required
AND locationsId = '{{ locationsId }}' --required
AND workstationClustersId = '{{ workstationClustersId }}' --required
AND workstationConfigsId = '{{ workstationConfigsId }}' --required
AND validateOnly = '{{ validateOnly }}'
AND etag = '{{ etag }}'
AND force = '{{ force }}';