All Downloads are FREE. Search and download functionalities are using the official Maven repository.

software.amazon.awssdk.services.s3.model.S3Object Maven / Gradle / Ivy

/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */

package software.amazon.awssdk.services.s3.model;

import java.io.Serializable;
import java.time.Instant;
import java.util.Arrays;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.BiConsumer;
import java.util.function.Consumer;
import java.util.function.Function;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.core.SdkField;
import software.amazon.awssdk.core.SdkPojo;
import software.amazon.awssdk.core.protocol.MarshallLocation;
import software.amazon.awssdk.core.protocol.MarshallingType;
import software.amazon.awssdk.core.traits.ListTrait;
import software.amazon.awssdk.core.traits.LocationTrait;
import software.amazon.awssdk.core.util.DefaultSdkAutoConstructList;
import software.amazon.awssdk.core.util.SdkAutoConstructList;
import software.amazon.awssdk.utils.ToString;
import software.amazon.awssdk.utils.builder.CopyableBuilder;
import software.amazon.awssdk.utils.builder.ToCopyableBuilder;

/**
 * 

* An object consists of data and its descriptive metadata. *

*/ @Generated("software.amazon.awssdk:codegen") public final class S3Object implements SdkPojo, Serializable, ToCopyableBuilder { private static final SdkField KEY_FIELD = SdkField . builder(MarshallingType.STRING) .memberName("Key") .getter(getter(S3Object::key)) .setter(setter(Builder::key)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Key").unmarshallLocationName("Key") .build()).build(); private static final SdkField LAST_MODIFIED_FIELD = SdkField . builder(MarshallingType.INSTANT) .memberName("LastModified") .getter(getter(S3Object::lastModified)) .setter(setter(Builder::lastModified)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("LastModified") .unmarshallLocationName("LastModified").build()).build(); private static final SdkField E_TAG_FIELD = SdkField . builder(MarshallingType.STRING) .memberName("ETag") .getter(getter(S3Object::eTag)) .setter(setter(Builder::eTag)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ETag") .unmarshallLocationName("ETag").build()).build(); private static final SdkField> CHECKSUM_ALGORITHM_FIELD = SdkField .> builder(MarshallingType.LIST) .memberName("ChecksumAlgorithm") .getter(getter(S3Object::checksumAlgorithmAsStrings)) .setter(setter(Builder::checksumAlgorithmWithStrings)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("ChecksumAlgorithm") .unmarshallLocationName("ChecksumAlgorithm").build(), ListTrait .builder() .memberLocationName(null) .memberFieldInfo( SdkField. builder(MarshallingType.STRING) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD) .locationName("member").unmarshallLocationName("member").build()).build()) .isFlattened(true).build()).build(); private static final SdkField SIZE_FIELD = SdkField . builder(MarshallingType.LONG) .memberName("Size") .getter(getter(S3Object::size)) .setter(setter(Builder::size)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Size") .unmarshallLocationName("Size").build()).build(); private static final SdkField STORAGE_CLASS_FIELD = SdkField . builder(MarshallingType.STRING) .memberName("StorageClass") .getter(getter(S3Object::storageClassAsString)) .setter(setter(Builder::storageClass)) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("StorageClass") .unmarshallLocationName("StorageClass").build()).build(); private static final SdkField OWNER_FIELD = SdkField . builder(MarshallingType.SDK_POJO) .memberName("Owner") .getter(getter(S3Object::owner)) .setter(setter(Builder::owner)) .constructor(Owner::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("Owner") .unmarshallLocationName("Owner").build()).build(); private static final SdkField RESTORE_STATUS_FIELD = SdkField . builder(MarshallingType.SDK_POJO) .memberName("RestoreStatus") .getter(getter(S3Object::restoreStatus)) .setter(setter(Builder::restoreStatus)) .constructor(RestoreStatus::builder) .traits(LocationTrait.builder().location(MarshallLocation.PAYLOAD).locationName("RestoreStatus") .unmarshallLocationName("RestoreStatus").build()).build(); private static final List> SDK_FIELDS = Collections.unmodifiableList(Arrays.asList(KEY_FIELD, LAST_MODIFIED_FIELD, E_TAG_FIELD, CHECKSUM_ALGORITHM_FIELD, SIZE_FIELD, STORAGE_CLASS_FIELD, OWNER_FIELD, RESTORE_STATUS_FIELD)); private static final long serialVersionUID = 1L; private final String key; private final Instant lastModified; private final String eTag; private final List checksumAlgorithm; private final Long size; private final String storageClass; private final Owner owner; private final RestoreStatus restoreStatus; private S3Object(BuilderImpl builder) { this.key = builder.key; this.lastModified = builder.lastModified; this.eTag = builder.eTag; this.checksumAlgorithm = builder.checksumAlgorithm; this.size = builder.size; this.storageClass = builder.storageClass; this.owner = builder.owner; this.restoreStatus = builder.restoreStatus; } /** *

* The name that you assign to an object. You use the object key to retrieve the object. *

* * @return The name that you assign to an object. You use the object key to retrieve the object. */ public final String key() { return key; } /** *

* Creation date of the object. *

* * @return Creation date of the object. */ public final Instant lastModified() { return lastModified; } /** *

* The entity tag is a hash of the object. The ETag reflects changes only to the contents of an object, not its * metadata. The ETag may or may not be an MD5 digest of the object data. Whether or not it is depends on how the * object was created and how it is encrypted as described below: *

*
    *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services Management * Console, and are encrypted by SSE-S3 or plaintext, have ETags that are an MD5 digest of their object data. *

    *
  • *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services Management * Console, and are encrypted by SSE-C or SSE-KMS, have ETags that are not an MD5 digest of their object data. *

    *
  • *
  • *

    * If an object is created by either the Multipart Upload or Part Copy operation, the ETag is not an MD5 digest, * regardless of the method of encryption. If an object is larger than 16 MB, the Amazon Web Services Management * Console will upload or copy that object as a Multipart Upload, and therefore the ETag will not be an MD5 digest. *

    *
  • *
* *

* Directory buckets - MD5 is not supported by directory buckets. *

*
* * @return The entity tag is a hash of the object. The ETag reflects changes only to the contents of an object, not * its metadata. The ETag may or may not be an MD5 digest of the object data. Whether or not it is depends * on how the object was created and how it is encrypted as described below:

*
    *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-S3 or plaintext, have ETags that are an MD5 digest of their * object data. *

    *
  • *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-C or SSE-KMS, have ETags that are not an MD5 digest of their * object data. *

    *
  • *
  • *

    * If an object is created by either the Multipart Upload or Part Copy operation, the ETag is not an MD5 * digest, regardless of the method of encryption. If an object is larger than 16 MB, the Amazon Web * Services Management Console will upload or copy that object as a Multipart Upload, and therefore the ETag * will not be an MD5 digest. *

    *
  • *
* *

* Directory buckets - MD5 is not supported by directory buckets. *

*/ public final String eTag() { return eTag; } /** *

* The algorithm that was used to create a checksum of the object. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasChecksumAlgorithm} method. *

* * @return The algorithm that was used to create a checksum of the object. */ public final List checksumAlgorithm() { return ChecksumAlgorithmListCopier.copyStringToEnum(checksumAlgorithm); } /** * For responses, this returns true if the service returned a value for the ChecksumAlgorithm property. This DOES * NOT check that the value is non-empty (for which, you should check the {@code isEmpty()} method on the property). * This is useful because the SDK will never return a null collection or map, but you may need to differentiate * between the service returning nothing (or null) and the service returning an empty collection or map. For * requests, this returns true if a value for the property was specified in the request builder, and false if a * value was not specified. */ public final boolean hasChecksumAlgorithm() { return checksumAlgorithm != null && !(checksumAlgorithm instanceof SdkAutoConstructList); } /** *

* The algorithm that was used to create a checksum of the object. *

*

* Attempts to modify the collection returned by this method will result in an UnsupportedOperationException. *

*

* This method will never return null. If you would like to know whether the service returned this field (so that * you can differentiate between null and empty), you can use the {@link #hasChecksumAlgorithm} method. *

* * @return The algorithm that was used to create a checksum of the object. */ public final List checksumAlgorithmAsStrings() { return checksumAlgorithm; } /** *

* Size in bytes of the object *

* * @return Size in bytes of the object */ public final Long size() { return size; } /** *

* The class of storage used to store the object. *

* *

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets to store * objects. *

*
*

* If the service returns an enum value that is not available in the current SDK version, {@link #storageClass} will * return {@link ObjectStorageClass#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #storageClassAsString}. *

* * @return The class of storage used to store the object.

*

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets * to store objects. *

* @see ObjectStorageClass */ public final ObjectStorageClass storageClass() { return ObjectStorageClass.fromValue(storageClass); } /** *

* The class of storage used to store the object. *

* *

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets to store * objects. *

*
*

* If the service returns an enum value that is not available in the current SDK version, {@link #storageClass} will * return {@link ObjectStorageClass#UNKNOWN_TO_SDK_VERSION}. The raw value returned by the service is available from * {@link #storageClassAsString}. *

* * @return The class of storage used to store the object.

*

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets * to store objects. *

* @see ObjectStorageClass */ public final String storageClassAsString() { return storageClass; } /** *

* The owner of the object *

* *

* Directory buckets - The bucket owner is returned as the object owner. *

*
* * @return The owner of the object

*

* Directory buckets - The bucket owner is returned as the object owner. *

*/ public final Owner owner() { return owner; } /** *

* Specifies the restoration status of an object. Objects in certain storage classes must be restored before they * can be retrieved. For more information about these storage classes and how to work with archived objects, see Working with archived * objects in the Amazon S3 User Guide. *

* *

* This functionality is not supported for directory buckets. Only the S3 Express One Zone storage class is * supported by directory buckets to store objects. *

*
* * @return Specifies the restoration status of an object. Objects in certain storage classes must be restored before * they can be retrieved. For more information about these storage classes and how to work with archived * objects, see * Working with archived objects in the Amazon S3 User Guide.

*

* This functionality is not supported for directory buckets. Only the S3 Express One Zone storage class is * supported by directory buckets to store objects. *

*/ public final RestoreStatus restoreStatus() { return restoreStatus; } @Override public Builder toBuilder() { return new BuilderImpl(this); } public static Builder builder() { return new BuilderImpl(); } public static Class serializableBuilderClass() { return BuilderImpl.class; } @Override public final int hashCode() { int hashCode = 1; hashCode = 31 * hashCode + Objects.hashCode(key()); hashCode = 31 * hashCode + Objects.hashCode(lastModified()); hashCode = 31 * hashCode + Objects.hashCode(eTag()); hashCode = 31 * hashCode + Objects.hashCode(hasChecksumAlgorithm() ? checksumAlgorithmAsStrings() : null); hashCode = 31 * hashCode + Objects.hashCode(size()); hashCode = 31 * hashCode + Objects.hashCode(storageClassAsString()); hashCode = 31 * hashCode + Objects.hashCode(owner()); hashCode = 31 * hashCode + Objects.hashCode(restoreStatus()); return hashCode; } @Override public final boolean equals(Object obj) { return equalsBySdkFields(obj); } @Override public final boolean equalsBySdkFields(Object obj) { if (this == obj) { return true; } if (obj == null) { return false; } if (!(obj instanceof S3Object)) { return false; } S3Object other = (S3Object) obj; return Objects.equals(key(), other.key()) && Objects.equals(lastModified(), other.lastModified()) && Objects.equals(eTag(), other.eTag()) && hasChecksumAlgorithm() == other.hasChecksumAlgorithm() && Objects.equals(checksumAlgorithmAsStrings(), other.checksumAlgorithmAsStrings()) && Objects.equals(size(), other.size()) && Objects.equals(storageClassAsString(), other.storageClassAsString()) && Objects.equals(owner(), other.owner()) && Objects.equals(restoreStatus(), other.restoreStatus()); } /** * Returns a string representation of this object. This is useful for testing and debugging. Sensitive data will be * redacted from this string using a placeholder value. */ @Override public final String toString() { return ToString.builder("S3Object").add("Key", key()).add("LastModified", lastModified()).add("ETag", eTag()) .add("ChecksumAlgorithm", hasChecksumAlgorithm() ? checksumAlgorithmAsStrings() : null).add("Size", size()) .add("StorageClass", storageClassAsString()).add("Owner", owner()).add("RestoreStatus", restoreStatus()).build(); } public final Optional getValueForField(String fieldName, Class clazz) { switch (fieldName) { case "Key": return Optional.ofNullable(clazz.cast(key())); case "LastModified": return Optional.ofNullable(clazz.cast(lastModified())); case "ETag": return Optional.ofNullable(clazz.cast(eTag())); case "ChecksumAlgorithm": return Optional.ofNullable(clazz.cast(checksumAlgorithmAsStrings())); case "Size": return Optional.ofNullable(clazz.cast(size())); case "StorageClass": return Optional.ofNullable(clazz.cast(storageClassAsString())); case "Owner": return Optional.ofNullable(clazz.cast(owner())); case "RestoreStatus": return Optional.ofNullable(clazz.cast(restoreStatus())); default: return Optional.empty(); } } @Override public final List> sdkFields() { return SDK_FIELDS; } private static Function getter(Function g) { return obj -> g.apply((S3Object) obj); } private static BiConsumer setter(BiConsumer s) { return (obj, val) -> s.accept((Builder) obj, val); } public interface Builder extends SdkPojo, CopyableBuilder { /** *

* The name that you assign to an object. You use the object key to retrieve the object. *

* * @param key * The name that you assign to an object. You use the object key to retrieve the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder key(String key); /** *

* Creation date of the object. *

* * @param lastModified * Creation date of the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder lastModified(Instant lastModified); /** *

* The entity tag is a hash of the object. The ETag reflects changes only to the contents of an object, not its * metadata. The ETag may or may not be an MD5 digest of the object data. Whether or not it is depends on how * the object was created and how it is encrypted as described below: *

*
    *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-S3 or plaintext, have ETags that are an MD5 digest of their * object data. *

    *
  • *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-C or SSE-KMS, have ETags that are not an MD5 digest of their * object data. *

    *
  • *
  • *

    * If an object is created by either the Multipart Upload or Part Copy operation, the ETag is not an MD5 digest, * regardless of the method of encryption. If an object is larger than 16 MB, the Amazon Web Services Management * Console will upload or copy that object as a Multipart Upload, and therefore the ETag will not be an MD5 * digest. *

    *
  • *
* *

* Directory buckets - MD5 is not supported by directory buckets. *

*
* * @param eTag * The entity tag is a hash of the object. The ETag reflects changes only to the contents of an object, * not its metadata. The ETag may or may not be an MD5 digest of the object data. Whether or not it is * depends on how the object was created and how it is encrypted as described below:

*
    *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-S3 or plaintext, have ETags that are an MD5 digest of * their object data. *

    *
  • *
  • *

    * Objects created by the PUT Object, POST Object, or Copy operation, or through the Amazon Web Services * Management Console, and are encrypted by SSE-C or SSE-KMS, have ETags that are not an MD5 digest of * their object data. *

    *
  • *
  • *

    * If an object is created by either the Multipart Upload or Part Copy operation, the ETag is not an MD5 * digest, regardless of the method of encryption. If an object is larger than 16 MB, the Amazon Web * Services Management Console will upload or copy that object as a Multipart Upload, and therefore the * ETag will not be an MD5 digest. *

    *
  • *
* *

* Directory buckets - MD5 is not supported by directory buckets. *

* @return Returns a reference to this object so that method calls can be chained together. */ Builder eTag(String eTag); /** *

* The algorithm that was used to create a checksum of the object. *

* * @param checksumAlgorithm * The algorithm that was used to create a checksum of the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder checksumAlgorithmWithStrings(Collection checksumAlgorithm); /** *

* The algorithm that was used to create a checksum of the object. *

* * @param checksumAlgorithm * The algorithm that was used to create a checksum of the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder checksumAlgorithmWithStrings(String... checksumAlgorithm); /** *

* The algorithm that was used to create a checksum of the object. *

* * @param checksumAlgorithm * The algorithm that was used to create a checksum of the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder checksumAlgorithm(Collection checksumAlgorithm); /** *

* The algorithm that was used to create a checksum of the object. *

* * @param checksumAlgorithm * The algorithm that was used to create a checksum of the object. * @return Returns a reference to this object so that method calls can be chained together. */ Builder checksumAlgorithm(ChecksumAlgorithm... checksumAlgorithm); /** *

* Size in bytes of the object *

* * @param size * Size in bytes of the object * @return Returns a reference to this object so that method calls can be chained together. */ Builder size(Long size); /** *

* The class of storage used to store the object. *

* *

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets to * store objects. *

*
* * @param storageClass * The class of storage used to store the object.

*

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory * buckets to store objects. *

* @see ObjectStorageClass * @return Returns a reference to this object so that method calls can be chained together. * @see ObjectStorageClass */ Builder storageClass(String storageClass); /** *

* The class of storage used to store the object. *

* *

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory buckets to * store objects. *

*
* * @param storageClass * The class of storage used to store the object.

*

* Directory buckets - Only the S3 Express One Zone storage class is supported by directory * buckets to store objects. *

* @see ObjectStorageClass * @return Returns a reference to this object so that method calls can be chained together. * @see ObjectStorageClass */ Builder storageClass(ObjectStorageClass storageClass); /** *

* The owner of the object *

* *

* Directory buckets - The bucket owner is returned as the object owner. *

*
* * @param owner * The owner of the object

*

* Directory buckets - The bucket owner is returned as the object owner. *

* @return Returns a reference to this object so that method calls can be chained together. */ Builder owner(Owner owner); /** *

* The owner of the object *

* *

* Directory buckets - The bucket owner is returned as the object owner. *

*
This is a convenience method that creates an instance of the {@link Owner.Builder} avoiding the need * to create one manually via {@link Owner#builder()}. * *

* When the {@link Consumer} completes, {@link Owner.Builder#build()} is called immediately and its result is * passed to {@link #owner(Owner)}. * * @param owner * a consumer that will call methods on {@link Owner.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #owner(Owner) */ default Builder owner(Consumer owner) { return owner(Owner.builder().applyMutation(owner).build()); } /** *

* Specifies the restoration status of an object. Objects in certain storage classes must be restored before * they can be retrieved. For more information about these storage classes and how to work with archived * objects, see Working * with archived objects in the Amazon S3 User Guide. *

* *

* This functionality is not supported for directory buckets. Only the S3 Express One Zone storage class is * supported by directory buckets to store objects. *

*
* * @param restoreStatus * Specifies the restoration status of an object. Objects in certain storage classes must be restored * before they can be retrieved. For more information about these storage classes and how to work with * archived objects, see Working with * archived objects in the Amazon S3 User Guide.

*

* This functionality is not supported for directory buckets. Only the S3 Express One Zone storage class * is supported by directory buckets to store objects. *

* @return Returns a reference to this object so that method calls can be chained together. */ Builder restoreStatus(RestoreStatus restoreStatus); /** *

* Specifies the restoration status of an object. Objects in certain storage classes must be restored before * they can be retrieved. For more information about these storage classes and how to work with archived * objects, see Working * with archived objects in the Amazon S3 User Guide. *

* *

* This functionality is not supported for directory buckets. Only the S3 Express One Zone storage class is * supported by directory buckets to store objects. *

*
This is a convenience method that creates an instance of the {@link RestoreStatus.Builder} avoiding * the need to create one manually via {@link RestoreStatus#builder()}. * *

* When the {@link Consumer} completes, {@link RestoreStatus.Builder#build()} is called immediately and its * result is passed to {@link #restoreStatus(RestoreStatus)}. * * @param restoreStatus * a consumer that will call methods on {@link RestoreStatus.Builder} * @return Returns a reference to this object so that method calls can be chained together. * @see #restoreStatus(RestoreStatus) */ default Builder restoreStatus(Consumer restoreStatus) { return restoreStatus(RestoreStatus.builder().applyMutation(restoreStatus).build()); } } static final class BuilderImpl implements Builder { private String key; private Instant lastModified; private String eTag; private List checksumAlgorithm = DefaultSdkAutoConstructList.getInstance(); private Long size; private String storageClass; private Owner owner; private RestoreStatus restoreStatus; private BuilderImpl() { } private BuilderImpl(S3Object model) { key(model.key); lastModified(model.lastModified); eTag(model.eTag); checksumAlgorithmWithStrings(model.checksumAlgorithm); size(model.size); storageClass(model.storageClass); owner(model.owner); restoreStatus(model.restoreStatus); } public final String getKey() { return key; } public final void setKey(String key) { this.key = key; } @Override public final Builder key(String key) { this.key = key; return this; } public final Instant getLastModified() { return lastModified; } public final void setLastModified(Instant lastModified) { this.lastModified = lastModified; } @Override public final Builder lastModified(Instant lastModified) { this.lastModified = lastModified; return this; } public final String getETag() { return eTag; } public final void setETag(String eTag) { this.eTag = eTag; } @Override public final Builder eTag(String eTag) { this.eTag = eTag; return this; } public final Collection getChecksumAlgorithm() { if (checksumAlgorithm instanceof SdkAutoConstructList) { return null; } return checksumAlgorithm; } public final void setChecksumAlgorithm(Collection checksumAlgorithm) { this.checksumAlgorithm = ChecksumAlgorithmListCopier.copy(checksumAlgorithm); } @Override public final Builder checksumAlgorithmWithStrings(Collection checksumAlgorithm) { this.checksumAlgorithm = ChecksumAlgorithmListCopier.copy(checksumAlgorithm); return this; } @Override @SafeVarargs public final Builder checksumAlgorithmWithStrings(String... checksumAlgorithm) { checksumAlgorithmWithStrings(Arrays.asList(checksumAlgorithm)); return this; } @Override public final Builder checksumAlgorithm(Collection checksumAlgorithm) { this.checksumAlgorithm = ChecksumAlgorithmListCopier.copyEnumToString(checksumAlgorithm); return this; } @Override @SafeVarargs public final Builder checksumAlgorithm(ChecksumAlgorithm... checksumAlgorithm) { checksumAlgorithm(Arrays.asList(checksumAlgorithm)); return this; } public final Long getSize() { return size; } public final void setSize(Long size) { this.size = size; } @Override public final Builder size(Long size) { this.size = size; return this; } public final String getStorageClass() { return storageClass; } public final void setStorageClass(String storageClass) { this.storageClass = storageClass; } @Override public final Builder storageClass(String storageClass) { this.storageClass = storageClass; return this; } @Override public final Builder storageClass(ObjectStorageClass storageClass) { this.storageClass(storageClass == null ? null : storageClass.toString()); return this; } public final Owner.Builder getOwner() { return owner != null ? owner.toBuilder() : null; } public final void setOwner(Owner.BuilderImpl owner) { this.owner = owner != null ? owner.build() : null; } @Override public final Builder owner(Owner owner) { this.owner = owner; return this; } public final RestoreStatus.Builder getRestoreStatus() { return restoreStatus != null ? restoreStatus.toBuilder() : null; } public final void setRestoreStatus(RestoreStatus.BuilderImpl restoreStatus) { this.restoreStatus = restoreStatus != null ? restoreStatus.build() : null; } @Override public final Builder restoreStatus(RestoreStatus restoreStatus) { this.restoreStatus = restoreStatus; return this; } @Override public S3Object build() { return new S3Object(this); } @Override public List> sdkFields() { return SDK_FIELDS; } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy