index.d.ts 129 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581
  1. /**
  2. * 腾讯云 COS JavaScript SDK 类型声明
  3. */
  4. /**
  5. * 定义 COS 命名空间,方便导出用到的变量类型给外部引用
  6. */
  7. declare namespace COS {
  8. /** 存储桶的名称,命名规则为 BucketName-APPID,例如 examplebucket-1250000000 */
  9. type Bucket = string;
  10. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  11. type Region = string;
  12. /** 请求的对象键,最前面不带 /,例如 images/1.jpg */
  13. type Key = string;
  14. /** 请求路径,最前面带 /,例如 /images/1.jpg */
  15. type Pathname = string;
  16. /** 对象的版本 ID;当未启用版本控制时,该节点的值为空字符串;当启用版本控制时,启用版本控制之前的对象,其版本 ID 为 null;当暂停版本控制时,新上传的对象其版本 ID 为 null,且同一个对象最多只存在一个版本 ID 为 null 的对象版本 */
  17. type VersionId = string;
  18. /** 前缀匹配,用来规定返回的文件前缀地址 */
  19. type Prefix = string;
  20. /** 分块上传的任务 ID */
  21. type UploadId = string;
  22. /** 标识本次分块上传的编号,范围在1 - 10000 */
  23. type PartNumber = number;
  24. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  25. type Location = string;
  26. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  27. type ETag = string;
  28. /** COS API 使用的时间字符串,为 ISO8601 格式,例如2019-05-24T10:56:40Z */
  29. type IsoDateTime = string;
  30. /** 请求里的 Url Query 参数 */
  31. type Query = Record<string, any>;
  32. /** 请求里的 Header 参数 */
  33. type Headers = Record<string, any>;
  34. /** 请求里的 URL 中对象存储 API 接口名,如 acl、tagging 等 */
  35. type Action = string;
  36. /** 一个字符的分隔符,常用 / 字符,用于对对象键进行分组。所有对象键中从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分将作为 CommonPrefixes 下的一个 Prefix 节点。被分组的对象键不再出现在后续对象列表中 */
  37. type Delimiter = '/' | string;
  38. /** 规定返回值的编码方式,可选值:url,代表返回的对象键为 URL 编码(百分号编码)后的值,例如“腾讯云”将被编码为%E8%85%BE%E8%AE%AF%E4%BA%91 */
  39. type EncodingType = 'url' | string;
  40. /** 上传的文件内容 */
  41. type UploadBody = File | Blob | String | ArrayBuffer;
  42. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  43. type StorageClass =
  44. | 'STANDARD'
  45. | 'STANDARD_IA'
  46. | 'ARCHIVE'
  47. | 'DEEP_ARCHIVE'
  48. | 'INTELLIGENT_TIERING'
  49. | 'MAZ_STANDARD'
  50. | 'MAZ_STANDARD_IA'
  51. | 'MAZ_INTELLIGENT_TIERING';
  52. /** 请求方法 */
  53. type Method = 'GET' | 'DELETE' | 'POST' | 'PUT' | 'OPTIONS' | 'get' | 'delete' | 'post' | 'put' | 'options';
  54. /** 权限信息,枚举值:READ | WRITE | READ_ACP | WRITE_ACP | FULL_CONTROL 腾讯云对象存储 COS 在资源 ACL 上支持的操作实际上是一系列的操作集合,对于存储桶和对象 ACL 来说分别代表不同的含义。 */
  55. type Permission = 'READ' | 'WRITE' | 'READ_ACP' | 'WRITE_ACP' | 'FULL_CONTROL';
  56. /** 存储桶的预设 ACL @see https://cloud.tencent.com/document/product/436/30752#.E9.A2.84.E8.AE.BE.E7.9A.84-acl */
  57. type BucketACL = 'private' | 'public-read' | 'public-read-write' | 'authenticated-read';
  58. /** 对象的预设 ACL @see https://cloud.tencent.com/document/product/436/30752#.E9.A2.84.E8.AE.BE.E7.9A.84-acl */
  59. type ObjectACL =
  60. | 'default'
  61. | 'private'
  62. | 'public-read'
  63. | 'authenticated-read'
  64. | 'bucket-owner-read'
  65. | 'bucket-owner-full-control';
  66. /** 二进制值的字符串,'true' | 'false' */
  67. type BooleanString = 'true' | 'false';
  68. /** 所有者的信息 */
  69. type Owner = {
  70. /** 存储桶持有者的完整 ID,格式为 qcs::cam::uin/[OwnerUin]:uin/[OwnerUin],如 qcs::cam::uin/100000000001:uin/100000000001 */
  71. ID: string;
  72. };
  73. /** 所有者的信息 */
  74. type GroupOwner = {
  75. /** 预设用户组,格式为 http://cam.qcloud.com/groups/global/AllUsers (匿名用户组) 或 http://cam.qcloud.com/groups/global/AuthenticatedUsers (认证用户组) 。参见 {@link https://cloud.tencent.com/document/product/436/30752#.E8.BA.AB.E4.BB.BD-grantee| ACL 概述} */
  76. URI: string;
  77. };
  78. /** 上传发起者的信息 */
  79. type Initiator = Owner;
  80. /** 单个授权信息 */
  81. type Grant = string;
  82. /** 被授权者信息与权限信息 */
  83. interface Grants {
  84. /** 所有者的信息 */
  85. Grantee: Owner | GroupOwner;
  86. /** 权限信息,枚举值:READ | WRITE | READ_ACP | WRITE_ACP | FULL_CONTROL 腾讯云对象存储 COS 在资源 ACL 上支持的操作实际上是一系列的操作集合,对于存储桶和对象 ACL 来说分别代表不同的含义。 */
  87. Permission: Permission;
  88. }
  89. /** 存储桶/对象标签信息 */
  90. interface Tag {
  91. /** 标签的 Key,长度不超过128字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 */
  92. Key: Key;
  93. /** 标签的 Value,长度不超过256字节, 支持英文字母、数字、空格、加号、减号、下划线、等号、点号、冒号、斜线 */
  94. Value: string;
  95. }
  96. /** 用来说明本次分块上传中每个块的信息 */
  97. interface Part {
  98. /** 标识本次分块上传的编号,范围在1 - 10000 */
  99. PartNumber: PartNumber;
  100. /** 使用 Upload Part 请求上传分块成功后返回的 ETag 响应头部的值 */
  101. ETag: ETag;
  102. }
  103. /** 当前需要用凭证的请求,需要的最小权限 */
  104. type Scope = {
  105. /** 需要的权限 */
  106. action: string;
  107. /** 操作的存储桶的名称,命名规则为 BucketName-APPID,例如 examplebucket-1250000000 */
  108. bucket: Bucket;
  109. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  110. region: Region;
  111. /** 前缀匹配,用来规定返回的文件前缀地址,支持 * 结尾 */
  112. prefix: Prefix;
  113. }[];
  114. /** onProgress 回调的进度信息 */
  115. interface ProgressInfo {
  116. /** 已上传/下载的字节数,单位 B(字节) */
  117. loaded: number;
  118. /** 要上传/下载的文件的大小,单位 B(字节) */
  119. total: number;
  120. /** 速度,单位 B/s */
  121. speed: number;
  122. /** 进度百分比,范围是 0-1,保留两位小数 */
  123. percent: number;
  124. }
  125. /** 上传/下载的进度回调方法 */
  126. type onProgress = (params: ProgressInfo) => any;
  127. // 实例参数
  128. interface COSOptions {
  129. /** 固定密钥的 SecretId,可从{@link https://console.cloud.tencent.com/cam/capi|API密钥管理}获取 */
  130. SecretId?: string;
  131. /** 固定密钥的 SecretKey,可从{@link https://console.cloud.tencent.com/cam/capi|API密钥管理}获取 */
  132. SecretKey?: string;
  133. /** 如果传入 SecretId、SecretKey 是临时密钥,需要再传入一个临时密钥的 sessionToken */
  134. SecurityToken?: string;
  135. /** 同 SecurityToken,推荐用 SecurityToken */
  136. XCosSecurityToken?: string;
  137. /** 分块上传及分块复制时,出错重试次数,默认值3(加第一次,请求共4次) */
  138. ChunkRetryTimes?: number;
  139. /** 同一个实例下上传的文件并发数,默认值3 */
  140. FileParallelLimit?: number;
  141. /** 同一个上传文件的分块并发数,默认值3 */
  142. ChunkParallelLimit?: number;
  143. /** 分块上传时,每片的字节数大小,默认值1048576(1MB) */
  144. ChunkSize?: number;
  145. /** 使用 uploadFiles 批量上传时,文件大小大于该数值将使用按分块上传,否则将调用简单上传,单位 Byte,默认值1048576(1MB) */
  146. SliceSize?: number;
  147. /** 进行分块复制操作中复制分块上传的并发数,默认值20 */
  148. CopyChunkParallelLimit?: number;
  149. /** 使用 sliceCopyFile 分块复制文件时,每片的大小字节数,默认值10485760(10MB) */
  150. CopyChunkSize?: number;
  151. /** 使用 sliceCopyFile 分块复制文件时,文件大小大于该数值将使用分块复制 ,否则将调用简单复制,默认值10485760(10MB) */
  152. CopySliceSize?: number;
  153. /** 最大分片数,默认 1000,最大 10000,分片上传超大文件时,会根据文件大小和该最大分片数计算合适的的分片大小 */
  154. MaxPartNumber?: number;
  155. /** 上传进度的回调方法 onProgress 的回调频率,单位 ms ,默认值1000 */
  156. ProgressInterval?: number;
  157. /** 上传队列最长大小,超出的任务如果状态不是 waiting、checking、uploading 会被清理,默认10000 */
  158. UploadQueueSize?: number;
  159. /** 调用操作存储桶和对象的 API 时自定义请求域名。可以使用模板,如"{Bucket}.cos.{Region}.myqcloud.com",即在调用 API 时会使用参数中传入的 Bucket 和 Region 进行替换。 */
  160. Domain?: string;
  161. /** getService方法可以使用的自定义域名 */
  162. ServiceDomain?: string;
  163. /** http协议,枚举值'http:','https:' */
  164. Protocol?: string;
  165. /** 开启兼容模式,默认 false 不开启,兼容模式下不校验 Region 是否格式有误,在用于私有化 COS 时使用 */
  166. CompatibilityMode?: boolean;
  167. /** 强制使用后缀式模式发请求。后缀式模式中 Bucket 会放在域名后的 pathname 里,并且 Bucket 会加入签名 pathname 计算,默认 false */
  168. ForcePathStyle?: boolean;
  169. /** 是否原样保留 Key 字段的 / 前缀,默认 false 不保留,这时如果 Key 是 / 开头,强制去掉第一个 / */
  170. UseRawKey?: boolean;
  171. /** 请求超时时间,单位 ms(毫秒),透传给 request 或 ajax 或小程序请求库 */
  172. Timeout?: number;
  173. /** 客户端时间是否不准确,默认 false,在第一次请求 COS API 返回时会判断是否偏差大于 30s,如果是会把该值设置为 true,开发者也可以预先判断并设置该参数 */
  174. CorrectClockSkew?: boolean;
  175. /** 校正时间的偏移值,单位 ms(毫秒),计算签名时会用设备当前时间戳加上该偏移值,在设备时间有误时可用于校正签名用的时间参数,在第一次请求 COS API 返回时会判断是否偏差大于 30s,如果是会把该值设置为 true,开发者也可以预先判断并设置该参数。 */
  176. SystemClockOffset?: number;
  177. /** 上传文件时校验 Content-MD5,默认 false。如果开启,上传文件时会对文件内容计算 MD5,大文件耗时较长 */
  178. UploadCheckContentMd5?: boolean;
  179. /** 上传文件时计算文件内容 md5 并设置为文件 x-cos-meta-md5 元数据 Header 字段 */
  180. UploadAddMetaMd5?: boolean;
  181. /** 分片上传缓存的 UploadId 列表大小限制,nodejs-sdk 默认 500 个,js-sdk、小程序 SDK 默认 50 */
  182. UploadIdCacheLimit?: number;
  183. /** 是否使用全球加速域名。开启该配置后仅以下接口支持操作:putObject、getObject、headObject、optionsObject、multipartInit、multipartListPart、multipartUpload、multipartAbort、multipartComplete、multipartList、sliceUploadFile、uploadFiles */
  184. UseAccelerate?: boolean;
  185. /** 默认为true,将host加入签名计算,关闭后可能导致越权风险,建议保持为true */
  186. ForceSignHost?: boolean;
  187. /** 链路上报 */
  188. EnableTracker?: boolean;
  189. DeepTracker?: boolean;
  190. TrackerDelay?: number;
  191. CustomId?: string;
  192. /** 链路上报 */
  193. /** 获取签名的回调方法,如果没有 SecretId、SecretKey 时,必选 */
  194. getAuthorization?: (
  195. options: GetAuthorizationOptions,
  196. /** callback 获取完签名或临时密钥后,回传给 SDK 的方法 */
  197. callback: (
  198. /** params 回传给 SDK 的签名或获取临时密钥 */
  199. params: GetAuthorizationCallbackParams
  200. ) => void
  201. ) => void;
  202. }
  203. interface Util {
  204. md5: (str: String, encoding?: string) => string;
  205. xml2json: (bodyStr: string) => any;
  206. json2xml: (json: any) => string;
  207. encodeBase64: (str: string, safe?: boolean) => string;
  208. }
  209. interface StaticGetAuthorizationOptions {
  210. /** 计算签名用的密钥 SecretId,必选 */
  211. SecretId: string;
  212. /** 计算签名用的密钥 SecretKey,必选 */
  213. SecretKey: string;
  214. /** 请求的存储桶,如果传入了 Bucket、Region,签名会默认加上 Host 字段,可选 */
  215. Bucket?: Bucket;
  216. /** 请求的地域,如果传入了 Bucket、Region,签名会默认加上 Host 字段,可选 */
  217. Region?: Region;
  218. /** 请求方法,可选 */
  219. Method?: Method;
  220. /** 请求路径,最前面带 /,例如 /images/1.jpg,可选 */
  221. Pathname?: Pathname;
  222. /** 请求的对象键,最前面不带 /,例如 images/1.jpg,可选 */
  223. Key?: Key;
  224. /** 要参与签名计算的 Url Query 参数,可选 */
  225. Query?: Query;
  226. /** 要参与签名计算的 Header 参数,可选 */
  227. Headers?: Headers;
  228. /** 签名几秒后失效,默认为900秒,如果传入了 KeyTime,以 KeyTime 为准,可选 */
  229. Expires?: number;
  230. /** 签名有效时间戳区间,如果传入了该参数,会赋值给在签名里的 q-key-time 和 q-sign-time 字段,格式如:1611915436;1611916336 */
  231. KeyTime?: string;
  232. /** 校正时间的偏移值,单位 ms(毫秒),计算签名时会用设备当前时间戳加上该偏移值,在设备时间有误时可用于校正签名用的时间参数。 */
  233. SystemClockOffset?: number;
  234. }
  235. /** 计算签名或获取临时密钥可能需要的参数列表 */
  236. interface GetAuthorizationOptions {
  237. /** 存储桶的名称,格式为<bucketname-appid>,例如examplebucket-1250000000 */
  238. Bucket: Bucket;
  239. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  240. Region: Region;
  241. /** 请求方法 */
  242. Method: Method;
  243. /** 请求路径,最前面带 /,例如 /images/1.jpg,Pathname 和 Key 二选一 */
  244. Pathname: Pathname;
  245. /** 请求的对象键,最前面不带 /,例如 images/1.jpg,如果是存储桶接口,传入空字符串,Key 和 Pathname 二选一,推荐使用 Pathname 参数 */
  246. Key: Key;
  247. /** 请求里的 Url Query 参数,可选 */
  248. Query: Query;
  249. /** 请求里的 Header 参数,可选 */
  250. Headers: Headers;
  251. /** 当前需要用凭证的请求,需要的最小权限 */
  252. Scope: Scope;
  253. /** 校正时间的偏移值,单位 ms(毫秒),计算签名时会用设备当前时间戳加上该偏移值,在设备时间有误时可用于校正签名用的时间参数。 */
  254. SystemClockOffset: number;
  255. }
  256. /** 请求凭证,包含临时密钥信息 */
  257. interface Credentials {
  258. /** 临时密钥 tmpSecretId */
  259. TmpSecretId: string;
  260. /** 临时密钥 tmpSecretKey */
  261. TmpSecretKey: string;
  262. /** 临时密钥 sessonToken */
  263. SecurityToken?: string;
  264. /** 同 SecurityToken,推荐用 SecurityToken */
  265. XCosSecurityToken?: string;
  266. /** 获取临时密钥时,服务端的时间,该时间用于计算签名,可以避免设备时间有偏差导致请求错误 */
  267. StartTime: number;
  268. /** 获取临时密钥的过期时间戳 */
  269. ExpiredTime: number;
  270. /** 该临时密钥是否仅用于相同 Scope 权限范围的请求 */
  271. ScopeLimit?: boolean;
  272. /** 签名 */
  273. Authorization?: string;
  274. }
  275. /** 用于发请求的签名字符串,会放在请求 Header 里的 Authorization 字段 */
  276. type Authorization = string;
  277. /** SDK 用于请求的凭证,可以是签名,也可以是临时密钥信息 */
  278. type GetAuthorizationCallbackParams = Authorization | Credentials;
  279. /** 一般接口的返回结果 */
  280. interface GeneralResult {
  281. /** 请求返回的 HTTP 状态码 */
  282. statusCode?: number;
  283. /** 请求返回的 header 字段 */
  284. headers?: Headers;
  285. /** 请求的唯一标识 */
  286. RequestId?: string;
  287. }
  288. /** SDK 的错误格式,其中服务端返回错误码可查看 @see https://cloud.tencent.com/document/product/436/7730 */
  289. interface CosSdkError extends GeneralResult {
  290. /** 错误码 */
  291. code: string;
  292. /** 错误信息 */
  293. message: string;
  294. /** 兼容老的错误信息字段,不建议使用,可能是参数错误、客户端出错、或服务端返回的错误 */
  295. error: string | Error | { Code: string; Message: string };
  296. }
  297. /** 回调的错误格式,其中服务端返回错误码可查看 @see https://cloud.tencent.com/document/product/436/7730 */
  298. type CosError = null | CosSdkError;
  299. /** 存储桶操作接口的公共参数 */
  300. interface BucketParams {
  301. /** 存储桶的名称,格式为<bucketname-appid>,例如examplebucket-1250000000 */
  302. Bucket: Bucket;
  303. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  304. Region: Region;
  305. /** 请求时带上的 Header 字段 */
  306. Headers?: Headers;
  307. tracker?: any;
  308. }
  309. /** 对象操作接口的公共参数 */
  310. interface ObjectParams {
  311. /** 存储桶的名称,格式为<bucketname-appid>,例如examplebucket-1250000000 */
  312. Bucket: Bucket;
  313. /** 存储桶所在地域,如果有传入只返回该地域的存储桶列表 */
  314. Region: Region;
  315. /** 请求的对象键,最前面不带 / */
  316. Key: Key;
  317. /** 发请求时带上的 Header 字段 */
  318. Headers?: Headers;
  319. tracker?: any;
  320. }
  321. // 所有接口的入参和出参
  322. // getService
  323. interface GetServiceParams {
  324. /** 存储桶所在地域,如果传入只返回该地域的存储桶 */
  325. Region?: Region;
  326. /** 发请求时带上的 Header 字段 */
  327. Headers?: Headers;
  328. }
  329. /** getService 接口返回值 */
  330. interface GetServiceResult extends GeneralResult {
  331. Buckets: {
  332. /** 存储桶的名称,格式为<bucketname-appid>,例如examplebucket-1250000000 */
  333. Name: Bucket;
  334. /** 存储桶所在地域 */
  335. Location: Region;
  336. /** 存储桶创建时间 */
  337. CreationDate: IsoDateTime;
  338. }[];
  339. /** 所有者的信息 */
  340. Owner: Owner;
  341. }
  342. // putBucket
  343. /** putBucket 接口参数 */
  344. interface PutBucketParams extends BucketParams {
  345. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  346. ACL?: BucketACL;
  347. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  348. GrantRead?: Grant;
  349. /** 赋予被授权者写取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  350. GrantWrite?: Grant;
  351. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  352. GrantReadAcp?: Grant;
  353. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  354. GrantWriteAcp?: Grant;
  355. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  356. GrantFullControl?: Grant;
  357. /** 要创建存储桶的AZ类型,创建多AZ存储桶,传入 'MAZ' */
  358. BucketAZConfig?: 'MAZ' | string;
  359. }
  360. /** putBucket 接口返回值 */
  361. interface PutBucketResult extends GeneralResult {
  362. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/ */
  363. Location: Location;
  364. }
  365. // headBucket
  366. /** headBucket 接口参数 */
  367. interface HeadBucketParams extends BucketParams {}
  368. /** headBucket 接口返回值 */
  369. interface HeadBucketResult extends GeneralResult {}
  370. // getBucket
  371. /** getBucket 接口参数 */
  372. interface GetBucketParams extends BucketParams {
  373. /** 前缀匹配,用来规定返回的文件前缀地址,可选 */
  374. Prefix?: Prefix;
  375. /** 一个字符的分隔符,常用 / 字符,用于对对象键进行分组。所有对象键中从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分将作为 CommonPrefixes 下的一个 Prefix 节点。被分组的对象键不再出现在后续对象列表中,可选 */
  376. Delimiter?: Delimiter;
  377. /** 默认以UTF-8二进制顺序列出条目,所有列出条目从marker开始,可选 */
  378. Marker?: Key;
  379. /** 单次返回最大的条目数量,默认值为1000,最大为1000,注意:该参数会限制每一次 List 操作返回的最大条目数,COS 在每次 List 操作中将返回不超过 max-keys 所设定数值的条目(即 CommonPrefixes 和 Contents 的总和),如果单次响应中未列出所有对象,COS 会返回 NextMarker 节点,其值作为您下次 List 请求的 marker 参数,以便您列出后续对象,可选 */
  380. MaxKeys?: number;
  381. /** 规定返回值的编码方式,可选值:url,代表返回的对象键为 URL 编码(百分号编码)后的值,例如“腾讯云”将被编码为%E8%85%BE%E8%AE%AF%E4%BA%91 */
  382. EncodingType?: EncodingType;
  383. }
  384. /** 对象信息 */
  385. interface CosObject {
  386. /** 对象键 */
  387. Key: Key;
  388. /** 当前版本的最后修改时间,为 ISO8601 格式,例如2019-05-24T10:56:40Z */
  389. LastModified: IsoDateTime;
  390. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如“8e0b617ca298a564c3331da28dcb50df”,此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  391. ETag: ETag;
  392. /** 对象大小,单位为 Byte */
  393. Size: string;
  394. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  395. StorageClass: StorageClass;
  396. /** 当对象存储类型为智能分层存储时,指示对象当前所处的存储层,枚举值:FREQUENT(标准层),INFREQUENT(低频层)。仅当 StorageClass 为 INTELLIGENT_TIERING(智能分层)时才会返回该节点 */
  397. StorageTier?: string;
  398. /** 对象持有者信息 */
  399. Owner: Owner;
  400. }
  401. /** getBucket 接口返回值 */
  402. interface GetBucketResult extends GeneralResult {
  403. /** 存储桶的名称,格式为<BucketName-APPID>,例如examplebucket-1250000000 */
  404. Name: string;
  405. /** 对象键匹配前缀,对应请求中的 prefix 参数 */
  406. Prefix: string;
  407. /** 起始对象键标记,从该标记之后(不含)按照 UTF-8 字典序返回对象键条目,对应请求中的 marker 参数 */
  408. Marker: string;
  409. /** 单次响应返回结果的最大条目数量,对应请求中的 max-keys 参数 */
  410. MaxKeys: string;
  411. /** 编码格式,对应请求中的 encoding-type 参数,且仅当请求中指定了 encoding-type 参数才会返回该节点 */
  412. EncodingType?: string;
  413. /** 对象条目 */
  414. Contents: CosObject[];
  415. /** 从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分,定义为 Common Prefix。仅当请求中指定了 delimiter 参数才有可能返回该节点 */
  416. CommonPrefixes: {
  417. /** 前缀匹配,用来规定返回的文件前缀地址 */
  418. Prefix: Prefix;
  419. }[];
  420. /** 响应条目是否被截断,布尔值,例如 true 或 false,可用于判断是否还需要继续列出文件 */
  421. IsTruncated: BooleanString;
  422. /** 仅当响应条目有截断(IsTruncated 为 true)才会返回该节点,该节点的值为当前响应条目中的最后一个对象键,当需要继续请求后续条目时,将该节点的值作为下一次请求的 marker 参数传入 */
  423. NextMarker?: string;
  424. }
  425. // listObjectVersions
  426. /** listObjectVersions 接口参数 */
  427. interface ListObjectVersionsParams extends BucketParams {
  428. /** 前缀匹配,用来规定返回的文件前缀地址,可选 */
  429. Prefix?: Prefix;
  430. /** 一个字符的分隔符,常用 / 字符,用于对对象键进行分组。所有对象键中从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分将作为 CommonPrefixes 下的一个 Prefix 节点。被分组的对象键不再出现在后续对象列表中,可选 */
  431. Delimiter?: Delimiter;
  432. /** 默认以UTF-8二进制顺序列出条目,所有列出条目从marker开始,可选 */
  433. Marker?: string;
  434. /** 单次返回最大的条目数量,默认值为1000,最大为1000,注意:该参数会限制每一次 List 操作返回的最大条目数,COS 在每次 List 操作中将返回不超过 max-keys 所设定数值的条目(即 CommonPrefixes 和 Contents 的总和),如果单次响应中未列出所有对象,COS 会返回 NextMarker 节点,其值作为您下次 List 请求的 marker 参数,以便您列出后续对象,可选 */
  435. MaxKeys?: string;
  436. /** 起始版本 ID 标记,从该标记之后(不含)返回对象版本条目,对应请求中的 url 参数 version-id-marker */
  437. VersionIdMarker?: string;
  438. /** 规定返回值的编码方式,可选值:url,代表返回的对象键为 URL 编码(百分号编码)后的值,例如“腾讯云”将被编码为%E8%85%BE%E8%AE%AF%E4%BA%91 */
  439. EncodingType?: EncodingType;
  440. }
  441. /** 对象删除标记条目 */
  442. interface DeleteMarker {
  443. /** 对象键 */
  444. Key: Key;
  445. /** 对象的版本 ID;当未启用版本控制时,该节点的值为空字符串;当启用版本控制时,启用版本控制之前的对象,其版本 ID 为 null;当暂停版本控制时,新上传的对象其版本 ID 为 null,且同一个对象最多只存在一个版本 ID 为 null 的对象版本 */
  446. VersionId: VersionId;
  447. /** 当前版本是否为该对象的最新版本 */
  448. IsLatest: string;
  449. /** 当前版本的最后修改时间,为 ISO8601 格式,例如2019-05-24T10:56:40Z */
  450. LastModified: IsoDateTime;
  451. Owner: Owner;
  452. }
  453. interface ObjectVersion {
  454. /** 对象键 */
  455. Key: Key;
  456. /** 对象的删除标记的版本 ID */
  457. VersionId: VersionId;
  458. /** 当前版本是否为该对象的最新版本 */
  459. IsLatest: BooleanString;
  460. /** 当前版本的最后修改时间,为 ISO8601 格式,例如2019-05-24T10:56:40Z */
  461. LastModified: IsoDateTime;
  462. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  463. ETag: ETag;
  464. /** 对象大小,单位为 Byte */
  465. Size: string;
  466. /** 对象大小,单位为 Byte */
  467. Owner: Owner;
  468. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  469. StorageClass: StorageClass;
  470. /** 当对象存储类型为智能分层存储时,指示对象当前所处的存储层,枚举值:FREQUENT(标准层),INFREQUENT(低频层)。仅当 StorageClass 为 INTELLIGENT_TIERING(智能分层)时才会返回该节点 */
  471. StorageTier?: string;
  472. }
  473. /** listObjectVersions 接口返回值 */
  474. interface ListObjectVersionsResult extends GeneralResult {
  475. /** 从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分,定义为 Common Prefix。仅当请求中指定了 delimiter 参数才有可能返回该节点 */
  476. CommonPrefixes: {
  477. /** 前缀匹配,用来规定返回的文件前缀地址 */
  478. Prefix: Prefix;
  479. }[];
  480. /** 对象版本条目 */
  481. Versions: ObjectVersion[];
  482. /** 对象删除标记条目 */
  483. DeleteMarkers: DeleteMarker[];
  484. /** 响应条目是否被截断,布尔值,例如 true 或 false,可用于判断是否还需要继续列出文件 */
  485. IsTruncated: BooleanString;
  486. /** 仅当响应条目有截断(IsTruncated 为 true)才会返回该节点,该节点的值为当前响应条目中的最后一个对象键,当需要继续请求后续条目时,将该节点的值作为下一次请求的 marker 参数传入 */
  487. NextMarker?: string;
  488. /** 仅当响应条目有截断(IsTruncated 为 true)才会返回该节点,该节点的值为当前响应条目中的最后一个对象的版本 ID,当需要继续请求后续条目时,将该节点的值作为下一次请求的 version-id-marker 参数传入。该节点的值可能为空,此时下一次请求的 version-id-marker 参数也需要指定为空。 */
  489. NextVersionIdMarker?: string;
  490. }
  491. // deleteBucket
  492. /** deleteBucket 接口参数 */
  493. interface DeleteBucketParams extends BucketParams {}
  494. /** deleteBucket 接口返回值 */
  495. interface DeleteBucketResult extends GeneralResult {}
  496. // putBucketAcl
  497. /** putBucketAcl 接口参数 */
  498. interface PutBucketAclParams extends BucketParams {
  499. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  500. ACL?: BucketACL;
  501. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  502. GrantRead?: Grant;
  503. /** 赋予被授权者写取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  504. GrantWrite?: Grant;
  505. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  506. GrantReadAcp?: Grant;
  507. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  508. GrantWriteAcp?: Grant;
  509. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  510. GrantFullControl?: Grant;
  511. /** 放在 XML Body 的授权参数 */
  512. AccessControlPolicy?: {
  513. /** 所有者的信息 */
  514. Owner: Owner;
  515. /** 被授权者信息与权限信息 */
  516. Grants: Grants[];
  517. };
  518. }
  519. /** putBucketAcl 接口返回值 */
  520. interface PutBucketAclResult extends GeneralResult {}
  521. // getBucketAcl
  522. /** getBucketAcl 接口参数 */
  523. interface GetBucketAclParams extends BucketParams {}
  524. /** getBucketAcl 接口返回值 */
  525. interface GetBucketAclResult extends GeneralResult {
  526. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write */
  527. ACL: BucketACL;
  528. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  529. GrantRead: Grant;
  530. /** 赋予被授权者写取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  531. GrantWrite: Grant;
  532. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  533. GrantReadAcp: Grant;
  534. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  535. GrantWriteAcp: Grant;
  536. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  537. GrantFullControl: Grant;
  538. /** 存储桶持有者信息 */
  539. Owner: Owner;
  540. /** 被授权者信息与权限信息 */
  541. Grants: Grants[];
  542. }
  543. // putBucketCors
  544. type CORSRule = {
  545. /** 允许的访问来源,单条 CORSRule 可以配置多个 AllowedOrigin。
  546. 配置支持 *,表示全部域名都允许,但不推荐。
  547. 支持单个具体域名,例如 http://www.example.com。
  548. 支持 * 通配符,通配符可出现在任何位置,包括协议、域名和端口,可匹配0个或多个字符,但是只能有一个 *。请谨慎使用通配符,因为可能意外匹配到非预期的来源
  549. 注意不要遗漏协议名 http 或 https,若端口不是默认的80(http)或443(https),还需要带上端口,例如 https://example.com:8443。 */
  550. AllowedOrigin: string[];
  551. /** 允许的 HTTP 操作方法(Method),对应 CORS 请求响应中的 Access-Control-Allow-Methods 头部,单条 CORSRule 可以配置多个 AllowedMethod。枚举值:PUT、GET、POST、DELETE、HEAD。 */
  552. AllowedMethod: string[];
  553. /** 在发送预检(OPTIONS)请求时,浏览器会告知服务端接下来的正式请求将使用的自定义 HTTP 请求头部,此配置用于指定允许浏览器发送 CORS 请求时携带的自定义 HTTP 请求头部,不区分英文大小写,单条 CORSRule 可以配置多个 AllowedHeader。
  554. 可以配置*,代表允许所有头部,为了避免遗漏,推荐配置为*。
  555. 如果不配置为*,那么在预检(OPTIONS)请求中 Access-Control-Request-Headers 头部出现的每个 Header,都必须在 AllowedHeader 中有对应项。 */
  556. AllowedHeader?: string[];
  557. /** 允许浏览器获取的 CORS 请求响应中的头部,不区分大小写,单条 CORSRule 可以配置多个 ExposeHeader。
  558. 默认情况下浏览器只能访问简单响应头部:Cache-Control、Content-Type、Expires、Last-Modified,如果需要访问其他响应头部,需要添加 ExposeHeader 配置。
  559. 不支持配置为 *,必须明确配置具体的 Header。
  560. 根据浏览器的实际需求确定,默认推荐填写 ETag,可参考各 API 文档的响应头部分及 公共响应头部 文档。@see https://cloud.tencent.com/document/product/436/7729 */
  561. ExposeHeader?: string[];
  562. /** 跨域资源共享配置的有效时间,单位为秒,在有效时间内,浏览器无须为同一请求再次发起预检(OPTIONS)请求,对应 CORS 请求响应中的 Access-Control-Max-Age 头部,单条 CORSRule 只能配置一个 MaxAgeSeconds。 */
  563. MaxAgeSeconds?: number;
  564. };
  565. /** putBucketCors 接口参数 */
  566. interface PutBucketCorsParams extends BucketParams {
  567. /** 存储桶跨域资源共享(CORS)访问控制规则 */
  568. CORSRules: CORSRule[];
  569. /** 是否允许同一个 url 有多份缓存,如果设置为 true 浏览器在 img 标签加载和 ajax 加载同一个对象 url 将会使用不同缓存 */
  570. ResponseVary?: BooleanString;
  571. }
  572. /** putBucketCors 接口返回值 */
  573. interface PutBucketCorsResult extends GeneralResult {
  574. /** 存储桶跨域资源共享(CORS)访问控制规则 */
  575. CORSRules: Record<string, any>;
  576. }
  577. // getBucketCors
  578. /** getBucketCors 接口参数 */
  579. interface GetBucketCorsParams extends BucketParams {}
  580. /** getBucketCors 接口返回值 */
  581. interface GetBucketCorsResult extends GeneralResult {
  582. /** 存储桶跨域资源共享(CORS)访问控制规则 */
  583. CORSRules: Record<string, any>;
  584. /** 是否允许同一个 url 有多份缓存,如果设置为 true 浏览器在 img 标签加载和 ajax 加载同一个对象 url 将会使用不同缓存 */
  585. ResponseVary?: BooleanString;
  586. }
  587. // deleteBucketCors
  588. /** deleteBucketCors 接口参数 */
  589. interface DeleteBucketCorsParams extends BucketParams {}
  590. /** deleteBucketCors 接口返回值 */
  591. interface DeleteBucketCorsResult extends GeneralResult {}
  592. // getBucketLocation
  593. interface GetBucketLocationResult {
  594. /** 存储桶所在地域 */
  595. LocationConstraint: Region;
  596. }
  597. /** getBucketLocation 接口参数 */
  598. interface GetBucketLocationParams extends BucketParams {}
  599. // putBucketPolicy
  600. /** putBucketPolicy 接口参数 */
  601. interface PutBucketPolicyParams extends BucketParams {
  602. /** 存储桶的权限策略 @see https://cloud.tencent.com/document/product/436/31923 */
  603. Policy: Record<string, any>;
  604. }
  605. /** putBucketPolicy 接口返回值 */
  606. interface PutBucketPolicyResult extends GeneralResult {}
  607. // getBucketPolicy
  608. /** getBucketPolicy 接口参数 */
  609. interface GetBucketPolicyParams extends BucketParams {}
  610. /** getBucketPolicy 接口返回值 */
  611. interface GetBucketPolicyResult extends GeneralResult {
  612. /** 存储桶的权限策略 @see https://cloud.tencent.com/document/product/436/31923 */
  613. Policy: Record<string, any>;
  614. }
  615. // deleteBucketPolicy
  616. /** deleteBucketPolicy 接口参数 */
  617. interface DeleteBucketPolicyParams extends BucketParams {}
  618. /** deleteBucketPolicy 接口返回值 */
  619. interface DeleteBucketPolicyResult extends GeneralResult {}
  620. // putBucketTagging
  621. /** putBucketTagging 接口参数 */
  622. interface PutBucketTaggingParams extends BucketParams {
  623. /** 标签集合,最多支持10个标签 */
  624. Tags: Tag[];
  625. }
  626. /** putBucketTagging 接口返回值 */
  627. interface PutBucketTaggingResult extends GeneralResult {}
  628. // getBucketTagging
  629. /** getBucketTagging 接口参数 */
  630. interface GetBucketTaggingParams extends BucketParams {}
  631. /** getBucketTagging 接口返回值 */
  632. interface GetBucketTaggingResult extends GeneralResult {
  633. /** 标签集合,最多支持10个标签 */
  634. Tags: Tag[];
  635. }
  636. // deleteBucketTagging
  637. /** deleteBucketTagging 接口参数 */
  638. interface DeleteBucketTaggingParams extends BucketParams {}
  639. /** deleteBucketTagging 接口返回值 */
  640. interface DeleteBucketTaggingResult extends GeneralResult {}
  641. // putBucketLifecycle
  642. /** 生命周期配置规则 */
  643. type LifecycleRule = {
  644. /** 用于唯一地标识规则,长度不能超过255个字符,可选 */
  645. ID: string;
  646. /** 指明规则是否启用,枚举值:Enabled,Disabled,必选 */
  647. Status: 'Enabled' | 'Disabled';
  648. /** Filter 用于描述规则影响的 Object 集合,必选 */
  649. Filter?: Record<string, any>;
  650. /** 规则转换属性,对象何时转换为 Standard_IA 或 Archive 等存储类型 */
  651. Transition?: Record<string, any>;
  652. /** 规则过期属性 */
  653. Expiration?: Record<string, any>;
  654. /** 设置允许分片上传保持运行的最长时间 */
  655. AbortIncompleteMultipartUpload?: Record<string, any>;
  656. /** 指明非当前版本对象何时过期 */
  657. NoncurrentVersionExpiration?: Record<string, any>;
  658. /** 指明非当前版本对象何时转换为 STANDARD_IA 或 ARCHIVE 等存储类型 */
  659. NoncurrentVersionTransition?: Record<string, any>;
  660. };
  661. /** putBucketLifecycle 接口参数 */
  662. interface PutBucketLifecycleParams extends BucketParams {
  663. /** 生命周期配置规则列表 */
  664. Rules: LifecycleRule[];
  665. }
  666. /** putBucketLifecycle 接口返回值 */
  667. interface PutBucketLifecycleResult extends GeneralResult {}
  668. // getBucketLifecycle
  669. /** getBucketLifecycle 接口参数 */
  670. interface GetBucketLifecycleParams extends BucketParams {}
  671. /** getBucketLifecycle 接口返回值 */
  672. interface GetBucketLifecycleResult extends GeneralResult {
  673. /** 生命周期配置规则列表 */
  674. Rules: LifecycleRule[];
  675. }
  676. // deleteBucketLifecycle
  677. /** deleteBucketLifecycle 接口参数 */
  678. interface DeleteBucketLifecycleParams extends BucketParams {}
  679. /** deleteBucketLifecycle 接口返回值 */
  680. interface DeleteBucketLifecycleResult extends GeneralResult {}
  681. // putBucketVersioning
  682. /** 存储桶版本控制开关信息 */
  683. interface VersioningConfiguration {
  684. /** 说明版本是否开启,枚举值:Suspended、Enabled */
  685. Status: 'Enabled' | 'Suspended';
  686. }
  687. /** putBucketVersioning 接口参数 */
  688. interface PutBucketVersioningParams extends BucketParams {
  689. /** 存储桶版本控制开关信息 */
  690. VersioningConfiguration: VersioningConfiguration;
  691. }
  692. /** putBucketVersioning 接口返回值 */
  693. interface PutBucketVersioningResult extends GeneralResult {}
  694. // getBucketVersioning
  695. /** getBucketVersioning 接口参数 */
  696. interface GetBucketVersioningParams extends BucketParams {}
  697. /** getBucketVersioning 接口返回值 */
  698. interface GetBucketVersioningResult extends GeneralResult {
  699. /** 存储桶版本控制开关信息 */
  700. VersioningConfiguration: VersioningConfiguration;
  701. }
  702. // putBucketReplication
  703. interface ReplicationRule {
  704. /** 用来标注具体 Rule 的名称 */
  705. ID?: string;
  706. /** 标识 Rule 是否生效,枚举值:Enabled, Disabled */
  707. Status: 'Enabled' | 'Disabled';
  708. /** 前缀匹配,用来规定返回的文件前缀地址 */
  709. Prefix: Prefix;
  710. /** 目标存储桶信息 */
  711. Destination: {
  712. /** 资源标识符:qcs::cos:<region>::<bucketname-appid> */
  713. Bucket: string;
  714. /** 存储类型,枚举值:STANDARD,INTELLIGENT_TIERING,STANDARD_IA 等。默认值:原存储类型 */
  715. StorageClass?: StorageClass;
  716. };
  717. }
  718. /** 说明所有复制配置信息 */
  719. interface ReplicationConfiguration {
  720. /** 发起者身份标示:qcs::cam::uin/&lt;OwnerUin>:uin/&lt;SubUin> */
  721. Role: string;
  722. /** 具体配置信息,最多支持1000个,所有策略只能指向一个目标存储桶 */
  723. Rules: ReplicationRule[];
  724. }
  725. /** putBucketReplication 接口参数 */
  726. interface PutBucketReplicationParams extends BucketParams {
  727. /** 说明所有复制配置信息 */
  728. ReplicationConfiguration: ReplicationConfiguration;
  729. }
  730. /** putBucketReplication 接口返回值 */
  731. interface PutBucketReplicationResult extends GeneralResult {}
  732. // getBucketReplication
  733. /** getBucketReplication 接口参数 */
  734. interface GetBucketReplicationParams extends BucketParams {}
  735. /** getBucketReplication 接口返回值 */
  736. interface GetBucketReplicationResult extends GeneralResult {
  737. /** 说明所有复制配置信息 */
  738. ReplicationConfiguration: ReplicationConfiguration;
  739. }
  740. // deleteBucketReplication
  741. /** deleteBucketReplication 接口参数 */
  742. interface DeleteBucketReplicationParams extends BucketParams {}
  743. /** deleteBucketReplication 接口返回值 */
  744. interface DeleteBucketReplicationResult extends GeneralResult {}
  745. // putBucketWebsite
  746. /** 存储桶配置静态网站配置信息 */
  747. interface WebsiteConfiguration {
  748. /** 索引文档配置 */
  749. IndexDocument: {
  750. /** 指定索引文档的对象键后缀。例如指定为index.html,那么当访问到存储桶的根目录时,会自动返回 index.html 的内容,或者当访问到article/目录时,会自动返回 article/index.html的内容 */
  751. Suffix: string;
  752. };
  753. /** 重定向所有请求配置 */
  754. RedirectAllRequestsTo?: {
  755. /** 指定重定向所有请求的目标协议,只能设置为 https */
  756. Protocol: 'https' | string;
  757. };
  758. /** 用于配置是否忽略扩展名 */
  759. AutoAddressing?: {
  760. /** 用于配置是否忽略 HTML 拓展名,可选值为 Enabled 或 Disabled,默认为 Disabled */
  761. Status: 'Disabled' | 'Enabled';
  762. };
  763. /** 错误文档配置 */
  764. ErrorDocument?: {
  765. /** 指定通用错误文档的对象键,当发生错误且未命中重定向规则中的错误码重定向时,将返回该对象键的内容 */
  766. Key: Key;
  767. /** 用于配置命中错误文档的 HTTP 状态码,可选值为 Enabled 或 Disabled,默认为 Enabled */
  768. OriginalHttpStatus?: 'Enabled' | 'Disabled';
  769. };
  770. /** 重定向规则配置,最多设置100条 RoutingRule */
  771. RoutingRules?: {
  772. /** 重定向规则的条件配置 */
  773. Condition: {
  774. /** 指定重定向规则的错误码匹配条件,只支持配置4XX返回码,例如403或404,HttpErrorCodeReturnedEquals 与 KeyPrefixEquals 必选其一 */
  775. HttpErrorCodeReturnedEquals?: string | number;
  776. /** 指定重定向规则的对象键前缀匹配条件,HttpErrorCodeReturnedEquals 与 KeyPrefixEquals 必选其一 */
  777. KeyPrefixEquals?: 'Enabled' | 'Disabled';
  778. };
  779. /** 重定向规则的具体重定向目标配置 */
  780. Redirect: {
  781. /** 指定重定向规则的目标协议,只能设置为 https */
  782. Protocol?: 'https' | string;
  783. /** 指定重定向规则的具体重定向目标的对象键,替换方式为替换整个原始请求的对象键,ReplaceKeyWith 与 ReplaceKeyPrefixWith 必选其一 */
  784. ReplaceKeyWith?: string;
  785. /** 指定重定向规则的具体重定向目标的对象键,替换方式为替换原始请求中所匹配到的前缀部分,仅可在 Condition 为 KeyPrefixEquals 时设置,ReplaceKeyWith 与 ReplaceKeyPrefixWith 必选其一 */
  786. ReplaceKeyPrefixWith?: string;
  787. };
  788. }[];
  789. }
  790. /** putBucketWebsite 接口参数 */
  791. interface PutBucketWebsiteParams extends BucketParams {
  792. /** 存储桶配置静态网站配置信息 */
  793. WebsiteConfiguration: WebsiteConfiguration;
  794. }
  795. /** putBucketWebsite 接口返回值 */
  796. interface PutBucketWebsiteResult extends GeneralResult {}
  797. // getBucketWebsite
  798. /** getBucketWebsite 接口参数 */
  799. interface GetBucketWebsiteParams extends BucketParams {}
  800. /** getBucketWebsite 接口返回值 */
  801. interface GetBucketWebsiteResult extends GeneralResult {
  802. /** 存储桶配置静态网站配置信息 */
  803. WebsiteConfiguration: WebsiteConfiguration;
  804. }
  805. // deleteBucketWebsite
  806. /** deleteBucketWebsite 接口参数 */
  807. interface DeleteBucketWebsiteParams extends BucketParams {}
  808. /** deleteBucketWebsite 接口返回值 */
  809. interface DeleteBucketWebsiteResult extends GeneralResult {}
  810. // putBucketReferer
  811. /** 防盗链配置信息 */
  812. interface RefererConfiguration {
  813. /** 是否开启防盗链,枚举值:Enabled、Disabled */
  814. Status: 'Enabled' | 'Disabled';
  815. /** 防盗链类型,枚举值:Black-List、White-List */
  816. RefererType: 'Black-List' | 'White-List';
  817. /** 生效域名列表, 支持多个域名且为前缀匹配, 支持带端口的域名和 IP, 支持通配符*,做二级域名或多级域名的通配 */
  818. DomainList: {
  819. /** 生效域名,例如www.qq.com/example,192.168.1.2:8080, *.qq.com */
  820. Domains: string[];
  821. };
  822. /** 是否允许空 Referer 访问,枚举值:Allow、Deny,默认值为 Deny */
  823. EmptyReferConfiguration?: 'Allow' | 'Deny';
  824. }
  825. /** putBucketReferer 接口参数 */
  826. interface PutBucketRefererParams extends BucketParams {
  827. /** 防盗链配置信息 */
  828. RefererConfiguration: RefererConfiguration;
  829. }
  830. /** putBucketReferer 接口返回值 */
  831. interface PutBucketRefererResult extends GeneralResult {}
  832. // getBucketReferer
  833. /** getBucketReferer 接口参数 */
  834. interface GetBucketRefererParams extends BucketParams {}
  835. /** getBucketReferer 接口返回值 */
  836. interface GetBucketRefererResult extends GeneralResult {
  837. /** 防盗链配置信息 */
  838. RefererConfiguration: RefererConfiguration;
  839. }
  840. // putBucketDomain
  841. /** 绑定的域名条目 */
  842. interface DomainRule {
  843. /** 是否启用。枚举值:ENABLED:启用,DISABLED:禁用,必选 */
  844. Status: 'DISABLED' | 'ENABLED';
  845. /** 完整域名,必选 */
  846. Name: string;
  847. /** 源站类型。枚举值:REST:默认源站,WEBSITE:静态源站源站,ACCELERATE:全球加速源站,必选 */
  848. Type: 'REST' | 'WEBSITE' | 'ACCELERATE';
  849. /** 如果指定域名已经作为其他存储桶的自定义域名,那么可以指定该元素强制将该域名作为当前存储桶的自定义域名。当前只支持 CNAME,代表您需要先将该域名的 CNAME 指向当前存储桶的源站域名(根据 Type 元素的不同对应为默认源站、静态网站源站或全球加速源站)后才能通过该接口设置自定义域名。可选 */
  850. ForcedReplacement?: string;
  851. }
  852. /** putBucketDomain 接口参数 */
  853. interface PutBucketDomainParams extends BucketParams {
  854. /** 绑定的域名条目 */
  855. DomainRule: DomainRule[];
  856. }
  857. /** putBucketDomain 接口返回值 */
  858. interface PutBucketDomainResult extends GeneralResult {}
  859. // getBucketDomain
  860. /** getBucketDomain 接口参数 */
  861. interface GetBucketDomainParams extends BucketParams {}
  862. /** getBucketDomain 接口返回值 */
  863. interface GetBucketDomainResult extends GeneralResult {
  864. /** 绑定的域名条目 */
  865. DomainRule: DomainRule[];
  866. }
  867. // deleteBucketDomain
  868. /** deleteBucketDomain 接口参数 */
  869. interface DeleteBucketDomainParams extends BucketParams {}
  870. /** deleteBucketDomain 接口返回值 */
  871. interface DeleteBucketDomainResult extends GeneralResult {}
  872. // putBucketOrigin
  873. /** Origin 回源规则配置 */
  874. interface OriginRule {
  875. /** 通过优先级区分规则执行先后,必选 */
  876. RulePriority: 1;
  877. /** 回源类型,支持同步回源(Mirror)和异步回源(Proxy)两种模式。 枚举值:Mirror、Proxy。必选 */
  878. OriginType: 'Mirror' | 'Proxy';
  879. /** 回源配置,配置用户使用的 HTTP 传输协议等信息。必选 */
  880. OriginCondition: {
  881. /** 触发回源的 HTTP 状态码,默认为404。必选 */
  882. HTTPStatusCode: number;
  883. /** 触发回源的文件前缀,默认为空,任意文件均可触发。可选 */
  884. Prefix: Prefix;
  885. };
  886. /** 回源地址相关信息,必选 */
  887. OriginParameter: {
  888. /** 回源使用的协议,枚举值为 HTTP(使用 HTTP 协议),HTTPS(使用 HTTPS 协议)、FOLLOW(跟随用户使用的协议),默认值为 FOLLOW。必选 */
  889. Protocol: 'HTTP' | 'HTTPS' | 'FOLLOW';
  890. /** Proxy 模式下是否需要透传 HTTP 请求串,枚举值:true、false,默认为 true。可选 */
  891. FollowQueryString?: BooleanString;
  892. /** Proxy 模式下是否需要 Http 头部传输配置。可选 */
  893. HttpHeader?: {
  894. /** Proxy 模式下是否传输请求头部,枚举值:true、false,默认为 false。可选 */
  895. FollowHttpHeader?: BooleanString;
  896. /** 设置 Proxy 模式传输的请求头部。可选 */
  897. NewHttpHeader?: {
  898. /** 回源到源站时添加新的自定义头部,默认为空。可选 */
  899. Header?: {
  900. /** 用户设置的头部名称,默认为空。形式如 x-cos、oss、amz-ContentType、CacheControl、ContentDisposition、ContentEncoding、HttpExpiresDate、UserMetaData。可选 */
  901. Key?: string;
  902. /** 用户设置的头部值,默认为空。可选 */
  903. Value?: string;
  904. }[];
  905. };
  906. };
  907. /** Proxy 模式下源站 3XX 响应策略,枚举值:true、false,选择 true 时跟随源站 3xx 重定向请求获取到资源,并将资源保存到 COS 上;选择 false 时透传 3XX 响应,不获取资源),默认为 true。可选 */
  908. FollowRedirection: BooleanString;
  909. /** Proxy 模式下的返回码参数,枚举值:301、302,默认为 302。可选 */
  910. HttpRedirectCode: ('301' | '302')[];
  911. };
  912. /** 回源配置,配置用户使用的 HTTP 传输协议等信息。必选 */
  913. OriginInfo: {
  914. /** 源站信息。必选 */
  915. HostInfo: {
  916. /** 源站域名或者源站 IP。必选 */
  917. HostName: string;
  918. };
  919. /** 回源文件信息。必选 */
  920. FileInfo: {
  921. /** 回源文件前缀配置信息。可选 */
  922. PrefixConfiguration: {
  923. /** 回源文件的文件前缀,默认为空。可选 */
  924. Prefix: Prefix;
  925. };
  926. /** 回源文件后缀配置信息。可选 */
  927. SuffixConfiguration: {
  928. /** 回源文件的文件后缀,默认为空。可选 */
  929. Suffix: string;
  930. };
  931. };
  932. };
  933. }
  934. /** putBucketOrigin 接口参数 */
  935. interface PutBucketOriginParams extends BucketParams {
  936. /** Origin 回源规则配置 */
  937. OriginRule: OriginRule[];
  938. }
  939. /** putBucketOrigin 接口返回值 */
  940. interface PutBucketOriginResult extends GeneralResult {}
  941. // getBucketOrigin
  942. /** getBucketOrigin 接口参数 */
  943. interface GetBucketOriginParams extends BucketParams {}
  944. /** getBucketOrigin 接口返回值 */
  945. interface GetBucketOriginResult extends GeneralResult {
  946. /** Origin 回源规则配置 */
  947. OriginRule: OriginRule[];
  948. }
  949. // deleteBucketOrigin
  950. /** deleteBucketOrigin 接口参数 */
  951. interface DeleteBucketOriginParams extends BucketParams {}
  952. /** deleteBucketOrigin 接口返回值 */
  953. interface DeleteBucketOriginResult extends GeneralResult {}
  954. // putBucketLogging
  955. interface BucketLoggingStatus {
  956. /** 存储桶 logging 设置的具体信息,主要是目标存储桶 */
  957. LoggingEnabled?: {
  958. /** 存放日志的目标存储桶,可以是同一个存储桶(但不推荐),或同一账户下、同一地域的存储桶 */
  959. TargetBucket: Bucket;
  960. /** 日志存放在目标存储桶的指定路径 */
  961. TargetPrefix: Prefix;
  962. };
  963. }
  964. /** putBucketLogging 接口参数 */
  965. interface PutBucketLoggingParams extends BucketParams {
  966. /** 说明日志记录配置的状态,如果无子节点信息则意为关闭日志记录 */
  967. BucketLoggingStatus: BucketLoggingStatus;
  968. }
  969. /** putBucketLogging 接口返回值 */
  970. interface PutBucketLoggingResult extends GeneralResult {}
  971. // getBucketLogging
  972. /** getBucketLogging 接口参数 */
  973. interface GetBucketLoggingParams extends BucketParams {}
  974. /** getBucketLogging 接口返回值 */
  975. interface GetBucketLoggingResult extends GeneralResult {
  976. /** 说明日志记录配置的状态,如果无子节点信息则意为关闭日志记录 */
  977. BucketLoggingStatus: BucketLoggingStatus;
  978. }
  979. interface BaseInventoryConfiguration {
  980. /** 清单的名称,与请求参数中的 id 对应,可选 */
  981. Id: string;
  982. /** 是否在清单中包含对象版本:如果设置为 All,清单中将会包含所有对象版本,并在清单中增加 VersionId,IsLatest,DeleteMarker 这几个字段,如果设置为 Current,则清单中不包含对象版本信息,必选 */
  983. IncludedObjectVersions: 'All' | 'Current';
  984. /** 筛选待分析对象。清单功能将分析符合 Filter 中设置的前缀的对象,可选 */
  985. Filter?: {
  986. /** 筛选待分析对象。清单功能将分析符合 Filter 中设置的前缀的对象,可选 */
  987. Prefix?: Prefix;
  988. /** 需要分析的对象的创建时间范围 */
  989. Period?: {
  990. StartTime?: number;
  991. EndTime?: number;
  992. };
  993. /** 筛选待分析对象时,可以用对象标签(支持多个)作为过滤条件 */
  994. Tag?: Tag[];
  995. /** 筛选待分析对象时,如果同时需要前缀与对象标签条件,需要用 And 包装 */
  996. And?: {
  997. Prefix: Prefix;
  998. Tag: Tag[];
  999. };
  1000. };
  1001. /** 设置清单结果中应包含的分析项目,可选 */
  1002. OptionalFields?: string[];
  1003. /** 描述存放清单结果的信息,必选 */
  1004. Destination: {
  1005. /** 清单结果导出后存放的存储桶信息,必选 */
  1006. COSBucketDestination: {
  1007. /** 清单分析结果的存储桶名,如:qcs::cos:ap-guangzhou::bucket-logging-1250000000,必选 */
  1008. Bucket: string;
  1009. /** 清单分析结果的文件形式,可选项为 CSV 格式,必选 */
  1010. Format: 'CSV';
  1011. /** 存储桶的所有者 ID,例如100000000001,可选 */
  1012. AccountId?: string;
  1013. /** 清单分析结果的前缀,可选 */
  1014. Prefix?: Prefix;
  1015. /** 为清单结果提供服务端加密的选项,可选 */
  1016. Encryption?: {
  1017. /** COS 托管密钥的加密方式,无需填充,可选 */
  1018. SSECOS?: '';
  1019. };
  1020. };
  1021. };
  1022. }
  1023. // putBucketInventory
  1024. /** putBucketInventory 接口参数 */
  1025. interface InventoryConfiguration extends BaseInventoryConfiguration {
  1026. /** 清单是否启用的标识:如果设置为 true,清单功能将生效,如果设置为 false,将不生成任何清单,必选 */
  1027. IsEnabled: BooleanString;
  1028. /** 配置清单任务周期,必选 */
  1029. Schedule: {
  1030. /** 清单任务周期,可选项为按日或者按周,枚举值:Daily、Weekly,必选 */
  1031. Frequency: 'Daily' | 'Weekly';
  1032. };
  1033. }
  1034. interface PutBucketInventoryParams extends BucketParams {
  1035. /** 清单的名称,与请求参数中的 id 对应 */
  1036. Id: string;
  1037. /** 包含清单任务的详细信息 */
  1038. InventoryConfiguration: InventoryConfiguration;
  1039. }
  1040. /** putBucketInventory 接口返回值 */
  1041. interface PutBucketInventoryResult extends GeneralResult {}
  1042. // postBucketInventory
  1043. /** postBucketInventory 接口参数 */
  1044. interface PostBucketInventoryParams extends BucketParams {
  1045. /** 清单的名称,与请求参数中的 id 对应 */
  1046. Id: string;
  1047. /** 包含清单任务的详细信息 */
  1048. InventoryConfiguration: BaseInventoryConfiguration;
  1049. }
  1050. /** postBucketInventory 接口返回值 */
  1051. interface PostBucketInventoryResult extends GeneralResult {}
  1052. // getBucketInventory
  1053. /** getBucketInventory 接口参数 */
  1054. interface GetBucketInventoryParams extends BucketParams {
  1055. /** 清单的名称,与请求参数中的 id 对应 */
  1056. Id: string;
  1057. }
  1058. /** getBucketInventory 接口返回值 */
  1059. interface GetBucketInventoryResult extends GeneralResult {
  1060. /** 包含清单任务的详细信息 */
  1061. InventoryConfiguration: InventoryConfiguration;
  1062. }
  1063. // listBucketInventory
  1064. /** listBucketInventory 接口参数 */
  1065. interface ListBucketInventoryParams extends BucketParams {
  1066. ContinuationToken?: string;
  1067. }
  1068. /** listBucketInventory 接口返回值 */
  1069. interface ListBucketInventoryResult extends GeneralResult {
  1070. /** 包含清单任务的详细信息 */
  1071. InventoryConfigurations: Record<string, any>;
  1072. /** 当 COS 响应体中 IsTruncated 为 true,且 NextContinuationToken 节点中存在参数值时,您可以将这个参数作为 continuation-token 参数值,以获取下一页的清单任务信息。缺省值:None */
  1073. ContinuationToken: string;
  1074. /** 是否已列出所有清单任务信息的标识。如果已经展示完则为 false,否则为 true */
  1075. IsTruncated: BooleanString;
  1076. /** 下一页清单列表的标识。如果该参数中有值,则可将该值作为 continuation-token 参数并发起 GET 请求以获取下一页清单任务信息 */
  1077. NextContinuationToken?: string;
  1078. }
  1079. // deleteBucketInventory
  1080. /** deleteBucketInventory 接口参数 */
  1081. interface DeleteBucketInventoryParams extends BucketParams {
  1082. Id: string;
  1083. }
  1084. /** deleteBucketInventory 接口返回值 */
  1085. interface DeleteBucketInventoryResult extends GeneralResult {}
  1086. // putBucketAccelerate
  1087. /** 全球加速的具体信息 */
  1088. interface AccelerateConfiguration {
  1089. /** 说明全球加速功能是否开启,枚举值:Suspended、Enabled */
  1090. Status: 'Enabled' | 'Suspended';
  1091. }
  1092. /** putBucketAccelerate 接口参数 */
  1093. interface PutBucketAccelerateParams extends BucketParams {
  1094. /** 全球加速的具体信息 */
  1095. AccelerateConfiguration: AccelerateConfiguration;
  1096. }
  1097. /** putBucketAccelerate 接口返回值 */
  1098. interface PutBucketAccelerateResult extends GeneralResult {}
  1099. // getBucketAccelerate
  1100. /** getBucketAccelerate 接口参数 */
  1101. interface GetBucketAccelerateParams extends BucketParams {}
  1102. /** getBucketAccelerate 接口返回值 */
  1103. interface GetBucketAccelerateResult extends GeneralResult {
  1104. /** 全球加速的具体信息 */
  1105. InventoryConfiguration: AccelerateConfiguration;
  1106. }
  1107. // putBucketEncryption
  1108. /** 默认的服务端加密配置规则 */
  1109. interface EncryptionRule {
  1110. /** 服务端加密的默认配置信息 */
  1111. ApplySideEncryptionConfiguration: {
  1112. /** 要使用的服务端加密算法,枚举值:AES256 */
  1113. SSEAlgorithm: 'AES256';
  1114. };
  1115. }
  1116. /** 包含默认加密的配置参数 */
  1117. interface ServerSideEncryptionConfiguration {
  1118. /** 默认的服务端加密配置规则 */
  1119. Rule: EncryptionRule[];
  1120. }
  1121. /** putBucketEncryption 接口参数 */
  1122. interface PutBucketEncryptionParams extends BucketParams {
  1123. /** 包含默认加密的配置参数 */
  1124. ServerSideEncryptionConfiguration: ServerSideEncryptionConfiguration;
  1125. }
  1126. /** putBucketEncryption 接口返回值 */
  1127. interface PutBucketEncryptionResult extends GeneralResult {}
  1128. // getBucketAccelerate
  1129. /** getBucketEncryption 接口参数 */
  1130. interface GetBucketEncryptionParams extends BucketParams {}
  1131. /** getBucketEncryption 接口返回值 */
  1132. interface GetBucketEncryptionResult extends GeneralResult {
  1133. /** 默认加密的配置参数 */
  1134. ServerSideEncryptionConfiguration: ServerSideEncryptionConfiguration;
  1135. }
  1136. // deleteBucketEncryption
  1137. /** deleteBucketEncryption 接口参数 */
  1138. interface DeleteBucketEncryptionParams extends BucketParams {}
  1139. /** deleteBucketEncryption 接口返回值 */
  1140. interface DeleteBucketEncryptionResult extends GeneralResult {}
  1141. // headObject
  1142. /** headObject 接口参数 */
  1143. interface HeadObjectParams extends ObjectParams {}
  1144. /** headObject 接口返回值 */
  1145. interface HeadObjectResult extends GeneralResult {
  1146. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1147. ETag: ETag;
  1148. /** 对象的版本 ID */
  1149. VersionId?: string;
  1150. }
  1151. // getObject
  1152. /** getObject 接口参数 */
  1153. interface GetObjectParams extends ObjectParams {
  1154. DataType?: 'text' | 'blob' | 'arraybuffer';
  1155. /** 请求里的 Url Query 参数,传入该值中的 key/value 将会被 URLEncode */
  1156. Query?: Query;
  1157. /** 请求里的 Url Query 参数。传入该值将直接拼接在 Url 上,不会对其进行 URLEncode */
  1158. QueryString?: string;
  1159. /** 当对象在指定时间后被修改,则返回对象,否则返回 HTTP 状态码为304(Not Modified) */
  1160. IfModifiedSince?: string;
  1161. /** 当对象在指定时间后未被修改,则返回对象,否则返回 HTTP 状态码为412(Precondition Failed) */
  1162. IfUnmodifiedSince?: string;
  1163. /** 当对象的 ETag 与指定的值一致,则返回对象,否则返回 HTTP 状态码为412(Precondition Failed) */
  1164. IfMatch?: string;
  1165. /** 当对象的 ETag 与指定的值不一致,则返回对象,否则返回 HTTP 状态码为304(Not Modified) */
  1166. IfNoneMatch?: string;
  1167. /** 针对本次下载进行流量控制的限速值,必须为数字,单位默认为 bit/s。限速值设置范围为819200 - 838860800,即100KB/s - 100MB/s,如果超出该范围将返回400错误 */
  1168. TrafficLimit?: number;
  1169. /** 设置响应中的 Cache-Control 头部的值 */
  1170. ResponseCacheControl?: string;
  1171. /** 设置响应中的 Content-Disposition 头部的值 */
  1172. ResponseContentDisposition?: string;
  1173. /** 设置响应中的 Content-Encoding 头部的值 */
  1174. ResponseContentEncoding?: string;
  1175. /** 设置响应中的 Content-Language 头部的值 */
  1176. ResponseContentLanguage?: string;
  1177. /** 设置响应中的 Content-Type 头部的值 */
  1178. ResponseExpires?: string;
  1179. /** 设置响应中的 Expires 头部的值 */
  1180. ResponseContentType?: string;
  1181. /** RFC 2616 中定义的字节范围,范围值必须使用 bytes=first-last 格式,first 和 last 都是基于0开始的偏移量。例如 bytes=0-9 表示下载对象的开头10个字节的数据 ,如果不指定,则表示下载整个对象 */
  1182. Range?: string;
  1183. /** 当启用版本控制时,指定要下载的版本 ID,如不指定则下载对象的最新版本 */
  1184. VersionId?: string;
  1185. /** 下载的进度回调方法 */
  1186. onProgress?: onProgress;
  1187. }
  1188. /** getObject 接口返回值 */
  1189. interface GetObjectResult extends GeneralResult {
  1190. /** 对象内容 */
  1191. Body: string | Blob | ArrayBuffer;
  1192. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1193. ETag: ETag;
  1194. /** 对象的版本 ID */
  1195. VersionId?: string;
  1196. }
  1197. // putObject
  1198. /** putObject 接口参数 */
  1199. interface PutObjectParams extends ObjectParams {
  1200. /** 要上传对象内容 */
  1201. Body: UploadBody;
  1202. /** 上传的文件大小,单位 Byte 字节,如果不传且 Body 是流,会走服务端流式上传 */
  1203. ContentLength?: number;
  1204. /** 请求里的 Url Query 参数 */
  1205. Query?: string;
  1206. /** RFC 2616 中定义的缓存指令,将作为对象元数据保存 */
  1207. CacheControl?: string;
  1208. /** RFC 2616 中定义的文件名称,将作为对象元数据保存 */
  1209. ContentDisposition?: string;
  1210. /** RFC 2616 中定义的编码格式,将作为对象元数据保存 */
  1211. ContentEncoding?: string;
  1212. /** RFC 2616 中定义的 HTTP 请求内容类型(MIME),此头部用于描述待上传对象的内容类型,将作为对象元数据保存。例如text/html或image/jpeg */
  1213. ContentType?: string;
  1214. /** RFC 2616 中定义的缓存失效时间,将作为对象元数据保存 */
  1215. Expires?: string;
  1216. /** RFC 2616 中定义的缓存失效时间,将作为对象元数据保存 */
  1217. Expect?: string;
  1218. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  1219. ACL?: ObjectACL;
  1220. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1221. GrantRead?: Grant;
  1222. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1223. GrantReadAcp?: Grant;
  1224. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1225. GrantWriteAcp?: Grant;
  1226. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1227. GrantFullControl?: Grant;
  1228. /** 对象存储类型。例如 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING。默认值:STANDARD */
  1229. StorageClass?: StorageClass;
  1230. /** 上传文件时计算文件内容 md5 并设置为文件 x-cos-meta-md5 元数据 Header 字段 */
  1231. UploadAddMetaMd5?: boolean;
  1232. /** 包括用户自定义元数据头部后缀和用户自定义元数据信息,将作为对象元数据保存,大小限制为2KB,注意:用户自定义元数据信息支持下划线(_),但用户自定义元数据头部后缀不支持下划线,仅支持减号(-) */
  1233. 'x-cos-meta-*'?: string;
  1234. /** 任务开始上传的回调方法 */
  1235. onTaskReady?: (TaskId: COS.TaskId) => void;
  1236. onTaskStart?: (TaskInfo: COS.Task) => void;
  1237. /** 上传的进度回调方法 */
  1238. onProgress?: onProgress;
  1239. /** 续传校验的进度回调方法 */
  1240. onHashProgress?: onProgress;
  1241. }
  1242. /** putObject 接口返回值 */
  1243. interface PutObjectResult extends GeneralResult {
  1244. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1245. ETag: ETag;
  1246. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  1247. Location: string;
  1248. /** 对象的版本 ID */
  1249. VersionId?: VersionId;
  1250. }
  1251. /** appendObject 接口参数 */
  1252. interface AppendObjectParams extends PutObjectParams {
  1253. /** 追加操作的起始点 */
  1254. Position: number;
  1255. }
  1256. // deleteObject
  1257. /** deleteObject 接口参数 */
  1258. interface DeleteObjectParams extends ObjectParams {}
  1259. /** deleteObject 接口返回值 */
  1260. interface DeleteObjectResult extends GeneralResult {}
  1261. // deleteMultipleObject
  1262. /** deleteMultipleObject 接口参数 */
  1263. interface DeleteMultipleObjectParams extends BucketParams {
  1264. /** 要删除的对象列表 */
  1265. Objects: {
  1266. /** 要删除的对象键 */
  1267. Key: Key;
  1268. /** 要删除的对象版本 ID */
  1269. VersionId?: string;
  1270. }[];
  1271. /** 是否启动 Quiet 模式 */
  1272. Quiet?: boolean;
  1273. }
  1274. /** deleteMultipleObject 接口返回值 */
  1275. interface DeleteMultipleObjectResult extends GeneralResult {
  1276. Deleted: {
  1277. /** 删除成功的对象的对象键 */
  1278. Key: Key;
  1279. /** 删除成功的版本 ID,仅当请求中指定了要删除对象的版本 ID 时才返回该元素 */
  1280. VersionId?: VersionId;
  1281. /** 仅当对该对象的删除创建了一个删除标记,或删除的是该对象的一个删除标记时才返回该元素,布尔值,固定为 true */
  1282. DeleteMarker?: BooleanString;
  1283. /** 仅当对该对象的删除创建了一个删除标记,或删除的是该对象的一个删除标记时才返回该元素,值为创建或删除的删除标记的版本 ID */
  1284. DeleteMarkerVersionId?: VersionId;
  1285. }[];
  1286. Error: {
  1287. /** 删除失败的对象的对象键 */
  1288. Key: Key;
  1289. /** 删除失败的版本 ID,仅当请求中指定了要删除对象的版本 ID 时才返回该元素 */
  1290. VersionId?: string;
  1291. /** 删除失败的错误码,用来定位唯一的错误条件和确定错误场景 */
  1292. Code?: string;
  1293. /** 删除失败的具体错误信息 */
  1294. Message?: string;
  1295. }[];
  1296. }
  1297. // getObjectAcl
  1298. /** getObjectAcl 接口参数 */
  1299. interface GetObjectAclParams extends ObjectParams {
  1300. /** 历史版本id */
  1301. VersionId?: VersionId;
  1302. }
  1303. /** getObjectAcl 接口返回值 */
  1304. interface GetObjectAclResult extends GeneralResult {
  1305. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write */
  1306. ACL: ObjectACL;
  1307. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  1308. GrantRead: Grant;
  1309. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  1310. GrantReadAcp: Grant;
  1311. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  1312. GrantWriteAcp: Grant;
  1313. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者 */
  1314. GrantFullControl: Grant;
  1315. /** 存储桶持有者信息 */
  1316. Owner: Owner;
  1317. /** 被授权者信息与权限信息 */
  1318. Grants: Grants[];
  1319. }
  1320. // putObjectAcl
  1321. /** putObjectAcl 接口参数 */
  1322. interface PutObjectAclParams extends ObjectParams {
  1323. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  1324. ACL?: ObjectACL;
  1325. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1326. GrantRead?: Grant;
  1327. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1328. GrantReadAcp?: Grant;
  1329. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1330. GrantWriteAcp?: Grant;
  1331. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1332. GrantFullControl?: Grant;
  1333. }
  1334. /** putObjectAcl 接口返回值 */
  1335. interface PutObjectAclResult extends GeneralResult {}
  1336. // optionsObject
  1337. /** optionsObject 接口参数 */
  1338. interface OptionsObjectParams extends ObjectParams {
  1339. /** 发起 CORS 请求所在的页面域名(Origin) */
  1340. Origin: string;
  1341. /** 发起 CORS 请求所用的方法(Method) */
  1342. AccessControlRequestMethod: Method;
  1343. /** 发起 CORS 请求时使用的 HTTP 请求头部,不区分英文大小写,可使用英文逗号(,)分隔多个头部 */
  1344. AccessControlRequestHeaders: string;
  1345. }
  1346. /** optionsObject 接口返回值 */
  1347. interface OptionsObjectResult extends GeneralResult {
  1348. /** 允许发起 CORS 的域名,可能的值有以下两种:
  1349. *:代表允许所有域名
  1350. 请求头 Origin 中指定的域名:代表允许指定域名 */
  1351. AccessControlAllowOrigin: string;
  1352. /** 允许发起 CORS 请求所使用的方法(Method),可使用英文逗号(,)分隔多个方法 */
  1353. AccessControlAllowMethods: string;
  1354. /** 允许发起 CORS 请求带的 HTTP 头部,不区分英文大小写,可使用英文逗号(,)分隔多个头部 */
  1355. AccessControlAllowHeaders: string;
  1356. /** 允许浏览器获取的 CORS 请求中的 HTTP 响应头部,不区分英文大小写,可使用英文逗号(,)分隔多个头部 */
  1357. AccessControlExposeHeaders: string;
  1358. /** CORS 配置的有效时间,单位为秒,在有效时间内,浏览器无须为同一请求再次发起预检请求 */
  1359. AccessControlMaxAge: string;
  1360. }
  1361. // restoreObject
  1362. interface RestoreRequest {
  1363. /** 指定恢复出的临时副本的有效时长,单位为“天” */
  1364. Days: number | string;
  1365. /** 恢复工作参数 */
  1366. CASJobParameters: {
  1367. /** 恢复时,Tier 可以指定为支持的恢复模式。
  1368. 对于恢复归档存储类型数据,有三种恢复模式,分别为:
  1369. Expedited:极速模式,恢复任务在1 - 5分钟内可完成。
  1370. Standard:标准模式,恢复任务在3 - 5小时内完成
  1371. Bulk:批量模式,恢复任务在5 - 12小时内完成。
  1372. 对于恢复深度归档存储类型数据,有两种恢复模式,分别为:
  1373. Standard:标准模式,恢复时间为12 - 24小时。
  1374. Bulk:批量模式,恢复时间为24 - 48小时。 */
  1375. Tier: 'Expedited' | 'Standard' | 'Bulk';
  1376. };
  1377. }
  1378. /** restoreObject 接口参数 */
  1379. interface RestoreObjectParams extends ObjectParams {
  1380. /** 包含 POST Object restore 操作的所有请求信息 */
  1381. RestoreRequest: RestoreRequest;
  1382. /** 当启用版本控制时,指定要恢复的版本 ID,如不指定则恢复对象的最新版本 */
  1383. VersionId?: VersionId;
  1384. }
  1385. /** restoreObject 接口返回值 */
  1386. interface RestoreObjectResult extends GeneralResult {}
  1387. // selectObjectContent
  1388. /** selectObjectContent 接口参数 */
  1389. interface SelectObjectContentParams extends ObjectParams {
  1390. /** 接口的版本信息,当前最新版本是 2 */
  1391. SelectType: number;
  1392. /** 检索参数,当前版本支持检索 JSON、CSV 文件内容 */
  1393. SelectRequest: Record<string, any>;
  1394. /** 当启用版本控制时,指定要检索的版本 ID,如不指定则检索对象的最新版本 */
  1395. VersionId?: VersionId;
  1396. }
  1397. /** selectObjectContent 接口返回值 */
  1398. interface SelectObjectContentResult extends GeneralResult {
  1399. /** 查询过程统计信息 */
  1400. Stats: {
  1401. /** 如果文件是压缩文件,该数值代表文件解压前的字节大小;如果文件不是压缩文件,该数值即文件的字节大小 */
  1402. BytesScanned: number;
  1403. /** 如果文件是压缩文件,该数值代表文件解压后的字节大小;如果文件不是压缩文件,该数值即文件的字节大小 */
  1404. BytesProcessed: number;
  1405. /** COS Select 在本次查询中返回的检索结果字节大小 */
  1406. BytesReturned: number;
  1407. };
  1408. /** 查询的结果内容 */
  1409. Payload?: string;
  1410. }
  1411. // putObjectCopy
  1412. /** putObjectCopy 接口参数 */
  1413. interface PutObjectCopyParams extends ObjectParams {
  1414. /** 源对象的 URL,其中对象键需经过 URLEncode,可以通过 versionId 参数指定源对象的版本,例如: sourcebucket-1250000001.cos.ap-shanghai.myqcloud.com/example-%E8%85%BE%E8%AE%AF%E4%BA%91.jpg 或 sourcebucket-1250000001.cos.ap-shanghai.myqcloud.com/example-%E8%85%BE%E8%AE%AF%E4%BA%91.jpg?versionId=MTg0NDUxNzYzMDc0NDMzNDExOTc */
  1415. CopySource: string;
  1416. /** 是否复制源对象的元数据信息,枚举值:Copy,Replaced,默认为 Copy。如果标记为 Copy,则复制源对象的元数据信息;如果标记为 Replaced,则按本次请求的请求头中的元数据信息作为目标对象的元数据信息;当目标对象和源对象为同一对象时,即用户试图修改元数据时,则标记必须为 Replaced */
  1417. MetadataDirective?: 'Copy' | 'Replaced';
  1418. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  1419. ACL?: ObjectACL;
  1420. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1421. GrantRead?: Grant;
  1422. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1423. GrantReadAcp?: Grant;
  1424. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1425. GrantWriteAcp?: Grant;
  1426. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1427. GrantFullControl?: Grant;
  1428. /** 当对象在指定时间后被修改,则执行复制操作,否则返回 HTTP 状态码为412(Precondition Failed) */
  1429. CopySourceIfModifiedSince?: string;
  1430. /** 当对象在指定时间后未被修改,则执行复制操作,否则返回 HTTP 状态码为412(Precondition Failed) */
  1431. CopySourceIfUnmodifiedSince?: string;
  1432. /** 当对象的 ETag 与指定的值一致,则执行复制操作,否则返回 HTTP 状态码为412(Precondition Failed) */
  1433. CopySourceIfMatch?: string;
  1434. /** 当对象的 ETag 与指定的值不一致,则执行复制操作,否则返回 HTTP 状态码为412(Precondition Failed) */
  1435. CopySourceIfNoneMatch?: string;
  1436. /** 对象存储类型。例如 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING。默认值:STANDARD */
  1437. StorageClass?: StorageClass;
  1438. /** RFC 2616 中定义的缓存指令,将作为目标对象元数据保存 */
  1439. CacheControl?: string;
  1440. /** RFC 2616 中定义的文件名称,将作为目标对象元数据保存 */
  1441. ContentDisposition?: string;
  1442. /** RFC 2616 中定义的编码格式,将作为目标对象元数据保存 */
  1443. ContentEncoding?: string;
  1444. /** RFC 2616 中定义的 HTTP 请求内容类型(MIME),此头部用于描述目标对象的内容类型,将作为目标对象元数据保存。例如 text/html 或 image/jpeg。 */
  1445. ContentType?: string;
  1446. /** RFC 2616 中定义的缓存失效时间,将作为目标对象元数据保存 */
  1447. Expires?: string;
  1448. /** 包括用户自定义元数据头部后缀和用户自定义元数据信息,将作为目标对象元数据保存,大小限制为2KB。注意:用户自定义元数据信息支持下划线(_),但用户自定义元数据头部后缀不支持下划线,仅支持减号(-) */
  1449. 'x-cos-meta-*'?: string;
  1450. }
  1451. /** putObjectCopy 接口返回值 */
  1452. interface PutObjectCopyResult extends GeneralResult {
  1453. ETag: string;
  1454. CRC64: string;
  1455. LastModified: string;
  1456. VersionId: string;
  1457. Location: Location;
  1458. }
  1459. // putObjectTagging
  1460. /** putObjectTagging 接口参数 */
  1461. interface PutObjectTaggingParams extends ObjectParams {
  1462. /** 标签集合,最多支持10个标签 */
  1463. Tags: Tag[];
  1464. /** 对象的版本 ID;当未启用版本控制时,该节点的值为空字符串;当启用版本控制时,启用版本控制之前的对象,其版本 ID 为 null;当暂停版本控制时,新上传的对象其版本 ID 为 null,且同一个对象最多只存在一个版本 ID 为 null 的对象版本 */
  1465. VersionId?: VersionId;
  1466. }
  1467. /** putObjectTagging 接口返回值 */
  1468. interface PutObjectTaggingResult extends GeneralResult {}
  1469. // getObjectTagging
  1470. /** getObjectTagging 接口参数 */
  1471. interface GetObjectTaggingParams extends ObjectParams {}
  1472. /** getObjectTagging 接口返回值 */
  1473. interface GetObjectTaggingResult extends GeneralResult {
  1474. /** 标签集合,最多支持10个标签 */
  1475. Tags: Tag[];
  1476. }
  1477. // deleteObjectTagging
  1478. /** deleteObjectTagging 接口参数 */
  1479. interface DeleteObjectTaggingParams extends ObjectParams {}
  1480. /** deleteObjectTagging 接口返回值 */
  1481. interface DeleteObjectTaggingResult extends GeneralResult {}
  1482. // multipartInit
  1483. /** multipartInit 接口参数 */
  1484. interface MultipartInitParams extends ObjectParams {
  1485. /** RFC 2616 中定义的缓存指令,将作为对象元数据保存 */
  1486. CacheControl?: string;
  1487. /** RFC 2616 中定义的文件名称,将作为对象元数据保存 */
  1488. ContentDisposition?: string;
  1489. /** RFC 2616 中定义的编码格式,将作为对象元数据保存 */
  1490. ContentEncoding?: string;
  1491. /** RFC 2616 中定义的 HTTP 请求内容类型(MIME),此头部用于描述待上传对象的内容类型,将作为对象元数据保存。例如text/html或 image/jpeg */
  1492. ContentType?: string;
  1493. /** RFC 2616 中定义的缓存失效时间,将作为对象元数据保存 */
  1494. Expires?: string;
  1495. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  1496. ACL?: ObjectACL;
  1497. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1498. GrantRead?: Grant;
  1499. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1500. GrantReadAcp?: Grant;
  1501. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1502. GrantWriteAcp?: Grant;
  1503. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1504. GrantFullControl?: Grant;
  1505. /** 请求里的 Url Query 参数 */
  1506. Query?: Query;
  1507. /** 对象存储类型。例如 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING。默认值:STANDARD */
  1508. StorageClass?: StorageClass;
  1509. /** 包括用户自定义元数据头部后缀和用户自定义元数据信息,将作为对象元数据保存,大小限制为2KB。注意:用户自定义元数据信息支持下划线(_),但用户自定义元数据头部后缀不支持下划线,仅支持减号(-) */
  1510. 'x-cos-meta-*'?: string;
  1511. }
  1512. /** multipartInit 接口返回值 */
  1513. interface MultipartInitResult extends GeneralResult {
  1514. UploadId: string;
  1515. }
  1516. // multipartUpload
  1517. /** multipartUpload 接口参数 */
  1518. interface MultipartUploadParams extends ObjectParams {
  1519. /** 分块上传的任务 ID */
  1520. UploadId: UploadId;
  1521. /** 标识本次分块上传的编号,范围在1 - 10000 */
  1522. PartNumber: PartNumber;
  1523. /** 要上传分片内容 */
  1524. Body: UploadBody;
  1525. /** 要上传分片内容大小 */
  1526. ContentLength?: number;
  1527. /** 服务端加密算法 */
  1528. ServerSideEncryption?: string;
  1529. }
  1530. /** multipartUpload 接口返回值 */
  1531. interface MultipartUploadResult extends GeneralResult {
  1532. /** 返回对象的 MD5 算法校验值,ETag 的值可以用于检查分块的内容是否发生变化 */
  1533. ETag: ETag;
  1534. }
  1535. // uploadPartCopy
  1536. /** uploadPartCopy 接口参数 */
  1537. interface UploadPartCopyParams extends ObjectParams {
  1538. /** 源对象 URL 路径,可以通过 versionid 子资源指定历史版本 */
  1539. CopySource: string;
  1540. /** 分块上传的任务 ID */
  1541. UploadId: UploadId;
  1542. /** 标识本次分块上传的编号,范围在1 - 10000 */
  1543. PartNumber: PartNumber;
  1544. /** 源对象的字节范围,范围值必须使用 bytes=first-last 格式,first 和 last 都是基于 0 开始的偏移量。例如 bytes=0-9 表示您希望拷贝源对象的开头10个字节的数据,如果不指定,则表示拷贝整个对象 */
  1545. CopySourceRange?: string;
  1546. /** 当 Object 在指定时间后被修改,则执行操作,否则返回412,可与 x-cos-copy-source-If-None-Match 一起使用,与其他条件联合使用返回冲突 */
  1547. CopySourceIfModifiedSince?: string;
  1548. /** 当 Object 在指定时间后未被修改,则执行操作,否则返回412,可与 x-cos-copy-source-If-Match 一起使用,与其他条件联合使用返回冲突 */
  1549. CopySourceIfUnmodifiedSince?: string;
  1550. /** 当 Object 的 Etag 和给定一致时,则执行操作,否则返回412,可与 x-cos-copy-source-If-Unmodified-Since 一起使用,与其他条件联合使用返回冲突 */
  1551. CopySourceIfMatch?: string;
  1552. /** 当 Object 的 Etag 和给定不一致时,则执行操作,否则返回412,可与 x-cos-copy-source-If-Modified-Since 一起使用,与其他条件联合使用返回冲突 */
  1553. CopySourceIfNoneMatch?: string;
  1554. }
  1555. /** uploadPartCopy 接口返回值 */
  1556. interface UploadPartCopyResult extends GeneralResult {
  1557. /** 返回对象的 MD5 算法校验值,ETag 的值可以用于检查分块的内容是否发生变化 */
  1558. ETag: ETag;
  1559. }
  1560. // multipartComplete
  1561. /** multipartComplete 接口参数 */
  1562. interface MultipartCompleteParams extends ObjectParams {
  1563. /** 分块上传的任务 ID */
  1564. UploadId: UploadId;
  1565. /** 用来说明本次分块上传中每个块的信息 */
  1566. Parts: Part[];
  1567. }
  1568. /** multipartComplete 接口返回值 */
  1569. interface MultipartCompleteResult extends GeneralResult {
  1570. /** 使用 Upload Part 请求上传分块成功后返回的 ETag 响应头部的值 */
  1571. ETag: ETag;
  1572. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  1573. Location: Location;
  1574. /** 对象的版本 ID;当未启用版本控制时,该节点的值为空字符串;当启用版本控制时,启用版本控制之前的对象,其版本 ID 为 null;当暂停版本控制时,新上传的对象其版本 ID 为 null,且同一个对象最多只存在一个版本 ID 为 null 的对象版本 */
  1575. VersionId?: VersionId;
  1576. }
  1577. // multipartList
  1578. /** multipartList 接口参数 */
  1579. interface MultipartListParams extends BucketParams {
  1580. /** 限定返回的 Object key 必须以 Prefix 作为前缀。注意使用 prefix 查询时,返回的 key 中仍会包含 Prefix。 */
  1581. Prefix: Prefix;
  1582. /** 一个字符的分隔符,常用 / 字符,用于对对象键进行分组。所有对象键中从 prefix 或从头(如未指定 prefix)到首个 delimiter 之间相同的部分将作为 CommonPrefixes 下的一个 Prefix 节点。被分组的对象键不再出现在后续对象列表中 */
  1583. Delimiter: Delimiter;
  1584. /** 设置最大返回的 multipart 数量,合法取值从1到1000,默认1000 */
  1585. MaxUploads?: number;
  1586. /** 与 upload-id-marker 一起使用:当 upload-id-marker 未被指定时,ObjectName 字母顺序大于 key-marker 的条目将被列出。当 upload-id-marker 被指定时,ObjectName 字母顺序大于 key-marker 的条目被列出,ObjectName 字母顺序等于 key-marker 同时 UploadId 大于 upload-id-marker 的条目将被列出。 */
  1587. KeyMarker?: Key;
  1588. /** 与 key-marker 一起使用:当 key-marker 未被指定时,upload-id-marker 将被忽略。当 key-marker 被指定时,ObjectName字母顺序大于 key-marker 的条目被列出,ObjectName 字母顺序等于 key-marker 同时 UploadId 大于 upload-id-marker 的条目将被列出。 */
  1589. UploadIdMarker?: UploadId;
  1590. /** 规定返回值的编码方式,可选值:url,代表返回的对象键为 URL 编码(百分号编码)后的值,例如“腾讯云”将被编码为%E8%85%BE%E8%AE%AF%E4%BA%91 */
  1591. EncodingType?: EncodingType;
  1592. }
  1593. /** multipartList 接口返回值 */
  1594. interface MultipartListResult extends GeneralResult {
  1595. /** 每个上传任务的信息 */
  1596. Upload: {
  1597. /** 对象键 */
  1598. Key: Key;
  1599. /** 分块上传的任务 ID */
  1600. UploadId: UploadId;
  1601. /** 上传任务发起者的信息 */
  1602. Initiator: Initiator;
  1603. /** 上传任务所有者的信息 */
  1604. Owner: Owner;
  1605. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  1606. StorageClass: StorageClass;
  1607. /** UploadId 的创建时间,为 ISO8601 格式,例如2019-05-24T10:56:40Z */
  1608. Initiated: IsoDateTime;
  1609. }[];
  1610. /** 仅当响应条目有截断(IsTruncated 为 true)才会返回该节点,该节点的值为当前响应条目中的最后一个对象键,当需要继续请求后续条目时,将该节点的值作为下一次请求的 marker 参数传入 */
  1611. IsTruncated: BooleanString;
  1612. /** 假如返回条目被截断,则返回的 NextKeyMarker 就是下一个条目的起点。 */
  1613. NextKeyMarker: Key;
  1614. /** 假如返回条目被截断,则返回的 UploadId 就是下一个条目的起点。 */
  1615. NextUploadIdMarker: UploadId;
  1616. }
  1617. // multipartListPart
  1618. /** multipartListPart 接口参数 */
  1619. interface MultipartListPartParams extends ObjectParams {
  1620. /** 请求的对象键,最前面不带 /,例如 images/1.jpg */
  1621. Key: Key;
  1622. /** 标识本次分块上传的 ID,使用 Initiate Multipart Upload 接口初始化分块上传时得到的 UploadId */
  1623. UploadId: UploadId;
  1624. /** 单次返回最大的条目数量,默认1000 */
  1625. MaxParts?: number;
  1626. /** 默认以 UTF-8 二进制顺序列出条目,所有列出条目从 marker 开始 */
  1627. PartNumberMarker?: string;
  1628. /** 规定返回值的编码方式,可选值:url,代表返回的对象键为 URL 编码(百分号编码)后的值,例如“腾讯云”将被编码为%E8%85%BE%E8%AE%AF%E4%BA%91 */
  1629. EncodingType?: EncodingType;
  1630. }
  1631. /** multipartListPart 接口返回值 */
  1632. interface MultipartListPartResult extends GeneralResult {
  1633. /** 用来说明本次分块上传中每个块的信息 */
  1634. Part: {
  1635. /** 块的编号 */
  1636. PartNumber: PartNumber;
  1637. /** 说明块最后被修改时间 */
  1638. LastModified: IsoDateTime;
  1639. /** 块的 MD5 算法校验值 */
  1640. ETag: ETag;
  1641. /** 说明块大小,单位是 Byte */
  1642. Size: number;
  1643. }[];
  1644. /** 上传任务所有者的信息 */
  1645. Owner: Owner;
  1646. /** 上传任务发起者的信息 */
  1647. Initiator: Initiator;
  1648. /** 假如返回条目被截断,则返回 NextMarker 就是下一个条目的起点 */
  1649. NextPartNumberMarker: number;
  1650. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  1651. StorageClass: StorageClass;
  1652. /** 仅当响应条目有截断(IsTruncated 为 true)才会返回该节点,该节点的值为当前响应条目中的最后一个对象键,当需要继续请求后续条目时,将该节点的值作为下一次请求的 marker 参数传入 */
  1653. IsTruncated: BooleanString;
  1654. }
  1655. // multipartAbort
  1656. /** multipartAbort 接口参数 */
  1657. interface MultipartAbortParams extends ObjectParams {
  1658. UploadId: string;
  1659. }
  1660. /** multipartAbort 接口返回值 */
  1661. interface MultipartAbortResult extends GeneralResult {}
  1662. // sliceUploadFile
  1663. /** sliceUploadFile 接口参数 */
  1664. interface SliceUploadFileParams extends ObjectParams {
  1665. /** 要上传的本地文件对象 */
  1666. Body: File | Blob;
  1667. /** 分块上传时,每片的字节数大小,默认值1048576(1MB) */
  1668. ChunkSize?: number;
  1669. /** 分块上传时,并发数,默认值1 */
  1670. AsyncLimit?: number;
  1671. /** 请求里的 Url Query 参数 */
  1672. Query?: string;
  1673. /** RFC 2616 中定义的缓存指令,将作为对象元数据保存 */
  1674. CacheControl?: string;
  1675. /** RFC 2616 中定义的文件名称,将作为对象元数据保存 */
  1676. ContentDisposition?: string;
  1677. /** RFC 2616 中定义的编码格式,将作为对象元数据保存 */
  1678. ContentEncoding?: string;
  1679. /** RFC 2616 中定义的 HTTP 请求内容类型(MIME),此头部用于描述待上传对象的内容类型,将作为对象元数据保存。例如text/html或image/jpeg */
  1680. ContentType?: string;
  1681. /** RFC 2616 中定义的缓存失效时间,将作为对象元数据保存 */
  1682. Expires?: string;
  1683. /** RFC 2616 中定义的缓存失效时间,将作为对象元数据保存 */
  1684. Expect?: string;
  1685. /** 允许用户自定义存储桶权限,有效值:private | public-read | public-read-write,可选 */
  1686. ACL?: ObjectACL;
  1687. /** 赋予被授权者读取对象的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1688. GrantRead?: Grant;
  1689. /** 赋予被授权者读取对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1690. GrantReadAcp?: Grant;
  1691. /** 赋予被授权者写入对象的访问控制列表(ACL)的权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1692. GrantWriteAcp?: Grant;
  1693. /** 赋予被授权者操作对象的所有权限,格式:id="[OwnerUin]",可使用半角逗号(,)分隔多组被授权者,可选 */
  1694. GrantFullControl?: Grant;
  1695. /** 对象存储类型。枚举值 STANDARD | STANDARD_IA | ARCHIVE | DEEP_ARCHIVE | INTELLIGENT_TIERING | MAZ_STANDARD | MAZ_STANDARD_IA | MAZ_INTELLIGENT_TIERING @see https://cloud.tencent.com/document/product/436/33417 */
  1696. StorageClass?: StorageClass;
  1697. /** 包括用户自定义元数据头部后缀和用户自定义元数据信息,将作为对象元数据保存,大小限制为2KB,注意:用户自定义元数据信息支持下划线(_),但用户自定义元数据头部后缀不支持下划线,仅支持减号(-) */
  1698. 'x-cos-meta-*'?: string;
  1699. /** 任务开始上传的回调方法 */
  1700. onTaskReady?: (TaskId: COS.TaskId) => void;
  1701. onTaskStart?: (TaskInfo: COS.Task) => void;
  1702. /** 上传的进度回调方法 */
  1703. onProgress?: onProgress;
  1704. /** 续传校验的进度回调方法 */
  1705. onHashProgress?: onProgress;
  1706. }
  1707. /** sliceUploadFile 接口返回值 */
  1708. interface SliceUploadFileResult extends GeneralResult {
  1709. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1710. ETag: ETag;
  1711. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  1712. Location: string;
  1713. /** 对象的版本 ID */
  1714. VersionId?: VersionId;
  1715. }
  1716. // abortUploadTask
  1717. /** abortUploadTask 接口参数 */
  1718. interface AbortUploadTaskParams extends ObjectParams {
  1719. /** 清理上传任务的级别,枚举值 'task' | 'file' | 'bucket',默认 task */
  1720. Level?: 'task' | 'file' | 'bucket';
  1721. /** 要清理的 UploadId,Level 为 task 时必选 */
  1722. UploadId?: UploadId;
  1723. }
  1724. /** abortUploadTask 接口返回值 */
  1725. interface AbortUploadTaskResult extends GeneralResult {}
  1726. // uploadFiles
  1727. type UploadFileItemParams = (PutObjectParams | SliceUploadFileParams) & {
  1728. /** 要上传的本地文件路径 */
  1729. Body: UploadBody;
  1730. /** 上传的进度回调方法 */
  1731. onProgress?: onProgress;
  1732. /** 上传完成回调方法 */
  1733. onFileFinish?: onFileFinish;
  1734. };
  1735. /** 要上传的单个文件参数 */
  1736. interface UploadFileItemResult extends GeneralResult {
  1737. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1738. ETag: ETag;
  1739. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  1740. Location: string;
  1741. /** 对象的版本 ID */
  1742. VersionId?: VersionId;
  1743. }
  1744. interface UploadFilesParams {
  1745. /** 要上传的文件参数列表 */
  1746. files: UploadFileItemParams[];
  1747. /** 使用 uploadFiles 批量上传时,文件大小大于该数值将使用按分块上传,否则将调用简单上传,单位 Byte,默认值1048576(1MB) */
  1748. SliceSize?: number;
  1749. /** 所有文件整体上传进度回调方法 */
  1750. onProgress?: onProgress;
  1751. /** 所有文件上传完成回调方法 */
  1752. onFileFinish?: onFileFinish;
  1753. }
  1754. /** uploadFiles 接口返回值 */
  1755. interface UploadFilesResult extends GeneralResult {
  1756. /** 文件列表上传结果 */
  1757. files: {
  1758. /** 单个文件上传参数 */
  1759. options: UploadFileItemParams;
  1760. /** 单个文件上传错误信息 */
  1761. error: Error;
  1762. /** 单个文件上传成功信息 */
  1763. data: UploadFileItemResult;
  1764. }[];
  1765. }
  1766. // uploadFile 高级上传
  1767. interface FileFinishInfo {
  1768. err: Error;
  1769. data: UploadFileItemResult;
  1770. options: UploadFileItemParams;
  1771. }
  1772. type onFileFinish = (err: Error, data: UploadFileItemResult, options: UploadFileItemParams) => void;
  1773. type UploadFileParams = (PutObjectParams | SliceUploadFileParams) & {
  1774. /** 要上传的本地文件路径 */
  1775. Body: UploadBody;
  1776. /** 使用 uploadFile 高级上传时,文件大小大于该数值将使用按分块上传,否则将调用简单上传,单位 Byte,默认值1048576(1MB) */
  1777. SliceSize?: number;
  1778. /** 上传的进度回调方法 */
  1779. onProgress?: onProgress;
  1780. /** 上传完成回调方法 */
  1781. onFileFinish?: onFileFinish;
  1782. };
  1783. /** uploadFiles 接口返回值 */
  1784. interface UploadFileResult extends GeneralResult {
  1785. /** 对象的实体标签(Entity Tag),是对象被创建时标识对象内容的信息标签,可用于检查对象的内容是否发生变化,例如"8e0b617ca298a564c3331da28dcb50df"。此头部并不一定返回对象的 MD5 值,而是根据对象上传和加密方式而有所不同 */
  1786. ETag: ETag;
  1787. /** 创建的存储桶访问地址,不带 https:// 前缀,例如 examplebucket-1250000000.cos.ap-guangzhou.myqcloud.com/images/1.jpg */
  1788. Location: string;
  1789. /** 对象的版本 ID */
  1790. VersionId?: VersionId;
  1791. }
  1792. // sliceCopyFile
  1793. /** sliceCopyFile 接口参数 */
  1794. interface SliceCopyFileParams extends ObjectParams {
  1795. /** 源对象的 URL,其中对象键需经过 URLEncode,可以通过 versionId 参数指定源对象的版本,例如: sourcebucket-1250000001.cos.ap-shanghai.myqcloud.com/example-%E8%85%BE%E8%AE%AF%E4%BA%91.jpg 或 sourcebucket-1250000001.cos.ap-shanghai.myqcloud.com/example-%E8%85%BE%E8%AE%AF%E4%BA%91.jpg?versionId=MTg0NDUxNzYzMDc0NDMzNDExOTc */
  1796. CopySource: string;
  1797. /** 使用 sliceCopyFile 分块复制文件时,文件大小大于该数值将使用分块复制 ,否则将调用简单复制,默认值10485760(10MB) */
  1798. CopySliceSize?: number;
  1799. /** 使用 sliceCopyFile 分块复制文件时,每片的大小字节数,默认值10485760(10MB) */
  1800. CopyChunkSize?: number;
  1801. SliceSize?: number;
  1802. /** 分片复制进度回调方法 */
  1803. onProgress: onProgress;
  1804. }
  1805. /** sliceCopyFile 接口返回值 */
  1806. interface SliceCopyFileResult extends GeneralResult {}
  1807. // getTaskList
  1808. type TaskId = string;
  1809. type Task = {
  1810. /** 上传任务 ID */
  1811. id: TaskId;
  1812. /** 存储桶的名称,格式为<bucketname-appid>,例如examplebucket-1250000000 */
  1813. Bucket: Bucket;
  1814. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  1815. Region: Region;
  1816. /** 请求的对象键,最前面不带 /,例如 images/1.jpg */
  1817. Key: Key;
  1818. /** 上传状态 */
  1819. state: 'waiting' | 'checking' | 'uploading' | 'error' | 'paused' | 'success' | 'canceled';
  1820. /** 上传错误信息 */
  1821. error: string | Error | { Code: string; Message: string };
  1822. /** 已上传内容大小,单位 B(字节) */
  1823. loaded: number;
  1824. /** 上传文件大小,单位 B(字节) */
  1825. size: number;
  1826. /** 上传速递,单位 B/s */
  1827. speed: number;
  1828. /** 上传进度,范围 0-1,保留两位小数 */
  1829. percent: number;
  1830. /** 续传校验进度,范围 0-1,保留两位小数 */
  1831. hashPercent: number;
  1832. };
  1833. /** 上传任务列表 */
  1834. type TaskList = Task[];
  1835. // request
  1836. /** request 接口参数 */
  1837. interface RequestParams {
  1838. /** 操作方法,如 get,post,delete, head 等 HTTP 方法 */
  1839. Method: string;
  1840. /** 请求的对象键,最前面不带 / */
  1841. Key?: Key;
  1842. /** 请求里的 Url Query 参数 */
  1843. Query?: Query;
  1844. /** 请求里的 Body 参数 */
  1845. Body?: Body | string;
  1846. /** 请求的 API 动作接口(可理解为不带 = 的 Query 参数),如 acl、tagging、image_process 等 */
  1847. Action?: Action;
  1848. /** 请求url */
  1849. Url?: string;
  1850. /** 返回值body是否不需要解析 */
  1851. RawBody?: boolean;
  1852. /** 返回文件内容格式,如string、blob、arraybuffer */
  1853. DataType?: string;
  1854. ContentType?: string;
  1855. Bucket?: Bucket;
  1856. /** 存储桶所在地域 @see https://cloud.tencent.com/document/product/436/6224 */
  1857. Region?: Region;
  1858. /** 请求时带上的 Header 字段 */
  1859. Headers?: Headers;
  1860. }
  1861. /** Request 接口返回值 */
  1862. interface RequestResult extends GeneralResult {
  1863. Body?: string | Blob | ArrayBuffer;
  1864. }
  1865. // getObjectUrl
  1866. /** getObjectUrl 接口参数 */
  1867. interface GetObjectUrlParams extends ObjectParams {
  1868. /** 获取的 Url 是否计算签名 */
  1869. Sign?: boolean;
  1870. /** 请求方法 */
  1871. Method?: Method;
  1872. /** 请求里的 Url Query 参数,传入该值中的 key/value 将会被 URLEncode */
  1873. Query?: Query;
  1874. /** 请求里的 Url Query 参数。传入该值将直接拼接在 Url 上,不会对其进行 URLEncode */
  1875. QueryString?: string;
  1876. /** 签名几秒后失效,默认为900秒 */
  1877. Expires?: number;
  1878. /** 是否使用全球加速域名,默认false */
  1879. UseAccelerate?: boolean;
  1880. /** 调用操作存储桶和对象的 API 时自定义请求域名。可以使用模板,如"{Bucket}.cos.{Region}.myqcloud.com",即在调用 API 时会使用参数中传入的 Bucket 和 Region 进行替换。 */
  1881. Domain?: string;
  1882. /** http协议,枚举值'http:','https:' */
  1883. Protocol?: string;
  1884. }
  1885. /** getObjectUrl 接口返回值 */
  1886. interface GetObjectUrlResult {
  1887. /** 返回对象 Url */
  1888. Url: string;
  1889. }
  1890. // getV4Auth
  1891. interface GetV4AuthParams {
  1892. /** 计算签名用的密钥 SecretId,如果不传会用实例本身的凭证,可选 */
  1893. SecretId?: string;
  1894. /** 计算签名用的密钥 SecretKey,如果不传会用实例本身的凭证,可选 */
  1895. SecretKey?: string;
  1896. /** 存储桶的名称,命名规则为 BucketName-APPID,例如 examplebucket-1250000000 */
  1897. Bucket?: Bucket;
  1898. /** 请求的对象键,最前面不带 /,例如 images/1.jpg */
  1899. Key?: Key;
  1900. /** 签名几秒后失效,默认为900秒 */
  1901. Expires?: number;
  1902. }
  1903. // getAuth
  1904. interface GetAuthParams {
  1905. /** 计算签名用的密钥 SecretId,如果不传会用实例本身的凭证,可选 */
  1906. SecretId?: string;
  1907. /** 计算签名用的密钥 SecretKey,如果不传会用实例本身的凭证,可选 */
  1908. SecretKey?: string;
  1909. /** 请求的存储桶,如果传入了 Bucket、Region,签名会默认加上 Host 字段,可选 */
  1910. Bucket?: Bucket;
  1911. /** 请求的地域,如果传入了 Bucket、Region,签名会默认加上 Host 字段,可选 */
  1912. Region?: Region;
  1913. /** 请求方法 */
  1914. Method?: Method;
  1915. /** 请求的对象键,最前面不带 /,例如 images/1.jpg */
  1916. Key?: Key;
  1917. /** 签名几秒后失效,默认为900秒 */
  1918. Expires?: number;
  1919. /** 请求里的 Url Query 参数 */
  1920. Query?: Query;
  1921. /** 请求里的 Header 参数 */
  1922. Headers?: Headers;
  1923. /** 默认为true,将host加入签名计算,关闭后可能导致越权风险,建议保持为true */
  1924. ForceSignHost?: boolean;
  1925. }
  1926. }
  1927. /**
  1928. * COS 类,创建该类的实例可用于调用 COS API
  1929. * @see https://cloud.tencent.com/document/product/436/7751
  1930. */
  1931. declare class COS {
  1932. // 构造方法
  1933. constructor(options: COS.COSOptions);
  1934. // 静态属性
  1935. /** 当前 SDK 版本号 */
  1936. static version: string;
  1937. // 静态方法
  1938. /** 计算签名 */
  1939. static getAuthorization: (options: COS.StaticGetAuthorizationOptions) => string;
  1940. /** 工具 */
  1941. static util: COS.Util;
  1942. // 实例方法
  1943. /** 获取用户的 bucket 列表 @see https://cloud.tencent.com/document/product/436/8291 */
  1944. getService(params: COS.GetServiceParams, callback: (err: COS.CosError, data: COS.GetServiceResult) => void): void;
  1945. getService(params: COS.GetServiceParams): Promise<COS.GetServiceResult>;
  1946. /** 创建 Bucket,并初始化访问权限 @see https://cloud.tencent.com/document/product/436/7738 */
  1947. putBucket(params: COS.PutBucketParams, callback: (err: COS.CosError, data: COS.PutBucketResult) => void): void;
  1948. putBucket(params: COS.PutBucketParams): Promise<COS.PutBucketResult>;
  1949. /** 查看是否存在该 Bucket,是否有权限访问 @see https://cloud.tencent.com/document/product/436/7735 */
  1950. headBucket(params: COS.HeadBucketParams, callback: (err: COS.CosError, data: COS.HeadBucketResult) => void): void;
  1951. headBucket(params: COS.HeadBucketParams): Promise<COS.HeadBucketResult>;
  1952. /** 获取 Bucket 下的 Object 列表 @see https://cloud.tencent.com/document/product/436/7734 */
  1953. getBucket(params: COS.GetBucketParams, callback: (err: COS.CosError, data: COS.GetBucketResult) => void): void;
  1954. getBucket(params: COS.GetBucketParams): Promise<COS.GetBucketResult>;
  1955. /** 获取 Bucket 下的 Object 版本列表 @see https://cloud.tencent.com/document/product/436/35521 */
  1956. listObjectVersions(
  1957. params: COS.ListObjectVersionsParams,
  1958. callback: (err: COS.CosError, data: COS.ListObjectVersionsResult) => void
  1959. ): void;
  1960. listObjectVersions(params: COS.ListObjectVersionsParams): Promise<COS.ListObjectVersionsResult>;
  1961. /** 删除 Bucket @see https://cloud.tencent.com/document/product/436/7732 */
  1962. deleteBucket(
  1963. params: COS.DeleteBucketParams,
  1964. callback: (err: COS.CosError, data: COS.DeleteBucketResult) => void
  1965. ): void;
  1966. deleteBucket(params: COS.DeleteBucketParams): Promise<COS.DeleteBucketResult>;
  1967. /** 设置 Bucket 的 权限列表 @see https://cloud.tencent.com/document/product/436/7737 */
  1968. putBucketAcl(
  1969. params: COS.PutBucketAclParams,
  1970. callback: (err: COS.CosError, data: COS.PutBucketAclResult) => void
  1971. ): void;
  1972. putBucketAcl(params: COS.PutBucketAclParams): Promise<COS.PutBucketAclResult>;
  1973. /** 获取 Bucket 的 权限列表 @see https://cloud.tencent.com/document/product/436/7733 */
  1974. getBucketAcl(
  1975. params: COS.GetBucketAclParams,
  1976. callback: (err: COS.CosError, data: COS.GetBucketAclResult) => void
  1977. ): void;
  1978. getBucketAcl(params: COS.GetBucketAclParams): Promise<COS.GetBucketAclResult>;
  1979. /** 设置 Bucket 的 跨域设置 @see https://cloud.tencent.com/document/product/436/8279 */
  1980. putBucketCors(
  1981. params: COS.PutBucketCorsParams,
  1982. callback: (err: COS.CosError, data: COS.PutBucketCorsResult) => void
  1983. ): void;
  1984. putBucketCors(params: COS.PutBucketCorsParams): Promise<COS.PutBucketCorsResult>;
  1985. /** 获取 Bucket 的 跨域设置 @see https://cloud.tencent.com/document/product/436/8274 */
  1986. getBucketCors(
  1987. params: COS.GetBucketCorsParams,
  1988. callback: (err: COS.CosError, data: COS.GetBucketCorsResult) => void
  1989. ): void;
  1990. getBucketCors(params: COS.GetBucketCorsParams): Promise<COS.GetBucketCorsResult>;
  1991. /** 删除 Bucket 的 跨域设置 @see https://cloud.tencent.com/document/product/436/8283 */
  1992. deleteBucketCors(
  1993. params: COS.DeleteBucketCorsParams,
  1994. callback: (err: COS.CosError, data: COS.DeleteBucketCorsResult) => void
  1995. ): void;
  1996. deleteBucketCors(params: COS.DeleteBucketCorsParams): Promise<COS.DeleteBucketCorsResult>;
  1997. /** 获取 Bucket 的 地域信息 */
  1998. getBucketLocation(
  1999. params: COS.GetBucketLocationParams,
  2000. callback: (err: COS.CosError, data: COS.GetBucketLocationResult) => void
  2001. ): void;
  2002. getBucketLocation(params: COS.GetBucketLocationParams): Promise<COS.GetBucketLocationResult>;
  2003. /** 获取 Bucket 的读取权限策略 @see https://cloud.tencent.com/document/product/436/8282 */
  2004. putBucketPolicy(
  2005. params: COS.PutBucketPolicyParams,
  2006. callback: (err: COS.CosError, data: COS.PutBucketPolicyResult) => void
  2007. ): void;
  2008. putBucketPolicy(params: COS.PutBucketPolicyParams): Promise<COS.PutBucketPolicyResult>;
  2009. /** 获取 Bucket 的读取权限策略 @see https://cloud.tencent.com/document/product/436/8276 */
  2010. getBucketPolicy(
  2011. params: COS.GetBucketPolicyParams,
  2012. callback: (err: COS.CosError, data: COS.GetBucketPolicyResult) => void
  2013. ): void;
  2014. getBucketPolicy(params: COS.GetBucketPolicyParams): Promise<COS.GetBucketPolicyResult>;
  2015. /** 删除 Bucket 的 跨域设置 @see https://cloud.tencent.com/document/product/436/8285 */
  2016. deleteBucketPolicy(
  2017. params: COS.DeleteBucketPolicyParams,
  2018. callback: (err: COS.CosError, data: COS.DeleteBucketPolicyResult) => void
  2019. ): void;
  2020. deleteBucketPolicy(params: COS.DeleteBucketPolicyParams): Promise<COS.DeleteBucketPolicyResult>;
  2021. /** 设置 Bucket 的标签 @see https://cloud.tencent.com/document/product/436/34838 */
  2022. putBucketTagging(
  2023. params: COS.PutBucketTaggingParams,
  2024. callback: (err: COS.CosError, data: COS.PutBucketTaggingResult) => void
  2025. ): void;
  2026. putBucketTagging(params: COS.PutBucketTaggingParams): Promise<COS.PutBucketTaggingResult>;
  2027. /** 获取 Bucket 的标签设置 @see https://cloud.tencent.com/document/product/436/34837 */
  2028. getBucketTagging(
  2029. params: COS.GetBucketTaggingParams,
  2030. callback: (err: COS.CosError, data: COS.GetBucketTaggingResult) => void
  2031. ): void;
  2032. getBucketTagging(params: COS.GetBucketTaggingParams): Promise<COS.GetBucketTaggingResult>;
  2033. /** 删除 Bucket 的 标签设置 @see https://cloud.tencent.com/document/product/436/34836 */
  2034. deleteBucketTagging(
  2035. params: COS.DeleteBucketTaggingParams,
  2036. callback: (err: COS.CosError, data: COS.DeleteBucketTaggingResult) => void
  2037. ): void;
  2038. deleteBucketTagging(params: COS.DeleteBucketTaggingParams): Promise<COS.DeleteBucketTaggingResult>;
  2039. /** 设置 Bucket 生命周期 @see https://cloud.tencent.com/document/product/436/8280 */
  2040. putBucketLifecycle(
  2041. params: COS.PutBucketLifecycleParams,
  2042. callback: (err: COS.CosError, data: COS.PutBucketLifecycleResult) => void
  2043. ): void;
  2044. putBucketLifecycle(params: COS.PutBucketLifecycleParams): Promise<COS.PutBucketLifecycleResult>;
  2045. /** 获取 Bucket 生命周期 @see https://cloud.tencent.com/document/product/436/8280 */
  2046. getBucketLifecycle(
  2047. params: COS.GetBucketLifecycleParams,
  2048. callback: (err: COS.CosError, data: COS.GetBucketLifecycleResult) => void
  2049. ): void;
  2050. getBucketLifecycle(params: COS.GetBucketLifecycleParams): Promise<COS.GetBucketLifecycleResult>;
  2051. /** 删除 Bucket 生命周期 @see https://cloud.tencent.com/document/product/436/8278 */
  2052. deleteBucketLifecycle(
  2053. params: COS.DeleteBucketLifecycleParams,
  2054. callback: (err: COS.CosError, data: COS.DeleteBucketLifecycleResult) => void
  2055. ): void;
  2056. deleteBucketLifecycle(params: COS.DeleteBucketLifecycleParams): Promise<COS.DeleteBucketLifecycleResult>;
  2057. /** 设置 Bucket 版本 @see https://cloud.tencent.com/document/product/436/19889 */
  2058. putBucketVersioning(
  2059. params: COS.PutBucketVersioningParams,
  2060. callback: (err: COS.CosError, data: COS.PutBucketVersioningResult) => void
  2061. ): void;
  2062. putBucketVersioning(params: COS.PutBucketVersioningParams): Promise<COS.PutBucketVersioningResult>;
  2063. /** 获取 Bucket 版本 @see https://cloud.tencent.com/document/product/436/19888 */
  2064. getBucketVersioning(
  2065. params: COS.GetBucketVersioningParams,
  2066. callback: (err: COS.CosError, data: COS.GetBucketVersioningResult) => void
  2067. ): void;
  2068. getBucketVersioning(params: COS.GetBucketVersioningParams): Promise<COS.GetBucketVersioningResult>;
  2069. /** 设置 Bucket 副本 @see https://cloud.tencent.com/document/product/436/19223 */
  2070. putBucketReplication(
  2071. params: COS.PutBucketReplicationParams,
  2072. callback: (err: COS.CosError, data: COS.PutBucketReplicationResult) => void
  2073. ): void;
  2074. putBucketReplication(params: COS.PutBucketReplicationParams): Promise<COS.PutBucketReplicationResult>;
  2075. /** 获取 Bucket 副本 @see https://cloud.tencent.com/document/product/436/19222 */
  2076. getBucketReplication(
  2077. params: COS.GetBucketReplicationParams,
  2078. callback: (err: COS.CosError, data: COS.GetBucketReplicationResult) => void
  2079. ): void;
  2080. getBucketReplication(params: COS.GetBucketReplicationParams): Promise<COS.GetBucketReplicationResult>;
  2081. /** 删除 Bucket 副本 @see https://cloud.tencent.com/document/product/436/19221 */
  2082. deleteBucketReplication(
  2083. params: COS.DeleteBucketReplicationParams,
  2084. callback: (err: COS.CosError, data: COS.DeleteBucketReplicationResult) => void
  2085. ): void;
  2086. deleteBucketReplication(params: COS.DeleteBucketReplicationParams): Promise<COS.DeleteBucketReplicationResult>;
  2087. /** 设置 Bucket 静态网站配置信息 @see https://cloud.tencent.com/document/product/436/31930 */
  2088. putBucketWebsite(
  2089. params: COS.PutBucketWebsiteParams,
  2090. callback: (err: COS.CosError, data: COS.PutBucketWebsiteResult) => void
  2091. ): void;
  2092. putBucketWebsite(params: COS.PutBucketWebsiteParams): Promise<COS.PutBucketWebsiteResult>;
  2093. /** 获取 Bucket 的静态网站配置信息 @see https://cloud.tencent.com/document/product/436/31929 */
  2094. getBucketWebsite(
  2095. params: COS.GetBucketWebsiteParams,
  2096. callback: (err: COS.CosError, data: COS.GetBucketWebsiteResult) => void
  2097. ): void;
  2098. getBucketWebsite(params: COS.GetBucketWebsiteParams): Promise<COS.GetBucketWebsiteResult>;
  2099. /** 删除 Bucket 的静态网站配置 @see https://cloud.tencent.com/document/product/436/31928 */
  2100. deleteBucketWebsite(
  2101. params: COS.DeleteBucketWebsiteParams,
  2102. callback: (err: COS.CosError, data: COS.DeleteBucketWebsiteResult) => void
  2103. ): void;
  2104. deleteBucketWebsite(params: COS.DeleteBucketWebsiteParams): Promise<COS.DeleteBucketWebsiteResult>;
  2105. /** 设置 Bucket 的防盗链白名单或者黑名单 @see https://cloud.tencent.com/document/product/436/32492 */
  2106. putBucketReferer(
  2107. params: COS.PutBucketRefererParams,
  2108. callback: (err: COS.CosError, data: COS.PutBucketRefererResult) => void
  2109. ): void;
  2110. putBucketReferer(params: COS.PutBucketRefererParams): Promise<COS.PutBucketRefererResult>;
  2111. /** 获取 Bucket 的防盗链白名单或者黑名单 @see https://cloud.tencent.com/document/product/436/32493 */
  2112. getBucketReferer(
  2113. params: COS.GetBucketRefererParams,
  2114. callback: (err: COS.CosError, data: COS.GetBucketRefererResult) => void
  2115. ): void;
  2116. getBucketReferer(params: COS.GetBucketRefererParams): Promise<COS.GetBucketRefererResult>;
  2117. /** 设置 Bucket 自定义域名 */
  2118. putBucketDomain(
  2119. params: COS.PutBucketDomainParams,
  2120. callback: (err: COS.CosError, data: COS.PutBucketDomainResult) => void
  2121. ): void;
  2122. putBucketDomain(params: COS.PutBucketDomainParams): Promise<COS.PutBucketDomainResult>;
  2123. /** 获取 Bucket 的自定义域名 */
  2124. getBucketDomain(
  2125. params: COS.GetBucketDomainParams,
  2126. callback: (err: COS.CosError, data: COS.GetBucketDomainResult) => void
  2127. ): void;
  2128. getBucketDomain(params: COS.GetBucketDomainParams): Promise<COS.GetBucketDomainResult>;
  2129. /** 删除 Bucket 自定义域名 */
  2130. deleteBucketDomain(
  2131. params: COS.DeleteBucketDomainParams,
  2132. callback: (err: COS.CosError, data: COS.DeleteBucketDomainResult) => void
  2133. ): void;
  2134. deleteBucketDomain(params: COS.DeleteBucketDomainParams): Promise<COS.DeleteBucketDomainResult>;
  2135. /** 设置 Bucket 的回源 */
  2136. putBucketOrigin(
  2137. params: COS.PutBucketOriginParams,
  2138. callback: (err: COS.CosError, data: COS.PutBucketOriginResult) => void
  2139. ): void;
  2140. putBucketOrigin(params: COS.PutBucketOriginParams): Promise<COS.PutBucketOriginResult>;
  2141. /** 获取 Bucket 的回源 */
  2142. getBucketOrigin(
  2143. params: COS.GetBucketOriginParams,
  2144. callback: (err: COS.CosError, data: COS.GetBucketOriginResult) => void
  2145. ): void;
  2146. getBucketOrigin(params: COS.GetBucketOriginParams): Promise<COS.GetBucketOriginResult>;
  2147. /** 删除 Bucket 的回源 */
  2148. deleteBucketOrigin(
  2149. params: COS.DeleteBucketOriginParams,
  2150. callback: (err: COS.CosError, data: COS.DeleteBucketOriginResult) => void
  2151. ): void;
  2152. deleteBucketOrigin(params: COS.DeleteBucketOriginParams): Promise<COS.DeleteBucketOriginResult>;
  2153. /** 设置 Bucket 的日志记录 @see https://cloud.tencent.com/document/product/436/17054 */
  2154. putBucketLogging(
  2155. params: COS.PutBucketLoggingParams,
  2156. callback: (err: COS.CosError, data: COS.PutBucketLoggingResult) => void
  2157. ): void;
  2158. putBucketLogging(params: COS.PutBucketLoggingParams): Promise<COS.PutBucketLoggingResult>;
  2159. /** 获取 Bucket 的日志记录 @see https://cloud.tencent.com/document/product/436/17053 */
  2160. getBucketLogging(
  2161. params: COS.GetBucketLoggingParams,
  2162. callback: (err: COS.CosError, data: COS.GetBucketLoggingResult) => void
  2163. ): void;
  2164. getBucketLogging(params: COS.GetBucketLoggingParams): Promise<COS.GetBucketLoggingResult>;
  2165. /** 创建/编辑 Bucket 的清单任务 @see https://cloud.tencent.com/document/product/436/33707 */
  2166. putBucketInventory(
  2167. params: COS.PutBucketInventoryParams,
  2168. callback: (err: COS.CosError, data: COS.PutBucketInventoryResult) => void
  2169. ): void;
  2170. putBucketInventory(params: COS.PutBucketInventoryParams): Promise<COS.PutBucketInventoryResult>;
  2171. /** 创建/编辑 Bucket 一次性清单任务 @see https://cloud.tencent.com/document/product/436/83382 */
  2172. postBucketInventory(
  2173. params: COS.PostBucketInventoryParams,
  2174. callback: (err: COS.CosError, data: COS.PostBucketInventoryResult) => void
  2175. ): void;
  2176. postBucketInventory(params: COS.PostBucketInventoryParams): Promise<COS.PostBucketInventoryResult>;
  2177. /** 获取 Bucket 的清单任务信息 @see https://cloud.tencent.com/document/product/436/33705 */
  2178. getBucketInventory(
  2179. params: COS.GetBucketInventoryParams,
  2180. callback: (err: COS.CosError, data: COS.GetBucketInventoryResult) => void
  2181. ): void;
  2182. getBucketInventory(params: COS.GetBucketInventoryParams): Promise<COS.GetBucketInventoryResult>;
  2183. /** 获取 Bucket 的清单任务信息 @see https://cloud.tencent.com/document/product/436/33706 */
  2184. listBucketInventory(
  2185. params: COS.ListBucketInventoryParams,
  2186. callback: (err: COS.CosError, data: COS.ListBucketInventoryResult) => void
  2187. ): void;
  2188. listBucketInventory(params: COS.ListBucketInventoryParams): Promise<COS.ListBucketInventoryResult>;
  2189. /** 删除 Bucket 的清单任务 @see https://cloud.tencent.com/document/product/436/33704 */
  2190. deleteBucketInventory(
  2191. params: COS.DeleteBucketInventoryParams,
  2192. callback: (err: COS.CosError, data: COS.DeleteBucketInventoryResult) => void
  2193. ): void;
  2194. deleteBucketInventory(params: COS.DeleteBucketInventoryParams): Promise<COS.DeleteBucketInventoryResult>;
  2195. /** 启用或者暂停存储桶的全球加速功能 @see https://cloud.tencent.com/document/product/436/38869 */
  2196. putBucketAccelerate(
  2197. params: COS.PutBucketAccelerateParams,
  2198. callback: (err: COS.CosError, data: COS.PutBucketAccelerateResult) => void
  2199. ): void;
  2200. putBucketAccelerate(params: COS.PutBucketAccelerateParams): Promise<COS.PutBucketAccelerateResult>;
  2201. /** 查询存储桶的全球加速功能配置 @see https://cloud.tencent.com/document/product/436/38868 */
  2202. getBucketAccelerate(
  2203. params: COS.GetBucketAccelerateParams,
  2204. callback: (err: COS.CosError, data: COS.GetBucketAccelerateResult) => void
  2205. ): void;
  2206. getBucketAccelerate(params: COS.GetBucketAccelerateParams): Promise<COS.GetBucketAccelerateResult>;
  2207. /** 设置指定存储桶下的默认加密配置 @see https://cloud.tencent.com/document/product/436/40136 */
  2208. putBucketEncryption(
  2209. params: COS.PutBucketEncryptionParams,
  2210. callback: (err: COS.CosError, data: COS.PutBucketEncryptionResult) => void
  2211. ): void;
  2212. putBucketEncryption(params: COS.PutBucketEncryptionParams): Promise<COS.PutBucketEncryptionResult>;
  2213. /** 查询指定存储桶下的默认加密配置 @see https://cloud.tencent.com/document/product/436/40137 */
  2214. getBucketEncryption(
  2215. params: COS.GetBucketEncryptionParams,
  2216. callback: (err: COS.CosError, data: COS.GetBucketEncryptionResult) => void
  2217. ): void;
  2218. getBucketEncryption(params: COS.GetBucketEncryptionParams): Promise<COS.GetBucketEncryptionResult>;
  2219. /** 删除指定存储桶下的默认加密配置 @see https://cloud.tencent.com/document/product/436/40138 */
  2220. deleteBucketEncryption(
  2221. params: COS.DeleteBucketEncryptionParams,
  2222. callback: (err: COS.CosError, data: COS.DeleteBucketEncryptionResult) => void
  2223. ): void;
  2224. deleteBucketEncryption(params: COS.DeleteBucketEncryptionParams): Promise<COS.DeleteBucketEncryptionResult>;
  2225. /** 取回对应对象(Object)的元数据,Head的权限与Get的权限一致 @see https://cloud.tencent.com/document/product/436/7745 */
  2226. headObject(params: COS.HeadObjectParams, callback: (err: COS.CosError, data: COS.HeadObjectResult) => void): void;
  2227. headObject(params: COS.HeadObjectParams): Promise<COS.HeadObjectResult>;
  2228. /** 下载对象(Object) @see https://cloud.tencent.com/document/product/436/7753 */
  2229. getObject(params: COS.GetObjectParams, callback: (err: COS.CosError, data: COS.GetObjectResult) => void): void;
  2230. getObject(params: COS.GetObjectParams): Promise<COS.GetObjectResult>;
  2231. /** 简单上传对象(Object)至指定存储桶 @see https://cloud.tencent.com/document/product/436/7749 */
  2232. putObject(params: COS.PutObjectParams, callback: (err: COS.CosError, data: COS.PutObjectResult) => void): void;
  2233. putObject(params: COS.PutObjectParams): Promise<COS.PutObjectResult>;
  2234. /** 删除一个指定的对象(Object) @see https://cloud.tencent.com/document/product/436/7743 */
  2235. deleteObject(
  2236. params: COS.DeleteObjectParams,
  2237. callback: (err: COS.CosError, data: COS.DeleteObjectResult) => void
  2238. ): void;
  2239. deleteObject(params: COS.DeleteObjectParams): Promise<COS.DeleteObjectResult>;
  2240. /** 批量删除指定存储桶中的多个对象(Object) @see https://cloud.tencent.com/document/product/436/8289 */
  2241. deleteMultipleObject(
  2242. params: COS.DeleteMultipleObjectParams,
  2243. callback: (err: COS.CosError, data: COS.DeleteMultipleObjectResult) => void
  2244. ): void;
  2245. deleteMultipleObject(params: COS.DeleteMultipleObjectParams): Promise<COS.DeleteMultipleObjectResult>;
  2246. /** 获取 Object 的权限列表 @see https://cloud.tencent.com/document/product/436/7744 */
  2247. getObjectAcl(
  2248. params: COS.GetObjectAclParams,
  2249. callback: (err: COS.CosError, data: COS.GetObjectAclResult) => void
  2250. ): void;
  2251. getObjectAcl(params: COS.GetObjectAclParams): Promise<COS.GetObjectAclResult>;
  2252. /** 设置 Object 的权限列表 @see https://cloud.tencent.com/document/product/436/7748 */
  2253. putObjectAcl(
  2254. params: COS.PutObjectAclParams,
  2255. callback: (err: COS.CosError, data: COS.PutObjectAclResult) => void
  2256. ): void;
  2257. putObjectAcl(params: COS.PutObjectAclParams): Promise<COS.PutObjectAclResult>;
  2258. /** 跨域资源共享(CORS)的预检(Preflight)请求 @see https://cloud.tencent.com/document/product/436/8288 */
  2259. optionsObject(
  2260. params: COS.OptionsObjectParams,
  2261. callback: (err: COS.CosError, data: COS.OptionsObjectResult) => void
  2262. ): void;
  2263. optionsObject(params: COS.OptionsObjectParams): Promise<COS.OptionsObjectResult>;
  2264. /** 恢复归档对象 @see https://cloud.tencent.com/document/product/436/12633 */
  2265. restoreObject(
  2266. params: COS.RestoreObjectParams,
  2267. callback: (err: COS.CosError, data: COS.RestoreObjectResult) => void
  2268. ): void;
  2269. restoreObject(params: COS.RestoreObjectParams): Promise<COS.RestoreObjectResult>;
  2270. /** 检索对象内容 @see https://cloud.tencent.com/document/product/436/37641 */
  2271. selectObjectContent(
  2272. params: COS.SelectObjectContentParams,
  2273. callback: (err: COS.CosError, data: COS.SelectObjectContentResult) => void
  2274. ): void;
  2275. selectObjectContent(params: COS.SelectObjectContentParams): Promise<COS.SelectObjectContentResult>;
  2276. /** 复制对象 @see https://cloud.tencent.com/document/product/436/10881 */
  2277. putObjectCopy(
  2278. params: COS.PutObjectCopyParams,
  2279. callback: (err: COS.CosError, data: COS.PutObjectCopyResult) => void
  2280. ): void;
  2281. putObjectCopy(params: COS.PutObjectCopyParams): Promise<COS.PutObjectCopyResult>;
  2282. /** 设置对象标签 @see https://cloud.tencent.com/document/product/436/42997 */
  2283. putObjectTagging(
  2284. params: COS.PutObjectTaggingParams,
  2285. callback: (err: COS.CosError, data: COS.PutObjectTaggingResult) => void
  2286. ): void;
  2287. putObjectTagging(params: COS.PutObjectTaggingParams): Promise<COS.PutObjectTaggingResult>;
  2288. /** 查询对象标签 @see https://cloud.tencent.com/document/product/436/42998 */
  2289. getObjectTagging(
  2290. params: COS.GetObjectTaggingParams,
  2291. callback: (err: COS.CosError, data: COS.GetObjectTaggingResult) => void
  2292. ): void;
  2293. getObjectTagging(params: COS.GetObjectTaggingParams): Promise<COS.GetObjectTaggingResult>;
  2294. /** 删除对象标签 @see https://cloud.tencent.com/document/product/436/42999 */
  2295. deleteObjectTagging(
  2296. params: COS.DeleteObjectTaggingParams,
  2297. callback: (err: COS.CosError, data: COS.DeleteObjectTaggingResult) => void
  2298. ): void;
  2299. deleteObjectTagging(params: COS.DeleteObjectTaggingParams): Promise<COS.DeleteObjectTaggingResult>;
  2300. /** 初始化分块上传 @see https://cloud.tencent.com/document/product/436/7746 */
  2301. multipartInit(
  2302. params: COS.MultipartInitParams,
  2303. callback: (err: COS.CosError, data: COS.MultipartInitResult) => void
  2304. ): void;
  2305. multipartInit(params: COS.MultipartInitParams): Promise<COS.MultipartInitResult>;
  2306. /** 分块上传 @see https://cloud.tencent.com/document/product/436/7750 */
  2307. multipartUpload(
  2308. params: COS.MultipartUploadParams,
  2309. callback: (err: COS.CosError, data: COS.MultipartUploadResult) => void
  2310. ): void;
  2311. multipartUpload(params: COS.MultipartUploadParams): Promise<COS.MultipartUploadResult>;
  2312. /** 分块上传 @see https://cloud.tencent.com/document/product/436/8287 */
  2313. uploadPartCopy(
  2314. params: COS.UploadPartCopyParams,
  2315. callback: (err: COS.CosError, data: COS.UploadPartCopyResult) => void
  2316. ): void;
  2317. uploadPartCopy(params: COS.UploadPartCopyParams): Promise<COS.UploadPartCopyResult>;
  2318. /** 完成分块上传 @see https://cloud.tencent.com/document/product/436/7742 */
  2319. multipartComplete(
  2320. params: COS.MultipartCompleteParams,
  2321. callback: (err: COS.CosError, data: COS.MultipartCompleteResult) => void
  2322. ): void;
  2323. multipartComplete(params: COS.MultipartCompleteParams): Promise<COS.MultipartCompleteResult>;
  2324. /** 分块上传任务列表查询 @see https://cloud.tencent.com/document/product/436/7736 */
  2325. multipartList(
  2326. params: COS.MultipartListParams,
  2327. callback: (err: COS.CosError, data: COS.MultipartListResult) => void
  2328. ): void;
  2329. multipartList(params: COS.MultipartListParams): Promise<COS.MultipartListResult>;
  2330. /** 上传的分块列表查询 @see https://cloud.tencent.com/document/product/436/7747 */
  2331. multipartListPart(
  2332. params: COS.MultipartListPartParams,
  2333. callback: (err: COS.CosError, data: COS.MultipartListPartResult) => void
  2334. ): void;
  2335. multipartListPart(params: COS.MultipartListPartParams): Promise<COS.MultipartListPartResult>;
  2336. /** 抛弃分块上传 @see https://cloud.tencent.com/document/product/436/7740 */
  2337. multipartAbort(
  2338. params: COS.MultipartAbortParams,
  2339. callback: (err: COS.CosError, data: COS.MultipartAbortResult) => void
  2340. ): void;
  2341. multipartAbort(params: COS.MultipartAbortParams): Promise<COS.MultipartAbortResult>;
  2342. /** 分片上传文件,封装好分片上传的多个步骤的上传方法。 */
  2343. sliceUploadFile(
  2344. params: COS.SliceUploadFileParams,
  2345. callback: (err: COS.CosError, data: COS.SliceUploadFileResult) => void
  2346. ): void;
  2347. sliceUploadFile(params: COS.SliceUploadFileParams): Promise<COS.SliceUploadFileResult>;
  2348. /** 清理分片上传 UploadId,封装好的清理单个文件或存储桶所有文件未完成的 UploadId。 */
  2349. abortUploadTask(
  2350. params: COS.AbortUploadTaskParams,
  2351. callback: (err: COS.CosError, data: COS.AbortUploadTaskResult) => void
  2352. ): void;
  2353. abortUploadTask(params: COS.AbortUploadTaskParams): Promise<COS.AbortUploadTaskResult>;
  2354. /** 高级上传文件 */
  2355. uploadFile(params: COS.UploadFileParams, callback: (err: COS.CosError, data: COS.UploadFileResult) => void): void;
  2356. uploadFile(params: COS.UploadFileParams): Promise<COS.UploadFileResult>;
  2357. /** 批量上传文件 */
  2358. uploadFiles(params: COS.UploadFilesParams, callback: (err: COS.CosError, data: COS.UploadFilesResult) => void): void;
  2359. uploadFiles(params: COS.UploadFilesParams): Promise<COS.UploadFilesResult>;
  2360. /** 分片复制文件 */
  2361. sliceCopyFile(
  2362. params: COS.SliceCopyFileParams,
  2363. callback: (err: COS.CosError, data: COS.SliceCopyFileResult) => void
  2364. ): void;
  2365. sliceCopyFile(params: COS.SliceCopyFileParams): Promise<COS.SliceCopyFileResult>;
  2366. /** 获取上传任务列表 */
  2367. getTaskList(): COS.TaskList;
  2368. /** 暂停任务 */
  2369. pauseTask(taskId: COS.TaskId): void;
  2370. /** 重启任务 */
  2371. restartTask(taskId: COS.TaskId): void;
  2372. /** 取消任务 */
  2373. cancelTask(taskId: COS.TaskId): void;
  2374. /** 判断上传队列是否有未完成的任务 */
  2375. isUploadRunning(): boolean;
  2376. /** 分片复制文件 */
  2377. request(params: COS.RequestParams, callback: (err: COS.CosError, data: COS.RequestResult) => void): void;
  2378. request(params: COS.RequestParams): Promise<COS.RequestResult>;
  2379. /** 获取文件下载链接 @see https://cloud.tencent.com/document/product/436/35651 */
  2380. getObjectUrl(
  2381. params: COS.GetObjectUrlParams,
  2382. callback: (err: COS.CosError, data: COS.GetObjectUrlResult) => void
  2383. ): string;
  2384. /** cos.request */
  2385. request(params: COS.RequestParams, callback: (err: COS.CosError, data: COS.RequestResult) => void): void;
  2386. request(params: COS.RequestParams): Promise<COS.RequestResult>;
  2387. /** 追加上传 @see https://cloud.tencent.com/document/product/436/7741 */
  2388. appendObject(params: COS.AppendObjectParams, callback: (err: COS.CosError, data: COS.GeneralResult) => void): void;
  2389. appendObject(params: COS.AppendObjectParams): Promise<COS.GeneralResult>;
  2390. /** 获取 COS JSON API (v4) 签名 @see https://cloud.tencent.com/document/product/436/6054 */
  2391. getV4Auth(params: COS.GetV4AuthParams): COS.Authorization;
  2392. /** 获取 COS XMl API (v5) 签名 @see https://cloud.tencent.com/document/product/436/7778 */
  2393. getAuth(params: COS.GetAuthParams): COS.Authorization;
  2394. on(action: string, callback: (params?: any) => void): void;
  2395. off(action: string, callback: (params?: any) => void): void;
  2396. emit(action: string, data?: any): void;
  2397. }
  2398. export = COS;