All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.obs.services.model.UploadPartRequest Maven / Gradle / Ivy

/**
 * Copyright 2019 Huawei Technologies Co.,Ltd.
 * Licensed 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 com.obs.services.model; import java.io.File; import java.io.InputStream; import com.obs.services.internal.ObsConstraint; import com.obs.services.internal.ProgressManager; /** * Parameters in a part upload request * */ public class UploadPartRequest extends AbstractMultipartRequest { { httpMethod = HttpMethodEnum.PUT; } private int partNumber; private Long partSize; private long offset; private SseCHeader sseCHeader; private String contentMd5; private boolean attachMd5 = false; private File file; private InputStream input; private boolean autoClose = true; private ProgressListener progressListener; private long progressInterval = ObsConstraint.DEFAULT_PROGRESS_INTERVAL; private boolean needCalculateCRC64 = false; private ProgressManager progressManager; public UploadPartRequest() { } /** * Constructor * * @param bucketName * Name of the bucket to which the multipart upload belongs * @param objectKey * Name of the object involved in the multipart upload */ public UploadPartRequest(String bucketName, String objectKey) { this.bucketName = bucketName; this.objectKey = objectKey; } /** * Constructor * * @param bucketName * Name of the bucket to which the multipart upload belongs * @param objectKey * Name of the object involved in the multipart upload * @param fileName * File name to be uploaded */ public UploadPartRequest(String bucketName, String objectKey, String fileName) { this.bucketName = bucketName; this.objectKey = objectKey; this.file = new File(fileName); } /** * Constructor * * @param bucketName * Name of the bucket to which the multipart upload belongs * @param objectKey * Name of the object involved in the multipart upload * @param file * File to be uploaded */ public UploadPartRequest(String bucketName, String objectKey, File file) { this.bucketName = bucketName; this.objectKey = objectKey; this.file = file; } /** * Constructor * * @param bucketName * Name of the bucket to which the multipart upload belongs * @param objectKey * Name of the object involved in the multipart upload * @param partSize * Part size (in bytes) * @param input * Data stream to be uploaded */ public UploadPartRequest(String bucketName, String objectKey, Long partSize, InputStream input) { this.bucketName = bucketName; this.objectKey = objectKey; this.partSize = partSize; this.input = input; } /** * Constructor * * @param bucketName * Name of the bucket to which the multipart upload belongs * @param objectKey * Name of the object involved in the multipart upload * @param partSize * Part size (in bytes) * @param offset * Offset of the part in the file. The default value is 0 (in * bytes). * @param file * File to be uploaded */ public UploadPartRequest(String bucketName, String objectKey, Long partSize, long offset, File file) { this.bucketName = bucketName; this.objectKey = objectKey; this.partSize = partSize; this.offset = offset; this.file = file; } /** * Obtain SSE-C encryption headers. * * @return SSE-C encryption headers */ public SseCHeader getSseCHeader() { return sseCHeader; } /** * Set SSE-C encryption headers. * * @param sseCHeader * SSE-C encryption headers */ public void setSseCHeader(SseCHeader sseCHeader) { this.sseCHeader = sseCHeader; } /** * Obtain the offset of the part in the file. The default value is 0 (in * bytes). * * @return Offset of the part in the file */ public long getOffset() { return offset; } /** * Set the start position of the to-be-uploaded content in the file. This * parameter is effective only when the path where the file is to be * uploaded is configured. The unit is byte and the default value is 0. * * @param offset * Offset of the part in the file */ public void setOffset(long offset) { this.offset = offset; } /** * Obtain the part number. * * @return Part number */ public int getPartNumber() { return partNumber; } /** * Set the part number. * * @param partNumber * Part number */ public void setPartNumber(int partNumber) { this.partNumber = partNumber; } /** * Set the part size (in bytes). * * @param partSize * Part size */ public void setPartSize(Long partSize) { this.partSize = partSize; } /** * Obtain the part size, in bytes. * * @return Part size */ public Long getPartSize() { return partSize; } /** * Obtain the file to be uploaded, which cannot be used with the data * stream. * * @return File to be uploaded */ public File getFile() { return file; } /** * Set the file to be uploaded, which cannot be used with the data stream. * * @param file * File to be uploaded */ public void setFile(File file) { this.file = file; this.input = null; } /** * Obtain the data stream to be uploaded, which cannot be used with the file * to be uploaded. * * @return Data stream to be uploaded */ public InputStream getInput() { return input; } /** * Set the data stream to be uploaded, which cannot be used with the file to * be uploaded. * * @param input * Data stream to be uploaded */ public void setInput(InputStream input) { this.input = input; this.file = null; } /** * Check whether the MD5 value of the data to be uploaded will be * automatically calculated. If the MD5 value is set, this parameter can be * ignored. * * @return Identifier specifying whether to automatically calculate the MD5 * value of the data to be uploaded */ public boolean isAttachMd5() { return attachMd5; } /** * Specify whether to automatically calculate the MD5 value of the data to * be uploaded. If the MD5 value is set, this parameter can be ignored. * * @param attachMd5 * Identifier specifying whether to automatically calculate the * MD5 value of the data to be uploaded */ public void setAttachMd5(boolean attachMd5) { this.attachMd5 = attachMd5; } /** * Set the MD5 value of the data to be uploaded. * * @return MD5 value of the data to be uploaded */ public String getContentMd5() { return contentMd5; } /** * Obtain the MD5 value of the data to be uploaded. * * @param contentMd5 * MD5 value of the data to be uploaded */ public void setContentMd5(String contentMd5) { this.contentMd5 = contentMd5; } /** * Check whether the input stream will be automatically closed. The default * value is "true". * * @return Identifier specifying whether the input stream will be * automatically closed */ public boolean isAutoClose() { return autoClose; } /** * Specify whether to automatically close the input stream. The default * value is "true". * * @param autoClose * Identifier specifying whether the input stream will be * automatically closed */ public void setAutoClose(boolean autoClose) { this.autoClose = autoClose; } /** * Obtain the data transfer listener. * * @return Data transfer listener */ public ProgressListener getProgressListener() { return progressListener; } /** * Set the data transfer listener. * * @param progressListener * Data transfer listener */ public void setProgressListener(ProgressListener progressListener) { this.progressListener = progressListener; } /** * Obtain the callback threshold of the data transfer listener. The default * value is 100 KB. * * @return Callback threshold of the data transfer listener */ public long getProgressInterval() { return progressInterval; } /** * Set the callback threshold of the data transfer listener. The default * value is 100 KB. * * @param progressInterval * Callback threshold of the data transfer listener */ public void setProgressInterval(long progressInterval) { this.progressInterval = progressInterval; } /** * @return Whether you need sdk to calculate CRC64 value and add it to header */ public boolean isNeedCalculateCRC64() { return needCalculateCRC64; } /** * @param needCalculateCRC64 * Whether you need sdk to calculate CRC64 value and add it to header */ public void setNeedCalculateCRC64(boolean needCalculateCRC64) { this.needCalculateCRC64 = needCalculateCRC64; } /** * @return progressManager * get progressManager which receives progress, progressManager priority is higher than ProgressListener */ public ProgressManager getProgressManager() { return progressManager; } /** * @param progressManager * set progressManager to receive progress, progressManager priority is higher than ProgressListener */ public void setProgressManager(ProgressManager progressManager) { this.progressManager = progressManager; } @Override public String toString() { return "UploadPartRequest [uploadId=" + this.getUploadId() + ", bucketName=" + this.getBucketName() + ", objectKey=" + this.getObjectKey() + ", partNumber=" + partNumber + ", partSize=" + partSize + ", offset=" + offset + ", sseCHeader=" + sseCHeader + ", contentMd5=" + contentMd5 + ", attachMd5=" + attachMd5 + ", file=" + file + ", input=" + input + "]"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy