@strapi/provider-upload-local 4.15.0-alpha.0 → 4.15.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
@@ -34,4 +34,5 @@ declare const _default: {
34
34
  delete(file: File): Promise<string | void>;
35
35
  };
36
36
  };
37
- export = _default;
37
+ export default _default;
38
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;AACA,OAAW,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAKpC,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,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;AAOD,UAAU,WAAW;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,UAAU,oBAAoB;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;;mDAG+C,WAAW;4BAiBjC,IAAI,WAAW,oBAAoB;2BAkBpC,IAAI,GAAG,QAAQ,IAAI,CAAC;qBAuB1B,IAAI,GAAG,QAAQ,IAAI,CAAC;qBAoBpB,IAAI,GAAG,QAAQ,MAAM,GAAG,IAAI,CAAC;;;AA/EhD,wBAoGE"}
package/dist/index.js CHANGED
@@ -1,110 +1,116 @@
1
1
  "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
2
+ const stream = require("stream");
3
+ const fs = require("fs");
4
+ const path = require("path");
5
+ const fse = require("fs-extra");
6
+ const utils = require("@strapi/utils");
7
+ const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
8
+ function _interopNamespace(e) {
9
+ if (e && e.__esModule)
10
+ return e;
11
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
12
+ if (e) {
13
+ for (const k in e) {
14
+ if (k !== "default") {
15
+ const d = Object.getOwnPropertyDescriptor(e, k);
16
+ Object.defineProperty(n, k, d.get ? d : {
17
+ enumerable: true,
18
+ get: () => e[k]
19
+ });
20
+ }
7
21
  }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- const stream_1 = require("stream");
29
- const fs_1 = __importDefault(require("fs"));
30
- const path_1 = __importDefault(require("path"));
31
- const fs_extra_1 = __importDefault(require("fs-extra"));
32
- const utils = __importStar(require("@strapi/utils"));
33
- const { PayloadTooLargeError } = utils.errors;
34
- const { kbytesToBytes, bytesToHumanReadable } = utils.file;
35
- const UPLOADS_FOLDER_NAME = 'uploads';
36
- module.exports = {
37
- init({ sizeLimit: providerOptionsSizeLimit } = {}) {
38
- // TODO V5: remove providerOptions sizeLimit
22
+ }
23
+ n.default = e;
24
+ return Object.freeze(n);
25
+ }
26
+ const fs__default = /* @__PURE__ */ _interopDefault(fs);
27
+ const path__default = /* @__PURE__ */ _interopDefault(path);
28
+ const fse__default = /* @__PURE__ */ _interopDefault(fse);
29
+ const utils__namespace = /* @__PURE__ */ _interopNamespace(utils);
30
+ const { PayloadTooLargeError } = utils__namespace.errors;
31
+ const { kbytesToBytes, bytesToHumanReadable } = utils__namespace.file;
32
+ const UPLOADS_FOLDER_NAME = "uploads";
33
+ const index = {
34
+ init({ sizeLimit: providerOptionsSizeLimit } = {}) {
35
+ if (providerOptionsSizeLimit) {
36
+ process.emitWarning(
37
+ '[deprecated] In future versions, "sizeLimit" argument will be ignored from upload.config.providerOptions. Move it to upload.config'
38
+ );
39
+ }
40
+ const uploadPath = path__default.default.resolve(strapi.dirs.static.public, UPLOADS_FOLDER_NAME);
41
+ if (!fse__default.default.pathExistsSync(uploadPath)) {
42
+ throw new Error(
43
+ `The upload folder (${uploadPath}) doesn't exist or is not accessible. Please make sure it exists.`
44
+ );
45
+ }
46
+ return {
47
+ checkFileSize(file, options) {
48
+ const { sizeLimit } = options ?? {};
39
49
  if (providerOptionsSizeLimit) {
40
- process.emitWarning('[deprecated] In future versions, "sizeLimit" argument will be ignored from upload.config.providerOptions. Move it to upload.config');
50
+ if (kbytesToBytes(file.size) > providerOptionsSizeLimit)
51
+ throw new PayloadTooLargeError(
52
+ `${file.name} exceeds size limit of ${bytesToHumanReadable(
53
+ providerOptionsSizeLimit
54
+ )}.`
55
+ );
56
+ } else if (sizeLimit) {
57
+ if (kbytesToBytes(file.size) > sizeLimit)
58
+ throw new PayloadTooLargeError(
59
+ `${file.name} exceeds size limit of ${bytesToHumanReadable(sizeLimit)}.`
60
+ );
61
+ }
62
+ },
63
+ uploadStream(file) {
64
+ if (!file.stream) {
65
+ return Promise.reject(new Error("Missing file stream"));
41
66
  }
42
- // Ensure uploads folder exists
43
- const uploadPath = path_1.default.resolve(strapi.dirs.static.public, UPLOADS_FOLDER_NAME);
44
- if (!fs_extra_1.default.pathExistsSync(uploadPath)) {
45
- throw new Error(`The upload folder (${uploadPath}) doesn't exist or is not accessible. Please make sure it exists.`);
67
+ const { stream: stream$1 } = file;
68
+ return new Promise((resolve, reject) => {
69
+ stream.pipeline(
70
+ stream$1,
71
+ fs__default.default.createWriteStream(path__default.default.join(uploadPath, `${file.hash}${file.ext}`)),
72
+ (err) => {
73
+ if (err) {
74
+ return reject(err);
75
+ }
76
+ file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
77
+ resolve();
78
+ }
79
+ );
80
+ });
81
+ },
82
+ upload(file) {
83
+ if (!file.buffer) {
84
+ return Promise.reject(new Error("Missing file buffer"));
46
85
  }
47
- return {
48
- checkFileSize(file, options) {
49
- const { sizeLimit } = options ?? {};
50
- // TODO V5: remove providerOptions sizeLimit
51
- if (providerOptionsSizeLimit) {
52
- if (kbytesToBytes(file.size) > providerOptionsSizeLimit)
53
- throw new PayloadTooLargeError(`${file.name} exceeds size limit of ${bytesToHumanReadable(providerOptionsSizeLimit)}.`);
54
- }
55
- else if (sizeLimit) {
56
- if (kbytesToBytes(file.size) > sizeLimit)
57
- throw new PayloadTooLargeError(`${file.name} exceeds size limit of ${bytesToHumanReadable(sizeLimit)}.`);
58
- }
59
- },
60
- uploadStream(file) {
61
- if (!file.stream) {
62
- return Promise.reject(new Error('Missing file stream'));
63
- }
64
- const { stream } = file;
65
- return new Promise((resolve, reject) => {
66
- (0, stream_1.pipeline)(stream, fs_1.default.createWriteStream(path_1.default.join(uploadPath, `${file.hash}${file.ext}`)), (err) => {
67
- if (err) {
68
- return reject(err);
69
- }
70
- file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
71
- resolve();
72
- });
73
- });
74
- },
75
- upload(file) {
76
- if (!file.buffer) {
77
- return Promise.reject(new Error('Missing file buffer'));
78
- }
79
- const { buffer } = file;
80
- return new Promise((resolve, reject) => {
81
- // write file in public/assets folder
82
- fs_1.default.writeFile(path_1.default.join(uploadPath, `${file.hash}${file.ext}`), buffer, (err) => {
83
- if (err) {
84
- return reject(err);
85
- }
86
- file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
87
- resolve();
88
- });
89
- });
90
- },
91
- delete(file) {
92
- return new Promise((resolve, reject) => {
93
- const filePath = path_1.default.join(uploadPath, `${file.hash}${file.ext}`);
94
- if (!fs_1.default.existsSync(filePath)) {
95
- resolve("File doesn't exist");
96
- return;
97
- }
98
- // remove file from public/assets folder
99
- fs_1.default.unlink(filePath, (err) => {
100
- if (err) {
101
- return reject(err);
102
- }
103
- resolve();
104
- });
105
- });
106
- },
107
- };
108
- },
86
+ const { buffer } = file;
87
+ return new Promise((resolve, reject) => {
88
+ fs__default.default.writeFile(path__default.default.join(uploadPath, `${file.hash}${file.ext}`), buffer, (err) => {
89
+ if (err) {
90
+ return reject(err);
91
+ }
92
+ file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
93
+ resolve();
94
+ });
95
+ });
96
+ },
97
+ delete(file) {
98
+ return new Promise((resolve, reject) => {
99
+ const filePath = path__default.default.join(uploadPath, `${file.hash}${file.ext}`);
100
+ if (!fs__default.default.existsSync(filePath)) {
101
+ resolve("File doesn't exist");
102
+ return;
103
+ }
104
+ fs__default.default.unlink(filePath, (err) => {
105
+ if (err) {
106
+ return reject(err);
107
+ }
108
+ resolve();
109
+ });
110
+ });
111
+ }
112
+ };
113
+ }
109
114
  };
110
- //# sourceMappingURL=index.js.map
115
+ module.exports = index;
116
+ //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import { pipeline } from 'stream';\nimport fs, { ReadStream } from 'fs';\nimport path from 'path';\nimport fse from 'fs-extra';\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 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\nconst { PayloadTooLargeError } = utils.errors;\nconst { kbytesToBytes, bytesToHumanReadable } = utils.file;\n\nconst UPLOADS_FOLDER_NAME = 'uploads';\n\ninterface InitOptions {\n sizeLimit?: number;\n}\n\ninterface CheckFileSizeOptions {\n sizeLimit?: number;\n}\n\nexport default {\n init({ sizeLimit: providerOptionsSizeLimit }: InitOptions = {}) {\n // TODO V5: remove providerOptions sizeLimit\n if (providerOptionsSizeLimit) {\n process.emitWarning(\n '[deprecated] In future versions, \"sizeLimit\" argument will be ignored from upload.config.providerOptions. Move it to upload.config'\n );\n }\n\n // Ensure uploads folder exists\n const uploadPath = path.resolve(strapi.dirs.static.public, UPLOADS_FOLDER_NAME);\n if (!fse.pathExistsSync(uploadPath)) {\n throw new Error(\n `The upload folder (${uploadPath}) doesn't exist or is not accessible. Please make sure it exists.`\n );\n }\n\n return {\n checkFileSize(file: File, options: CheckFileSizeOptions) {\n const { sizeLimit } = options ?? {};\n\n // TODO V5: remove providerOptions sizeLimit\n if (providerOptionsSizeLimit) {\n if (kbytesToBytes(file.size) > providerOptionsSizeLimit)\n throw new PayloadTooLargeError(\n `${file.name} exceeds size limit of ${bytesToHumanReadable(\n providerOptionsSizeLimit\n )}.`\n );\n } else if (sizeLimit) {\n if (kbytesToBytes(file.size) > sizeLimit)\n throw new PayloadTooLargeError(\n `${file.name} exceeds size limit of ${bytesToHumanReadable(sizeLimit)}.`\n );\n }\n },\n uploadStream(file: File): Promise<void> {\n if (!file.stream) {\n return Promise.reject(new Error('Missing file stream'));\n }\n\n const { stream } = file;\n\n return new Promise((resolve, reject) => {\n pipeline(\n stream,\n fs.createWriteStream(path.join(uploadPath, `${file.hash}${file.ext}`)),\n (err) => {\n if (err) {\n return reject(err);\n }\n\n file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;\n\n resolve();\n }\n );\n });\n },\n upload(file: File): Promise<void> {\n if (!file.buffer) {\n return Promise.reject(new Error('Missing file buffer'));\n }\n\n const { buffer } = file;\n\n return new Promise((resolve, reject) => {\n // write file in public/assets folder\n fs.writeFile(path.join(uploadPath, `${file.hash}${file.ext}`), buffer, (err) => {\n if (err) {\n return reject(err);\n }\n\n file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;\n\n resolve();\n });\n });\n },\n delete(file: File): Promise<string | void> {\n return new Promise((resolve, reject) => {\n const filePath = path.join(uploadPath, `${file.hash}${file.ext}`);\n\n if (!fs.existsSync(filePath)) {\n resolve(\"File doesn't exist\");\n return;\n }\n\n // remove file from public/assets folder\n fs.unlink(filePath, (err) => {\n if (err) {\n return reject(err);\n }\n\n resolve();\n });\n });\n },\n };\n },\n};\n"],"names":["utils","path","fse","stream","pipeline","fs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0BA,MAAM,EAAE,qBAAqB,IAAIA,iBAAM;AACvC,MAAM,EAAE,eAAe,yBAAyBA,iBAAM;AAEtD,MAAM,sBAAsB;AAU5B,MAAe,QAAA;AAAA,EACb,KAAK,EAAE,WAAW,yBAAyB,IAAiB,CAAA,GAAI;AAE9D,QAAI,0BAA0B;AACpB,cAAA;AAAA,QACN;AAAA,MAAA;AAAA,IAEJ;AAGA,UAAM,aAAaC,cAAK,QAAA,QAAQ,OAAO,KAAK,OAAO,QAAQ,mBAAmB;AAC9E,QAAI,CAACC,aAAA,QAAI,eAAe,UAAU,GAAG;AACnC,YAAM,IAAI;AAAA,QACR,sBAAsB,UAAU;AAAA,MAAA;AAAA,IAEpC;AAEO,WAAA;AAAA,MACL,cAAc,MAAY,SAA+B;AACvD,cAAM,EAAE,UAAA,IAAc,WAAW;AAGjC,YAAI,0BAA0B;AACxB,cAAA,cAAc,KAAK,IAAI,IAAI;AAC7B,kBAAM,IAAI;AAAA,cACR,GAAG,KAAK,IAAI,0BAA0B;AAAA,gBACpC;AAAA,cACD,CAAA;AAAA,YAAA;AAAA,mBAEI,WAAW;AAChB,cAAA,cAAc,KAAK,IAAI,IAAI;AAC7B,kBAAM,IAAI;AAAA,cACR,GAAG,KAAK,IAAI,0BAA0B,qBAAqB,SAAS,CAAC;AAAA,YAAA;AAAA,QAE3E;AAAA,MACF;AAAA,MACA,aAAa,MAA2B;AAClC,YAAA,CAAC,KAAK,QAAQ;AAChB,iBAAO,QAAQ,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,QACxD;AAEM,cAAA,EAAEC,QAAAA,SAAW,IAAA;AAEnB,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtCC,iBAAA;AAAA,YACED;AAAAA,YACAE,YAAAA,QAAG,kBAAkBJ,sBAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE,CAAC;AAAA,YACrE,CAAC,QAAQ;AACP,kBAAI,KAAK;AACP,uBAAO,OAAO,GAAG;AAAA,cACnB;AAEK,mBAAA,MAAM,IAAI,mBAAmB,IAAI,KAAK,IAAI,GAAG,KAAK,GAAG;AAElD;YACV;AAAA,UAAA;AAAA,QACF,CACD;AAAA,MACH;AAAA,MACA,OAAO,MAA2B;AAC5B,YAAA,CAAC,KAAK,QAAQ;AAChB,iBAAO,QAAQ,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,QACxD;AAEM,cAAA,EAAE,OAAW,IAAA;AAEnB,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAEtCI,sBAAA,QAAG,UAAUJ,cAAA,QAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE,GAAG,QAAQ,CAAC,QAAQ;AAC9E,gBAAI,KAAK;AACP,qBAAO,OAAO,GAAG;AAAA,YACnB;AAEK,iBAAA,MAAM,IAAI,mBAAmB,IAAI,KAAK,IAAI,GAAG,KAAK,GAAG;AAElD;UAAA,CACT;AAAA,QAAA,CACF;AAAA,MACH;AAAA,MACA,OAAO,MAAoC;AACzC,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAChC,gBAAA,WAAWA,cAAAA,QAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE;AAEhE,cAAI,CAACI,YAAA,QAAG,WAAW,QAAQ,GAAG;AAC5B,oBAAQ,oBAAoB;AAC5B;AAAA,UACF;AAGGA,sBAAAA,QAAA,OAAO,UAAU,CAAC,QAAQ;AAC3B,gBAAI,KAAK;AACP,qBAAO,OAAO,GAAG;AAAA,YACnB;AAEQ;UAAA,CACT;AAAA,QAAA,CACF;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AACF;;"}
package/dist/index.mjs ADDED
@@ -0,0 +1,94 @@
1
+ import { pipeline } from "stream";
2
+ import fs from "fs";
3
+ import path from "path";
4
+ import fse from "fs-extra";
5
+ import * as utils from "@strapi/utils";
6
+ const { PayloadTooLargeError } = utils.errors;
7
+ const { kbytesToBytes, bytesToHumanReadable } = utils.file;
8
+ const UPLOADS_FOLDER_NAME = "uploads";
9
+ const index = {
10
+ init({ sizeLimit: providerOptionsSizeLimit } = {}) {
11
+ if (providerOptionsSizeLimit) {
12
+ process.emitWarning(
13
+ '[deprecated] In future versions, "sizeLimit" argument will be ignored from upload.config.providerOptions. Move it to upload.config'
14
+ );
15
+ }
16
+ const uploadPath = path.resolve(strapi.dirs.static.public, UPLOADS_FOLDER_NAME);
17
+ if (!fse.pathExistsSync(uploadPath)) {
18
+ throw new Error(
19
+ `The upload folder (${uploadPath}) doesn't exist or is not accessible. Please make sure it exists.`
20
+ );
21
+ }
22
+ return {
23
+ checkFileSize(file, options) {
24
+ const { sizeLimit } = options ?? {};
25
+ if (providerOptionsSizeLimit) {
26
+ if (kbytesToBytes(file.size) > providerOptionsSizeLimit)
27
+ throw new PayloadTooLargeError(
28
+ `${file.name} exceeds size limit of ${bytesToHumanReadable(
29
+ providerOptionsSizeLimit
30
+ )}.`
31
+ );
32
+ } else if (sizeLimit) {
33
+ if (kbytesToBytes(file.size) > sizeLimit)
34
+ throw new PayloadTooLargeError(
35
+ `${file.name} exceeds size limit of ${bytesToHumanReadable(sizeLimit)}.`
36
+ );
37
+ }
38
+ },
39
+ uploadStream(file) {
40
+ if (!file.stream) {
41
+ return Promise.reject(new Error("Missing file stream"));
42
+ }
43
+ const { stream } = file;
44
+ return new Promise((resolve, reject) => {
45
+ pipeline(
46
+ stream,
47
+ fs.createWriteStream(path.join(uploadPath, `${file.hash}${file.ext}`)),
48
+ (err) => {
49
+ if (err) {
50
+ return reject(err);
51
+ }
52
+ file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
53
+ resolve();
54
+ }
55
+ );
56
+ });
57
+ },
58
+ upload(file) {
59
+ if (!file.buffer) {
60
+ return Promise.reject(new Error("Missing file buffer"));
61
+ }
62
+ const { buffer } = file;
63
+ return new Promise((resolve, reject) => {
64
+ fs.writeFile(path.join(uploadPath, `${file.hash}${file.ext}`), buffer, (err) => {
65
+ if (err) {
66
+ return reject(err);
67
+ }
68
+ file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;
69
+ resolve();
70
+ });
71
+ });
72
+ },
73
+ delete(file) {
74
+ return new Promise((resolve, reject) => {
75
+ const filePath = path.join(uploadPath, `${file.hash}${file.ext}`);
76
+ if (!fs.existsSync(filePath)) {
77
+ resolve("File doesn't exist");
78
+ return;
79
+ }
80
+ fs.unlink(filePath, (err) => {
81
+ if (err) {
82
+ return reject(err);
83
+ }
84
+ resolve();
85
+ });
86
+ });
87
+ }
88
+ };
89
+ }
90
+ };
91
+ export {
92
+ index as default
93
+ };
94
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import { pipeline } from 'stream';\nimport fs, { ReadStream } from 'fs';\nimport path from 'path';\nimport fse from 'fs-extra';\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 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\nconst { PayloadTooLargeError } = utils.errors;\nconst { kbytesToBytes, bytesToHumanReadable } = utils.file;\n\nconst UPLOADS_FOLDER_NAME = 'uploads';\n\ninterface InitOptions {\n sizeLimit?: number;\n}\n\ninterface CheckFileSizeOptions {\n sizeLimit?: number;\n}\n\nexport default {\n init({ sizeLimit: providerOptionsSizeLimit }: InitOptions = {}) {\n // TODO V5: remove providerOptions sizeLimit\n if (providerOptionsSizeLimit) {\n process.emitWarning(\n '[deprecated] In future versions, \"sizeLimit\" argument will be ignored from upload.config.providerOptions. Move it to upload.config'\n );\n }\n\n // Ensure uploads folder exists\n const uploadPath = path.resolve(strapi.dirs.static.public, UPLOADS_FOLDER_NAME);\n if (!fse.pathExistsSync(uploadPath)) {\n throw new Error(\n `The upload folder (${uploadPath}) doesn't exist or is not accessible. Please make sure it exists.`\n );\n }\n\n return {\n checkFileSize(file: File, options: CheckFileSizeOptions) {\n const { sizeLimit } = options ?? {};\n\n // TODO V5: remove providerOptions sizeLimit\n if (providerOptionsSizeLimit) {\n if (kbytesToBytes(file.size) > providerOptionsSizeLimit)\n throw new PayloadTooLargeError(\n `${file.name} exceeds size limit of ${bytesToHumanReadable(\n providerOptionsSizeLimit\n )}.`\n );\n } else if (sizeLimit) {\n if (kbytesToBytes(file.size) > sizeLimit)\n throw new PayloadTooLargeError(\n `${file.name} exceeds size limit of ${bytesToHumanReadable(sizeLimit)}.`\n );\n }\n },\n uploadStream(file: File): Promise<void> {\n if (!file.stream) {\n return Promise.reject(new Error('Missing file stream'));\n }\n\n const { stream } = file;\n\n return new Promise((resolve, reject) => {\n pipeline(\n stream,\n fs.createWriteStream(path.join(uploadPath, `${file.hash}${file.ext}`)),\n (err) => {\n if (err) {\n return reject(err);\n }\n\n file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;\n\n resolve();\n }\n );\n });\n },\n upload(file: File): Promise<void> {\n if (!file.buffer) {\n return Promise.reject(new Error('Missing file buffer'));\n }\n\n const { buffer } = file;\n\n return new Promise((resolve, reject) => {\n // write file in public/assets folder\n fs.writeFile(path.join(uploadPath, `${file.hash}${file.ext}`), buffer, (err) => {\n if (err) {\n return reject(err);\n }\n\n file.url = `/${UPLOADS_FOLDER_NAME}/${file.hash}${file.ext}`;\n\n resolve();\n });\n });\n },\n delete(file: File): Promise<string | void> {\n return new Promise((resolve, reject) => {\n const filePath = path.join(uploadPath, `${file.hash}${file.ext}`);\n\n if (!fs.existsSync(filePath)) {\n resolve(\"File doesn't exist\");\n return;\n }\n\n // remove file from public/assets folder\n fs.unlink(filePath, (err) => {\n if (err) {\n return reject(err);\n }\n\n resolve();\n });\n });\n },\n };\n },\n};\n"],"names":[],"mappings":";;;;;AA0BA,MAAM,EAAE,qBAAqB,IAAI,MAAM;AACvC,MAAM,EAAE,eAAe,yBAAyB,MAAM;AAEtD,MAAM,sBAAsB;AAU5B,MAAe,QAAA;AAAA,EACb,KAAK,EAAE,WAAW,yBAAyB,IAAiB,CAAA,GAAI;AAE9D,QAAI,0BAA0B;AACpB,cAAA;AAAA,QACN;AAAA,MAAA;AAAA,IAEJ;AAGA,UAAM,aAAa,KAAK,QAAQ,OAAO,KAAK,OAAO,QAAQ,mBAAmB;AAC9E,QAAI,CAAC,IAAI,eAAe,UAAU,GAAG;AACnC,YAAM,IAAI;AAAA,QACR,sBAAsB,UAAU;AAAA,MAAA;AAAA,IAEpC;AAEO,WAAA;AAAA,MACL,cAAc,MAAY,SAA+B;AACvD,cAAM,EAAE,UAAA,IAAc,WAAW;AAGjC,YAAI,0BAA0B;AACxB,cAAA,cAAc,KAAK,IAAI,IAAI;AAC7B,kBAAM,IAAI;AAAA,cACR,GAAG,KAAK,IAAI,0BAA0B;AAAA,gBACpC;AAAA,cACD,CAAA;AAAA,YAAA;AAAA,mBAEI,WAAW;AAChB,cAAA,cAAc,KAAK,IAAI,IAAI;AAC7B,kBAAM,IAAI;AAAA,cACR,GAAG,KAAK,IAAI,0BAA0B,qBAAqB,SAAS,CAAC;AAAA,YAAA;AAAA,QAE3E;AAAA,MACF;AAAA,MACA,aAAa,MAA2B;AAClC,YAAA,CAAC,KAAK,QAAQ;AAChB,iBAAO,QAAQ,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,QACxD;AAEM,cAAA,EAAE,OAAW,IAAA;AAEnB,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AACtC;AAAA,YACE;AAAA,YACA,GAAG,kBAAkB,KAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE,CAAC;AAAA,YACrE,CAAC,QAAQ;AACP,kBAAI,KAAK;AACP,uBAAO,OAAO,GAAG;AAAA,cACnB;AAEK,mBAAA,MAAM,IAAI,mBAAmB,IAAI,KAAK,IAAI,GAAG,KAAK,GAAG;AAElD;YACV;AAAA,UAAA;AAAA,QACF,CACD;AAAA,MACH;AAAA,MACA,OAAO,MAA2B;AAC5B,YAAA,CAAC,KAAK,QAAQ;AAChB,iBAAO,QAAQ,OAAO,IAAI,MAAM,qBAAqB,CAAC;AAAA,QACxD;AAEM,cAAA,EAAE,OAAW,IAAA;AAEnB,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAEtC,aAAG,UAAU,KAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE,GAAG,QAAQ,CAAC,QAAQ;AAC9E,gBAAI,KAAK;AACP,qBAAO,OAAO,GAAG;AAAA,YACnB;AAEK,iBAAA,MAAM,IAAI,mBAAmB,IAAI,KAAK,IAAI,GAAG,KAAK,GAAG;AAElD;UAAA,CACT;AAAA,QAAA,CACF;AAAA,MACH;AAAA,MACA,OAAO,MAAoC;AACzC,eAAO,IAAI,QAAQ,CAAC,SAAS,WAAW;AAChC,gBAAA,WAAW,KAAK,KAAK,YAAY,GAAG,KAAK,IAAI,GAAG,KAAK,GAAG,EAAE;AAEhE,cAAI,CAAC,GAAG,WAAW,QAAQ,GAAG;AAC5B,oBAAQ,oBAAoB;AAC5B;AAAA,UACF;AAGG,aAAA,OAAO,UAAU,CAAC,QAAQ;AAC3B,gBAAI,KAAK;AACP,qBAAO,OAAO,GAAG;AAAA,YACnB;AAEQ;UAAA,CACT;AAAA,QAAA,CACF;AAAA,MACH;AAAA,IAAA;AAAA,EAEJ;AACF;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/provider-upload-local",
3
- "version": "4.15.0-alpha.0",
3
+ "version": "4.15.0",
4
4
  "description": "Local provider for strapi upload",
5
5
  "keywords": [
6
6
  "upload",
@@ -28,32 +28,34 @@
28
28
  }
29
29
  ],
30
30
  "main": "./dist/index.js",
31
+ "module": "./dist/index.mjs",
32
+ "source": "./src/index.ts",
31
33
  "types": "./dist/index.d.ts",
32
34
  "files": [
33
35
  "./dist"
34
36
  ],
35
37
  "scripts": {
36
- "build": "run -T tsc",
37
- "build:ts": "run -T tsc",
38
- "watch": "run -T tsc -w --preserveWatchOutput",
38
+ "build": "pack-up build",
39
39
  "clean": "run -T rimraf ./dist",
40
+ "lint": "run -T eslint .",
40
41
  "prepublishOnly": "yarn clean && yarn build",
41
42
  "test:unit": "run -T jest",
42
43
  "test:unit:watch": "run -T jest --watch",
43
- "lint": "run -T eslint ."
44
+ "watch": "pack-up watch"
44
45
  },
45
46
  "dependencies": {
46
- "@strapi/utils": "4.15.0-alpha.0",
47
+ "@strapi/utils": "4.15.0",
47
48
  "fs-extra": "10.0.0"
48
49
  },
49
50
  "devDependencies": {
51
+ "@strapi/pack-up": "4.15.0",
50
52
  "@types/jest": "29.5.2",
51
- "eslint-config-custom": "4.15.0-alpha.0",
52
- "tsconfig": "4.15.0-alpha.0"
53
+ "eslint-config-custom": "4.15.0",
54
+ "tsconfig": "4.15.0"
53
55
  },
54
56
  "engines": {
55
- "node": ">=16.0.0 <=20.x.x",
57
+ "node": ">=18.0.0 <=20.x.x",
56
58
  "npm": ">=6.0.0"
57
59
  },
58
- "gitHead": "682a070df9ef90f2aa6966666488e066d61831e2"
60
+ "gitHead": "6e44e1e68db5153e485e61bdc03f42efb0311406"
59
61
  }