Struct google_api_proto::google::cloud::compute::v1::Commitment

source ·
pub struct Commitment {
Show 21 fields pub auto_renew: Option<bool>, pub category: Option<String>, pub creation_timestamp: Option<String>, pub description: Option<String>, pub end_timestamp: Option<String>, pub existing_reservations: Vec<String>, pub id: Option<u64>, pub kind: Option<String>, pub license_resource: Option<LicenseResourceCommitment>, pub merge_source_commitments: Vec<String>, pub name: Option<String>, pub plan: Option<String>, pub region: Option<String>, pub reservations: Vec<Reservation>, pub resources: Vec<ResourceCommitment>, pub self_link: Option<String>, pub split_source_commitment: Option<String>, pub start_timestamp: Option<String>, pub status: Option<String>, pub status_message: Option<String>, pub type: Option<String>,
}
Expand description

Represents a regional Commitment resource. Creating a commitment resource means that you are purchasing a committed use contract with an explicit start and end time. You can create commitments based on vCPUs and memory usage and receive discounted rates. For full details, read Signing Up for Committed Use Discounts.

Fields§

§auto_renew: Option<bool>

Specifies whether to enable automatic renewal for the commitment. The default value is false if not specified. The field can be updated until the day of the commitment expiration at 12:00am PST. If the field is set to true, the commitment will be automatically renewed for either one or three years according to the terms of the existing commitment.

§category: Option<String>

The category of the commitment. Category MACHINE specifies commitments composed of machine resources such as VCPU or MEMORY, listed in resources. Category LICENSE specifies commitments composed of software licenses, listed in licenseResources. Note that only MACHINE commitments should have a Type specified. Check the Category enum for the list of possible values.

§creation_timestamp: Option<String>

[Output Only] Creation timestamp in RFC3339 text format.

§description: Option<String>

An optional description of this resource. Provide this property when you create the resource.

§end_timestamp: Option<String>

[Output Only] Commitment end time in RFC3339 text format.

§existing_reservations: Vec<String>

Specifies the already existing reservations to attach to the Commitment. This field is optional, and it can be a full or partial URL. For example, the following are valid URLs to an reservation: - https://www.googleapis.com/compute/v1/projects/project/zones/zone /reservations/reservation - projects/project/zones/zone/reservations/reservation

§id: Option<u64>

[Output Only] The unique identifier for the resource. This identifier is defined by the server.

§kind: Option<String>

[Output Only] Type of the resource. Always compute#commitment for commitments.

§license_resource: Option<LicenseResourceCommitment>

The license specification required as part of a license commitment.

§merge_source_commitments: Vec<String>

List of source commitments to be merged into a new commitment.

§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 with RFC1035. 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.

§plan: Option<String>

The plan for this commitment, which determines duration and discount rate. The currently supported plans are TWELVE_MONTH (1 year), and THIRTY_SIX_MONTH (3 years). Check the Plan enum for the list of possible values.

§region: Option<String>

[Output Only] URL of the region where this commitment may be used.

§reservations: Vec<Reservation>

List of create-on-create reservations for this commitment.

§resources: Vec<ResourceCommitment>

A list of commitment amounts for particular resources. Note that VCPU and MEMORY resource commitments must occur together.

§self_link: Option<String>

[Output Only] Server-defined URL for the resource.

§split_source_commitment: Option<String>

Source commitment to be split into a new commitment.

§start_timestamp: Option<String>

[Output Only] Commitment start time in RFC3339 text format.

§status: Option<String>

[Output Only] Status of the commitment with regards to eventual expiration (each commitment has an end date defined). One of the following values: NOT_YET_ACTIVE, ACTIVE, EXPIRED. Check the Status enum for the list of possible values.

§status_message: Option<String>

[Output Only] An optional, human-readable explanation of the status.

§type: Option<String>

The type of commitment, which affects the discount rate and the eligible resources. Type MEMORY_OPTIMIZED specifies a commitment that will only apply to memory optimized machines. Type ACCELERATOR_OPTIMIZED specifies a commitment that will only apply to accelerator optimized machines. Check the Type enum for the list of possible values.

Implementations§

source§

impl Commitment

source

pub fn id(&self) -> u64

Returns the value of id, or the default value if id is unset.

source

pub fn kind(&self) -> &str

Returns the value of kind, or the default value if kind is unset.

source

pub fn name(&self) -> &str

Returns the value of name, or the default value if name is unset.

source

pub fn plan(&self) -> &str

Returns the value of plan, or the default value if plan is unset.

source

pub fn type(&self) -> &str

Returns the value of type, or the default value if type is unset.

source

pub fn creation_timestamp(&self) -> &str

Returns the value of creation_timestamp, or the default value if creation_timestamp is unset.

source

pub fn category(&self) -> &str

Returns the value of category, or the default value if category is unset.

source

pub fn start_timestamp(&self) -> &str

Returns the value of start_timestamp, or the default value if start_timestamp is unset.

source

pub fn region(&self) -> &str

Returns the value of region, or the default value if region is unset.

source

pub fn status(&self) -> &str

Returns the value of status, or the default value if status is unset.

source

pub fn status_message(&self) -> &str

Returns the value of status_message, or the default value if status_message is unset.

source

pub fn split_source_commitment(&self) -> &str

Returns the value of split_source_commitment, or the default value if split_source_commitment is unset.

source

pub fn description(&self) -> &str

Returns the value of description, or the default value if description is unset.

Returns the value of self_link, or the default value if self_link is unset.

source

pub fn end_timestamp(&self) -> &str

Returns the value of end_timestamp, or the default value if end_timestamp is unset.

source

pub fn auto_renew(&self) -> bool

Returns the value of auto_renew, or the default value if auto_renew is unset.

Trait Implementations§

source§

impl Clone for Commitment

source§

fn clone(&self) -> Commitment

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Commitment

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Commitment

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl Message for Commitment

source§

fn encoded_len(&self) -> usize

Returns the encoded length of the message without a length delimiter.
source§

fn clear(&mut self)

Clears the message, resetting all fields to their default.
source§

fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>
where Self: Sized,

Encodes the message to a buffer. Read more
source§

fn encode_to_vec(&self) -> Vec<u8>
where Self: Sized,

Encodes the message to a newly allocated buffer.
source§

fn encode_length_delimited( &self, buf: &mut impl BufMut, ) -> Result<(), EncodeError>
where Self: Sized,

Encodes the message with a length-delimiter to a buffer. Read more
source§

fn encode_length_delimited_to_vec(&self) -> Vec<u8>
where Self: Sized,

Encodes the message with a length-delimiter to a newly allocated buffer.
source§

fn decode(buf: impl Buf) -> Result<Self, DecodeError>
where Self: Default,

Decodes an instance of the message from a buffer. Read more
source§

fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>
where Self: Default,

Decodes a length-delimited instance of the message from the buffer.
source§

fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>
where Self: Sized,

Decodes an instance of the message from a buffer, and merges it into self. Read more
source§

fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>
where Self: Sized,

Decodes a length-delimited instance of the message from buffer, and merges it into self.
source§

impl PartialEq for Commitment

source§

fn eq(&self, other: &Commitment) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl StructuralPartialEq for Commitment

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

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

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more