Struct google_storage1::BucketRetentionPolicy[][src]

pub struct BucketRetentionPolicy {
    pub effective_time: Option<String>,
    pub is_locked: Option<bool>,
    pub retention_period: Option<String>,
}

The bucket's retention policy. The retention policy enforces a minimum retention time for all objects contained in the bucket, based on their creation time. Any attempt to overwrite or delete objects younger than the retention period will result in a PERMISSION_DENIED error. An unlocked retention policy can be modified or removed from the bucket via a storage.buckets.update operation. A locked retention policy cannot be removed or shortened in duration for the lifetime of the bucket. Attempting to remove or decrease period of a locked retention policy will result in a PERMISSION_DENIED error.

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

Fields

Server-determined value that indicates the time from which policy was enforced and effective. This value is in RFC 3339 format.

Once locked, an object retention policy cannot be modified.

The duration in seconds that objects need to be retained. Retention duration must be greater than zero and less than 100 years. Note that enforcement of retention periods less than a day is not guaranteed. Such periods should only be used for testing purposes.

Trait Implementations

impl Default for BucketRetentionPolicy
[src]

Returns the "default value" for a type. Read more

impl Clone for BucketRetentionPolicy
[src]

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

impl Debug for BucketRetentionPolicy
[src]

Formats the value using the given formatter. Read more

impl NestedType for BucketRetentionPolicy
[src]

impl Part for BucketRetentionPolicy
[src]

Auto Trait Implementations