Struct google_api_proto::google::storagetransfer::v1::ObjectConditions
source · pub struct ObjectConditions {
pub min_time_elapsed_since_last_modification: Option<Duration>,
pub max_time_elapsed_since_last_modification: Option<Duration>,
pub include_prefixes: Vec<String>,
pub exclude_prefixes: Vec<String>,
pub last_modified_since: Option<Timestamp>,
pub last_modified_before: Option<Timestamp>,
}
Expand description
Conditions that determine which objects are transferred. Applies only to Cloud Data Sources such as S3, Azure, and Cloud Storage.
The “last modification time” refers to the time of the
last change to the object’s content or metadata — specifically, this is
the updated
property of Cloud Storage objects, the LastModified
field
of S3 objects, and the Last-Modified
header of Azure blobs.
Transfers with a [PosixFilesystem][google.storagetransfer.v1.PosixFilesystem]
source or destination don’t support ObjectConditions
.
Fields§
§min_time_elapsed_since_last_modification: Option<Duration>
Ensures that objects are not transferred until a specific minimum time
has elapsed after the “last modification time”. When a
[TransferOperation][google.storagetransfer.v1.TransferOperation] begins,
objects with a “last modification time” are transferred only if the elapsed
time between the
[start_time][google.storagetransfer.v1.TransferOperation.start_time] of the
TransferOperation
and the “last modification time” of the object is equal
to or greater than the value of min_time_elapsed_since_last_modification`.
Objects that do not have a “last modification time” are also transferred.
max_time_elapsed_since_last_modification: Option<Duration>
Ensures that objects are not transferred if a specific maximum time
has elapsed since the “last modification time”.
When a [TransferOperation][google.storagetransfer.v1.TransferOperation]
begins, objects with a “last modification time” are transferred only if the
elapsed time between the
[start_time][google.storagetransfer.v1.TransferOperation.start_time] of the
TransferOperation
and the “last modification time” of the object
is less than the value of max_time_elapsed_since_last_modification`.
Objects that do not have a “last modification time” are also transferred.
include_prefixes: Vec<String>
If you specify include_prefixes
, Storage Transfer Service uses the items
in the include_prefixes
array to determine which objects to include in a
transfer. Objects must start with one of the matching include_prefixes
for inclusion in the transfer. If
[exclude_prefixes][google.storagetransfer.v1.ObjectConditions.exclude_prefixes]
is specified, objects must not start with any of the exclude_prefixes
specified for inclusion in the transfer.
The following are requirements of include_prefixes
:
-
Each include-prefix can contain any sequence of Unicode characters, to a max length of 1024 bytes when UTF8-encoded, and must not contain Carriage Return or Line Feed characters. Wildcard matching and regular expression matching are not supported.
-
Each include-prefix must omit the leading slash. For example, to include the object
s3://my-aws-bucket/logs/y=2015/requests.gz
, specify the include-prefix aslogs/y=2015/requests.gz
. -
None of the include-prefix values can be empty, if specified.
-
Each include-prefix must include a distinct portion of the object namespace. No include-prefix may be a prefix of another include-prefix.
The max size of include_prefixes
is 1000.
For more information, see Filtering objects from transfers.
exclude_prefixes: Vec<String>
If you specify exclude_prefixes
, Storage Transfer Service uses the items
in the exclude_prefixes
array to determine which objects to exclude from
a transfer. Objects must not start with one of the matching
exclude_prefixes
for inclusion in a transfer.
The following are requirements of exclude_prefixes
:
-
Each exclude-prefix can contain any sequence of Unicode characters, to a max length of 1024 bytes when UTF8-encoded, and must not contain Carriage Return or Line Feed characters. Wildcard matching and regular expression matching are not supported.
-
Each exclude-prefix must omit the leading slash. For example, to exclude the object
s3://my-aws-bucket/logs/y=2015/requests.gz
, specify the exclude-prefix aslogs/y=2015/requests.gz
. -
None of the exclude-prefix values can be empty, if specified.
-
Each exclude-prefix must exclude a distinct portion of the object namespace. No exclude-prefix may be a prefix of another exclude-prefix.
-
If [include_prefixes][google.storagetransfer.v1.ObjectConditions.include_prefixes] is specified, then each exclude-prefix must start with the value of a path explicitly included by
include_prefixes
.
The max size of exclude_prefixes
is 1000.
For more information, see Filtering objects from transfers.
last_modified_since: Option<Timestamp>
If specified, only objects with a “last modification time” on or after this timestamp and objects that don’t have a “last modification time” are transferred.
The last_modified_since
and last_modified_before
fields can be used
together for chunked data processing. For example, consider a script that
processes each day’s worth of data at a time. For that you’d set each
of the fields as follows:
-
last_modified_since
to the start of the day -
last_modified_before
to the end of the day
last_modified_before: Option<Timestamp>
If specified, only objects with a “last modification time” before this timestamp and objects that don’t have a “last modification time” are transferred.
Trait Implementations§
source§impl Clone for ObjectConditions
impl Clone for ObjectConditions
source§fn clone(&self) -> ObjectConditions
fn clone(&self) -> ObjectConditions
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for ObjectConditions
impl Debug for ObjectConditions
source§impl Default for ObjectConditions
impl Default for ObjectConditions
source§impl Message for ObjectConditions
impl Message for ObjectConditions
source§fn encoded_len(&self) -> usize
fn encoded_len(&self) -> usize
source§fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
fn encode(&self, buf: &mut impl BufMut) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
fn encode_length_delimited(
&self,
buf: &mut impl BufMut,
) -> Result<(), EncodeError>where
Self: Sized,
source§fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
fn encode_length_delimited_to_vec(&self) -> Vec<u8>where
Self: Sized,
source§fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
fn decode_length_delimited(buf: impl Buf) -> Result<Self, DecodeError>where
Self: Default,
source§fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
. Read moresource§fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
fn merge_length_delimited(&mut self, buf: impl Buf) -> Result<(), DecodeError>where
Self: Sized,
self
.source§impl PartialEq for ObjectConditions
impl PartialEq for ObjectConditions
source§fn eq(&self, other: &ObjectConditions) -> bool
fn eq(&self, other: &ObjectConditions) -> bool
self
and other
values to be equal, and is used
by ==
.impl StructuralPartialEq for ObjectConditions
Auto Trait Implementations§
impl Freeze for ObjectConditions
impl RefUnwindSafe for ObjectConditions
impl Send for ObjectConditions
impl Sync for ObjectConditions
impl Unpin for ObjectConditions
impl UnwindSafe for ObjectConditions
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request