Skip to content

Commit bee04bf

Browse files
authored
Merge pull request #2737 from vlsi/lang3
chore: drop commons-lang3 dependency and replace its usages with core Java
2 parents ec62153 + f8d51f7 commit bee04bf

File tree

15 files changed

+91
-78
lines changed

15 files changed

+91
-78
lines changed

pom.xml

Lines changed: 5 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -178,6 +178,11 @@
178178
<artifactId>commons-io</artifactId>
179179
<version>${commons-io.version}</version>
180180
</dependency>
181+
<dependency>
182+
<groupId>org.apache.commons</groupId>
183+
<artifactId>commons-lang3</artifactId>
184+
<version>${commons-lang3.version}</version>
185+
</dependency>
181186
<dependency>
182187
<groupId>junit</groupId>
183188
<artifactId>junit</artifactId>
@@ -248,11 +253,6 @@
248253
<artifactId>commons-compress</artifactId>
249254
<version>${commons-compress.version}</version>
250255
</dependency>
251-
<dependency>
252-
<groupId>org.apache.commons</groupId>
253-
<artifactId>commons-lang3</artifactId>
254-
<version>${commons-lang3.version}</version>
255-
</dependency>
256256
<dependency>
257257
<groupId>commons-codec</groupId>
258258
<artifactId>commons-codec</artifactId>

server/pom.xml

Lines changed: 0 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -80,10 +80,6 @@
8080
<groupId>commons-io</groupId>
8181
<artifactId>commons-io</artifactId>
8282
</dependency>
83-
<dependency>
84-
<groupId>org.apache.commons</groupId>
85-
<artifactId>commons-lang3</artifactId>
86-
</dependency>
8783
<dependency>
8884
<groupId>org.jspecify</groupId>
8985
<artifactId>jspecify</artifactId>

server/src/main/java/com/adobe/testing/s3mock/KmsValidationFilter.java

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,6 @@
1818

