#[non_exhaustive]pub struct MachineImage {Show 20 fields
pub creation_timestamp: Option<String>,
pub description: Option<String>,
pub guest_flush: Option<bool>,
pub id: Option<u64>,
pub instance_properties: Option<InstanceProperties>,
pub kind: Option<String>,
pub label_fingerprint: Option<Bytes>,
pub labels: HashMap<String, String>,
pub machine_image_encryption_key: Option<CustomerEncryptionKey>,
pub name: Option<String>,
pub satisfies_pzi: Option<bool>,
pub satisfies_pzs: Option<bool>,
pub saved_disks: Vec<SavedDisk>,
pub self_link: Option<String>,
pub source_disk_encryption_keys: Vec<SourceDiskEncryptionKey>,
pub source_instance: Option<String>,
pub source_instance_properties: Option<SourceInstanceProperties>,
pub status: Option<Status>,
pub storage_locations: Vec<String>,
pub total_storage_bytes: Option<i64>,
/* private fields */
}machine-images only.Expand description
Represents a machine image resource.
A machine image is a Compute Engine resource that stores all the configuration, metadata, permissions, and data from one or more disks required to create a Virtual machine (VM) instance. For more information, seeMachine images.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.creation_timestamp: Option<String>Output only. [Output Only] The creation timestamp for this machine image inRFC3339 text format.
description: Option<String>An optional description of this resource. Provide this property when you create the resource.
guest_flush: Option<bool>[Input Only] Whether to attempt an application consistent machine image by informing the OS to prepare for the snapshot process.
id: Option<u64>Output only. [Output Only] A unique identifier for this machine image. The server defines this identifier.
instance_properties: Option<InstanceProperties>[Output Only] Properties of source instance
kind: Option<String>Output only. [Output Only] The resource type, which is alwayscompute#machineImage for machine image.
label_fingerprint: Option<Bytes>A fingerprint for the labels being applied to this machine image, 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.
To see the latest fingerprint, make get() request to the machine image.
labels: HashMap<String, String>Labels to apply to this machine image. These can be later modified by the setLabels method.
machine_image_encryption_key: Option<CustomerEncryptionKey>Encrypts the machine image using acustomer-supplied encryption key.
After you encrypt a machine image using a customer-supplied key, you must provide the same key if you use the machine image later. For example, you must provide the encryption key when you create an instance from the encrypted machine image in a future request.
Customer-supplied encryption keys do not protect access to metadata of the machine image.
If you do not provide an encryption key when creating the machine image, then the machine image will be encrypted using an automatically generated key and you do not need to provide a key to use the machine image later.
name: Option<String>Name of the resource; provided by the client when the resource is created.
The name must be 1-63 characters long, and comply withRFC1035.
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.
satisfies_pzi: Option<bool>Output only. Reserved for future use.
satisfies_pzs: Option<bool>Output only. [Output Only] Reserved for future use.
saved_disks: Vec<SavedDisk>Output only. An array of Machine Image specific properties for disks attached to the source instance
self_link: Option<String>Output only. [Output Only] The URL for this machine image. The server defines this URL.
source_disk_encryption_keys: Vec<SourceDiskEncryptionKey>[Input Only] Thecustomer-supplied encryption key of the disks attached to the source instance. Required if the source disk is protected by a customer-supplied encryption key.
source_instance: Option<String>The source instance used to create the machine image. You can provide this as a partial or full URL to the resource. For example, the following are valid values:
- https://www.googleapis.com/compute/v1/projects/project/zones/zone/instances/instance- projects/project/zones/zone/instances/instance
source_instance_properties: Option<SourceInstanceProperties>Output only. [Output Only] DEPRECATED: Please use instance_properties instead for source instance related properties. New properties will not be added to this field.
status: Option<Status>Output only. [Output Only] The status of the machine image. One of the following values:INVALID, CREATING, READY,DELETING, and UPLOADING.
storage_locations: Vec<String>The regional or multi-regional Cloud Storage bucket location where themachine image is stored.
total_storage_bytes: Option<i64>Output only. [Output Only] Total size of the storage used by the machine image.
Implementations§
Source§impl MachineImage
impl MachineImage
pub fn new() -> Self
Sourcepub fn set_creation_timestamp<T>(self, v: T) -> Self
pub fn set_creation_timestamp<T>(self, v: T) -> Self
Sets the value of creation_timestamp.
§Example
let x = MachineImage::new().set_creation_timestamp("example");Sourcepub fn set_or_clear_creation_timestamp<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_creation_timestamp<T>(self, v: Option<T>) -> Self
Sets or clears the value of creation_timestamp.
§Example
let x = MachineImage::new().set_or_clear_creation_timestamp(Some("example"));
let x = MachineImage::new().set_or_clear_creation_timestamp(None::<String>);Sourcepub fn set_description<T>(self, v: T) -> Self
pub fn set_description<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_description<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_description<T>(self, v: Option<T>) -> Self
Sets or clears the value of description.
§Example
let x = MachineImage::new().set_or_clear_description(Some("example"));
let x = MachineImage::new().set_or_clear_description(None::<String>);Sourcepub fn set_guest_flush<T>(self, v: T) -> Self
pub fn set_guest_flush<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_guest_flush<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_guest_flush<T>(self, v: Option<T>) -> Self
Sets or clears the value of guest_flush.
§Example
let x = MachineImage::new().set_or_clear_guest_flush(Some(false));
let x = MachineImage::new().set_or_clear_guest_flush(None::<bool>);Sourcepub fn set_or_clear_id<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_id<T>(self, v: Option<T>) -> Self
Sourcepub fn set_instance_properties<T>(self, v: T) -> Selfwhere
T: Into<InstanceProperties>,
pub fn set_instance_properties<T>(self, v: T) -> Selfwhere
T: Into<InstanceProperties>,
Sets the value of instance_properties.
§Example
use google_cloud_compute_v1::model::InstanceProperties;
let x = MachineImage::new().set_instance_properties(InstanceProperties::default()/* use setters */);Sourcepub fn set_or_clear_instance_properties<T>(self, v: Option<T>) -> Selfwhere
T: Into<InstanceProperties>,
pub fn set_or_clear_instance_properties<T>(self, v: Option<T>) -> Selfwhere
T: Into<InstanceProperties>,
Sets or clears the value of instance_properties.
§Example
use google_cloud_compute_v1::model::InstanceProperties;
let x = MachineImage::new().set_or_clear_instance_properties(Some(InstanceProperties::default()/* use setters */));
let x = MachineImage::new().set_or_clear_instance_properties(None::<InstanceProperties>);Sourcepub fn set_or_clear_kind<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_kind<T>(self, v: Option<T>) -> Self
Sourcepub fn set_label_fingerprint<T>(self, v: T) -> Self
pub fn set_label_fingerprint<T>(self, v: T) -> Self
Sets the value of label_fingerprint.
§Example
let x = MachineImage::new().set_label_fingerprint(bytes::Bytes::from_static(b"example"));Sourcepub fn set_or_clear_label_fingerprint<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_label_fingerprint<T>(self, v: Option<T>) -> Self
Sets or clears the value of label_fingerprint.
§Example
let x = MachineImage::new().set_or_clear_label_fingerprint(Some(bytes::Bytes::from_static(b"example")));
let x = MachineImage::new().set_or_clear_label_fingerprint(None::<bytes::Bytes>);Sourcepub fn set_labels<T, K, V>(self, v: T) -> Self
pub fn set_labels<T, K, V>(self, v: T) -> Self
Sourcepub fn set_machine_image_encryption_key<T>(self, v: T) -> Selfwhere
T: Into<CustomerEncryptionKey>,
pub fn set_machine_image_encryption_key<T>(self, v: T) -> Selfwhere
T: Into<CustomerEncryptionKey>,
Sets the value of machine_image_encryption_key.
§Example
use google_cloud_compute_v1::model::CustomerEncryptionKey;
let x = MachineImage::new().set_machine_image_encryption_key(CustomerEncryptionKey::default()/* use setters */);Sourcepub fn set_or_clear_machine_image_encryption_key<T>(self, v: Option<T>) -> Selfwhere
T: Into<CustomerEncryptionKey>,
pub fn set_or_clear_machine_image_encryption_key<T>(self, v: Option<T>) -> Selfwhere
T: Into<CustomerEncryptionKey>,
Sets or clears the value of machine_image_encryption_key.
§Example
use google_cloud_compute_v1::model::CustomerEncryptionKey;
let x = MachineImage::new().set_or_clear_machine_image_encryption_key(Some(CustomerEncryptionKey::default()/* use setters */));
let x = MachineImage::new().set_or_clear_machine_image_encryption_key(None::<CustomerEncryptionKey>);Sourcepub fn set_or_clear_name<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_name<T>(self, v: Option<T>) -> Self
Sourcepub fn set_satisfies_pzi<T>(self, v: T) -> Self
pub fn set_satisfies_pzi<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_satisfies_pzi<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_satisfies_pzi<T>(self, v: Option<T>) -> Self
Sets or clears the value of satisfies_pzi.
§Example
let x = MachineImage::new().set_or_clear_satisfies_pzi(Some(false));
let x = MachineImage::new().set_or_clear_satisfies_pzi(None::<bool>);Sourcepub fn set_satisfies_pzs<T>(self, v: T) -> Self
pub fn set_satisfies_pzs<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_satisfies_pzs<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_satisfies_pzs<T>(self, v: Option<T>) -> Self
Sets or clears the value of satisfies_pzs.
§Example
let x = MachineImage::new().set_or_clear_satisfies_pzs(Some(false));
let x = MachineImage::new().set_or_clear_satisfies_pzs(None::<bool>);Sourcepub fn set_saved_disks<T, V>(self, v: T) -> Self
pub fn set_saved_disks<T, V>(self, v: T) -> Self
Sets the value of saved_disks.
§Example
use google_cloud_compute_v1::model::SavedDisk;
let x = MachineImage::new()
.set_saved_disks([
SavedDisk::default()/* use setters */,
SavedDisk::default()/* use (different) setters */,
]);Sourcepub fn set_self_link<T>(self, v: T) -> Self
pub fn set_self_link<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_self_link<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_self_link<T>(self, v: Option<T>) -> Self
Sourcepub fn set_source_disk_encryption_keys<T, V>(self, v: T) -> Self
pub fn set_source_disk_encryption_keys<T, V>(self, v: T) -> Self
Sets the value of source_disk_encryption_keys.
§Example
use google_cloud_compute_v1::model::SourceDiskEncryptionKey;
let x = MachineImage::new()
.set_source_disk_encryption_keys([
SourceDiskEncryptionKey::default()/* use setters */,
SourceDiskEncryptionKey::default()/* use (different) setters */,
]);Sourcepub fn set_source_instance<T>(self, v: T) -> Self
pub fn set_source_instance<T>(self, v: T) -> Self
Sets the value of source_instance.
§Example
let x = MachineImage::new().set_source_instance("example");Sourcepub fn set_or_clear_source_instance<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_source_instance<T>(self, v: Option<T>) -> Self
Sets or clears the value of source_instance.
§Example
let x = MachineImage::new().set_or_clear_source_instance(Some("example"));
let x = MachineImage::new().set_or_clear_source_instance(None::<String>);Sourcepub fn set_source_instance_properties<T>(self, v: T) -> Selfwhere
T: Into<SourceInstanceProperties>,
pub fn set_source_instance_properties<T>(self, v: T) -> Selfwhere
T: Into<SourceInstanceProperties>,
Sets the value of source_instance_properties.
§Example
use google_cloud_compute_v1::model::SourceInstanceProperties;
let x = MachineImage::new().set_source_instance_properties(SourceInstanceProperties::default()/* use setters */);Sourcepub fn set_or_clear_source_instance_properties<T>(self, v: Option<T>) -> Selfwhere
T: Into<SourceInstanceProperties>,
pub fn set_or_clear_source_instance_properties<T>(self, v: Option<T>) -> Selfwhere
T: Into<SourceInstanceProperties>,
Sets or clears the value of source_instance_properties.
§Example
use google_cloud_compute_v1::model::SourceInstanceProperties;
let x = MachineImage::new().set_or_clear_source_instance_properties(Some(SourceInstanceProperties::default()/* use setters */));
let x = MachineImage::new().set_or_clear_source_instance_properties(None::<SourceInstanceProperties>);Sourcepub fn set_status<T>(self, v: T) -> Self
pub fn set_status<T>(self, v: T) -> Self
Sourcepub fn set_or_clear_status<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_status<T>(self, v: Option<T>) -> Self
Sets or clears the value of status.
§Example
use google_cloud_compute_v1::model::machine_image::Status;
let x0 = MachineImage::new().set_or_clear_status(Some(Status::Deleting));
let x1 = MachineImage::new().set_or_clear_status(Some(Status::Invalid));
let x2 = MachineImage::new().set_or_clear_status(Some(Status::Ready));
let x_none = MachineImage::new().set_or_clear_status(None::<Status>);Sourcepub fn set_storage_locations<T, V>(self, v: T) -> Self
pub fn set_storage_locations<T, V>(self, v: T) -> Self
Sets the value of storage_locations.
§Example
let x = MachineImage::new().set_storage_locations(["a", "b", "c"]);Sourcepub fn set_total_storage_bytes<T>(self, v: T) -> Self
pub fn set_total_storage_bytes<T>(self, v: T) -> Self
Sets the value of total_storage_bytes.
§Example
let x = MachineImage::new().set_total_storage_bytes(42);Sourcepub fn set_or_clear_total_storage_bytes<T>(self, v: Option<T>) -> Self
pub fn set_or_clear_total_storage_bytes<T>(self, v: Option<T>) -> Self
Sets or clears the value of total_storage_bytes.
§Example
let x = MachineImage::new().set_or_clear_total_storage_bytes(Some(42));
let x = MachineImage::new().set_or_clear_total_storage_bytes(None::<i32>);Trait Implementations§
Source§impl Clone for MachineImage
impl Clone for MachineImage
Source§fn clone(&self) -> MachineImage
fn clone(&self) -> MachineImage
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more