@imagekit/nodejs 7.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (622) hide show
  1. package/CHANGELOG.md +102 -0
  2. package/LICENSE +201 -0
  3. package/README.md +633 -0
  4. package/api-promise.d.mts +2 -0
  5. package/api-promise.d.mts.map +1 -0
  6. package/api-promise.d.ts +2 -0
  7. package/api-promise.d.ts.map +1 -0
  8. package/api-promise.js +6 -0
  9. package/api-promise.js.map +1 -0
  10. package/api-promise.mjs +2 -0
  11. package/api-promise.mjs.map +1 -0
  12. package/client.d.mts +238 -0
  13. package/client.d.mts.map +1 -0
  14. package/client.d.ts +238 -0
  15. package/client.d.ts.map +1 -0
  16. package/client.js +506 -0
  17. package/client.js.map +1 -0
  18. package/client.mjs +502 -0
  19. package/client.mjs.map +1 -0
  20. package/core/api-promise.d.mts +46 -0
  21. package/core/api-promise.d.mts.map +1 -0
  22. package/core/api-promise.d.ts +46 -0
  23. package/core/api-promise.d.ts.map +1 -0
  24. package/core/api-promise.js +74 -0
  25. package/core/api-promise.js.map +1 -0
  26. package/core/api-promise.mjs +70 -0
  27. package/core/api-promise.mjs.map +1 -0
  28. package/core/error.d.mts +46 -0
  29. package/core/error.d.mts.map +1 -0
  30. package/core/error.d.ts +46 -0
  31. package/core/error.d.ts.map +1 -0
  32. package/core/error.js +113 -0
  33. package/core/error.js.map +1 -0
  34. package/core/error.mjs +97 -0
  35. package/core/error.mjs.map +1 -0
  36. package/core/resource.d.mts +6 -0
  37. package/core/resource.d.mts.map +1 -0
  38. package/core/resource.d.ts +6 -0
  39. package/core/resource.d.ts.map +1 -0
  40. package/core/resource.js +11 -0
  41. package/core/resource.js.map +1 -0
  42. package/core/resource.mjs +7 -0
  43. package/core/resource.mjs.map +1 -0
  44. package/core/uploads.d.mts +3 -0
  45. package/core/uploads.d.mts.map +1 -0
  46. package/core/uploads.d.ts +3 -0
  47. package/core/uploads.d.ts.map +1 -0
  48. package/core/uploads.js +6 -0
  49. package/core/uploads.js.map +1 -0
  50. package/core/uploads.mjs +2 -0
  51. package/core/uploads.mjs.map +1 -0
  52. package/error.d.mts +2 -0
  53. package/error.d.mts.map +1 -0
  54. package/error.d.ts +2 -0
  55. package/error.d.ts.map +1 -0
  56. package/error.js +6 -0
  57. package/error.js.map +1 -0
  58. package/error.mjs +2 -0
  59. package/error.mjs.map +1 -0
  60. package/index.d.mts +6 -0
  61. package/index.d.mts.map +1 -0
  62. package/index.d.ts +6 -0
  63. package/index.d.ts.map +1 -0
  64. package/index.js +30 -0
  65. package/index.js.map +1 -0
  66. package/index.mjs +7 -0
  67. package/index.mjs.map +1 -0
  68. package/internal/builtin-types.d.mts +73 -0
  69. package/internal/builtin-types.d.mts.map +1 -0
  70. package/internal/builtin-types.d.ts +73 -0
  71. package/internal/builtin-types.d.ts.map +1 -0
  72. package/internal/builtin-types.js +4 -0
  73. package/internal/builtin-types.js.map +1 -0
  74. package/internal/builtin-types.mjs +3 -0
  75. package/internal/builtin-types.mjs.map +1 -0
  76. package/internal/detect-platform.d.mts +15 -0
  77. package/internal/detect-platform.d.mts.map +1 -0
  78. package/internal/detect-platform.d.ts +15 -0
  79. package/internal/detect-platform.d.ts.map +1 -0
  80. package/internal/detect-platform.js +162 -0
  81. package/internal/detect-platform.js.map +1 -0
  82. package/internal/detect-platform.mjs +157 -0
  83. package/internal/detect-platform.mjs.map +1 -0
  84. package/internal/errors.d.mts +3 -0
  85. package/internal/errors.d.mts.map +1 -0
  86. package/internal/errors.d.ts +3 -0
  87. package/internal/errors.d.ts.map +1 -0
  88. package/internal/errors.js +41 -0
  89. package/internal/errors.js.map +1 -0
  90. package/internal/errors.mjs +36 -0
  91. package/internal/errors.mjs.map +1 -0
  92. package/internal/headers.d.mts +20 -0
  93. package/internal/headers.d.mts.map +1 -0
  94. package/internal/headers.d.ts +20 -0
  95. package/internal/headers.d.ts.map +1 -0
  96. package/internal/headers.js +79 -0
  97. package/internal/headers.js.map +1 -0
  98. package/internal/headers.mjs +74 -0
  99. package/internal/headers.mjs.map +1 -0
  100. package/internal/parse.d.mts +12 -0
  101. package/internal/parse.d.mts.map +1 -0
  102. package/internal/parse.d.ts +12 -0
  103. package/internal/parse.d.ts.map +1 -0
  104. package/internal/parse.js +35 -0
  105. package/internal/parse.js.map +1 -0
  106. package/internal/parse.mjs +32 -0
  107. package/internal/parse.mjs.map +1 -0
  108. package/internal/request-options.d.mts +75 -0
  109. package/internal/request-options.d.mts.map +1 -0
  110. package/internal/request-options.d.ts +75 -0
  111. package/internal/request-options.d.ts.map +1 -0
  112. package/internal/request-options.js +14 -0
  113. package/internal/request-options.js.map +1 -0
  114. package/internal/request-options.mjs +10 -0
  115. package/internal/request-options.mjs.map +1 -0
  116. package/internal/shim-types.d.mts +17 -0
  117. package/internal/shim-types.d.mts.map +1 -0
  118. package/internal/shim-types.d.ts +17 -0
  119. package/internal/shim-types.d.ts.map +1 -0
  120. package/internal/shim-types.js +4 -0
  121. package/internal/shim-types.js.map +1 -0
  122. package/internal/shim-types.mjs +3 -0
  123. package/internal/shim-types.mjs.map +1 -0
  124. package/internal/shims.d.mts +20 -0
  125. package/internal/shims.d.mts.map +1 -0
  126. package/internal/shims.d.ts +20 -0
  127. package/internal/shims.d.ts.map +1 -0
  128. package/internal/shims.js +92 -0
  129. package/internal/shims.js.map +1 -0
  130. package/internal/shims.mjs +85 -0
  131. package/internal/shims.mjs.map +1 -0
  132. package/internal/to-file.d.mts +45 -0
  133. package/internal/to-file.d.mts.map +1 -0
  134. package/internal/to-file.d.ts +45 -0
  135. package/internal/to-file.d.ts.map +1 -0
  136. package/internal/to-file.js +91 -0
  137. package/internal/to-file.js.map +1 -0
  138. package/internal/to-file.mjs +88 -0
  139. package/internal/to-file.mjs.map +1 -0
  140. package/internal/tslib.js +81 -0
  141. package/internal/tslib.mjs +17 -0
  142. package/internal/types.d.mts +69 -0
  143. package/internal/types.d.mts.map +1 -0
  144. package/internal/types.d.ts +69 -0
  145. package/internal/types.d.ts.map +1 -0
  146. package/internal/types.js +4 -0
  147. package/internal/types.js.map +1 -0
  148. package/internal/types.mjs +3 -0
  149. package/internal/types.mjs.map +1 -0
  150. package/internal/uploads.d.mts +42 -0
  151. package/internal/uploads.d.mts.map +1 -0
  152. package/internal/uploads.d.ts +42 -0
  153. package/internal/uploads.d.ts.map +1 -0
  154. package/internal/uploads.js +141 -0
  155. package/internal/uploads.js.map +1 -0
  156. package/internal/uploads.mjs +131 -0
  157. package/internal/uploads.mjs.map +1 -0
  158. package/internal/utils/base64.d.mts +3 -0
  159. package/internal/utils/base64.d.mts.map +1 -0
  160. package/internal/utils/base64.d.ts +3 -0
  161. package/internal/utils/base64.d.ts.map +1 -0
  162. package/internal/utils/base64.js +38 -0
  163. package/internal/utils/base64.js.map +1 -0
  164. package/internal/utils/base64.mjs +33 -0
  165. package/internal/utils/base64.mjs.map +1 -0
  166. package/internal/utils/bytes.d.mts +4 -0
  167. package/internal/utils/bytes.d.mts.map +1 -0
  168. package/internal/utils/bytes.d.ts +4 -0
  169. package/internal/utils/bytes.d.ts.map +1 -0
  170. package/internal/utils/bytes.js +31 -0
  171. package/internal/utils/bytes.js.map +1 -0
  172. package/internal/utils/bytes.mjs +26 -0
  173. package/internal/utils/bytes.mjs.map +1 -0
  174. package/internal/utils/env.d.mts +9 -0
  175. package/internal/utils/env.d.mts.map +1 -0
  176. package/internal/utils/env.d.ts +9 -0
  177. package/internal/utils/env.d.ts.map +1 -0
  178. package/internal/utils/env.js +22 -0
  179. package/internal/utils/env.js.map +1 -0
  180. package/internal/utils/env.mjs +18 -0
  181. package/internal/utils/env.mjs.map +1 -0
  182. package/internal/utils/log.d.mts +37 -0
  183. package/internal/utils/log.d.mts.map +1 -0
  184. package/internal/utils/log.d.ts +37 -0
  185. package/internal/utils/log.d.ts.map +1 -0
  186. package/internal/utils/log.js +85 -0
  187. package/internal/utils/log.js.map +1 -0
  188. package/internal/utils/log.mjs +79 -0
  189. package/internal/utils/log.mjs.map +1 -0
  190. package/internal/utils/path.d.mts +15 -0
  191. package/internal/utils/path.d.mts.map +1 -0
  192. package/internal/utils/path.d.ts +15 -0
  193. package/internal/utils/path.d.ts.map +1 -0
  194. package/internal/utils/path.js +79 -0
  195. package/internal/utils/path.js.map +1 -0
  196. package/internal/utils/path.mjs +74 -0
  197. package/internal/utils/path.mjs.map +1 -0
  198. package/internal/utils/sleep.d.mts +2 -0
  199. package/internal/utils/sleep.d.mts.map +1 -0
  200. package/internal/utils/sleep.d.ts +2 -0
  201. package/internal/utils/sleep.d.ts.map +1 -0
  202. package/internal/utils/sleep.js +7 -0
  203. package/internal/utils/sleep.js.map +1 -0
  204. package/internal/utils/sleep.mjs +3 -0
  205. package/internal/utils/sleep.mjs.map +1 -0
  206. package/internal/utils/uuid.d.mts +5 -0
  207. package/internal/utils/uuid.d.mts.map +1 -0
  208. package/internal/utils/uuid.d.ts +5 -0
  209. package/internal/utils/uuid.d.ts.map +1 -0
  210. package/internal/utils/uuid.js +19 -0
  211. package/internal/utils/uuid.js.map +1 -0
  212. package/internal/utils/uuid.mjs +15 -0
  213. package/internal/utils/uuid.mjs.map +1 -0
  214. package/internal/utils/values.d.mts +18 -0
  215. package/internal/utils/values.d.mts.map +1 -0
  216. package/internal/utils/values.d.ts +18 -0
  217. package/internal/utils/values.d.ts.map +1 -0
  218. package/internal/utils/values.js +112 -0
  219. package/internal/utils/values.js.map +1 -0
  220. package/internal/utils/values.mjs +94 -0
  221. package/internal/utils/values.mjs.map +1 -0
  222. package/internal/utils.d.mts +7 -0
  223. package/internal/utils.d.mts.map +1 -0
  224. package/internal/utils.d.ts +7 -0
  225. package/internal/utils.d.ts.map +1 -0
  226. package/internal/utils.js +11 -0
  227. package/internal/utils.js.map +1 -0
  228. package/internal/utils.mjs +8 -0
  229. package/internal/utils.mjs.map +1 -0
  230. package/lib/crypto-utils.d.mts +16 -0
  231. package/lib/crypto-utils.d.mts.map +1 -0
  232. package/lib/crypto-utils.d.ts +16 -0
  233. package/lib/crypto-utils.d.ts.map +1 -0
  234. package/lib/crypto-utils.js +35 -0
  235. package/lib/crypto-utils.js.map +1 -0
  236. package/lib/crypto-utils.mjs +32 -0
  237. package/lib/crypto-utils.mjs.map +1 -0
  238. package/lib/serialization-utils.d.mts +11 -0
  239. package/lib/serialization-utils.d.mts.map +1 -0
  240. package/lib/serialization-utils.d.ts +11 -0
  241. package/lib/serialization-utils.d.ts.map +1 -0
  242. package/lib/serialization-utils.js +45 -0
  243. package/lib/serialization-utils.js.map +1 -0
  244. package/lib/serialization-utils.mjs +42 -0
  245. package/lib/serialization-utils.mjs.map +1 -0
  246. package/lib/transformation-utils.d.mts +18 -0
  247. package/lib/transformation-utils.d.mts.map +1 -0
  248. package/lib/transformation-utils.d.ts +18 -0
  249. package/lib/transformation-utils.d.ts.map +1 -0
  250. package/lib/transformation-utils.js +110 -0
  251. package/lib/transformation-utils.js.map +1 -0
  252. package/lib/transformation-utils.mjs +106 -0
  253. package/lib/transformation-utils.mjs.map +1 -0
  254. package/package.json +150 -0
  255. package/resource.d.mts +2 -0
  256. package/resource.d.mts.map +1 -0
  257. package/resource.d.ts +2 -0
  258. package/resource.d.ts.map +1 -0
  259. package/resource.js +6 -0
  260. package/resource.js.map +1 -0
  261. package/resource.mjs +2 -0
  262. package/resource.mjs.map +1 -0
  263. package/resources/accounts/accounts.d.mts +18 -0
  264. package/resources/accounts/accounts.d.mts.map +1 -0
  265. package/resources/accounts/accounts.d.ts +18 -0
  266. package/resources/accounts/accounts.d.ts.map +1 -0
  267. package/resources/accounts/accounts.js +25 -0
  268. package/resources/accounts/accounts.js.map +1 -0
  269. package/resources/accounts/accounts.mjs +20 -0
  270. package/resources/accounts/accounts.mjs.map +1 -0
  271. package/resources/accounts/index.d.mts +5 -0
  272. package/resources/accounts/index.d.mts.map +1 -0
  273. package/resources/accounts/index.d.ts +5 -0
  274. package/resources/accounts/index.d.ts.map +1 -0
  275. package/resources/accounts/index.js +13 -0
  276. package/resources/accounts/index.js.map +1 -0
  277. package/resources/accounts/index.mjs +6 -0
  278. package/resources/accounts/index.mjs.map +1 -0
  279. package/resources/accounts/origins.d.mts +945 -0
  280. package/resources/accounts/origins.d.mts.map +1 -0
  281. package/resources/accounts/origins.d.ts +945 -0
  282. package/resources/accounts/origins.d.ts.map +1 -0
  283. package/resources/accounts/origins.js +95 -0
  284. package/resources/accounts/origins.js.map +1 -0
  285. package/resources/accounts/origins.mjs +91 -0
  286. package/resources/accounts/origins.mjs.map +1 -0
  287. package/resources/accounts/url-endpoints.d.mts +226 -0
  288. package/resources/accounts/url-endpoints.d.mts.map +1 -0
  289. package/resources/accounts/url-endpoints.d.ts +226 -0
  290. package/resources/accounts/url-endpoints.d.ts.map +1 -0
  291. package/resources/accounts/url-endpoints.js +84 -0
  292. package/resources/accounts/url-endpoints.js.map +1 -0
  293. package/resources/accounts/url-endpoints.mjs +80 -0
  294. package/resources/accounts/url-endpoints.mjs.map +1 -0
  295. package/resources/accounts/usage.d.mts +58 -0
  296. package/resources/accounts/usage.d.mts.map +1 -0
  297. package/resources/accounts/usage.d.ts +58 -0
  298. package/resources/accounts/usage.d.ts.map +1 -0
  299. package/resources/accounts/usage.js +26 -0
  300. package/resources/accounts/usage.js.map +1 -0
  301. package/resources/accounts/usage.mjs +22 -0
  302. package/resources/accounts/usage.mjs.map +1 -0
  303. package/resources/accounts.d.mts +2 -0
  304. package/resources/accounts.d.mts.map +1 -0
  305. package/resources/accounts.d.ts +2 -0
  306. package/resources/accounts.d.ts.map +1 -0
  307. package/resources/accounts.js +6 -0
  308. package/resources/accounts.js.map +1 -0
  309. package/resources/accounts.mjs +3 -0
  310. package/resources/accounts.mjs.map +1 -0
  311. package/resources/assets.d.mts +75 -0
  312. package/resources/assets.d.mts.map +1 -0
  313. package/resources/assets.d.ts +75 -0
  314. package/resources/assets.d.ts.map +1 -0
  315. package/resources/assets.js +18 -0
  316. package/resources/assets.js.map +1 -0
  317. package/resources/assets.mjs +14 -0
  318. package/resources/assets.mjs.map +1 -0
  319. package/resources/beta/beta.d.mts +10 -0
  320. package/resources/beta/beta.d.mts.map +1 -0
  321. package/resources/beta/beta.d.ts +10 -0
  322. package/resources/beta/beta.d.ts.map +1 -0
  323. package/resources/beta/beta.js +17 -0
  324. package/resources/beta/beta.js.map +1 -0
  325. package/resources/beta/beta.mjs +12 -0
  326. package/resources/beta/beta.mjs.map +1 -0
  327. package/resources/beta/index.d.mts +3 -0
  328. package/resources/beta/index.d.mts.map +1 -0
  329. package/resources/beta/index.d.ts +3 -0
  330. package/resources/beta/index.d.ts.map +1 -0
  331. package/resources/beta/index.js +9 -0
  332. package/resources/beta/index.js.map +1 -0
  333. package/resources/beta/index.mjs +4 -0
  334. package/resources/beta/index.mjs.map +1 -0
  335. package/resources/beta/v2/files.d.mts +460 -0
  336. package/resources/beta/v2/files.d.mts.map +1 -0
  337. package/resources/beta/v2/files.d.ts +460 -0
  338. package/resources/beta/v2/files.d.ts.map +1 -0
  339. package/resources/beta/v2/files.js +52 -0
  340. package/resources/beta/v2/files.js.map +1 -0
  341. package/resources/beta/v2/files.mjs +48 -0
  342. package/resources/beta/v2/files.mjs.map +1 -0
  343. package/resources/beta/v2/index.d.mts +3 -0
  344. package/resources/beta/v2/index.d.mts.map +1 -0
  345. package/resources/beta/v2/index.d.ts +3 -0
  346. package/resources/beta/v2/index.d.ts.map +1 -0
  347. package/resources/beta/v2/index.js +9 -0
  348. package/resources/beta/v2/index.js.map +1 -0
  349. package/resources/beta/v2/index.mjs +4 -0
  350. package/resources/beta/v2/index.mjs.map +1 -0
  351. package/resources/beta/v2/v2.d.mts +10 -0
  352. package/resources/beta/v2/v2.d.mts.map +1 -0
  353. package/resources/beta/v2/v2.d.ts +10 -0
  354. package/resources/beta/v2/v2.d.ts.map +1 -0
  355. package/resources/beta/v2/v2.js +17 -0
  356. package/resources/beta/v2/v2.js.map +1 -0
  357. package/resources/beta/v2/v2.mjs +12 -0
  358. package/resources/beta/v2/v2.mjs.map +1 -0
  359. package/resources/beta/v2.d.mts +2 -0
  360. package/resources/beta/v2.d.mts.map +1 -0
  361. package/resources/beta/v2.d.ts +2 -0
  362. package/resources/beta/v2.d.ts.map +1 -0
  363. package/resources/beta/v2.js +6 -0
  364. package/resources/beta/v2.js.map +1 -0
  365. package/resources/beta/v2.mjs +3 -0
  366. package/resources/beta/v2.mjs.map +1 -0
  367. package/resources/beta.d.mts +2 -0
  368. package/resources/beta.d.mts.map +1 -0
  369. package/resources/beta.d.ts +2 -0
  370. package/resources/beta.d.ts.map +1 -0
  371. package/resources/beta.js +6 -0
  372. package/resources/beta.js.map +1 -0
  373. package/resources/beta.mjs +3 -0
  374. package/resources/beta.mjs.map +1 -0
  375. package/resources/cache/cache.d.mts +10 -0
  376. package/resources/cache/cache.d.mts.map +1 -0
  377. package/resources/cache/cache.d.ts +10 -0
  378. package/resources/cache/cache.d.ts.map +1 -0
  379. package/resources/cache/cache.js +17 -0
  380. package/resources/cache/cache.js.map +1 -0
  381. package/resources/cache/cache.mjs +12 -0
  382. package/resources/cache/cache.mjs.map +1 -0
  383. package/resources/cache/index.d.mts +3 -0
  384. package/resources/cache/index.d.mts.map +1 -0
  385. package/resources/cache/index.d.ts +3 -0
  386. package/resources/cache/index.d.ts.map +1 -0
  387. package/resources/cache/index.js +9 -0
  388. package/resources/cache/index.js.map +1 -0
  389. package/resources/cache/index.mjs +4 -0
  390. package/resources/cache/index.mjs.map +1 -0
  391. package/resources/cache/invalidation.d.mts +54 -0
  392. package/resources/cache/invalidation.d.mts.map +1 -0
  393. package/resources/cache/invalidation.d.ts +54 -0
  394. package/resources/cache/invalidation.d.ts.map +1 -0
  395. package/resources/cache/invalidation.js +40 -0
  396. package/resources/cache/invalidation.js.map +1 -0
  397. package/resources/cache/invalidation.mjs +36 -0
  398. package/resources/cache/invalidation.mjs.map +1 -0
  399. package/resources/cache.d.mts +2 -0
  400. package/resources/cache.d.mts.map +1 -0
  401. package/resources/cache.d.ts +2 -0
  402. package/resources/cache.d.ts.map +1 -0
  403. package/resources/cache.js +6 -0
  404. package/resources/cache.js.map +1 -0
  405. package/resources/cache.mjs +3 -0
  406. package/resources/cache.mjs.map +1 -0
  407. package/resources/custom-metadata-fields.d.mts +274 -0
  408. package/resources/custom-metadata-fields.d.mts.map +1 -0
  409. package/resources/custom-metadata-fields.d.ts +274 -0
  410. package/resources/custom-metadata-fields.d.ts.map +1 -0
  411. package/resources/custom-metadata-fields.js +79 -0
  412. package/resources/custom-metadata-fields.js.map +1 -0
  413. package/resources/custom-metadata-fields.mjs +75 -0
  414. package/resources/custom-metadata-fields.mjs.map +1 -0
  415. package/resources/files/bulk.d.mts +137 -0
  416. package/resources/files/bulk.d.mts.map +1 -0
  417. package/resources/files/bulk.d.ts +137 -0
  418. package/resources/files/bulk.d.ts.map +1 -0
  419. package/resources/files/bulk.js +85 -0
  420. package/resources/files/bulk.js.map +1 -0
  421. package/resources/files/bulk.mjs +81 -0
  422. package/resources/files/bulk.mjs.map +1 -0
  423. package/resources/files/files.d.mts +1133 -0
  424. package/resources/files/files.d.mts.map +1 -0
  425. package/resources/files/files.d.ts +1133 -0
  426. package/resources/files/files.d.ts.map +1 -0
  427. package/resources/files/files.js +164 -0
  428. package/resources/files/files.js.map +1 -0
  429. package/resources/files/files.mjs +159 -0
  430. package/resources/files/files.mjs.map +1 -0
  431. package/resources/files/index.d.mts +5 -0
  432. package/resources/files/index.d.mts.map +1 -0
  433. package/resources/files/index.d.ts +5 -0
  434. package/resources/files/index.d.ts.map +1 -0
  435. package/resources/files/index.js +11 -0
  436. package/resources/files/index.js.map +1 -0
  437. package/resources/files/index.mjs +5 -0
  438. package/resources/files/index.mjs.map +1 -0
  439. package/resources/files/metadata.d.mts +42 -0
  440. package/resources/files/metadata.d.mts.map +1 -0
  441. package/resources/files/metadata.d.ts +42 -0
  442. package/resources/files/metadata.d.ts.map +1 -0
  443. package/resources/files/metadata.js +39 -0
  444. package/resources/files/metadata.js.map +1 -0
  445. package/resources/files/metadata.mjs +35 -0
  446. package/resources/files/metadata.mjs.map +1 -0
  447. package/resources/files/versions.d.mts +81 -0
  448. package/resources/files/versions.d.mts.map +1 -0
  449. package/resources/files/versions.d.ts +81 -0
  450. package/resources/files/versions.d.ts.map +1 -0
  451. package/resources/files/versions.js +68 -0
  452. package/resources/files/versions.js.map +1 -0
  453. package/resources/files/versions.mjs +64 -0
  454. package/resources/files/versions.mjs.map +1 -0
  455. package/resources/files.d.mts +2 -0
  456. package/resources/files.d.mts.map +1 -0
  457. package/resources/files.d.ts +2 -0
  458. package/resources/files.d.ts.map +1 -0
  459. package/resources/files.js +6 -0
  460. package/resources/files.js.map +1 -0
  461. package/resources/files.mjs +3 -0
  462. package/resources/files.mjs.map +1 -0
  463. package/resources/folders/folders.d.mts +203 -0
  464. package/resources/folders/folders.d.mts.map +1 -0
  465. package/resources/folders/folders.d.ts +203 -0
  466. package/resources/folders/folders.d.ts.map +1 -0
  467. package/resources/folders/folders.js +97 -0
  468. package/resources/folders/folders.js.map +1 -0
  469. package/resources/folders/folders.mjs +92 -0
  470. package/resources/folders/folders.mjs.map +1 -0
  471. package/resources/folders/index.d.mts +3 -0
  472. package/resources/folders/index.d.mts.map +1 -0
  473. package/resources/folders/index.d.ts +3 -0
  474. package/resources/folders/index.d.ts.map +1 -0
  475. package/resources/folders/index.js +9 -0
  476. package/resources/folders/index.js.map +1 -0
  477. package/resources/folders/index.mjs +4 -0
  478. package/resources/folders/index.mjs.map +1 -0
  479. package/resources/folders/job.d.mts +37 -0
  480. package/resources/folders/job.d.mts.map +1 -0
  481. package/resources/folders/job.d.ts +37 -0
  482. package/resources/folders/job.d.ts.map +1 -0
  483. package/resources/folders/job.js +21 -0
  484. package/resources/folders/job.js.map +1 -0
  485. package/resources/folders/job.mjs +17 -0
  486. package/resources/folders/job.mjs.map +1 -0
  487. package/resources/folders.d.mts +2 -0
  488. package/resources/folders.d.mts.map +1 -0
  489. package/resources/folders.d.ts +2 -0
  490. package/resources/folders.d.ts.map +1 -0
  491. package/resources/folders.js +6 -0
  492. package/resources/folders.js.map +1 -0
  493. package/resources/folders.mjs +3 -0
  494. package/resources/folders.mjs.map +1 -0
  495. package/resources/helper.d.mts +42 -0
  496. package/resources/helper.d.mts.map +1 -0
  497. package/resources/helper.d.ts +42 -0
  498. package/resources/helper.d.ts.map +1 -0
  499. package/resources/helper.js +402 -0
  500. package/resources/helper.js.map +1 -0
  501. package/resources/helper.mjs +397 -0
  502. package/resources/helper.mjs.map +1 -0
  503. package/resources/index.d.mts +11 -0
  504. package/resources/index.d.mts.map +1 -0
  505. package/resources/index.d.ts +11 -0
  506. package/resources/index.d.ts.map +1 -0
  507. package/resources/index.js +25 -0
  508. package/resources/index.js.map +1 -0
  509. package/resources/index.mjs +12 -0
  510. package/resources/index.mjs.map +1 -0
  511. package/resources/shared.d.mts +817 -0
  512. package/resources/shared.d.mts.map +1 -0
  513. package/resources/shared.d.ts +817 -0
  514. package/resources/shared.d.ts.map +1 -0
  515. package/resources/shared.js +4 -0
  516. package/resources/shared.js.map +1 -0
  517. package/resources/shared.mjs +3 -0
  518. package/resources/shared.mjs.map +1 -0
  519. package/resources/webhooks.d.mts +811 -0
  520. package/resources/webhooks.d.mts.map +1 -0
  521. package/resources/webhooks.d.ts +811 -0
  522. package/resources/webhooks.d.ts.map +1 -0
  523. package/resources/webhooks.js +24 -0
  524. package/resources/webhooks.js.map +1 -0
  525. package/resources/webhooks.mjs +20 -0
  526. package/resources/webhooks.mjs.map +1 -0
  527. package/resources.d.mts +2 -0
  528. package/resources.d.mts.map +1 -0
  529. package/resources.d.ts +2 -0
  530. package/resources.d.ts.map +1 -0
  531. package/resources.js +5 -0
  532. package/resources.js.map +1 -0
  533. package/resources.mjs +2 -0
  534. package/resources.mjs.map +1 -0
  535. package/src/api-promise.ts +2 -0
  536. package/src/client.ts +929 -0
  537. package/src/core/README.md +3 -0
  538. package/src/core/api-promise.ts +92 -0
  539. package/src/core/error.ts +130 -0
  540. package/src/core/resource.ts +11 -0
  541. package/src/core/uploads.ts +2 -0
  542. package/src/error.ts +2 -0
  543. package/src/index.ts +22 -0
  544. package/src/internal/README.md +3 -0
  545. package/src/internal/builtin-types.ts +93 -0
  546. package/src/internal/detect-platform.ts +196 -0
  547. package/src/internal/errors.ts +33 -0
  548. package/src/internal/headers.ts +97 -0
  549. package/src/internal/parse.ts +50 -0
  550. package/src/internal/request-options.ts +91 -0
  551. package/src/internal/shim-types.ts +26 -0
  552. package/src/internal/shims.ts +107 -0
  553. package/src/internal/to-file.ts +154 -0
  554. package/src/internal/types.ts +95 -0
  555. package/src/internal/uploads.ts +187 -0
  556. package/src/internal/utils/base64.ts +40 -0
  557. package/src/internal/utils/bytes.ts +32 -0
  558. package/src/internal/utils/env.ts +18 -0
  559. package/src/internal/utils/log.ts +126 -0
  560. package/src/internal/utils/path.ts +88 -0
  561. package/src/internal/utils/sleep.ts +3 -0
  562. package/src/internal/utils/uuid.ts +17 -0
  563. package/src/internal/utils/values.ts +105 -0
  564. package/src/internal/utils.ts +8 -0
  565. package/src/lib/.keep +4 -0
  566. package/src/lib/crypto-utils.ts +37 -0
  567. package/src/lib/serialization-utils.ts +42 -0
  568. package/src/lib/transformation-utils.ts +117 -0
  569. package/src/resource.ts +2 -0
  570. package/src/resources/accounts/accounts.ts +55 -0
  571. package/src/resources/accounts/index.ts +20 -0
  572. package/src/resources/accounts/origins.ts +1250 -0
  573. package/src/resources/accounts/url-endpoints.ts +298 -0
  574. package/src/resources/accounts/usage.ts +70 -0
  575. package/src/resources/accounts.ts +3 -0
  576. package/src/resources/assets.ts +105 -0
  577. package/src/resources/beta/beta.ts +15 -0
  578. package/src/resources/beta/index.ts +4 -0
  579. package/src/resources/beta/v2/files.ts +546 -0
  580. package/src/resources/beta/v2/index.ts +4 -0
  581. package/src/resources/beta/v2/v2.ts +19 -0
  582. package/src/resources/beta/v2.ts +3 -0
  583. package/src/resources/beta.ts +3 -0
  584. package/src/resources/cache/cache.ts +25 -0
  585. package/src/resources/cache/index.ts +9 -0
  586. package/src/resources/cache/invalidation.ts +70 -0
  587. package/src/resources/cache.ts +3 -0
  588. package/src/resources/custom-metadata-fields.ts +337 -0
  589. package/src/resources/files/bulk.ts +171 -0
  590. package/src/resources/files/files.ts +1430 -0
  591. package/src/resources/files/index.ts +39 -0
  592. package/src/resources/files/metadata.ts +52 -0
  593. package/src/resources/files/versions.ts +117 -0
  594. package/src/resources/files.ts +3 -0
  595. package/src/resources/folders/folders.ts +249 -0
  596. package/src/resources/folders/index.ts +16 -0
  597. package/src/resources/folders/job.ts +47 -0
  598. package/src/resources/folders.ts +3 -0
  599. package/src/resources/helper.ts +462 -0
  600. package/src/resources/index.ts +60 -0
  601. package/src/resources/shared.ts +952 -0
  602. package/src/resources/webhooks.ts +999 -0
  603. package/src/resources.ts +1 -0
  604. package/src/tsconfig.json +11 -0
  605. package/src/uploads.ts +2 -0
  606. package/src/version.ts +1 -0
  607. package/uploads.d.mts +2 -0
  608. package/uploads.d.mts.map +1 -0
  609. package/uploads.d.ts +2 -0
  610. package/uploads.d.ts.map +1 -0
  611. package/uploads.js +6 -0
  612. package/uploads.js.map +1 -0
  613. package/uploads.mjs +2 -0
  614. package/uploads.mjs.map +1 -0
  615. package/version.d.mts +2 -0
  616. package/version.d.mts.map +1 -0
  617. package/version.d.ts +2 -0
  618. package/version.d.ts.map +1 -0
  619. package/version.js +5 -0
  620. package/version.js.map +1 -0
  621. package/version.mjs +2 -0
  622. package/version.mjs.map +1 -0
