mirror of https://github.com/apache/nifi.git
NIFI-9520 update AWS SDK and Kinesis Client Library versions; Allow PutS3Object to use all available StorageClasses
This closes #5632. Signed-off-by: Peter Turcsanyi <turcsanyi@apache.org>
This commit is contained in:
parent
dc42012755
commit
bd1b2b4d69
|
@ -35,10 +35,13 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Map.Entry;
|
import java.util.Map.Entry;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.TreeSet;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicLong;
|
import java.util.concurrent.atomic.AtomicLong;
|
||||||
import java.util.concurrent.locks.Lock;
|
import java.util.concurrent.locks.Lock;
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
import com.amazonaws.services.s3.model.ObjectTagging;
|
import com.amazonaws.services.s3.model.ObjectTagging;
|
||||||
import com.amazonaws.services.s3.model.Tag;
|
import com.amazonaws.services.s3.model.Tag;
|
||||||
|
@ -140,6 +143,10 @@ public class PutS3Object extends AbstractS3Processor {
|
||||||
public static final String CONTENT_DISPOSITION_INLINE = "inline";
|
public static final String CONTENT_DISPOSITION_INLINE = "inline";
|
||||||
public static final String CONTENT_DISPOSITION_ATTACHMENT = "attachment";
|
public static final String CONTENT_DISPOSITION_ATTACHMENT = "attachment";
|
||||||
|
|
||||||
|
private static final Set<String> STORAGE_CLASSES = Collections.unmodifiableSortedSet(new TreeSet<>(
|
||||||
|
Arrays.stream(StorageClass.values()).map(StorageClass::name).collect(Collectors.toSet())
|
||||||
|
));
|
||||||
|
|
||||||
public static final PropertyDescriptor EXPIRATION_RULE_ID = new PropertyDescriptor.Builder()
|
public static final PropertyDescriptor EXPIRATION_RULE_ID = new PropertyDescriptor.Builder()
|
||||||
.name("Expiration Time Rule")
|
.name("Expiration Time Rule")
|
||||||
.required(false)
|
.required(false)
|
||||||
|
@ -183,9 +190,7 @@ public class PutS3Object extends AbstractS3Processor {
|
||||||
public static final PropertyDescriptor STORAGE_CLASS = new PropertyDescriptor.Builder()
|
public static final PropertyDescriptor STORAGE_CLASS = new PropertyDescriptor.Builder()
|
||||||
.name("Storage Class")
|
.name("Storage Class")
|
||||||
.required(true)
|
.required(true)
|
||||||
.allowableValues(StorageClass.Standard.name(), StorageClass.IntelligentTiering.name(), StorageClass.StandardInfrequentAccess.name(),
|
.allowableValues(STORAGE_CLASSES)
|
||||||
StorageClass.OneZoneInfrequentAccess.name(), StorageClass.Glacier.name(), StorageClass.DeepArchive.name(),
|
|
||||||
StorageClass.ReducedRedundancy.name(), StorageClass.Outposts.name())
|
|
||||||
.defaultValue(StorageClass.Standard.name())
|
.defaultValue(StorageClass.Standard.name())
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -19,6 +19,8 @@ package org.apache.nifi.processors.aws.wag;
|
||||||
import com.amazonaws.ClientConfiguration;
|
import com.amazonaws.ClientConfiguration;
|
||||||
import com.amazonaws.http.AmazonHttpClient;
|
import com.amazonaws.http.AmazonHttpClient;
|
||||||
import com.amazonaws.http.apache.client.impl.SdkHttpClient;
|
import com.amazonaws.http.apache.client.impl.SdkHttpClient;
|
||||||
|
import com.amazonaws.internal.TokenBucket;
|
||||||
|
import com.amazonaws.metrics.RequestMetricCollector;
|
||||||
import org.apache.http.HttpResponse;
|
import org.apache.http.HttpResponse;
|
||||||
import org.apache.http.HttpVersion;
|
import org.apache.http.HttpVersion;
|
||||||
import org.apache.http.client.methods.HttpUriRequest;
|
import org.apache.http.client.methods.HttpUriRequest;
|
||||||
|
@ -36,6 +38,7 @@ import org.junit.Test;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
|
|
||||||
import java.io.ByteArrayInputStream;
|
import java.io.ByteArrayInputStream;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
@ -47,7 +50,6 @@ import static org.mockito.Mockito.times;
|
||||||
public class TestInvokeAmazonGatewayApiMock {
|
public class TestInvokeAmazonGatewayApiMock {
|
||||||
|
|
||||||
private TestRunner runner = null;
|
private TestRunner runner = null;
|
||||||
private InvokeAWSGatewayApi mockGetApi = null;
|
|
||||||
private SdkHttpClient mockSdkClient = null;
|
private SdkHttpClient mockSdkClient = null;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
|
@ -55,8 +57,8 @@ public class TestInvokeAmazonGatewayApiMock {
|
||||||
mockSdkClient = Mockito.mock(SdkHttpClient.class);
|
mockSdkClient = Mockito.mock(SdkHttpClient.class);
|
||||||
ClientConfiguration clientConfig = new ClientConfiguration();
|
ClientConfiguration clientConfig = new ClientConfiguration();
|
||||||
|
|
||||||
mockGetApi = new InvokeAWSGatewayApi(
|
InvokeAWSGatewayApi mockGetApi = new InvokeAWSGatewayApi(
|
||||||
new AmazonHttpClient(clientConfig, mockSdkClient, null));
|
new AmazonHttpClient(clientConfig, mockSdkClient, RequestMetricCollector.NONE, new TokenBucket()));
|
||||||
runner = TestRunners.newTestRunner(mockGetApi);
|
runner = TestRunners.newTestRunner(mockGetApi);
|
||||||
runner.setValidateExpressionUsage(false);
|
runner.setValidateExpressionUsage(false);
|
||||||
|
|
||||||
|
@ -133,7 +135,7 @@ public class TestInvokeAmazonGatewayApiMock {
|
||||||
final Map<String, String> attributes = new HashMap<>();
|
final Map<String, String> attributes = new HashMap<>();
|
||||||
attributes.put(CoreAttributes.MIME_TYPE.key(), "application/plain-text");
|
attributes.put(CoreAttributes.MIME_TYPE.key(), "application/plain-text");
|
||||||
attributes.put("Foo", "Bar");
|
attributes.put("Foo", "Bar");
|
||||||
runner.enqueue("Hello".getBytes("UTF-8"), attributes);
|
runner.enqueue("Hello".getBytes(StandardCharsets.UTF_8), attributes);
|
||||||
// execute
|
// execute
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
runner.run(1);
|
runner.run(1);
|
||||||
|
@ -184,7 +186,7 @@ public class TestInvokeAmazonGatewayApiMock {
|
||||||
final Map<String, String> attributes = new HashMap<>();
|
final Map<String, String> attributes = new HashMap<>();
|
||||||
attributes.put(CoreAttributes.MIME_TYPE.key(), "application/plain-text");
|
attributes.put(CoreAttributes.MIME_TYPE.key(), "application/plain-text");
|
||||||
attributes.put("Foo", "Bar");
|
attributes.put("Foo", "Bar");
|
||||||
runner.enqueue("Hello".getBytes("UTF-8"), attributes);
|
runner.enqueue("Hello".getBytes(StandardCharsets.UTF_8), attributes);
|
||||||
// execute
|
// execute
|
||||||
runner.assertValid();
|
runner.assertValid();
|
||||||
runner.run(1);
|
runner.run(1);
|
||||||
|
|
|
@ -27,9 +27,9 @@
|
||||||
|
|
||||||
<properties>
|
<properties>
|
||||||
<!-- keep AWS 1.x until NIFI-8287 -->
|
<!-- keep AWS 1.x until NIFI-8287 -->
|
||||||
<aws-java-sdk-version>1.11.1016</aws-java-sdk-version>
|
<aws-java-sdk-version>1.12.133</aws-java-sdk-version>
|
||||||
<!-- Do not upgrade to 1.14.x+ until https://github.com/awslabs/amazon-kinesis-client/issues/796 is fixed -->
|
<!-- keep KCL 1.x until NIFI-8531 (blocked by NIFI-8287) -->
|
||||||
<aws-kinesis-client-library-version>1.13.3</aws-kinesis-client-library-version>
|
<aws-kinesis-client-library-version>1.14.7</aws-kinesis-client-library-version>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
<dependencyManagement>
|
<dependencyManagement>
|
||||||
|
|
Loading…
Reference in New Issue