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
-
#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.
-
#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.
-
#etag ⇒ String
Optional.
-
#host ⇒ Google::Apis::WorkstationsV1beta::Host
Runtime host for a workstation.
-
#idle_timeout ⇒ String
Optional.
-
#labels ⇒ Hash<String,String>
Optional.
-
#name ⇒ String
Full name of this workstation configuration.
-
#persistent_directories ⇒ Array<Google::Apis::WorkstationsV1beta::PersistentDirectory>
Optional.
-
#readiness_checks ⇒ Array<Google::Apis::WorkstationsV1beta::ReadinessCheck>
Optional.
-
#reconciling ⇒ Boolean
(also: #reconciling?)
Output only.
-
#running_timeout ⇒ String
Optional.
-
#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.
1755 1756 1757 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1755 def initialize(**args) update!(**args) end |
Instance Attribute Details
#annotations ⇒ Hash<String,String>
Optional. Client-specified annotations.
Corresponds to the JSON property annotations
1620 1621 1622 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1620 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
1625 1626 1627 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1625 def conditions @conditions end |
#container ⇒ Google::Apis::WorkstationsV1beta::Container
A Docker container.
Corresponds to the JSON property container
1630 1631 1632 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1630 def container @container end |
#create_time ⇒ String
Output only. Time when this workstation configuration was created.
Corresponds to the JSON property createTime
1635 1636 1637 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1635 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
1641 1642 1643 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1641 def degraded @degraded end |
#delete_time ⇒ String
Output only. Time when this workstation configuration was soft-deleted.
Corresponds to the JSON property deleteTime
1647 1648 1649 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1647 def delete_time @delete_time end |
#display_name ⇒ String
Optional. Human-readable name for this workstation configuration.
Corresponds to the JSON property displayName
1652 1653 1654 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1652 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 logging.buckets.
write permission on the project. Operating system audit logging is distinct
from Cloud Audit Logs.
Corresponds to the JSON property enableAuditAgent
1661 1662 1663 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1661 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
1671 1672 1673 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1671 def encryption_key @encryption_key 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
1678 1679 1680 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1678 def etag @etag end |
#host ⇒ Google::Apis::WorkstationsV1beta::Host
Runtime host for a workstation.
Corresponds to the JSON property host
1683 1684 1685 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1683 def host @host 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
1693 1694 1695 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1693 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
1700 1701 1702 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1700 def labels @labels end |
#name ⇒ String
Full name of this workstation configuration.
Corresponds to the JSON property name
1705 1706 1707 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1705 def name @name end |
#persistent_directories ⇒ Array<Google::Apis::WorkstationsV1beta::PersistentDirectory>
Optional. Directories to persist across workstation sessions.
Corresponds to the JSON property persistentDirectories
1710 1711 1712 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1710 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
1717 1718 1719 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1717 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
1723 1724 1725 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1723 def reconciling @reconciling 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
1741 1742 1743 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1741 def running_timeout @running_timeout end |
#uid ⇒ String
Output only. A system-assigned unique identifier for this workstation
configuration.
Corresponds to the JSON property uid
1747 1748 1749 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1747 def uid @uid end |
#update_time ⇒ String
Output only. Time when this workstation configuration was most recently
updated.
Corresponds to the JSON property updateTime
1753 1754 1755 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1753 def update_time @update_time end |
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
1760 1761 1762 1763 1764 1765 1766 1767 1768 1769 1770 1771 1772 1773 1774 1775 1776 1777 1778 1779 1780 1781 |
# File 'lib/google/apis/workstations_v1beta/classes.rb', line 1760 def update!(**args) @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) @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) @etag = args[:etag] if args.key?(:etag) @host = args[:host] if args.key?(:host) @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) @running_timeout = args[:running_timeout] if args.key?(:running_timeout) @uid = args[:uid] if args.key?(:uid) @update_time = args[:update_time] if args.key?(:update_time) end |