@Override public void putObject(String bucketName, String key, Range range, Object content) { putObject(new PutObjectRequest(bucketName, key, content).withRange(range)); }
public PutObjectRequest withAcl(AccessControlList acl) { setAcl(acl); return this; }
@Override public PutObjectResult putObject(PutObjectRequest request) { if (request.getRange() != null) throw new UnsupportedOperationException(PARTIAL_UPDATE_MSG); // make user metadata available as a request property if (request.getObjectMetadata() == null) request.setObjectMetadata(new S3ObjectMetadata()); Map<String, String> userMeta = request.getObjectMetadata().getUserMetadata(); request.property(RestUtil.PROPERTY_USER_METADATA, userMeta); // activate codec filter request.property(RestUtil.PROPERTY_ENCODE_ENTITY, Boolean.TRUE); // write data PutObjectResult result = super.putObject(request); // encryption filter will modify userMeta with encryption metadata *after* the object is transferred // we must send a separate metadata update or the object will be unreadable // TODO: should this be atomic? how do we handle rollback? CopyObjectRequest metadataUpdate = new CopyObjectRequest(request.getBucketName(), request.getKey(), request.getBucketName(), request.getKey()).withAcl(request.getAcl()) .withObjectMetadata(request.getObjectMetadata()).withIfMatch(result.getETag()); return super.copyObject(metadataUpdate); }
public void doSinglePut() { configure(); InputStream is = null; try { is = file != null ? new FileInputStream(file) : stream; is = new ProgressInputStream(is, this); PutObjectRequest putRequest = new PutObjectRequest(bucket, key, is); putRequest.setObjectMetadata(objectMetadata); putRequest.setAcl(acl); putRequest.setCannedAcl(cannedAcl); PutObjectResult result = s3Client.putObject(putRequest); eTag = result.getETag(); } catch (IOException e) { throw new RuntimeException("Error opening file", e); } finally { // make sure we close the input stream if necessary if (is != null && closeStream) { try { is.close(); } catch (Throwable t) { log.warn("could not close stream", t); } } } }
metadata.setContentLength((long) 0); PutObjectRequest request = new PutObjectRequest(config.getBucket(), config.getRoot() + streamSegmentName, null); request.setAcl(acl); request.setIfNoneMatch("*");
om.setContentEncoding(null); final PutObjectRequest req = new PutObjectRequest(config.getBucketName(), targetKey, data).withObjectMetadata(om); if (options.isSyncAcl()) req.setAcl(acl);
@Override public void putObject(String bucketName, String key, Object content, String contentType) { S3ObjectMetadata metadata = new S3ObjectMetadata().withContentType(contentType); putObject(new PutObjectRequest(bucketName, key, content).withObjectMetadata(metadata)); }
@Synchronized @Override public void putObject(String bucketName, String key, Range range, Object content) { byte[] totalByes = new byte[Math.toIntExact(range.getLast() + 1)]; try { if (range.getFirst() != 0) { int bytesRead = client.getObject(bucketName, key).getObject().read(totalByes, 0, Math.toIntExact(range.getFirst())); if (bytesRead != range.getFirst()) { throw new IllegalStateException("Unable to read from the object " + key); } } int bytesRead = ((InputStream) content).read(totalByes, Math.toIntExact(range.getFirst()), Math.toIntExact(range.getLast() + 1 - range.getFirst())); if (bytesRead != range.getLast() + 1 - range.getFirst()) { throw new IllegalStateException("Not able to read from input stream."); } client.putObject(new PutObjectRequest(bucketName, key, (Object) new ByteArrayInputStream(totalByes))); aclMap.put(key, aclMap.get(key).withSize(range.getLast() - 1)); } catch (IOException e) { throw new S3Exception("NoObject", HttpStatus.SC_NOT_FOUND, "NoSuchKey", key); } }
public PutObjectRequest withObjectMetadata(S3ObjectMetadata objectMetadata) { setObjectMetadata(objectMetadata); return this; }
public PutObjectRequest withIfNoneMatch(String ifNoneMatch) { setIfNoneMatch(ifNoneMatch); return this; }
PutObjectRequest request = new PutObjectRequest(bucket, key, null); request.setObjectMetadata(objectMetadata); request.setAcl(acl); request.setCannedAcl(cannedAcl); s3Client.putObject(request);
@Override public PutObjectResult putObject(PutObjectRequest request) { S3ObjectMetadata metadata = request.getObjectMetadata(); if (request.getObjectMetadata() != null) { request.setObjectMetadata(null); } PutObjectResult retVal = client.putObject(request); if (request.getAcl() != null) { long size = 0; if (request.getRange() != null) { size = request.getRange().getLast() - 1; } aclMap.put(request.getKey(), new AclSize(request.getAcl(), size)); } return retVal; }
@Override public long appendObject(String bucketName, String key, Object content) { return putObject(new PutObjectRequest(bucketName, key, content) .withRange(Range.fromOffset(-1))).getAppendOffset(); }
@Override public PutObjectResult putObject(PutObjectRequest request) { if (request.getObjectMetadata() != null) { request.setObjectMetadata(null); } try { Path path = Paths.get(this.baseDir, request.getBucketName(), request.getKey()); Path parent = path.getParent(); assert parent != null; Files.createDirectories(parent); Files.createFile(path); } catch (IOException e) { throw new S3Exception(e.getMessage(), 0, e); } PutObjectResult retVal = new PutObjectResult(); if (request.getAcl() != null) { long size = 0; if (request.getRange() != null) { size = request.getRange().getLast() + 1; } aclMap.putIfAbsent(request.getKey(), new AclSize(request.getAcl(), size)); } return retVal; }
@Override public String call() throws Exception { Range range = Range.fromOffsetLength(offset, length); InputStream is = file != null ? new FileInputStream(file) : stream; is = new ProgressInputStream(is, LargeFileUploader.this); SizedInputStream segmentStream = file != null ? new InputStreamSegment(is, offset, length) : new SizedInputStream(is, length); PutObjectRequest request = new PutObjectRequest(bucket, key, segmentStream).withRange(range); return s3Client.putObject(request).getETag(); } }