org.apache.iceberg.aws.s3.S3RequestUtil Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of iceberg-aws Show documentation
Show all versions of iceberg-aws Show documentation
A table format for huge analytic datasets
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License 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 org.apache.iceberg.aws.s3;
import java.util.Locale;
import java.util.function.Function;
import software.amazon.awssdk.services.s3.model.CreateMultipartUploadRequest;
import software.amazon.awssdk.services.s3.model.GetObjectRequest;
import software.amazon.awssdk.services.s3.model.HeadObjectRequest;
import software.amazon.awssdk.services.s3.model.ObjectCannedACL;
import software.amazon.awssdk.services.s3.model.PutObjectRequest;
import software.amazon.awssdk.services.s3.model.S3Request;
import software.amazon.awssdk.services.s3.model.ServerSideEncryption;
import software.amazon.awssdk.services.s3.model.UploadPartRequest;
@SuppressWarnings("UnnecessaryLambda")
public class S3RequestUtil {
private static final Function NULL_SSE_SETTER =
sse -> null;
private static final Function NULL_STRING_SETTER = s -> null;
private S3RequestUtil() {}
static void configureEncryption(
S3FileIOProperties s3FileIOProperties, PutObjectRequest.Builder requestBuilder) {
configureEncryption(
s3FileIOProperties,
requestBuilder::serverSideEncryption,
requestBuilder::ssekmsKeyId,
requestBuilder::sseCustomerAlgorithm,
requestBuilder::sseCustomerKey,
requestBuilder::sseCustomerKeyMD5);
}
static void configureEncryption(
S3FileIOProperties s3FileIOProperties, CreateMultipartUploadRequest.Builder requestBuilder) {
configureEncryption(
s3FileIOProperties,
requestBuilder::serverSideEncryption,
requestBuilder::ssekmsKeyId,
requestBuilder::sseCustomerAlgorithm,
requestBuilder::sseCustomerKey,
requestBuilder::sseCustomerKeyMD5);
}
static void configureEncryption(
S3FileIOProperties s3FileIOProperties, UploadPartRequest.Builder requestBuilder) {
configureEncryption(
s3FileIOProperties,
NULL_SSE_SETTER,
NULL_STRING_SETTER,
requestBuilder::sseCustomerAlgorithm,
requestBuilder::sseCustomerKey,
requestBuilder::sseCustomerKeyMD5);
}
static void configureEncryption(
S3FileIOProperties s3FileIOProperties, GetObjectRequest.Builder requestBuilder) {
configureEncryption(
s3FileIOProperties,
NULL_SSE_SETTER,
NULL_STRING_SETTER,
requestBuilder::sseCustomerAlgorithm,
requestBuilder::sseCustomerKey,
requestBuilder::sseCustomerKeyMD5);
}
static void configureEncryption(
S3FileIOProperties s3FileIOProperties, HeadObjectRequest.Builder requestBuilder) {
configureEncryption(
s3FileIOProperties,
NULL_SSE_SETTER,
NULL_STRING_SETTER,
requestBuilder::sseCustomerAlgorithm,
requestBuilder::sseCustomerKey,
requestBuilder::sseCustomerKeyMD5);
}
@SuppressWarnings("ReturnValueIgnored")
static void configureEncryption(
S3FileIOProperties s3FileIOProperties,
Function encryptionSetter,
Function kmsKeySetter,
Function customAlgorithmSetter,
Function customKeySetter,
Function customMd5Setter) {
switch (s3FileIOProperties.sseType().toLowerCase(Locale.ENGLISH)) {
case S3FileIOProperties.SSE_TYPE_NONE:
break;
case S3FileIOProperties.SSE_TYPE_KMS:
encryptionSetter.apply(ServerSideEncryption.AWS_KMS);
kmsKeySetter.apply(s3FileIOProperties.sseKey());
break;
case S3FileIOProperties.DSSE_TYPE_KMS:
encryptionSetter.apply(ServerSideEncryption.AWS_KMS_DSSE);
kmsKeySetter.apply(s3FileIOProperties.sseKey());
break;
case S3FileIOProperties.SSE_TYPE_S3:
encryptionSetter.apply(ServerSideEncryption.AES256);
break;
case S3FileIOProperties.SSE_TYPE_CUSTOM:
// setters for SSE-C exist for all request builders, no need to check null
customAlgorithmSetter.apply(ServerSideEncryption.AES256.name());
customKeySetter.apply(s3FileIOProperties.sseKey());
customMd5Setter.apply(s3FileIOProperties.sseMd5());
break;
default:
throw new IllegalArgumentException(
"Cannot support given S3 encryption type: " + s3FileIOProperties.sseType());
}
}
static void configurePermission(
S3FileIOProperties s3FileIOProperties, PutObjectRequest.Builder requestBuilder) {
configurePermission(s3FileIOProperties, requestBuilder::acl);
}
static void configurePermission(
S3FileIOProperties s3FileIOProperties, CreateMultipartUploadRequest.Builder requestBuilder) {
configurePermission(s3FileIOProperties, requestBuilder::acl);
}
@SuppressWarnings("ReturnValueIgnored")
static void configurePermission(
S3FileIOProperties s3FileIOProperties,
Function aclSetter) {
aclSetter.apply(s3FileIOProperties.acl());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy