/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include #include namespace Aws { template class AmazonWebServiceResult; namespace Utils { namespace Xml { class XmlDocument; } // namespace Xml } // namespace Utils namespace S3 { namespace Model { class AWS_S3_API ListObjectVersionsResult { public: ListObjectVersionsResult(); ListObjectVersionsResult(const Aws::AmazonWebServiceResult& result); ListObjectVersionsResult& operator=(const Aws::AmazonWebServiceResult& result); /** *

A flag that indicates whether Amazon S3 returned all of the results that * satisfied the search criteria. If your results were truncated, you can make a * follow-up paginated request using the NextKeyMarker and NextVersionIdMarker * response parameters as a starting place in another request to return the rest of * the results.

*/ inline bool GetIsTruncated() const{ return m_isTruncated; } /** *

A flag that indicates whether Amazon S3 returned all of the results that * satisfied the search criteria. If your results were truncated, you can make a * follow-up paginated request using the NextKeyMarker and NextVersionIdMarker * response parameters as a starting place in another request to return the rest of * the results.

*/ inline void SetIsTruncated(bool value) { m_isTruncated = value; } /** *

A flag that indicates whether Amazon S3 returned all of the results that * satisfied the search criteria. If your results were truncated, you can make a * follow-up paginated request using the NextKeyMarker and NextVersionIdMarker * response parameters as a starting place in another request to return the rest of * the results.

*/ inline ListObjectVersionsResult& WithIsTruncated(bool value) { SetIsTruncated(value); return *this;} /** *

Marks the last key returned in a truncated response.

*/ inline const Aws::String& GetKeyMarker() const{ return m_keyMarker; } /** *

Marks the last key returned in a truncated response.

*/ inline void SetKeyMarker(const Aws::String& value) { m_keyMarker = value; } /** *

Marks the last key returned in a truncated response.

*/ inline void SetKeyMarker(Aws::String&& value) { m_keyMarker = std::move(value); } /** *

Marks the last key returned in a truncated response.

*/ inline void SetKeyMarker(const char* value) { m_keyMarker.assign(value); } /** *

Marks the last key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithKeyMarker(const Aws::String& value) { SetKeyMarker(value); return *this;} /** *

Marks the last key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithKeyMarker(Aws::String&& value) { SetKeyMarker(std::move(value)); return *this;} /** *

Marks the last key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithKeyMarker(const char* value) { SetKeyMarker(value); return *this;} /** *

Marks the last version of the key returned in a truncated response.

*/ inline const Aws::String& GetVersionIdMarker() const{ return m_versionIdMarker; } /** *

Marks the last version of the key returned in a truncated response.

*/ inline void SetVersionIdMarker(const Aws::String& value) { m_versionIdMarker = value; } /** *

Marks the last version of the key returned in a truncated response.

*/ inline void SetVersionIdMarker(Aws::String&& value) { m_versionIdMarker = std::move(value); } /** *

Marks the last version of the key returned in a truncated response.

*/ inline void SetVersionIdMarker(const char* value) { m_versionIdMarker.assign(value); } /** *

Marks the last version of the key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithVersionIdMarker(const Aws::String& value) { SetVersionIdMarker(value); return *this;} /** *

Marks the last version of the key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithVersionIdMarker(Aws::String&& value) { SetVersionIdMarker(std::move(value)); return *this;} /** *

Marks the last version of the key returned in a truncated response.

*/ inline ListObjectVersionsResult& WithVersionIdMarker(const char* value) { SetVersionIdMarker(value); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline const Aws::String& GetNextKeyMarker() const{ return m_nextKeyMarker; } /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline void SetNextKeyMarker(const Aws::String& value) { m_nextKeyMarker = value; } /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline void SetNextKeyMarker(Aws::String&& value) { m_nextKeyMarker = std::move(value); } /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline void SetNextKeyMarker(const char* value) { m_nextKeyMarker.assign(value); } /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline ListObjectVersionsResult& WithNextKeyMarker(const Aws::String& value) { SetNextKeyMarker(value); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline ListObjectVersionsResult& WithNextKeyMarker(Aws::String&& value) { SetNextKeyMarker(std::move(value)); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextKeyMarker specifies the first key not returned that satisfies * the search criteria. Use this value for the key-marker request parameter in a * subsequent request.

*/ inline ListObjectVersionsResult& WithNextKeyMarker(const char* value) { SetNextKeyMarker(value); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline const Aws::String& GetNextVersionIdMarker() const{ return m_nextVersionIdMarker; } /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline void SetNextVersionIdMarker(const Aws::String& value) { m_nextVersionIdMarker = value; } /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline void SetNextVersionIdMarker(Aws::String&& value) { m_nextVersionIdMarker = std::move(value); } /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline void SetNextVersionIdMarker(const char* value) { m_nextVersionIdMarker.assign(value); } /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline ListObjectVersionsResult& WithNextVersionIdMarker(const Aws::String& value) { SetNextVersionIdMarker(value); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline ListObjectVersionsResult& WithNextVersionIdMarker(Aws::String&& value) { SetNextVersionIdMarker(std::move(value)); return *this;} /** *

When the number of responses exceeds the value of MaxKeys, * NextVersionIdMarker specifies the first object version not returned * that satisfies the search criteria. Use this value for the version-id-marker * request parameter in a subsequent request.

*/ inline ListObjectVersionsResult& WithNextVersionIdMarker(const char* value) { SetNextVersionIdMarker(value); return *this;} /** *

Container for version information.

*/ inline const Aws::Vector& GetVersions() const{ return m_versions; } /** *

Container for version information.

*/ inline void SetVersions(const Aws::Vector& value) { m_versions = value; } /** *

Container for version information.

*/ inline void SetVersions(Aws::Vector&& value) { m_versions = std::move(value); } /** *

Container for version information.

*/ inline ListObjectVersionsResult& WithVersions(const Aws::Vector& value) { SetVersions(value); return *this;} /** *

Container for version information.

*/ inline ListObjectVersionsResult& WithVersions(Aws::Vector&& value) { SetVersions(std::move(value)); return *this;} /** *

Container for version information.

*/ inline ListObjectVersionsResult& AddVersions(const ObjectVersion& value) { m_versions.push_back(value); return *this; } /** *

Container for version information.

*/ inline ListObjectVersionsResult& AddVersions(ObjectVersion&& value) { m_versions.push_back(std::move(value)); return *this; } /** *

Container for an object that is a delete marker.

*/ inline const Aws::Vector& GetDeleteMarkers() const{ return m_deleteMarkers; } /** *

Container for an object that is a delete marker.

*/ inline void SetDeleteMarkers(const Aws::Vector& value) { m_deleteMarkers = value; } /** *

Container for an object that is a delete marker.

*/ inline void SetDeleteMarkers(Aws::Vector&& value) { m_deleteMarkers = std::move(value); } /** *

Container for an object that is a delete marker.

*/ inline ListObjectVersionsResult& WithDeleteMarkers(const Aws::Vector& value) { SetDeleteMarkers(value); return *this;} /** *

Container for an object that is a delete marker.

*/ inline ListObjectVersionsResult& WithDeleteMarkers(Aws::Vector&& value) { SetDeleteMarkers(std::move(value)); return *this;} /** *

Container for an object that is a delete marker.

*/ inline ListObjectVersionsResult& AddDeleteMarkers(const DeleteMarkerEntry& value) { m_deleteMarkers.push_back(value); return *this; } /** *

Container for an object that is a delete marker.

*/ inline ListObjectVersionsResult& AddDeleteMarkers(DeleteMarkerEntry&& value) { m_deleteMarkers.push_back(std::move(value)); return *this; } /** *

The bucket name.

*/ inline const Aws::String& GetName() const{ return m_name; } /** *

The bucket name.

*/ inline void SetName(const Aws::String& value) { m_name = value; } /** *

The bucket name.

*/ inline void SetName(Aws::String&& value) { m_name = std::move(value); } /** *

The bucket name.

*/ inline void SetName(const char* value) { m_name.assign(value); } /** *

The bucket name.

*/ inline ListObjectVersionsResult& WithName(const Aws::String& value) { SetName(value); return *this;} /** *

The bucket name.

*/ inline ListObjectVersionsResult& WithName(Aws::String&& value) { SetName(std::move(value)); return *this;} /** *

The bucket name.

*/ inline ListObjectVersionsResult& WithName(const char* value) { SetName(value); return *this;} /** *

Selects objects that start with the value supplied by this parameter.

*/ inline const Aws::String& GetPrefix() const{ return m_prefix; } /** *

Selects objects that start with the value supplied by this parameter.

*/ inline void SetPrefix(const Aws::String& value) { m_prefix = value; } /** *

Selects objects that start with the value supplied by this parameter.

*/ inline void SetPrefix(Aws::String&& value) { m_prefix = std::move(value); } /** *

Selects objects that start with the value supplied by this parameter.

*/ inline void SetPrefix(const char* value) { m_prefix.assign(value); } /** *

Selects objects that start with the value supplied by this parameter.

*/ inline ListObjectVersionsResult& WithPrefix(const Aws::String& value) { SetPrefix(value); return *this;} /** *

Selects objects that start with the value supplied by this parameter.

*/ inline ListObjectVersionsResult& WithPrefix(Aws::String&& value) { SetPrefix(std::move(value)); return *this;} /** *

Selects objects that start with the value supplied by this parameter.

*/ inline ListObjectVersionsResult& WithPrefix(const char* value) { SetPrefix(value); return *this;} /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline const Aws::String& GetDelimiter() const{ return m_delimiter; } /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline void SetDelimiter(const Aws::String& value) { m_delimiter = value; } /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline void SetDelimiter(Aws::String&& value) { m_delimiter = std::move(value); } /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline void SetDelimiter(const char* value) { m_delimiter.assign(value); } /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline ListObjectVersionsResult& WithDelimiter(const Aws::String& value) { SetDelimiter(value); return *this;} /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline ListObjectVersionsResult& WithDelimiter(Aws::String&& value) { SetDelimiter(std::move(value)); return *this;} /** *

The delimiter grouping the included keys. A delimiter is a character that you * specify to group keys. All keys that contain the same string between the prefix * and the first occurrence of the delimiter are grouped under a single result * element in CommonPrefixes. These groups are counted as one result * against the max-keys limitation. These keys are not returned elsewhere in the * response.

*/ inline ListObjectVersionsResult& WithDelimiter(const char* value) { SetDelimiter(value); return *this;} /** *

Specifies the maximum number of objects to return.

*/ inline int GetMaxKeys() const{ return m_maxKeys; } /** *

Specifies the maximum number of objects to return.

*/ inline void SetMaxKeys(int value) { m_maxKeys = value; } /** *

Specifies the maximum number of objects to return.

*/ inline ListObjectVersionsResult& WithMaxKeys(int value) { SetMaxKeys(value); return *this;} /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline const Aws::Vector& GetCommonPrefixes() const{ return m_commonPrefixes; } /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline void SetCommonPrefixes(const Aws::Vector& value) { m_commonPrefixes = value; } /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline void SetCommonPrefixes(Aws::Vector&& value) { m_commonPrefixes = std::move(value); } /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline ListObjectVersionsResult& WithCommonPrefixes(const Aws::Vector& value) { SetCommonPrefixes(value); return *this;} /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline ListObjectVersionsResult& WithCommonPrefixes(Aws::Vector&& value) { SetCommonPrefixes(std::move(value)); return *this;} /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline ListObjectVersionsResult& AddCommonPrefixes(const CommonPrefix& value) { m_commonPrefixes.push_back(value); return *this; } /** *

All of the keys rolled up into a common prefix count as a single return when * calculating the number of returns.

*/ inline ListObjectVersionsResult& AddCommonPrefixes(CommonPrefix&& value) { m_commonPrefixes.push_back(std::move(value)); return *this; } /** *

Encoding type used by Amazon S3 to encode object key names in the XML * response.

If you specify encoding-type request parameter, Amazon S3 * includes this element in the response, and returns encoded key name values in * the following response elements:

KeyMarker, NextKeyMarker, Prefix, * Key, and Delimiter.

*/ inline const EncodingType& GetEncodingType() const{ return m_encodingType; } /** *

Encoding type used by Amazon S3 to encode object key names in the XML * response.

If you specify encoding-type request parameter, Amazon S3 * includes this element in the response, and returns encoded key name values in * the following response elements:

KeyMarker, NextKeyMarker, Prefix, * Key, and Delimiter.

*/ inline void SetEncodingType(const EncodingType& value) { m_encodingType = value; } /** *

Encoding type used by Amazon S3 to encode object key names in the XML * response.

If you specify encoding-type request parameter, Amazon S3 * includes this element in the response, and returns encoded key name values in * the following response elements:

KeyMarker, NextKeyMarker, Prefix, * Key, and Delimiter.

*/ inline void SetEncodingType(EncodingType&& value) { m_encodingType = std::move(value); } /** *

Encoding type used by Amazon S3 to encode object key names in the XML * response.

If you specify encoding-type request parameter, Amazon S3 * includes this element in the response, and returns encoded key name values in * the following response elements:

KeyMarker, NextKeyMarker, Prefix, * Key, and Delimiter.

*/ inline ListObjectVersionsResult& WithEncodingType(const EncodingType& value) { SetEncodingType(value); return *this;} /** *

Encoding type used by Amazon S3 to encode object key names in the XML * response.

If you specify encoding-type request parameter, Amazon S3 * includes this element in the response, and returns encoded key name values in * the following response elements:

KeyMarker, NextKeyMarker, Prefix, * Key, and Delimiter.

*/ inline ListObjectVersionsResult& WithEncodingType(EncodingType&& value) { SetEncodingType(std::move(value)); return *this;} private: bool m_isTruncated; Aws::String m_keyMarker; Aws::String m_versionIdMarker; Aws::String m_nextKeyMarker; Aws::String m_nextVersionIdMarker; Aws::Vector m_versions; Aws::Vector m_deleteMarkers; Aws::String m_name; Aws::String m_prefix; Aws::String m_delimiter; int m_maxKeys; Aws::Vector m_commonPrefixes; EncodingType m_encodingType; }; } // namespace Model } // namespace S3 } // namespace Aws