Class: Google::Apis::WorkstationsV1beta::WorkstationConfig
- Inherits:
-
Object
- Object
- Google::Apis::WorkstationsV1beta::WorkstationConfig
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- lib/google/apis/workstations_v1beta/classes.rb,
lib/google/apis/workstations_v1beta/representations.rb,
lib/google/apis/workstations_v1beta/representations.rb
Overview
A workstation configuration resource in the Cloud Workstations API. Workstation configurations act as templates for workstations. The workstation configuration defines details such as the workstation virtual machine (VM) instance type, persistent storage, container image defining environment, which IDE or Code Editor to use, and more. Administrators and platform teams can also use Identity and Access Management (IAM) rules to grant access to teams or to individual developers.
Instance Attribute Summary collapse
-
#allowed_ports ⇒ Array<Google::Apis::WorkstationsV1beta::PortRange>
Optional.
-
#annotations ⇒ Hash<String,String>
Optional.
-
#conditions ⇒ Array<Google::Apis::WorkstationsV1beta::Status>
Output only.
-
#container ⇒ Google::Apis::WorkstationsV1beta::Container
A Docker container.
-
#create_time ⇒ String
Output only.
-
#degraded ⇒ Boolean
(also: #degraded?)
Output only.
-
#delete_time ⇒ String
Output only.
-
#disable_tcp_connections ⇒ Boolean
(also: #disable_tcp_connections?)
Optional.
-
#display_name ⇒ String
Optional.
-
#enable_audit_agent ⇒ Boolean
(also: #enable_audit_agent?)
Optional.
-
#encryption_key ⇒ Google::Apis::WorkstationsV1beta::CustomerEncryptionKey
A customer-managed encryption key (CMEK) for the Compute Engine resources of the associated workstation configuration.
-
#ephemeral_directories ⇒ Array<Google::Apis::WorkstationsV1beta::EphemeralDirectory>
Optional.
-
#etag ⇒ String
Optional.
-
#host ⇒ Google::Apis::WorkstationsV1beta::Host
Runtime host for a workstation.
-
#http_options ⇒ Google::Apis::WorkstationsV1beta::HttpOptions
Http options for the running workstations.
-
#idle_timeout ⇒ String
Optional.
-
#labels ⇒ Hash<String,String>
Optional.
-
#name ⇒ String
Identifier.
-
#persistent_directories ⇒ Array<Google::Apis::WorkstationsV1beta::PersistentDirectory>
Optional.
-
#readiness_checks ⇒ Array<Google::Apis::WorkstationsV1beta::ReadinessCheck>
Optional.
-
#reconciling ⇒ Boolean
(also: #reconciling?)
Output only.
-
#replica_zones ⇒ Array<String>
Optional.
-
#running_timeout ⇒ String
Optional.
-
#satisfies_pzi ⇒ Boolean
(also: #satisfies_pzi?)
Output only.
-
#satisfies_pzs ⇒ Boolean
(also: #satisfies_pzs?)
Output only.
-
#uid ⇒ String
Output only.
-
#update_time ⇒ String
Output only.
Instance Method Summary collapse
-
#initialize(**args) ⇒ WorkstationConfig
constructor
A new instance of WorkstationConfig.
-
#update!(**args) ⇒ Object
Update properties of this object.
Constructor Details
#initialize(**args) ⇒ WorkstationConfig
Returns a new instance of WorkstationConfig.
2177 2178 2179 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2177 def initialize(**args) update!(**args) end |
Instance Attribute Details
#allowed_ports ⇒ Array<Google::Apis::WorkstationsV1beta::PortRange>
Optional. A Single or Range of ports externally accessible in the workstation.
If not specified defaults to ports 22, 80 and ports 1024-65535.
Corresponds to the JSON property allowedPorts
1991 1992 1993 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1991 def allowed_ports @allowed_ports end |
#annotations ⇒ Hash<String,String>
Optional. Client-specified annotations.
Corresponds to the JSON property annotations
1996 1997 1998 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1996 def annotations @annotations end |
#conditions ⇒ Array<Google::Apis::WorkstationsV1beta::Status>
Output only. Status conditions describing the current resource state.
Corresponds to the JSON property conditions
2001 2002 2003 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2001 def conditions @conditions end |
#container ⇒ Google::Apis::WorkstationsV1beta::Container
A Docker container.
Corresponds to the JSON property container
2006 2007 2008 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2006 def container @container end |
#create_time ⇒ String
Output only. Time when this workstation configuration was created.
Corresponds to the JSON property createTime
2011 2012 2013 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2011 def create_time @create_time end |
#degraded ⇒ Boolean Also known as: degraded?
Output only. Whether this resource is degraded, in which case it may require
user action to restore full functionality. See also the conditions field.
Corresponds to the JSON property degraded
2017 2018 2019 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2017 def degraded @degraded end |
#delete_time ⇒ String
Output only. Time when this workstation configuration was soft-deleted.
Corresponds to the JSON property deleteTime
2023 2024 2025 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2023 def delete_time @delete_time end |
#disable_tcp_connections ⇒ Boolean Also known as: disable_tcp_connections?
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.
Corresponds to the JSON property disableTcpConnections
2032 2033 2034 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2032 def disable_tcp_connections @disable_tcp_connections end |
#display_name ⇒ String
Optional. Human-readable name for this workstation configuration.
Corresponds to the JSON property displayName
2038 2039 2040 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2038 def display_name @display_name end |
#enable_audit_agent ⇒ Boolean Also known as: enable_audit_agent?
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"
Corresponds to the JSON property enableAuditAgent
2051 2052 2053 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2051 def enable_audit_agent @enable_audit_agent end |
#encryption_key ⇒ Google::Apis::WorkstationsV1beta::CustomerEncryptionKey
A customer-managed encryption key (CMEK) for the Compute Engine resources of
the associated workstation configuration. Specify the name of your Cloud KMS
encryption key and the default service account. We recommend that you use a
separate service account and follow Cloud KMS best practices.
Corresponds to the JSON property encryptionKey
2061 2062 2063 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2061 def encryption_key @encryption_key end |
#ephemeral_directories ⇒ Array<Google::Apis::WorkstationsV1beta::EphemeralDirectory>
Optional. Ephemeral directories which won't persist across workstation
sessions.
Corresponds to the JSON property ephemeralDirectories
2067 2068 2069 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2067 def ephemeral_directories @ephemeral_directories end |
#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.
Corresponds to the JSON property etag
2074 2075 2076 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2074 def etag @etag end |
#host ⇒ Google::Apis::WorkstationsV1beta::Host
Runtime host for a workstation.
Corresponds to the JSON property host
2079 2080 2081 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2079 def host @host end |
#http_options ⇒ Google::Apis::WorkstationsV1beta::HttpOptions
Http options for the running workstations.
Corresponds to the JSON property httpOptions
2084 2085 2086 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2084 def @http_options end |
#idle_timeout ⇒ String
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).
Corresponds to the JSON property idleTimeout
2094 2095 2096 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2094 def idle_timeout @idle_timeout end |
#labels ⇒ Hash<String,String>
Optional. Labels
that are applied to the workstation configuration and that are also propagated
to the underlying Compute Engine resources.
Corresponds to the JSON property labels
2101 2102 2103 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2101 def labels @labels end |
#name ⇒ String
Identifier. Full name of this workstation configuration.
Corresponds to the JSON property name
2106 2107 2108 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2106 def name @name end |
#persistent_directories ⇒ Array<Google::Apis::WorkstationsV1beta::PersistentDirectory>
Optional. Directories to persist across workstation sessions.
Corresponds to the JSON property persistentDirectories
2111 2112 2113 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2111 def persistent_directories @persistent_directories end |
#readiness_checks ⇒ Array<Google::Apis::WorkstationsV1beta::ReadinessCheck>
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.
Corresponds to the JSON property readinessChecks
2118 2119 2120 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2118 def readiness_checks @readiness_checks end |
#reconciling ⇒ Boolean Also known as: reconciling?
Output only. Indicates whether this workstation configuration is currently
being updated to match its intended state.
Corresponds to the JSON property reconciling
2124 2125 2126 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2124 def reconciling @reconciling end |
#replica_zones ⇒ Array<String>
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.
Corresponds to the JSON property replicaZones
2134 2135 2136 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2134 def replica_zones @replica_zones end |
#running_timeout ⇒ String
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.
Corresponds to the JSON property runningTimeout
2151 2152 2153 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2151 def running_timeout @running_timeout end |
#satisfies_pzi ⇒ Boolean Also known as: satisfies_pzi?
Output only. Reserved for future use.
Corresponds to the JSON property satisfiesPzi
2156 2157 2158 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2156 def satisfies_pzi @satisfies_pzi end |
#satisfies_pzs ⇒ Boolean Also known as: satisfies_pzs?
Output only. Reserved for future use.
Corresponds to the JSON property satisfiesPzs
2162 2163 2164 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2162 def satisfies_pzs @satisfies_pzs end |
#uid ⇒ String
Output only. A system-assigned unique identifier for this workstation
configuration.
Corresponds to the JSON property uid
2169 2170 2171 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2169 def uid @uid end |
#update_time ⇒ String
Output only. Time when this workstation configuration was most recently
updated.
Corresponds to the JSON property updateTime
2175 2176 2177 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2175 def update_time @update_time end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
2182 2183 2184 2185 2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205 2206 2207 2208 2209 2210 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 2182 def update!(**args) @allowed_ports = args[:allowed_ports] if args.key?(:allowed_ports) @annotations = args[:annotations] if args.key?(:annotations) @conditions = args[:conditions] if args.key?(:conditions) @container = args[:container] if args.key?(:container) @create_time = args[:create_time] if args.key?(:create_time) @degraded = args[:degraded] if args.key?(:degraded) @delete_time = args[:delete_time] if args.key?(:delete_time) @disable_tcp_connections = args[:disable_tcp_connections] if args.key?(:disable_tcp_connections) @display_name = args[:display_name] if args.key?(:display_name) @enable_audit_agent = args[:enable_audit_agent] if args.key?(:enable_audit_agent) @encryption_key = args[:encryption_key] if args.key?(:encryption_key) @ephemeral_directories = args[:ephemeral_directories] if args.key?(:ephemeral_directories) @etag = args[:etag] if args.key?(:etag) @host = args[:host] if args.key?(:host) @http_options = args[:http_options] if args.key?(:http_options) @idle_timeout = args[:idle_timeout] if args.key?(:idle_timeout) @labels = args[:labels] if args.key?(:labels) @name = args[:name] if args.key?(:name) @persistent_directories = args[:persistent_directories] if args.key?(:persistent_directories) @readiness_checks = args[:readiness_checks] if args.key?(:readiness_checks) @reconciling = args[:reconciling] if args.key?(:reconciling) @replica_zones = args[:replica_zones] if args.key?(:replica_zones) @running_timeout = args[:running_timeout] if args.key?(:running_timeout) @satisfies_pzi = args[:satisfies_pzi] if args.key?(:satisfies_pzi) @satisfies_pzs = args[:satisfies_pzs] if args.key?(:satisfies_pzs) @uid = args[:uid] if args.key?(:uid) @update_time = args[:update_time] if args.key?(:update_time) end |