-
Notifications
You must be signed in to change notification settings - Fork 116
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Resolved issues: 1. PutObject、Getobject、GetObjectMetadata、UploadPart、AppendObject、CopyObject、CopyPart、CompeleMultiUploadPart now supports crc64 checksum. 2. UploadFile can be cancelled and aborted now. 3. Allow you set okhttp's EventListenerFactory to profile each stage of a http request,not set by default. 4. Fixed the issue that client encryption is available only in obs protocal and add some check logic when encryption algrithm is null. 5. Optimised the logic of set progress listener when using uploadFile. 6. Optimised some log info format. 7. Added some logic to compatible with Android 7.0 when using DateTimeFormatter. Third-party dependence: 1. Replace okio 3.8.0 with okio 3.6.0 2. Replace log4j-core 2.20.0 with log4j-core 2.18.0 3. Replace jackson-core 2.15.4 with jackson-core 2.15.2 4. Replace jackson-databind 2.15.4 with jackson-databind 2.15.2 5. Replace jackson-annotations 2.15.4 with jackson-annotations 2.15.2 6. Replace log4j-api 2.20.0 with log4j-api 2.18.0
- Loading branch information
Showing
56 changed files
with
2,402 additions
and
153 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
package com.obs.services; | ||
|
||
import com.obs.services.internal.task.UploadFileTask; | ||
import com.obs.services.model.CompleteMultipartUploadResult; | ||
import com.obs.services.model.TaskCallback; | ||
import com.obs.services.model.UploadFileRequest; | ||
|
||
public interface IObsClientAsync { | ||
UploadFileTask uploadFileAsync( | ||
UploadFileRequest uploadFileRequest, | ||
TaskCallback<CompleteMultipartUploadResult, UploadFileRequest> completeCallback); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,159 @@ | ||
package com.obs.services; | ||
|
||
import com.obs.log.ILogger; | ||
import com.obs.log.LoggerBuilder; | ||
import com.obs.services.internal.task.UploadFileTask; | ||
import com.obs.services.model.CompleteMultipartUploadResult; | ||
import com.obs.services.model.TaskCallback; | ||
import com.obs.services.model.UploadFileRequest; | ||
|
||
import java.io.IOException; | ||
import java.util.concurrent.Callable; | ||
import java.util.concurrent.ExecutorService; | ||
import java.util.concurrent.Executors; | ||
import java.util.concurrent.Future; | ||
|
||
public class ObsClientAsync extends ObsClient implements IObsClientAsync { | ||
/** | ||
* Constructor | ||
* | ||
* @param endPoint OBS endpoint | ||
*/ | ||
public ObsClientAsync(String endPoint) { | ||
super(endPoint); | ||
} | ||
|
||
/** | ||
* Constructor | ||
* | ||
* @param config Configuration parameters of ObsClient | ||
*/ | ||
public ObsClientAsync(ObsConfiguration config) { | ||
super(config); | ||
} | ||
|
||
/** | ||
* Constructor | ||
* | ||
* @param accessKey AK in the access key | ||
* @param secretKey SK in the access key | ||
* @param endPoint OBS endpoint | ||
*/ | ||
public ObsClientAsync(String accessKey, String secretKey, String endPoint) { | ||
super(accessKey, secretKey, endPoint); | ||
} | ||
|
||
/** | ||
* Constructor | ||
* | ||
* @param accessKey AK in the access key | ||
* @param secretKey SK in the access key | ||
* @param config Configuration parameters of ObsClient | ||
*/ | ||
public ObsClientAsync(String accessKey, String secretKey, ObsConfiguration config) { | ||
super(accessKey, secretKey, config); | ||
} | ||
|
||
/** | ||
* Constructor | ||
* | ||
* @param accessKey AK in the temporary access key | ||
* @param secretKey SK in the temporary access key | ||
* @param securityToken Security token | ||
* @param endPoint OBS endpoint | ||
*/ | ||
public ObsClientAsync(String accessKey, String secretKey, String securityToken, String endPoint) { | ||
super(accessKey, secretKey, securityToken, endPoint); | ||
} | ||
|
||
/** | ||
* Constructor | ||
* | ||
* @param accessKey AK in the temporary access key | ||
* @param secretKey SK in the temporary access key | ||
* @param securityToken Security token | ||
* @param config Configuration parameters of ObsClient | ||
*/ | ||
public ObsClientAsync(String accessKey, String secretKey, String securityToken, ObsConfiguration config) { | ||
super(accessKey, secretKey, securityToken, config); | ||
} | ||
|
||
public ObsClientAsync(IObsCredentialsProvider provider, String endPoint) { | ||
super(provider, endPoint); | ||
} | ||
|
||
public ObsClientAsync(IObsCredentialsProvider provider, ObsConfiguration config) { | ||
super(provider, config); | ||
} | ||
|
||
private static final ILogger log = LoggerBuilder.getLogger(ObsClientAsync.class); | ||
private ExecutorService asyncClientExecutorService; | ||
private static final int DEFAULT_CLIENT_EXECUTOR_SERVICE_SIZE = 128; | ||
|
||
private int queryInterval = 1000; | ||
|
||
@Override | ||
public void close() throws IOException { | ||
log.warn("ObsClientAsync closing"); | ||
try { | ||
// finishing all task | ||
getExecutorService().shutdown(); | ||
log.warn("ObsClientAsync closed"); | ||
} catch (Exception e) { | ||
log.warn("ObsClientAsync close failed, detail:", e); | ||
} | ||
super.close(); | ||
} | ||
|
||
private static final String ASYNC_CLIENT_EXECUTOR_SERVICE_THREAD_NAME = "async-client-thread"; | ||
protected ExecutorService getExecutorService() { | ||
if (asyncClientExecutorService == null) { | ||
asyncClientExecutorService = Executors.newFixedThreadPool(DEFAULT_CLIENT_EXECUTOR_SERVICE_SIZE, | ||
r -> new Thread(r, ASYNC_CLIENT_EXECUTOR_SERVICE_THREAD_NAME)); | ||
} | ||
return asyncClientExecutorService; | ||
} | ||
|
||
public void setExecutorService(ExecutorService service) { | ||
if (asyncClientExecutorService != null) { // wait for all task finish | ||
asyncClientExecutorService.shutdown(); | ||
while (!asyncClientExecutorService.isTerminated()) { | ||
try { | ||
Thread.sleep(queryInterval); | ||
} catch (InterruptedException e) { | ||
log.warn("ObsClientAsync setExecutorService failed, detail:", e); | ||
} | ||
} | ||
} | ||
asyncClientExecutorService = service; | ||
} | ||
|
||
public int getQueryInterval() { | ||
return queryInterval; | ||
} | ||
|
||
public void setQueryInterval(int queryInterval) { | ||
this.queryInterval = queryInterval; | ||
} | ||
|
||
/** | ||
* @param uploadFileRequest | ||
* @param completeCallback | ||
* @return | ||
*/ | ||
@Override | ||
public UploadFileTask uploadFileAsync( | ||
UploadFileRequest uploadFileRequest, | ||
TaskCallback<CompleteMultipartUploadResult, UploadFileRequest> completeCallback) { | ||
log.debug("start uploadFileAsync"); | ||
if (uploadFileRequest.getCancelHandler() != null) { | ||
uploadFileRequest.getCancelHandler().resetCancelStatus(); | ||
} | ||
UploadFileTask uploadFileTask = | ||
new UploadFileTask(this, uploadFileRequest.getBucketName(), uploadFileRequest, completeCallback); | ||
Future<?> future = getExecutorService().submit((Callable<?>) uploadFileTask); | ||
|
||
uploadFileTask.setResultFuture(future); | ||
return uploadFileTask; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.