|
|
@ -57,6 +57,8 @@ public class S3ResourceRepository extends BaseResourceRepository { |
|
|
|
|
|
|
|
|
|
|
|
public static final String HTTP = "http:"; |
|
|
|
public static final String HTTP = "http:"; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private final boolean preserveMetadata; |
|
|
|
|
|
|
|
|
|
|
|
private final AmazonS3 s3; |
|
|
|
private final AmazonS3 s3; |
|
|
|
private final String bucket; |
|
|
|
private final String bucket; |
|
|
|
|
|
|
|
|
|
|
@ -83,6 +85,7 @@ public class S3ResourceRepository extends BaseResourceRepository { |
|
|
|
amazonS3ClientBuilder = amazonS3ClientBuilder.withClientConfiguration(clientConfiguration); |
|
|
|
amazonS3ClientBuilder = amazonS3ClientBuilder.withClientConfiguration(clientConfiguration); |
|
|
|
this.s3 = amazonS3ClientBuilder.build(); |
|
|
|
this.s3 = amazonS3ClientBuilder.build(); |
|
|
|
this.bucket = config.getBucket(); |
|
|
|
this.bucket = config.getBucket(); |
|
|
|
|
|
|
|
this.preserveMetadata = config.isPreserveMetadata(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
@ -158,19 +161,21 @@ public class S3ResourceRepository extends BaseResourceRepository { |
|
|
|
if (length > MULTIPART_UPLOAD_LIMIT) { |
|
|
|
if (length > MULTIPART_UPLOAD_LIMIT) { |
|
|
|
multipartUpload(path, new ByteArrayInputStream(data)); |
|
|
|
multipartUpload(path, new ByteArrayInputStream(data)); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
ObjectMetadata metadata; |
|
|
|
ObjectMetadata metadata = null; |
|
|
|
try { |
|
|
|
if (preserveMetadata) { |
|
|
|
metadata = s3.getObjectMetadata(bucket, path); |
|
|
|
try { |
|
|
|
} catch (Exception e) { |
|
|
|
metadata = s3.getObjectMetadata(bucket, path); |
|
|
|
|
|
|
|
} catch (Exception ignore) { |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
if (metadata == null) { |
|
|
|
metadata = new ObjectMetadata(); |
|
|
|
metadata = new ObjectMetadata(); |
|
|
|
String mimeType = URLConnection.guessContentTypeFromName(path); |
|
|
|
String mimeType = URLConnection.guessContentTypeFromName(path); |
|
|
|
if (mimeType != null) { |
|
|
|
if (mimeType != null) { |
|
|
|
metadata.setContentType(mimeType); |
|
|
|
metadata.setContentType(mimeType); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
if (metadata != null) { |
|
|
|
metadata.setContentLength(length); |
|
|
|
metadata.setContentLength(length); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
s3.putObject(bucket, path, new ByteArrayInputStream(data), metadata); |
|
|
|
s3.putObject(bucket, path, new ByteArrayInputStream(data), metadata); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -269,7 +274,7 @@ public class S3ResourceRepository extends BaseResourceRepository { |
|
|
|
try { |
|
|
|
try { |
|
|
|
s3.putObject(req); |
|
|
|
s3.putObject(req); |
|
|
|
} catch (Exception e) { |
|
|
|
} catch (Exception e) { |
|
|
|
LogKit.error("[S3] Failed to create parent path {}", path); |
|
|
|
LogKit.error("[S3] Failed to create path {}", path); |
|
|
|
return false; |
|
|
|
return false; |
|
|
|
} |
|
|
|
} |
|
|
|
return true; |
|
|
|
return true; |
|
|
|