@strapi/provider-upload-cloudinary 5.30.0 → 5.31.0

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.
package/dist/index.d.ts CHANGED
@@ -1,5 +1,6 @@
1
1
  /// <reference types="node" />
2
2
  /// <reference types="node" />
3
+ /// <reference types="node" />
3
4
  import type { ReadStream } from 'node:fs';
4
5
  import { ConfigOptions } from 'cloudinary';
5
6
  interface File {
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAO,EAAoB,aAAa,EAAoB,MAAM,YAAY,CAAC;AAI/E,UAAU,IAAI;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC5C,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;;kBAGe,aAAa;2BAwEJ,IAAI;qBAGV,IAAI;qBAGE,IAAI;;;AA/E7B,wBAuGE"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAO,EAAoB,aAAa,EAAoB,MAAM,YAAY,CAAC;AAI/E,UAAU,IAAI;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC5C,MAAM,CAAC,EAAE,UAAU,CAAC;IACpB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;;kBAGe,aAAa;2BAwEJ,IAAI;qBAGV,IAAI;qBAGE,IAAI;;;AA/E7B,wBAuGE"}
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import type { ReadStream } from 'node:fs';\nimport { v2 as cloudinary, ConfigOptions, UploadApiOptions } from 'cloudinary';\nimport intoStream from 'into-stream';\nimport * as utils from '@strapi/utils';\n\ninterface File {\n name: string;\n alternativeText?: string;\n caption?: string;\n width?: number;\n height?: number;\n formats?: Record<string, unknown>;\n hash: string;\n ext?: string;\n mime: string;\n size: number;\n sizeInBytes: number;\n url: string;\n previewUrl?: string;\n path?: string;\n provider?: string;\n provider_metadata?: Record<string, unknown>;\n stream?: ReadStream;\n buffer?: Buffer;\n}\n\nexport default {\n init(options: ConfigOptions) {\n cloudinary.config(options);\n\n const upload = (file: File, customConfig = {}): Promise<void> => {\n return new Promise((resolve, reject) => {\n const config: Partial<UploadApiOptions> = {\n resource_type: 'auto',\n public_id: file.hash,\n };\n\n if (file.ext) {\n config.filename = `${file.hash}${file.ext}`;\n }\n\n if (file.path) {\n config.folder = file.path;\n }\n\n // For files smaller than 99 MB use regular upload as it tends to be faster\n // and fallback to chunked upload for larger files as that's required by Cloudinary.\n // https://support.cloudinary.com/hc/en-us/community/posts/360009586100-Upload-movie-video-with-large-size?page=1#community_comment_360002140099\n // The Cloudinary's max limit for regular upload is actually 100 MB but add some headroom\n // for size counting shenanigans. (Strapi provides the size in kilobytes rounded to two decimal places here).\n const uploadMethod =\n file.size && file.size < 1000 * 99\n ? cloudinary.uploader.upload_stream\n : cloudinary.uploader.upload_chunked_stream;\n\n const uploadStream = uploadMethod({ ...config, ...customConfig }, (err, image) => {\n if (err) {\n if (err.message.includes('File size too large')) {\n reject(new utils.errors.PayloadTooLargeError());\n } else {\n reject(new Error(`Error uploading to cloudinary: ${err.message}`));\n }\n return;\n }\n\n if (!image) {\n return;\n }\n\n if (image.resource_type === 'video') {\n file.previewUrl = cloudinary.url(`${image.public_id}.gif`, {\n video_sampling: 6,\n delay: 200,\n width: 250,\n crop: 'scale',\n resource_type: 'video',\n });\n }\n\n file.url = image.secure_url;\n file.provider_metadata = {\n public_id: image.public_id,\n resource_type: image.resource_type,\n };\n\n resolve();\n });\n\n if (file.stream) {\n file.stream.pipe(uploadStream);\n } else if (file.buffer) {\n intoStream(file.buffer).pipe(uploadStream);\n } else {\n throw new Error('Missing file stream or buffer');\n }\n });\n };\n\n return {\n uploadStream(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n upload(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n async delete(file: File, customConfig = {}) {\n try {\n const { resource_type: resourceType, public_id: publicId } = file.provider_metadata ?? {};\n const deleteConfig = {\n resource_type: (resourceType || 'image') as string,\n invalidate: true,\n ...customConfig,\n };\n\n const response = await cloudinary.uploader.destroy(`${publicId}`, deleteConfig);\n\n if (response.result !== 'ok' && response.result !== 'not found') {\n throw new Error(response.result);\n }\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(`Error deleting on cloudinary: ${error.message}`);\n }\n\n throw error;\n }\n },\n };\n },\n};\n"],"names":["init","options","cloudinary","config","upload","file","customConfig","Promise","resolve","reject","resource_type","public_id","hash","ext","filename","path","folder","uploadMethod","size","uploader","upload_stream","upload_chunked_stream","uploadStream","err","image","message","includes","utils","errors","PayloadTooLargeError","Error","previewUrl","url","video_sampling","delay","width","crop","secure_url","provider_metadata","stream","pipe","buffer","intoStream","delete","resourceType","publicId","deleteConfig","invalidate","response","destroy","result","error"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import type { ReadStream } from 'node:fs';\nimport { v2 as cloudinary, ConfigOptions, UploadApiOptions } from 'cloudinary';\nimport intoStream from 'into-stream';\nimport * as utils from '@strapi/utils';\n\ninterface File {\n name: string;\n alternativeText?: string;\n caption?: string;\n width?: number;\n height?: number;\n formats?: Record<string, unknown>;\n hash: string;\n ext?: string;\n mime: string;\n size: number;\n sizeInBytes: number;\n url: string;\n previewUrl?: string;\n path?: string;\n provider?: string;\n provider_metadata?: Record<string, unknown>;\n stream?: ReadStream;\n buffer?: Buffer;\n}\n\nexport default {\n init(options: ConfigOptions) {\n cloudinary.config(options);\n\n const upload = (file: File, customConfig = {}): Promise<void> => {\n return new Promise((resolve, reject) => {\n const config: Partial<UploadApiOptions> = {\n resource_type: 'auto',\n public_id: file.hash,\n };\n\n if (file.ext) {\n config.filename = `${file.hash}${file.ext}`;\n }\n\n if (file.path) {\n config.folder = file.path;\n }\n\n // For files smaller than 99 MB use regular upload as it tends to be faster\n // and fallback to chunked upload for larger files as that's required by Cloudinary.\n // https://support.cloudinary.com/hc/en-us/community/posts/360009586100-Upload-movie-video-with-large-size?page=1#community_comment_360002140099\n // The Cloudinary's max limit for regular upload is actually 100 MB but add some headroom\n // for size counting shenanigans. (Strapi provides the size in kilobytes rounded to two decimal places here).\n const uploadMethod =\n file.size && file.size < 1000 * 99\n ? cloudinary.uploader.upload_stream\n : cloudinary.uploader.upload_chunked_stream;\n\n const uploadStream = uploadMethod({ ...config, ...customConfig }, (err, image) => {\n if (err) {\n if (err.message.includes('File size too large')) {\n reject(new utils.errors.PayloadTooLargeError());\n } else {\n reject(new Error(`Error uploading to cloudinary: ${err.message}`));\n }\n return;\n }\n\n if (!image) {\n return;\n }\n\n if (image.resource_type === 'video') {\n file.previewUrl = cloudinary.url(`${image.public_id}.gif`, {\n video_sampling: 6,\n delay: 200,\n width: 250,\n crop: 'scale',\n resource_type: 'video',\n });\n }\n\n file.url = image.secure_url;\n file.provider_metadata = {\n public_id: image.public_id,\n resource_type: image.resource_type,\n };\n\n resolve();\n });\n\n if (file.stream) {\n file.stream.pipe(uploadStream);\n } else if (file.buffer) {\n intoStream(file.buffer).pipe(uploadStream);\n } else {\n throw new Error('Missing file stream or buffer');\n }\n });\n };\n\n return {\n uploadStream(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n upload(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n async delete(file: File, customConfig = {}) {\n try {\n const { resource_type: resourceType, public_id: publicId } = file.provider_metadata ?? {};\n const deleteConfig = {\n resource_type: (resourceType || 'image') as string,\n invalidate: true,\n ...customConfig,\n };\n\n const response = await cloudinary.uploader.destroy(`${publicId}`, deleteConfig);\n\n if (response.result !== 'ok' && response.result !== 'not found') {\n throw new Error(response.result);\n }\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(`Error deleting on cloudinary: ${error.message}`);\n }\n\n throw error;\n }\n },\n };\n },\n};\n"],"names":["init","options","cloudinary","config","upload","file","customConfig","Promise","resolve","reject","resource_type","public_id","hash","ext","filename","path","folder","uploadMethod","size","uploader","upload_stream","upload_chunked_stream","uploadStream","err","image","message","includes","utils","errors","PayloadTooLargeError","Error","previewUrl","url","video_sampling","delay","width","crop","secure_url","provider_metadata","stream","pipe","buffer","intoStream","delete","resourceType","publicId","deleteConfig","invalidate","response","destroy","result","error"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,YAAe;AACbA,IAAAA,IAAAA,CAAAA,CAAKC,OAAsB,EAAA;AACzBC,QAAAA,aAAAA,CAAWC,MAAM,CAACF,OAAAA,CAAAA;AAElB,QAAA,MAAMG,MAAS,GAAA,CAACC,IAAYC,EAAAA,YAAAA,GAAe,EAAE,GAAA;YAC3C,OAAO,IAAIC,OAAQ,CAAA,CAACC,OAASC,EAAAA,MAAAA,GAAAA;AAC3B,gBAAA,MAAMN,MAAoC,GAAA;oBACxCO,aAAe,EAAA,MAAA;AACfC,oBAAAA,SAAAA,EAAWN,KAAKO;AAClB,iBAAA;gBAEA,IAAIP,IAAAA,CAAKQ,GAAG,EAAE;oBACZV,MAAOW,CAAAA,QAAQ,GAAG,CAAGT,EAAAA,IAAAA,CAAKO,IAAI,CAAGP,EAAAA,IAAAA,CAAKQ,GAAG,CAAE,CAAA;AAC7C;gBAEA,IAAIR,IAAAA,CAAKU,IAAI,EAAE;oBACbZ,MAAOa,CAAAA,MAAM,GAAGX,IAAAA,CAAKU,IAAI;AAC3B;;;;;;AAOA,gBAAA,MAAME,eACJZ,IAAKa,CAAAA,IAAI,IAAIb,IAAAA,CAAKa,IAAI,GAAG,IAAA,GAAO,EAC5BhB,GAAAA,aAAAA,CAAWiB,QAAQ,CAACC,aAAa,GACjClB,aAAWiB,CAAAA,QAAQ,CAACE,qBAAqB;AAE/C,gBAAA,MAAMC,eAAeL,YAAa,CAAA;AAAE,oBAAA,GAAGd,MAAM;AAAE,oBAAA,GAAGG;AAAa,iBAAA,EAAG,CAACiB,GAAKC,EAAAA,KAAAA,GAAAA;AACtE,oBAAA,IAAID,GAAK,EAAA;AACP,wBAAA,IAAIA,GAAIE,CAAAA,OAAO,CAACC,QAAQ,CAAC,qBAAwB,CAAA,EAAA;AAC/CjB,4BAAAA,MAAAA,CAAO,IAAIkB,gBAAAA,CAAMC,MAAM,CAACC,oBAAoB,EAAA,CAAA;yBACvC,MAAA;AACLpB,4BAAAA,MAAAA,CAAO,IAAIqB,KAAM,CAAA,CAAC,+BAA+B,EAAEP,GAAAA,CAAIE,OAAO,CAAE,CAAA,CAAA,CAAA;AAClE;AACA,wBAAA;AACF;AAEA,oBAAA,IAAI,CAACD,KAAO,EAAA;AACV,wBAAA;AACF;oBAEA,IAAIA,KAAAA,CAAMd,aAAa,KAAK,OAAS,EAAA;wBACnCL,IAAK0B,CAAAA,UAAU,GAAG7B,aAAAA,CAAW8B,GAAG,CAAC,CAAGR,EAAAA,KAAAA,CAAMb,SAAS,CAAC,IAAI,CAAC,EAAE;4BACzDsB,cAAgB,EAAA,CAAA;4BAChBC,KAAO,EAAA,GAAA;4BACPC,KAAO,EAAA,GAAA;4BACPC,IAAM,EAAA,OAAA;4BACN1B,aAAe,EAAA;AACjB,yBAAA,CAAA;AACF;oBAEAL,IAAK2B,CAAAA,GAAG,GAAGR,KAAAA,CAAMa,UAAU;AAC3BhC,oBAAAA,IAAAA,CAAKiC,iBAAiB,GAAG;AACvB3B,wBAAAA,SAAAA,EAAWa,MAAMb,SAAS;AAC1BD,wBAAAA,aAAAA,EAAec,MAAMd;AACvB,qBAAA;AAEAF,oBAAAA,OAAAA,EAAAA;AACF,iBAAA,CAAA;gBAEA,IAAIH,IAAAA,CAAKkC,MAAM,EAAE;oBACflC,IAAKkC,CAAAA,MAAM,CAACC,IAAI,CAAClB,YAAAA,CAAAA;iBACZ,MAAA,IAAIjB,IAAKoC,CAAAA,MAAM,EAAE;AACtBC,oBAAAA,UAAAA,CAAWrC,IAAKoC,CAAAA,MAAM,CAAED,CAAAA,IAAI,CAAClB,YAAAA,CAAAA;iBACxB,MAAA;AACL,oBAAA,MAAM,IAAIQ,KAAM,CAAA,+BAAA,CAAA;AAClB;AACF,aAAA,CAAA;AACF,SAAA;QAEA,OAAO;AACLR,YAAAA,YAAAA,CAAAA,CAAajB,IAAU,EAAEC,YAAe,GAAA,EAAE,EAAA;AACxC,gBAAA,OAAOF,OAAOC,IAAMC,EAAAA,YAAAA,CAAAA;AACtB,aAAA;AACAF,YAAAA,MAAAA,CAAAA,CAAOC,IAAU,EAAEC,YAAe,GAAA,EAAE,EAAA;AAClC,gBAAA,OAAOF,OAAOC,IAAMC,EAAAA,YAAAA,CAAAA;AACtB,aAAA;AACA,YAAA,MAAMqC,MAAOtC,CAAAA,CAAAA,IAAU,EAAEC,YAAAA,GAAe,EAAE,EAAA;gBACxC,IAAI;oBACF,MAAM,EAAEI,aAAekC,EAAAA,YAAY,EAAEjC,SAAAA,EAAWkC,QAAQ,EAAE,GAAGxC,IAAAA,CAAKiC,iBAAiB,IAAI,EAAC;AACxF,oBAAA,MAAMQ,YAAe,GAAA;AACnBpC,wBAAAA,aAAAA,EAAgBkC,YAAgB,IAAA,OAAA;wBAChCG,UAAY,EAAA,IAAA;AACZ,wBAAA,GAAGzC;AACL,qBAAA;oBAEA,MAAM0C,QAAAA,GAAW,MAAM9C,aAAWiB,CAAAA,QAAQ,CAAC8B,OAAO,CAAC,CAAGJ,EAAAA,QAAAA,CAAAA,CAAU,EAAEC,YAAAA,CAAAA;AAElE,oBAAA,IAAIE,SAASE,MAAM,KAAK,QAAQF,QAASE,CAAAA,MAAM,KAAK,WAAa,EAAA;wBAC/D,MAAM,IAAIpB,KAAMkB,CAAAA,QAAAA,CAASE,MAAM,CAAA;AACjC;AACF,iBAAA,CAAE,OAAOC,KAAO,EAAA;AACd,oBAAA,IAAIA,iBAAiBrB,KAAO,EAAA;AAC1B,wBAAA,MAAM,IAAIA,KAAM,CAAA,CAAC,8BAA8B,EAAEqB,KAAAA,CAAM1B,OAAO,CAAE,CAAA,CAAA;AAClE;oBAEA,MAAM0B,KAAAA;AACR;AACF;AACF,SAAA;AACF;AACF,CAAE;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import type { ReadStream } from 'node:fs';\nimport { v2 as cloudinary, ConfigOptions, UploadApiOptions } from 'cloudinary';\nimport intoStream from 'into-stream';\nimport * as utils from '@strapi/utils';\n\ninterface File {\n name: string;\n alternativeText?: string;\n caption?: string;\n width?: number;\n height?: number;\n formats?: Record<string, unknown>;\n hash: string;\n ext?: string;\n mime: string;\n size: number;\n sizeInBytes: number;\n url: string;\n previewUrl?: string;\n path?: string;\n provider?: string;\n provider_metadata?: Record<string, unknown>;\n stream?: ReadStream;\n buffer?: Buffer;\n}\n\nexport default {\n init(options: ConfigOptions) {\n cloudinary.config(options);\n\n const upload = (file: File, customConfig = {}): Promise<void> => {\n return new Promise((resolve, reject) => {\n const config: Partial<UploadApiOptions> = {\n resource_type: 'auto',\n public_id: file.hash,\n };\n\n if (file.ext) {\n config.filename = `${file.hash}${file.ext}`;\n }\n\n if (file.path) {\n config.folder = file.path;\n }\n\n // For files smaller than 99 MB use regular upload as it tends to be faster\n // and fallback to chunked upload for larger files as that's required by Cloudinary.\n // https://support.cloudinary.com/hc/en-us/community/posts/360009586100-Upload-movie-video-with-large-size?page=1#community_comment_360002140099\n // The Cloudinary's max limit for regular upload is actually 100 MB but add some headroom\n // for size counting shenanigans. (Strapi provides the size in kilobytes rounded to two decimal places here).\n const uploadMethod =\n file.size && file.size < 1000 * 99\n ? cloudinary.uploader.upload_stream\n : cloudinary.uploader.upload_chunked_stream;\n\n const uploadStream = uploadMethod({ ...config, ...customConfig }, (err, image) => {\n if (err) {\n if (err.message.includes('File size too large')) {\n reject(new utils.errors.PayloadTooLargeError());\n } else {\n reject(new Error(`Error uploading to cloudinary: ${err.message}`));\n }\n return;\n }\n\n if (!image) {\n return;\n }\n\n if (image.resource_type === 'video') {\n file.previewUrl = cloudinary.url(`${image.public_id}.gif`, {\n video_sampling: 6,\n delay: 200,\n width: 250,\n crop: 'scale',\n resource_type: 'video',\n });\n }\n\n file.url = image.secure_url;\n file.provider_metadata = {\n public_id: image.public_id,\n resource_type: image.resource_type,\n };\n\n resolve();\n });\n\n if (file.stream) {\n file.stream.pipe(uploadStream);\n } else if (file.buffer) {\n intoStream(file.buffer).pipe(uploadStream);\n } else {\n throw new Error('Missing file stream or buffer');\n }\n });\n };\n\n return {\n uploadStream(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n upload(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n async delete(file: File, customConfig = {}) {\n try {\n const { resource_type: resourceType, public_id: publicId } = file.provider_metadata ?? {};\n const deleteConfig = {\n resource_type: (resourceType || 'image') as string,\n invalidate: true,\n ...customConfig,\n };\n\n const response = await cloudinary.uploader.destroy(`${publicId}`, deleteConfig);\n\n if (response.result !== 'ok' && response.result !== 'not found') {\n throw new Error(response.result);\n }\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(`Error deleting on cloudinary: ${error.message}`);\n }\n\n throw error;\n }\n },\n };\n },\n};\n"],"names":["init","options","cloudinary","config","upload","file","customConfig","Promise","resolve","reject","resource_type","public_id","hash","ext","filename","path","folder","uploadMethod","size","uploader","upload_stream","upload_chunked_stream","uploadStream","err","image","message","includes","utils","errors","PayloadTooLargeError","Error","previewUrl","url","video_sampling","delay","width","crop","secure_url","provider_metadata","stream","pipe","buffer","intoStream","delete","resourceType","publicId","deleteConfig","invalidate","response","destroy","result","error"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import type { ReadStream } from 'node:fs';\nimport { v2 as cloudinary, ConfigOptions, UploadApiOptions } from 'cloudinary';\nimport intoStream from 'into-stream';\nimport * as utils from '@strapi/utils';\n\ninterface File {\n name: string;\n alternativeText?: string;\n caption?: string;\n width?: number;\n height?: number;\n formats?: Record<string, unknown>;\n hash: string;\n ext?: string;\n mime: string;\n size: number;\n sizeInBytes: number;\n url: string;\n previewUrl?: string;\n path?: string;\n provider?: string;\n provider_metadata?: Record<string, unknown>;\n stream?: ReadStream;\n buffer?: Buffer;\n}\n\nexport default {\n init(options: ConfigOptions) {\n cloudinary.config(options);\n\n const upload = (file: File, customConfig = {}): Promise<void> => {\n return new Promise((resolve, reject) => {\n const config: Partial<UploadApiOptions> = {\n resource_type: 'auto',\n public_id: file.hash,\n };\n\n if (file.ext) {\n config.filename = `${file.hash}${file.ext}`;\n }\n\n if (file.path) {\n config.folder = file.path;\n }\n\n // For files smaller than 99 MB use regular upload as it tends to be faster\n // and fallback to chunked upload for larger files as that's required by Cloudinary.\n // https://support.cloudinary.com/hc/en-us/community/posts/360009586100-Upload-movie-video-with-large-size?page=1#community_comment_360002140099\n // The Cloudinary's max limit for regular upload is actually 100 MB but add some headroom\n // for size counting shenanigans. (Strapi provides the size in kilobytes rounded to two decimal places here).\n const uploadMethod =\n file.size && file.size < 1000 * 99\n ? cloudinary.uploader.upload_stream\n : cloudinary.uploader.upload_chunked_stream;\n\n const uploadStream = uploadMethod({ ...config, ...customConfig }, (err, image) => {\n if (err) {\n if (err.message.includes('File size too large')) {\n reject(new utils.errors.PayloadTooLargeError());\n } else {\n reject(new Error(`Error uploading to cloudinary: ${err.message}`));\n }\n return;\n }\n\n if (!image) {\n return;\n }\n\n if (image.resource_type === 'video') {\n file.previewUrl = cloudinary.url(`${image.public_id}.gif`, {\n video_sampling: 6,\n delay: 200,\n width: 250,\n crop: 'scale',\n resource_type: 'video',\n });\n }\n\n file.url = image.secure_url;\n file.provider_metadata = {\n public_id: image.public_id,\n resource_type: image.resource_type,\n };\n\n resolve();\n });\n\n if (file.stream) {\n file.stream.pipe(uploadStream);\n } else if (file.buffer) {\n intoStream(file.buffer).pipe(uploadStream);\n } else {\n throw new Error('Missing file stream or buffer');\n }\n });\n };\n\n return {\n uploadStream(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n upload(file: File, customConfig = {}) {\n return upload(file, customConfig);\n },\n async delete(file: File, customConfig = {}) {\n try {\n const { resource_type: resourceType, public_id: publicId } = file.provider_metadata ?? {};\n const deleteConfig = {\n resource_type: (resourceType || 'image') as string,\n invalidate: true,\n ...customConfig,\n };\n\n const response = await cloudinary.uploader.destroy(`${publicId}`, deleteConfig);\n\n if (response.result !== 'ok' && response.result !== 'not found') {\n throw new Error(response.result);\n }\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(`Error deleting on cloudinary: ${error.message}`);\n }\n\n throw error;\n }\n },\n };\n },\n};\n"],"names":["init","options","cloudinary","config","upload","file","customConfig","Promise","resolve","reject","resource_type","public_id","hash","ext","filename","path","folder","uploadMethod","size","uploader","upload_stream","upload_chunked_stream","uploadStream","err","image","message","includes","utils","errors","PayloadTooLargeError","Error","previewUrl","url","video_sampling","delay","width","crop","secure_url","provider_metadata","stream","pipe","buffer","intoStream","delete","resourceType","publicId","deleteConfig","invalidate","response","destroy","result","error"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/provider-upload-cloudinary",
3
- "version": "5.30.0",
3
+ "version": "5.31.0",
4
4
  "description": "Cloudinary provider for strapi upload",
5
5
  "keywords": [
6
6
  "upload",
@@ -44,16 +44,16 @@
44
44
  "watch": "run -T rollup -c -w"
45
45
  },
46
46
  "dependencies": {
47
- "@strapi/utils": "5.30.0",
47
+ "@strapi/utils": "5.31.0",
48
48
  "cloudinary": "^1.41.0",
49
49
  "into-stream": "^5.1.0"
50
50
  },
51
51
  "devDependencies": {
52
- "eslint-config-custom": "5.30.0",
53
- "tsconfig": "5.30.0"
52
+ "eslint-config-custom": "5.31.0",
53
+ "tsconfig": "5.31.0"
54
54
  },
55
55
  "engines": {
56
- "node": ">=18.0.0 <=22.x.x",
56
+ "node": ">=20.0.0 <=24.x.x",
57
57
  "npm": ">=6.0.0"
58
58
  }
59
59
  }