// 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. #ifndef OBSListMultipartUploadsModel_h #define OBSListMultipartUploadsModel_h #import "OBSBaseModel.h" #import "OBSBaseNetworking.h" #import "OBSClient.h" #import "OBSServiceBaseModel.h" #import "OBSServiceCommonEntities.h" #pragma mark - entities @interface OBSUpload: OBSBaseEntity @property (nonatomic, strong, nonnull) NSString *objectKey; @property (nonatomic, strong, nonnull) NSString *uploadID; @property (nonatomic, strong, nonnull) OBSUser *initiator; @property (nonatomic, strong, nonnull) OBSUser *owner; @property (nonatomic, assign) OBSStorageClass storageClass; @property (nonatomic, strong, nonnull) NSDate *initiatedTime; @end #pragma mark - request /** 列举多段上传任务 */ @protocol OBSListMultipartUploadsProtocol @required /** 桶名 */ @property (nonatomic, strong, nonnull) NSString *bucketName; /** 分组标识 */ @property (nonatomic, strong, nonnull) NSString *delimiter; /** 响应对象名以prefix开始的任务信息 */ @property (nonatomic, strong, nonnull) NSString *prefix; /** 列举最大的上传任务数目 */ @property (nonatomic, strong, nonnull) NSNumber *maxUploads; /** 列举指定的keyMarker之后的多段任务 */ @property (nonatomic, strong, nonnull) NSString *keyMarker; /** 只有和keyMarker一起使用才有意义,列举时返回指定的keyMarker的uploadIDMarker之后的多段任务 */ @property (nonatomic, strong, nonnull) NSString *uploadIDMarker; @end /** 列举多段上传任务request */ @interface OBSListMultipartUploadsRequest: OBSBaseRequest /** 桶名 */ @property (nonatomic, strong, nonnull) NSString *bucketName; /** 分组标识 */ @property (nonatomic, strong, nonnull) NSString *delimiter; /** 响应对象名以prefix开始的任务信息 */ @property (nonatomic, strong, nonnull) NSString *prefix; /** 列举的多段任务的最大条目 */ @property (nonatomic, strong, nonnull) NSNumber *maxUploads; /** 列举指定的keyMarker之后的多段任务 */ @property (nonatomic, strong, nonnull) NSString *keyMarker; /** 只有和keyMarker一起使用才有意义,列举时返回指定的keyMarker的uploadIDMarker之后的多段任务 */ @property (nonatomic, strong, nonnull) NSString *uploadIDMarker; /** 初始化列举多段上传任务request @param bucketName 桶名 @return 列举多段上传任务 */ -(instancetype)initWithBucketName:(NSString*) bucketName; @end #pragma mark - networking request @interface OBSListMultipartUploadsRequestNetworking : OBSServiceNetworkingCommandRequest @end //response #pragma mark - response /** 列举多段上传任务response */ @interface OBSListMultipartUploadsResponse: OBSBaseResponse /** 桶名 */ @property (nonatomic, strong, nonnull) NSString *bucketName; /** 列举时的起始对象位置 */ @property (nonatomic, strong, nonnull) NSString *keyMarker; /** 列举时的起始uploadID位置 */ @property (nonatomic, strong, nonnull) NSString *uploadIDMarker; /** 如果本次没有返回全部结果,响应请求中将包含nextKeyMarker字段,用于标明接下来请求的keyMarker值 */ @property (nonatomic, strong, nonnull) NSString *nextKeyMarker; /** 如果本次没有返回全部结果,响应请求中将 包含nextUploadIDMarker字段,用于标明接下来请求的uploadMarker值 */ @property (nonatomic, strong, nonnull) NSString *nextUploadIDMarker; /** 返回的最大多段上传任务数目 */ @property (nonatomic, strong, nonnull) NSNumber *maxUploads; /** 表明是否本次返回的multipartUpload结果列表被截断。“YES”表示本次没有返回全部结果;“NO”表示本次已经返回了全部结果 */ @property (nonatomic, assign) BOOL isTruncated; /** 多段上传任务列表 */ @property (nonatomic, strong, nonnull) NSArray *uploadsList; /** 请求中带的prefix */ @property (nonatomic, strong, nonnull) NSString *prefix; /** 请求中带的delimiter */ @property (nonatomic, strong, nonnull) NSString *delimiter; /** 请求中带delimiter参数时,返回消息带commonPrefixes分组信息 */ @property (nonatomic, strong, nonnull) NSArray *commonPrefixesList; @end #pragma mark - client method @interface OBSClient(listMultipartUploads) /** 列举多段上传任务 @param request 列举多段上传任务request @param completionHandler 列举多段上传任务回调 @return OBSBFTask */ - (OBSBFTask*)listMultipartUploads:(__kindof OBSBaseRequest*)request completionHandler:(void (^)(OBSListMultipartUploadsResponse * response, NSError * error))completionHandler; @end #endif /* OBSListMultipartUploadsModel_h */