[][src]Struct google_compute1::AttachedDiskInitializeParams

pub struct AttachedDiskInitializeParams {
    pub source_snapshot: Option<String>,
    pub source_image_encryption_key: Option<CustomerEncryptionKey>,
    pub description: Option<String>,
    pub labels: Option<HashMap<String, String>>,
    pub disk_name: Option<String>,
    pub disk_type: Option<String>,
    pub disk_size_gb: Option<String>,
    pub resource_policies: Option<Vec<String>>,
    pub source_image: Option<String>,
    pub source_snapshot_encryption_key: Option<CustomerEncryptionKey>,
}

[Input Only] Specifies the parameters for a new disk that will be created alongside the new instance. Use initialization parameters to create boot disks or local SSDs attached to the new instance.

This property is mutually exclusive with the source property; you can only define one or the other, but not both.

This type is not used in any activity, and only used as part of another schema.

Fields

source_snapshot: Option<String>

The source snapshot to create this disk. When creating a new instance, one of initializeParams.sourceSnapshot or disks.source is required except for local SSD.

To create a disk with a snapshot that you created, specify the snapshot name in the following format: global/snapshots/my-backup

If the source snapshot is deleted later, this field will not be set.

source_image_encryption_key: Option<CustomerEncryptionKey>

The customer-supplied encryption key of the source image. Required if the source image is protected by a customer-supplied encryption key.

Instance templates do not store customer-supplied encryption keys, so you cannot create disks for instances in a managed instance group if the source images are encrypted with your own keys.

description: Option<String>

An optional description. Provide this property when creating the disk.

labels: Option<HashMap<String, String>>

Labels to apply to this disk. These can be later modified by the disks.setLabels method. This field is only applicable for persistent disks.

disk_name: Option<String>

Specifies the disk name. If not specified, the default is to use the name of the instance. If the disk with the instance name exists already in the given zone/region, a new name will be automatically generated.

disk_type: Option<String>

Specifies the disk type to use to create the instance. If not specified, the default is pd-standard, specified using the full URL. For example: https://www.googleapis.com/compute/v1/projects/project/zones/zone/diskTypes/pd-standard

Other values include pd-ssd and local-ssd. If you define this field, you can provide either the full or partial URL. For example, the following are valid values:

  • https://www.googleapis.com/compute/v1/projects/project/zones/zone/diskTypes/diskType
  • projects/project/zones/zone/diskTypes/diskType
  • zones/zone/diskTypes/diskType Note that for InstanceTemplate, this is the name of the disk type, not URL.
disk_size_gb: Option<String>

Specifies the size of the disk in base-2 GB.

resource_policies: Option<Vec<String>>

Resource policies applied to this disk for automatic snapshot creations. Specified using the full or partial URL. For instance template, specify only the resource policy name.

source_image: Option<String>

The source image to create this disk. When creating a new instance, one of initializeParams.sourceImage or disks.source is required except for local SSD.

To create a disk with one of the public operating system images, specify the image by its family name. For example, specify family/debian-9 to use the latest Debian 9 image: projects/debian-cloud/global/images/family/debian-9

Alternatively, use a specific version of a public operating system image: projects/debian-cloud/global/images/debian-9-stretch-vYYYYMMDD

To create a disk with a custom image that you created, specify the image name in the following format: global/images/my-custom-image

You can also specify a custom image by its image family, which returns the latest version of the image in that family. Replace the image name with family/family-name: global/images/family/my-image-family

If the source image is deleted later, this field will not be set.

source_snapshot_encryption_key: Option<CustomerEncryptionKey>

The customer-supplied encryption key of the source snapshot.

Trait Implementations

impl Part for AttachedDiskInitializeParams[src]

impl Default for AttachedDiskInitializeParams[src]

impl Clone for AttachedDiskInitializeParams[src]

fn clone_from(&mut self, source: &Self)1.0.0[src]

Performs copy-assignment from source. Read more

impl Debug for AttachedDiskInitializeParams[src]

impl Serialize for AttachedDiskInitializeParams[src]

impl<'de> Deserialize<'de> for AttachedDiskInitializeParams[src]

Auto Trait Implementations

Blanket Implementations

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Typeable for T where
    T: Any

fn get_type(&self) -> TypeId

Get the TypeId of this object.

impl<T> DeserializeOwned for T where
    T: Deserialize<'de>, 
[src]