Struct aws_sdk_ec2::operation::lock_snapshot::LockSnapshotInput   
source · #[non_exhaustive]pub struct LockSnapshotInput {
    pub snapshot_id: Option<String>,
    pub dry_run: Option<bool>,
    pub lock_mode: Option<LockMode>,
    pub cool_off_period: Option<i32>,
    pub lock_duration: Option<i32>,
    pub expiration_date: Option<DateTime>,
}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.snapshot_id: Option<String>The ID of the snapshot to lock.
dry_run: Option<bool>Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is DryRunOperation. Otherwise, it is UnauthorizedOperation.
lock_mode: Option<LockMode>The mode in which to lock the snapshot. Specify one of the following:
- 
governance- Locks the snapshot in governance mode. Snapshots locked in governance mode can't be deleted until one of the following conditions are met:- 
The lock duration expires. 
- 
The snapshot is unlocked by a user with the appropriate permissions. 
 Users with the appropriate IAM permissions can unlock the snapshot, increase or decrease the lock duration, and change the lock mode to complianceat any time.If you lock a snapshot in governancemode, omit CoolOffPeriod.
- 
- 
compliance- Locks the snapshot in compliance mode. Snapshots locked in compliance mode can't be unlocked by any user. They can be deleted only after the lock duration expires. Users can't decrease the lock duration or change the lock mode togovernance. However, users with appropriate IAM permissions can increase the lock duration at any time.If you lock a snapshot in compliancemode, you can optionally specify CoolOffPeriod.
cool_off_period: Option<i32>The cooling-off period during which you can unlock the snapshot or modify the lock settings after locking the snapshot in compliance mode, in hours. After the cooling-off period expires, you can't unlock or delete the snapshot, decrease the lock duration, or change the lock mode. You can increase the lock duration after the cooling-off period expires.
The cooling-off period is optional when locking a snapshot in compliance mode. If you are locking the snapshot in governance mode, omit this parameter.
To lock the snapshot in compliance mode immediately without a cooling-off period, omit this parameter.
If you are extending the lock duration for a snapshot that is locked in compliance mode after the cooling-off period has expired, omit this parameter. If you specify a cooling-period in a such a request, the request fails.
Allowed values: Min 1, max 72.
lock_duration: Option<i32>The period of time for which to lock the snapshot, in days. The snapshot lock will automatically expire after this period lapses.
You must specify either this parameter or ExpirationDate, but not both.
Allowed values: Min: 1, max 36500
expiration_date: Option<DateTime>The date and time at which the snapshot lock is to automatically expire, in the UTC time zone (YYYY-MM-DDThh:mm:ss.sssZ).
You must specify either this parameter or LockDuration, but not both.
Implementations§
source§impl LockSnapshotInput
 
impl LockSnapshotInput
sourcepub fn snapshot_id(&self) -> Option<&str>
 
pub fn snapshot_id(&self) -> Option<&str>
The ID of the snapshot to lock.
sourcepub fn dry_run(&self) -> Option<bool>
 
pub fn dry_run(&self) -> Option<bool>
Checks whether you have the required permissions for the action, without actually making the request, and provides an error response. If you have the required permissions, the error response is DryRunOperation. Otherwise, it is UnauthorizedOperation.
sourcepub fn lock_mode(&self) -> Option<&LockMode>
 
pub fn lock_mode(&self) -> Option<&LockMode>
The mode in which to lock the snapshot. Specify one of the following:
- 
governance- Locks the snapshot in governance mode. Snapshots locked in governance mode can't be deleted until one of the following conditions are met:- 
The lock duration expires. 
- 
The snapshot is unlocked by a user with the appropriate permissions. 
 Users with the appropriate IAM permissions can unlock the snapshot, increase or decrease the lock duration, and change the lock mode to complianceat any time.If you lock a snapshot in governancemode, omit CoolOffPeriod.
- 
- 
compliance- Locks the snapshot in compliance mode. Snapshots locked in compliance mode can't be unlocked by any user. They can be deleted only after the lock duration expires. Users can't decrease the lock duration or change the lock mode togovernance. However, users with appropriate IAM permissions can increase the lock duration at any time.If you lock a snapshot in compliancemode, you can optionally specify CoolOffPeriod.
sourcepub fn cool_off_period(&self) -> Option<i32>
 
pub fn cool_off_period(&self) -> Option<i32>
The cooling-off period during which you can unlock the snapshot or modify the lock settings after locking the snapshot in compliance mode, in hours. After the cooling-off period expires, you can't unlock or delete the snapshot, decrease the lock duration, or change the lock mode. You can increase the lock duration after the cooling-off period expires.
The cooling-off period is optional when locking a snapshot in compliance mode. If you are locking the snapshot in governance mode, omit this parameter.
To lock the snapshot in compliance mode immediately without a cooling-off period, omit this parameter.
If you are extending the lock duration for a snapshot that is locked in compliance mode after the cooling-off period has expired, omit this parameter. If you specify a cooling-period in a such a request, the request fails.
Allowed values: Min 1, max 72.
sourcepub fn lock_duration(&self) -> Option<i32>
 
pub fn lock_duration(&self) -> Option<i32>
The period of time for which to lock the snapshot, in days. The snapshot lock will automatically expire after this period lapses.
You must specify either this parameter or ExpirationDate, but not both.
Allowed values: Min: 1, max 36500
sourcepub fn expiration_date(&self) -> Option<&DateTime>
 
pub fn expiration_date(&self) -> Option<&DateTime>
The date and time at which the snapshot lock is to automatically expire, in the UTC time zone (YYYY-MM-DDThh:mm:ss.sssZ).
You must specify either this parameter or LockDuration, but not both.
source§impl LockSnapshotInput
 
impl LockSnapshotInput
sourcepub fn builder() -> LockSnapshotInputBuilder
 
pub fn builder() -> LockSnapshotInputBuilder
Creates a new builder-style object to manufacture LockSnapshotInput.
Trait Implementations§
source§impl Clone for LockSnapshotInput
 
impl Clone for LockSnapshotInput
source§fn clone(&self) -> LockSnapshotInput
 
fn clone(&self) -> LockSnapshotInput
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Debug for LockSnapshotInput
 
impl Debug for LockSnapshotInput
source§impl PartialEq for LockSnapshotInput
 
impl PartialEq for LockSnapshotInput
source§fn eq(&self, other: &LockSnapshotInput) -> bool
 
fn eq(&self, other: &LockSnapshotInput) -> bool
self and other values to be equal, and is used
by ==.impl StructuralPartialEq for LockSnapshotInput
Auto Trait Implementations§
impl Freeze for LockSnapshotInput
impl RefUnwindSafe for LockSnapshotInput
impl Send for LockSnapshotInput
impl Sync for LockSnapshotInput
impl Unpin for LockSnapshotInput
impl UnwindSafe for LockSnapshotInput
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> Instrument for T
 
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more