@@ -0,0 +1,546 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../../core/resource';
4
+ import * as Shared from '../../shared';
5
+ import * as FilesAPI from '../../files/files';
6
+ import { APIPromise } from '../../../core/api-promise';
7
+ import { type Uploadable } from '../../../core/uploads';
8
+ import { RequestOptions } from '../../../internal/request-options';
9
+ import { multipartFormRequestOptions } from '../../../internal/uploads';
10
+ import { serializeUploadOptions } from '../../../lib/serialization-utils';
11
+
12
+ export class Files extends APIResource {
13
+ /**
14
+ * The V2 API enhances security by verifying the entire payload using JWT. This API
15
+ * is in beta.
16
+ *
17
+ * ImageKit.io allows you to upload files directly from both the server and client
18
+ * sides. For server-side uploads, private API key authentication is used. For
19
+ * client-side uploads, generate a one-time `token` from your secure backend using
20
+ * private API.
21
+ * [Learn more](/docs/api-reference/upload-file/upload-file-v2#how-to-implement-secure-client-side-file-upload)
22
+ * about how to implement secure client-side file upload.
23
+ *
24
+ * **File size limit** \
25
+ * On the free plan, the maximum upload file sizes are 20MB for images, audio, and raw
26
+ * files, and 100MB for videos. On the paid plan, these limits increase to 40MB for
27
+ * images, audio, and raw files, and 2GB for videos. These limits can be further increased
28
+ * with higher-tier plans.
29
+ *
30
+ * **Version limit** \
31
+ * A file can have a maximum of 100 versions.
32
+ *
33
+ * **Demo applications**
34
+ *
35
+ * - A full-fledged
36
+ * [upload widget using Uppy](https://github.com/imagekit-samples/uppy-uploader),
37
+ * supporting file selections from local storage, URL, Dropbox, Google Drive,
38
+ * Instagram, and more.
39
+ * - [Quick start guides](/docs/quick-start-guides) for various frameworks and
40
+ * technologies.
41
+ *
42
+ * @example
43
+ * ```ts
44
+ * const response = await client.beta.v2.files.upload({
45
+ * file: fs.createReadStream('path/to/file'),
46
+ * fileName: 'fileName',
47
+ * });
48
+ * ```
49
+ */
50
+ upload(body: FileUploadParams, options?: RequestOptions): APIPromise<FileUploadResponse> {
51
+ const serializedBody = serializeUploadOptions(body);
52
+
53
+ return this._client.post(
54
+ '/api/v2/files/upload',
55
+ multipartFormRequestOptions(
56
+ { body: serializedBody, defaultBaseURL: 'https://upload.imagekit.io', ...options },
57
+ this._client,
58
+ ),
59
+ );
60
+ }
61
+ }
62
+
63
+ /**
64
+ * Object containing details of a successful upload.
65
+ */
66
+ export interface FileUploadResponse {
67
+ /**
68
+ * An array of tags assigned to the uploaded file by auto tagging.
69
+ */
70
+ AITags?: Array<FileUploadResponse.AITag> | null;
71
+
72
+ /**
73
+ * The audio codec used in the video (only for video).
74
+ */
75
+ audioCodec?: string;
76
+
77
+ /**
78
+ * The bit rate of the video in kbps (only for video).
79
+ */
80
+ bitRate?: number;
81
+
82
+ /**
83
+ * Value of custom coordinates associated with the image in the format
84
+ * `x,y,width,height`. If `customCoordinates` are not defined, then it is `null`.
85
+ * Send `customCoordinates` in `responseFields` in API request to get the value of
86
+ * this field.
87
+ */
88
+ customCoordinates?: string | null;
89
+
90
+ /**
91
+ * A key-value data associated with the asset. Use `responseField` in API request
92
+ * to get `customMetadata` in the upload API response. Before setting any custom
93
+ * metadata on an asset, you have to create the field using custom metadata fields
94
+ * API. Send `customMetadata` in `responseFields` in API request to get the value
95
+ * of this field.
96
+ */
97
+ customMetadata?: { [key: string]: unknown };
98
+
99
+ /**
100
+ * Optional text to describe the contents of the file. Can be set by the user or
101
+ * the ai-auto-description extension.
102
+ */
103
+ description?: string;
104
+
105
+ /**
106
+ * The duration of the video in seconds (only for video).
107
+ */
108
+ duration?: number;
109
+
110
+ /**
111
+ * Consolidated embedded metadata associated with the file. It includes exif, iptc,
112
+ * and xmp data. Send `embeddedMetadata` in `responseFields` in API request to get
113
+ * embeddedMetadata in the upload API response.
114
+ */
115
+ embeddedMetadata?: { [key: string]: unknown };
116
+
117
+ /**
118
+ * Extension names with their processing status at the time of completion of the
119
+ * request. It could have one of the following status values:
120
+ *
121
+ * `success`: The extension has been successfully applied. `failed`: The extension
122
+ * has failed and will not be retried. `pending`: The extension will finish
123
+ * processing in some time. On completion, the final status (success / failed) will
124
+ * be sent to the `webhookUrl` provided.
125
+ *
126
+ * If no extension was requested, then this parameter is not returned.
127
+ */
128
+ extensionStatus?: FileUploadResponse.ExtensionStatus;
129
+
130
+ /**
131
+ * Unique fileId. Store this fileld in your database, as this will be used to
132
+ * perform update action on this file.
133
+ */
134
+ fileId?: string;
135
+
136
+ /**
137
+ * The relative path of the file in the media library e.g.
138
+ * `/marketing-assets/new-banner.jpg`.
139
+ */
140
+ filePath?: string;
141
+
142
+ /**
143
+ * Type of the uploaded file. Possible values are `image`, `non-image`.
144
+ */
145
+ fileType?: string;
146
+
147
+ /**
148
+ * Height of the image in pixels (Only for images)
149
+ */
150
+ height?: number;
151
+
152
+ /**
153
+ * Is the file marked as private. It can be either `true` or `false`. Send
154
+ * `isPrivateFile` in `responseFields` in API request to get the value of this
155
+ * field.
156
+ */
157
+ isPrivateFile?: boolean;
158
+
159
+ /**
160
+ * Is the file published or in draft state. It can be either `true` or `false`.
161
+ * Send `isPublished` in `responseFields` in API request to get the value of this
162
+ * field.
163
+ */
164
+ isPublished?: boolean;
165
+
166
+ /**
167
+ * Legacy metadata. Send `metadata` in `responseFields` in API request to get
168
+ * metadata in the upload API response.
169
+ */
170
+ metadata?: FilesAPI.Metadata;
171
+
172
+ /**
173
+ * Name of the asset.
174
+ */
175
+ name?: string;
176
+
177
+ /**
178
+ * Size of the image file in Bytes.
179
+ */
180
+ size?: number;
181
+
182
+ /**
183
+ * The array of tags associated with the asset. If no tags are set, it will be
184
+ * `null`. Send `tags` in `responseFields` in API request to get the value of this
185
+ * field.
186
+ */
187
+ tags?: Array<string> | null;
188
+
189
+ /**
190
+ * In the case of an image, a small thumbnail URL.
191
+ */
192
+ thumbnailUrl?: string;
193
+
194
+ /**
195
+ * A publicly accessible URL of the file.
196
+ */
197
+ url?: string;
198
+
199
+ /**
200
+ * An object containing the file or file version's `id` (versionId) and `name`.
201
+ */
202
+ versionInfo?: FileUploadResponse.VersionInfo;
203
+
204
+ /**
205
+ * The video codec used in the video (only for video).
206
+ */
207
+ videoCodec?: string;
208
+
209
+ /**
210
+ * Width of the image in pixels (Only for Images)
211
+ */
212
+ width?: number;
213
+ }
214
+
215
+ export namespace FileUploadResponse {
216
+ export interface AITag {
217
+ /**
218
+ * Confidence score of the tag.
219
+ */
220
+ confidence?: number;
221
+
222
+ /**
223
+ * Name of the tag.
224
+ */
225
+ name?: string;
226
+
227
+ /**
228
+ * Array of `AITags` associated with the image. If no `AITags` are set, it will be
229
+ * null. These tags can be added using the `google-auto-tagging` or
230
+ * `aws-auto-tagging` extensions.
231
+ */
232
+ source?: string;
233
+ }
234
+
235
+ /**
236
+ * Extension names with their processing status at the time of completion of the
237
+ * request. It could have one of the following status values:
238
+ *
239
+ * `success`: The extension has been successfully applied. `failed`: The extension
240
+ * has failed and will not be retried. `pending`: The extension will finish
241
+ * processing in some time. On completion, the final status (success / failed) will
242
+ * be sent to the `webhookUrl` provided.
243
+ *
244
+ * If no extension was requested, then this parameter is not returned.
245
+ */
246
+ export interface ExtensionStatus {
247
+ 'ai-auto-description'?: 'success' | 'pending' | 'failed';
248
+
249
+ 'aws-auto-tagging'?: 'success' | 'pending' | 'failed';
250
+
251
+ 'google-auto-tagging'?: 'success' | 'pending' | 'failed';
252
+
253
+ 'remove-bg'?: 'success' | 'pending' | 'failed';
254
+ }
255
+
256
+ /**
257
+ * An object containing the file or file version's `id` (versionId) and `name`.
258
+ */
259
+ export interface VersionInfo {
260
+ /**
261
+ * Unique identifier of the file version.
262
+ */
263
+ id?: string;
264
+
265
+ /**
266
+ * Name of the file version.
267
+ */
268
+ name?: string;
269
+ }
270
+ }
271
+
272
+ export interface FileUploadParams {
273
+ /**
274
+ * The API accepts any of the following:
275
+ *
276
+ * - **Binary data** – send the raw bytes as `multipart/form-data`.
277
+ * - **HTTP / HTTPS URL** – a publicly reachable URL that ImageKit’s servers can
278
+ * fetch.
279
+ * - **Base64 string** – the file encoded as a Base64 data URI or plain Base64.
280
+ *
281
+ * When supplying a URL, the server must receive the response headers within 8
282
+ * seconds; otherwise the request fails with 400 Bad Request.
283
+ */
284
+ file: Uploadable | string;
285
+
286
+ /**
287
+ * The name with which the file has to be uploaded.
288
+ */
289
+ fileName: string;
290
+
291
+ /**
292
+ * This is the client-generated JSON Web Token (JWT). The ImageKit.io server uses
293
+ * it to authenticate and check that the upload request parameters have not been
294
+ * tampered with after the token has been generated. Learn how to create the token
295
+ * on the page below. This field is only required for authentication when uploading
296
+ * a file from the client side.
297
+ *
298
+ * **Note**: Sending a JWT that has been used in the past will result in a
299
+ * validation error. Even if your previous request resulted in an error, you should
300
+ * always send a new token.
301
+ *
302
+ * **⚠️Warning**: JWT must be generated on the server-side because it is generated
303
+ * using your account's private API key. This field is required for authentication
304
+ * when uploading a file from the client-side.
305
+ */
306
+ token?: string;
307
+
308
+ /**
309
+ * Server-side checks to run on the asset. Read more about
310
+ * [Upload API checks](/docs/api-reference/upload-file/upload-file-v2#upload-api-checks).
311
+ */
312
+ checks?: string;
313
+
314
+ /**
315
+ * Define an important area in the image. This is only relevant for image type
316
+ * files.
317
+ *
318
+ * - To be passed as a string with the x and y coordinates of the top-left corner,
319
+ * and width and height of the area of interest in the format `x,y,width,height`.
320
+ * For example - `10,10,100,100`
321
+ * - Can be used with fo-customtransformation.
322
+ * - If this field is not specified and the file is overwritten, then
323
+ * customCoordinates will be removed.
324
+ */
325
+ customCoordinates?: string;
326
+
327
+ /**
328
+ * JSON key-value pairs to associate with the asset. Create the custom metadata
329
+ * fields before setting these values.
330
+ */
331
+ customMetadata?: { [key: string]: unknown };
332
+
333
+ /**
334
+ * Optional text to describe the contents of the file.
335
+ */
336
+ description?: string;
337
+
338
+ /**
339
+ * Array of extensions to be applied to the asset. Each extension can be configured
340
+ * with specific parameters based on the extension type.
341
+ */
342
+ extensions?: Shared.Extensions;
343
+
344
+ /**
345
+ * The folder path in which the image has to be uploaded. If the folder(s) didn't
346
+ * exist before, a new folder(s) is created. Using multiple `/` creates a nested
347
+ * folder.
348
+ */
349
+ folder?: string;
350
+
351
+ /**
352
+ * Whether to mark the file as private or not.
353
+ *
354
+ * If `true`, the file is marked as private and is accessible only using named
355
+ * transformation or signed URL.
356
+ */
357
+ isPrivateFile?: boolean;
358
+
359
+ /**
360
+ * Whether to upload file as published or not.
361
+ *
362
+ * If `false`, the file is marked as unpublished, which restricts access to the
363
+ * file only via the media library. Files in draft or unpublished state can only be
364
+ * publicly accessed after being published.
365
+ *
366
+ * The option to upload in draft state is only available in custom enterprise
367
+ * pricing plans.
368
+ */
369
+ isPublished?: boolean;
370
+
371
+ /**
372
+ * If set to `true` and a file already exists at the exact location, its AITags
373
+ * will be removed. Set `overwriteAITags` to `false` to preserve AITags.
374
+ */
375
+ overwriteAITags?: boolean;
376
+
377
+ /**
378
+ * If the request does not have `customMetadata`, and a file already exists at the
379
+ * exact location, existing customMetadata will be removed.
380
+ */
381
+ overwriteCustomMetadata?: boolean;
382
+
383
+ /**
384
+ * If `false` and `useUniqueFileName` is also `false`, and a file already exists at
385
+ * the exact location, upload API will return an error immediately.
386
+ */
387
+ overwriteFile?: boolean;
388
+
389
+ /**
390
+ * If the request does not have `tags`, and a file already exists at the exact
391
+ * location, existing tags will be removed.
392
+ */
393
+ overwriteTags?: boolean;
394
+
395
+ /**
396
+ * Array of response field keys to include in the API response body.
397
+ */
398
+ responseFields?: Array<
399
+ | 'tags'
400
+ | 'customCoordinates'
401
+ | 'isPrivateFile'
402
+ | 'embeddedMetadata'
403
+ | 'isPublished'
404
+ | 'customMetadata'
405
+ | 'metadata'
406
+ >;
407
+
408
+ /**
409
+ * Set the tags while uploading the file. Provide an array of tag strings (e.g.
410
+ * `["tag1", "tag2", "tag3"]`). The combined length of all tag characters must not
411
+ * exceed 500, and the `%` character is not allowed. If this field is not specified
412
+ * and the file is overwritten, the existing tags will be removed.
413
+ */
414
+ tags?: Array<string>;
415
+
416
+ /**
417
+ * Configure pre-processing (`pre`) and post-processing (`post`) transformations.
418
+ *
419
+ * - `pre` — applied before the file is uploaded to the Media Library.
420
+ * Useful for reducing file size or applying basic optimizations upfront (e.g.,
421
+ * resize, compress).
422
+ *
423
+ * - `post` — applied immediately after upload.
424
+ * Ideal for generating transformed versions (like video encodes or thumbnails)
425
+ * in advance, so they're ready for delivery without delay.
426
+ *
427
+ * You can mix and match any combination of post-processing types.
428
+ */
429
+ transformation?: FileUploadParams.Transformation;
430
+
431
+ /**
432
+ * Whether to use a unique filename for this file or not.
433
+ *
434
+ * If `true`, ImageKit.io will add a unique suffix to the filename parameter to get
435
+ * a unique filename.
436
+ *
437
+ * If `false`, then the image is uploaded with the provided filename parameter, and
438
+ * any existing file with the same name is replaced.
439
+ */
440
+ useUniqueFileName?: boolean;
441
+
442
+ /**
443
+ * The final status of extensions after they have completed execution will be
444
+ * delivered to this endpoint as a POST request.
445
+ * [Learn more](/docs/api-reference/digital-asset-management-dam/managing-assets/update-file-details#webhook-payload-structure)
446
+ * about the webhook payload structure.
447
+ */
448
+ webhookUrl?: string;
449
+ }
450
+
451
+ export namespace FileUploadParams {
452
+ /**
453
+ * Configure pre-processing (`pre`) and post-processing (`post`) transformations.
454
+ *
455
+ * - `pre` — applied before the file is uploaded to the Media Library.
456
+ * Useful for reducing file size or applying basic optimizations upfront (e.g.,
457
+ * resize, compress).
458
+ *
459
+ * - `post` — applied immediately after upload.
460
+ * Ideal for generating transformed versions (like video encodes or thumbnails)
461
+ * in advance, so they're ready for delivery without delay.
462
+ *
463
+ * You can mix and match any combination of post-processing types.
464
+ */
465
+ export interface Transformation {
466
+ /**
467
+ * List of transformations to apply _after_ the file is uploaded.
468
+ * Each item must match one of the following types: `transformation`,
469
+ * `gif-to-video`, `thumbnail`, `abs`.
470
+ */
471
+ post?: Array<
472
+ | Transformation.Transformation
473
+ | Transformation.GifToVideo
474
+ | Transformation.Thumbnail
475
+ | Transformation.Abs
476
+ >;
477
+
478
+ /**
479
+ * Transformation string to apply before uploading the file to the Media Library.
480
+ * Useful for optimizing files at ingestion.
481
+ */
482
+ pre?: string;
483
+ }
484
+
485
+ export namespace Transformation {
486
+ export interface Transformation {
487
+ /**
488
+ * Transformation type.
489
+ */
490
+ type: 'transformation';
491
+
492
+ /**
493
+ * Transformation string (e.g. `w-200,h-200`).
494
+ * Same syntax as ImageKit URL-based transformations.
495
+ */
496
+ value: string;
497
+ }
498
+
499
+ export interface GifToVideo {
500
+ /**
501
+ * Converts an animated GIF into an MP4.
502
+ */
503
+ type: 'gif-to-video';
504
+
505
+ /**
506
+ * Optional transformation string to apply to the output video.
507
+ * **Example**: `q-80`
508
+ */
509
+ value?: string;
510
+ }
511
+
512
+ export interface Thumbnail {
513
+ /**
514
+ * Generates a thumbnail image.
515
+ */
516
+ type: 'thumbnail';
517
+
518
+ /**
519
+ * Optional transformation string.
520
+ * **Example**: `w-150,h-150`
521
+ */
522
+ value?: string;
523
+ }
524
+
525
+ export interface Abs {
526
+ /**
527
+ * Streaming protocol to use (`hls` or `dash`).
528
+ */
529
+ protocol: 'hls' | 'dash';
530
+
531
+ /**
532
+ * Adaptive Bitrate Streaming (ABS) setup.
533
+ */
534
+ type: 'abs';
535
+
536
+ /**
537
+ * List of different representations you want to create separated by an underscore.
538
+ */
539
+ value: string;
540
+ }
541
+ }
542
+ }
543
+
544
+ export declare namespace Files {
545
+ export { type FileUploadResponse as FileUploadResponse, type FileUploadParams as FileUploadParams };
546
+ }
@@ -0,0 +1,4 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export { Files, type FileUploadResponse, type FileUploadParams } from './files';
4
+ export { V2 } from './v2';
@@ -0,0 +1,19 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../../core/resource';
4
+ import * as FilesAPI from './files';
5
+ import { FileUploadParams, FileUploadResponse, Files } from './files';
6
+
7
+ export class V2 extends APIResource {
8
+ files: FilesAPI.Files = new FilesAPI.Files(this._client);
9
+ }
10
+
11
+ V2.Files = Files;
12
+
13
+ export declare namespace V2 {
14
+ export {
15
+ Files as Files,
16
+ type FileUploadResponse as FileUploadResponse,
17
+ type FileUploadParams as FileUploadParams,
18
+ };
19
+ }
@@ -0,0 +1,3 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export * from './v2/index';
@@ -0,0 +1,3 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export * from './beta/index';
@@ -0,0 +1,25 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../core/resource';
4
+ import * as InvalidationAPI from './invalidation';
5
+ import {
6
+ Invalidation,
7
+ InvalidationCreateParams,
8
+ InvalidationCreateResponse,
9
+ InvalidationGetResponse,
10
+ } from './invalidation';
11
+
12
+ export class Cache extends APIResource {
13
+ invalidation: InvalidationAPI.Invalidation = new InvalidationAPI.Invalidation(this._client);
14
+ }
15
+
16
+ Cache.Invalidation = Invalidation;
17
+
18
+ export declare namespace Cache {
19
+ export {
20
+ Invalidation as Invalidation,
21
+ type InvalidationCreateResponse as InvalidationCreateResponse,
22
+ type InvalidationGetResponse as InvalidationGetResponse,
23
+ type InvalidationCreateParams as InvalidationCreateParams,
24
+ };
25
+ }
@@ -0,0 +1,9 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export { Cache } from './cache';
4
+ export {
5
+ Invalidation,
6
+ type InvalidationCreateResponse,
7
+ type InvalidationGetResponse,
8
+ type InvalidationCreateParams,
9
+ } from './invalidation';
@@ -0,0 +1,70 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ import { APIResource } from '../../core/resource';
4
+ import { APIPromise } from '../../core/api-promise';
5
+ import { RequestOptions } from '../../internal/request-options';
6
+ import { path } from '../../internal/utils/path';
7
+
8
+ export class Invalidation extends APIResource {
9
+ /**
10
+ * This API will purge CDN cache and ImageKit.io's internal cache for a file. Note:
11
+ * Purge cache is an asynchronous process and it may take some time to reflect the
12
+ * changes.
13
+ *
14
+ * @example
15
+ * ```ts
16
+ * const invalidation = await client.cache.invalidation.create(
17
+ * {
18
+ * url: 'https://ik.imagekit.io/your_imagekit_id/default-image.jpg',
19
+ * },
20
+ * );
21
+ * ```
22
+ */
23
+ create(body: InvalidationCreateParams, options?: RequestOptions): APIPromise<InvalidationCreateResponse> {
24
+ return this._client.post('/v1/files/purge', { body, ...options });
25
+ }
26
+
27
+ /**
28
+ * This API returns the status of a purge cache request.
29
+ *
30
+ * @example
31
+ * ```ts
32
+ * const invalidation = await client.cache.invalidation.get(
33
+ * 'requestId',
34
+ * );
35
+ * ```
36
+ */
37
+ get(requestID: string, options?: RequestOptions): APIPromise<InvalidationGetResponse> {
38
+ return this._client.get(path`/v1/files/purge/${requestID}`, options);
39
+ }
40
+ }
41
+
42
+ export interface InvalidationCreateResponse {
43
+ /**
44
+ * Unique identifier of the purge request. This can be used to check the status of
45
+ * the purge request.
46
+ */
47
+ requestId?: string;
48
+ }
49
+
50
+ export interface InvalidationGetResponse {
51
+ /**
52
+ * Status of the purge request.
53
+ */
54
+ status?: 'Pending' | 'Completed';
55
+ }
56
+
57
+ export interface InvalidationCreateParams {
58
+ /**
59
+ * The full URL of the file to be purged.
60
+ */
61
+ url: string;
62
+ }
63
+
64
+ export declare namespace Invalidation {
65
+ export {
66
+ type InvalidationCreateResponse as InvalidationCreateResponse,
67
+ type InvalidationGetResponse as InvalidationGetResponse,
68
+ type InvalidationCreateParams as InvalidationCreateParams,
69
+ };
70
+ }
@@ -0,0 +1,3 @@
1
+ // File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ export * from './cache/index';