org.apache.inlong.sort.filesystem.shaded.com.amazonaws.services.s3.transfer.ObjectTaggingProvider Maven / Gradle / Ivy
/*
* Copyright 2010-2022 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 com.amazonaws.services.s3.transfer;
import com.amazonaws.services.s3.model.ObjectTagging;
import java.io.File;
import java.util.List;
/**
* This is the callback interface which is used by {@link TransferManager#uploadDirectory(String,
* String, File, boolean, ObjectMetadataProvider, ObjectTaggingProvider)} and
* {@link TransferManager#uploadFileList(String, String, File, List, ObjectMetadataProvider,
* ObjectTaggingProvider)}. The callback is invoked for each file that is uploaded by
* TransferManager
and given an opportunity to specify the tags for each file.
*/
public interface ObjectTaggingProvider {
/**
* This method is called for every file that is uploaded by TransferManager
* and gives an opportunity to specify the tags for the file.
*
* @param uploadContext
* The context object providing information about the file being uploaded.
*
* @return ObjectTagging
* The ObjectTagging to be used in the PutObjectRequest withTagging call.
*
*/
public ObjectTagging provideObjectTags(UploadContext uploadContext);
}