1919
import static com.adobe.testing.s3mock.util.AwsHttpHeaders.X_AMZ_SERVER_SIDE_ENCRYPTION;
2020
import static com.adobe.testing.s3mock.util.AwsHttpHeaders.X_AMZ_SERVER_SIDE_ENCRYPTION_AWS_KMS_KEY_ID;
21-
import static org.apache.commons.lang3.StringUtils.isBlank;
2221
import static org.springframework.http.HttpHeaders.CONTENT_TYPE;
2322
import static org.springframework.http.HttpStatus.BAD_REQUEST;
2423
import static org.springframework.http.MediaType.APPLICATION_XML_VALUE;
@@ -70,7 +69,7 @@ protected void doFilterInternal(HttpServletRequest request,
7069
var encryptionKeyId = request.getHeader(X_AMZ_SERVER_SIDE_ENCRYPTION_AWS_KMS_KEY_ID);
7170

7271
if (AWS_KMS.equals(encryptionTypeHeader)
73-
&& !isBlank(encryptionKeyId)
72+
&& encryptionKeyId != null && !encryptionKeyId.isBlank()
7473
&& !keystore.validateKeyId(encryptionKeyId)) {
7574
LOG.info("Received invalid KMS key ID {}. Sending error response.", encryptionKeyId);
7675

@@ -90,7 +89,7 @@ protected void doFilterInternal(HttpServletRequest request,
9089

9190
response.flushBuffer();
9291
} else if (AWS_KMS.equals(encryptionTypeHeader)
93-
&& !isBlank(encryptionKeyId)
92+
&& encryptionKeyId != null && !encryptionKeyId.isBlank()
9493
&& keystore.validateKeyId(encryptionKeyId)) {
9594
LOG.info("Received valid KMS key ID {}.", encryptionKeyId);
9695
filterChain.doFilter(request, response);

server/src/main/java/com/adobe/testing/s3mock/MultipartController.java

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -242,7 +242,7 @@ public ResponseEntity<Void> uploadPart(
242242
ChecksumAlgorithm checksumAlgorithm = null;
243243
var algorithmFromSdk = checksumAlgorithmFromSdk(httpHeaders);
244244
if (algorithmFromSdk != null) {
245-
checksum = tempFileAndChecksum.getRight();
245+
checksum = tempFileAndChecksum.checksum();
246246
checksumAlgorithm = algorithmFromSdk;
247247
}
248248
var algorithmFromHeader = checksumAlgorithmFromHeader(httpHeaders);
@@ -251,7 +251,7 @@ public ResponseEntity<Void> uploadPart(
251251
checksumAlgorithm = algorithmFromHeader;
252252
}
253253

254-
var tempFile = tempFileAndChecksum.getLeft();
254+
var tempFile = tempFileAndChecksum.path();
255255
if (checksum != null) {
256256
multipartService.verifyChecksum(tempFile, checksum, checksumAlgorithm);
257257
}

server/src/main/java/com/adobe/testing/s3mock/ObjectController.java

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -209,7 +209,7 @@ public ResponseEntity<Void> postObject(
209209
var tempFileAndChecksum = objectService.toTempFile(file.getInputStream());
210210

211211
var bucket = bucketService.verifyBucketExists(bucketName);
212-
var tempFile = tempFileAndChecksum.getLeft();
212+
var tempFile = tempFileAndChecksum.path();
213213
objectService.verifyMd5(tempFile, contentMd5);
214214

215215
var owner = Owner.DEFAULT_OWNER;
@@ -825,7 +825,7 @@ public ResponseEntity<Void> putObject(
825825

826826
var algorithmFromSdk = checksumAlgorithmFromSdk(httpHeaders);
827827
if (algorithmFromSdk != null) {
828-
checksum = tempFileAndChecksum.getRight();
828+
checksum = tempFileAndChecksum.checksum();
829829
checksumAlgorithm = algorithmFromSdk;
830830
}
831831
var algorithmFromHeader = checksumAlgorithmFromHeader(httpHeaders);
@@ -835,7 +835,7 @@ public ResponseEntity<Void> putObject(
835835
}
836836
final var bucket = bucketService.verifyBucketExists(bucketName);
837837
objectService.verifyObjectMatching(bucketName, key.key(), match, noneMatch);
838-
var tempFile = tempFileAndChecksum.getLeft();
838+
var tempFile = tempFileAndChecksum.path();
839839
objectService.verifyMd5(tempFile, contentMd5);
840840
if (checksum != null) {
841841
objectService.verifyChecksum(tempFile, checksum, checksumAlgorithm);

server/src/main/java/com/adobe/testing/s3mock/TaggingHeaderConverter.java

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,6 @@
2323
import com.fasterxml.jackson.dataformat.xml.XmlMapper;
2424
import java.util.ArrayList;
2525
import java.util.List;
26-
import org.apache.commons.lang3.StringUtils;
2726
import org.jspecify.annotations.Nullable;
2827
import org.springframework.core.convert.converter.Converter;
2928

@@ -75,8 +74,11 @@ private List<Tag> convertTagXml(String source) {
7574

7675
@Nullable
7776
private static List<Tag> convertTagPairs(String source) {
77+
if (source.isEmpty()) {
78+
return null;
79+
}
7880
var tags = new ArrayList<Tag>();
79-
String[] tagPairs = StringUtils.split(source, '&');
81+
String[] tagPairs = source.split("&");
8082
for (String tag : tagPairs) {
8183
tags.add(new Tag(tag));
8284
}

server/src/main/java/com/adobe/testing/s3mock/service/BucketService.java

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,6 @@
3131
import static com.adobe.testing.s3mock.service.ServiceBase.mapContents;
3232
import static com.adobe.testing.s3mock.util.AwsHttpHeaders.X_AMZ_BUCKET_LOCATION_NAME;
3333
import static com.adobe.testing.s3mock.util.AwsHttpHeaders.X_AMZ_BUCKET_LOCATION_TYPE;
34-
import static org.apache.commons.lang3.StringUtils.isNotEmpty;
3534
import static software.amazon.awssdk.utils.http.SdkHttpUtils.urlEncodeIgnoreSlashes;
3635

3736
import com.adobe.testing.s3mock.dto.Bucket;
@@ -592,7 +591,7 @@ public void verifyMaxKeys(Integer maxKeys) {
592591
}
593592

594593
public void verifyEncodingType(String encodingType) {
595-
if (isNotEmpty(encodingType) && !"url".equals(encodingType)) {
594+
if (encodingType != null && !encodingType.isEmpty() && !"url".equals(encodingType)) {
596595
throw INVALID_REQUEST_ENCODING_TYPE;
597596
}
598597
}
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
/*
2+
* Copyright 2017-2025 Adobe.
3+
*
4+
* Licensed under the Apache License, Version 2.0 (the "License");
5+
* you may not use this file except in compliance with the License.
6+
* You may obtain a copy of the License at
7+
*
8+
* http://www.apache.org/licenses/LICENSE-2.0
9+
*
10+
* Unless required by applicable law or agreed to in writing, software
11+
* distributed under the License is distributed on an "AS IS" BASIS,
12+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13+
* See the License for the specific language governing permissions and
14+
* limitations under the License.
15+
*/
16+
17+
package com.adobe.testing.s3mock.service;
18+
19+
import java.nio.file.Path;
20+
import org.jspecify.annotations.Nullable;
21+
22+
public record FileChecksum(Path path, @Nullable String checksum) {
23+
}

server/src/main/java/com/adobe/testing/s3mock/service/ServiceBase.java

Lines changed: 7 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -21,8 +21,6 @@
2121
import static com.adobe.testing.s3mock.util.HeaderUtil.checksumAlgorithmFromSdk;
2222
import static com.adobe.testing.s3mock.util.HeaderUtil.isChunkedEncoding;
2323
import static com.adobe.testing.s3mock.util.HeaderUtil.isV4Signed;
24-
import static org.apache.commons.lang3.StringUtils.isEmpty;
25-
import static org.apache.commons.lang3.StringUtils.isNotEmpty;
2624

2725
import com.adobe.testing.s3mock.dto.ChecksumAlgorithm;
2826
import com.adobe.testing.s3mock.util.AbstractAwsInputStream;
@@ -37,7 +35,6 @@
3735
import java.util.List;
3836
import java.util.function.Function;
3937
import java.util.function.UnaryOperator;
40-
import org.apache.commons.lang3.tuple.Pair;
4138
import org.jspecify.annotations.Nullable;
4239
import org.slf4j.Logger;
4340
import org.slf4j.LoggerFactory;
@@ -52,7 +49,7 @@ public void verifyChecksum(Path path, String checksum, ChecksumAlgorithm checksu
5249
DigestUtil.verifyChecksum(checksum, checksumFor, checksumAlgorithm);
5350
}
5451

55-
public Pair<Path, @Nullable String> toTempFile(InputStream inputStream, HttpHeaders httpHeaders) {
52+
public FileChecksum toTempFile(InputStream inputStream, HttpHeaders httpHeaders) {
5653
try {
5754
var tempFile = Files.createTempFile("ObjectService", "toTempFile");
5855
try (var os = Files.newOutputStream(tempFile);
@@ -61,22 +58,22 @@ public void verifyChecksum(Path path, String checksum, ChecksumAlgorithm checksu
6158
ChecksumAlgorithm algorithmFromSdk = checksumAlgorithmFromSdk(httpHeaders);
6259
if (algorithmFromSdk != null
6360
&& wrappedStream instanceof AbstractAwsInputStream awsInputStream) {
64-
return Pair.of(tempFile, awsInputStream.getChecksum());
61+
return new FileChecksum(tempFile, awsInputStream.getChecksum());
6562
}
66-
return Pair.of(tempFile, null);
63+
return new FileChecksum(tempFile, null);
6764
}
6865
} catch (IOException e) {
6966
LOG.error("Error reading from InputStream", e);
7067
throw BAD_REQUEST_CONTENT;
7168
}
7269
}
7370

74-
public Pair<Path, @Nullable String> toTempFile(InputStream inputStream) {
71+
public FileChecksum toTempFile(InputStream inputStream) {
7572
try {
7673
var tempFile = Files.createTempFile("ObjectService", "toTempFile");
7774
try (var os = Files.newOutputStream(tempFile)) {
7875
inputStream.transferTo(os);
79-
return Pair.of(tempFile, null);
76+
return new FileChecksum(tempFile, null);
8077
}
8178
} catch (IOException e) {
8279
LOG.error("Error reading from InputStream", e);
@@ -99,7 +96,7 @@ static <T> List<T> filterBy(
9996
Function<T, String> function,
10097
@Nullable String compareTo
10198
) {
102-
if (isNotEmpty(compareTo)) {
99+
if (compareTo != null && !compareTo.isEmpty()) {
103100
return contents
104101
.stream()
105102
.filter(content -> function.apply(content).compareTo(compareTo) > 0)
@@ -161,7 +158,7 @@ static <T> List<String> collapseCommonPrefixes(
161158
Function<T, String> function
162159
) {
163160
var commonPrefixes = new ArrayList<String>();
164-
if (isEmpty(delimiter)) {
161+
if (delimiter == null || delimiter.isEmpty()) {
165162
return commonPrefixes;
166163
}
167164

server/src/main/java/com/adobe/testing/s3mock/store/MultipartStore.java

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,6 @@
2222
import static java.nio.file.Files.newDirectoryStream;
2323
import static java.nio.file.Files.newOutputStream;
2424
import static org.apache.commons.io.FileUtils.openInputStream;
25-
import static org.apache.commons.lang3.StringUtils.isBlank;
2625

2726
import com.adobe.testing.s3mock.S3Exception;
2827
import com.adobe.testing.s3mock.dto.ChecksumAlgorithm;
@@ -55,7 +54,6 @@
5554
import java.util.stream.StreamSupport;
5655
import org.apache.commons.io.FileUtils;
5756
import org.apache.commons.io.input.BoundedInputStream;
58-
import org.apache.commons.lang3.stream.Streams;
5957
import org.jspecify.annotations.Nullable;
6058
import org.slf4j.Logger;
6159
import org.slf4j.LoggerFactory;
@@ -135,8 +133,7 @@ public List<MultipartUpload> listMultipartUploads(BucketMetadata bucketMetadata,
135133
return Collections.emptyList();
136134
}
137135
try (var paths = Files.newDirectoryStream(multipartsFolder)) {
138-
return Streams
139-
.of(paths)
136+
return StreamSupport.stream(paths.spliterator(), false)
140137
.map(
141138
path -> {
142139
var fileName = path.getFileName().toString();
@@ -146,7 +143,7 @@ public List<MultipartUpload> listMultipartUploads(BucketMetadata bucketMetadata,
146143
.filter(Objects::nonNull)
147144
.filter(uploadMetadata -> !uploadMetadata.completed())
148145
.map(MultipartUploadInfo::upload)
149-
.filter(upload -> isBlank(prefix) || upload.key().startsWith(prefix))
146+
.filter(upload -> prefix == null || prefix.isBlank() || upload.key().startsWith(prefix))
150147
.toList();
151148
} catch (IOException e) {
152149
throw new IllegalStateException("Could not load buckets from data directory ", e);

0 commit comments

Comments
 (0)