@azteam/express 1.2.451 → 1.2.454
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/lib/middleware/index.js
CHANGED
|
@@ -57,6 +57,12 @@ Object.defineProperty(exports, "systemRoleMiddleware", {
|
|
|
57
57
|
return _systemRoleMiddleware["default"];
|
|
58
58
|
}
|
|
59
59
|
});
|
|
60
|
+
Object.defineProperty(exports, "uploadMiddleware", {
|
|
61
|
+
enumerable: true,
|
|
62
|
+
get: function get() {
|
|
63
|
+
return _uploadMiddleware["default"];
|
|
64
|
+
}
|
|
65
|
+
});
|
|
60
66
|
Object.defineProperty(exports, "validateMiddleware", {
|
|
61
67
|
enumerable: true,
|
|
62
68
|
get: function get() {
|
|
@@ -80,4 +86,5 @@ var _limitRequestMiddleware = _interopRequireDefault(require("./limitRequestMidd
|
|
|
80
86
|
var _cacheMiddleware = _interopRequireDefault(require("./cacheMiddleware"));
|
|
81
87
|
var _verifyGoogleAppMiddleware = _interopRequireDefault(require("./verifyGoogleAppMiddleware"));
|
|
82
88
|
var _recaptchaMiddleware = _interopRequireDefault(require("./recaptchaMiddleware"));
|
|
89
|
+
var _uploadMiddleware = _interopRequireDefault(require("./uploadMiddleware"));
|
|
83
90
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports["default"] = _default;
|
|
7
|
+
var _lodash = _interopRequireDefault(require("lodash"));
|
|
8
|
+
var _multer = _interopRequireDefault(require("multer"));
|
|
9
|
+
var _error = require("@azteam/error");
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
11
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
12
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
13
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
14
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
15
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
16
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
17
|
+
function _default(fieldName) {
|
|
18
|
+
var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
19
|
+
var opts = _objectSpread({
|
|
20
|
+
isMultiple: false,
|
|
21
|
+
maxFile: 5,
|
|
22
|
+
limitFileSize: 5,
|
|
23
|
+
// 5MB
|
|
24
|
+
allowedMimes: [],
|
|
25
|
+
storageDir: process.env.TEMPS_DIR,
|
|
26
|
+
callBackFileName: function callBackFileName(req, file, cb) {
|
|
27
|
+
cb(null, file.originalname);
|
|
28
|
+
}
|
|
29
|
+
}, options),
|
|
30
|
+
isMultiple = opts.isMultiple,
|
|
31
|
+
allowedMimes = opts.allowedMimes,
|
|
32
|
+
maxFile = opts.maxFile,
|
|
33
|
+
storageDir = opts.storageDir,
|
|
34
|
+
callBackFileName = opts.callBackFileName,
|
|
35
|
+
limitFileSize = opts.limitFileSize,
|
|
36
|
+
tempsStorage = _multer["default"].diskStorage({
|
|
37
|
+
destination: function destination(req, file, cb) {
|
|
38
|
+
cb(null, storageDir);
|
|
39
|
+
},
|
|
40
|
+
filename: callBackFileName
|
|
41
|
+
}),
|
|
42
|
+
upload = (0, _multer["default"])({
|
|
43
|
+
storage: tempsStorage,
|
|
44
|
+
limits: {
|
|
45
|
+
files: 1,
|
|
46
|
+
fileSize: limitFileSize * 1024 * 1024
|
|
47
|
+
},
|
|
48
|
+
fileFilter: function fileFilter(req, file, cb) {
|
|
49
|
+
if (_lodash["default"].includes(allowedMimes, file.mimetype)) {
|
|
50
|
+
cb(null, true);
|
|
51
|
+
} else {
|
|
52
|
+
cb(new _error.ErrorException(_error.FILE_TYPE, {
|
|
53
|
+
mime: file.mimetype
|
|
54
|
+
}));
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
if (isMultiple) {
|
|
59
|
+
return upload.array(fieldName, maxFile);
|
|
60
|
+
}
|
|
61
|
+
return upload.single(fieldName);
|
|
62
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@azteam/express",
|
|
3
|
-
"version": "1.2.
|
|
3
|
+
"version": "1.2.454",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"author": "toda <sp.azsolution.net@gmail.com>",
|
|
6
6
|
"main": "./lib/index.js",
|
|
@@ -14,7 +14,7 @@
|
|
|
14
14
|
"@azteam/error": "1.0.40",
|
|
15
15
|
"@azteam/http-client": "1.0.118",
|
|
16
16
|
"@azteam/util": "1.0.52",
|
|
17
|
-
"@azteam/validator": "1.0.
|
|
17
|
+
"@azteam/validator": "1.0.30",
|
|
18
18
|
"@grpc/grpc-js": "1.6.7",
|
|
19
19
|
"@grpc/proto-loader": "0.6.12",
|
|
20
20
|
"@socket.io/redis-adapter": "7.2.0",
|
|
@@ -36,6 +36,7 @@
|
|
|
36
36
|
"pluralize": "8.0.0",
|
|
37
37
|
"psl": "1.8.0",
|
|
38
38
|
"socket.io": "4.4.1",
|
|
39
|
-
"ua-parser-js": "1.0.32"
|
|
39
|
+
"ua-parser-js": "1.0.32",
|
|
40
|
+
"multer": "1.4.5-lts.1"
|
|
40
41
|
}
|
|
41
42
|
}
|
package/src/middleware/index.js
CHANGED
|
@@ -9,3 +9,4 @@ export {default as limitRequestMiddleware} from './limitRequestMiddleware';
|
|
|
9
9
|
export {default as cacheMiddleware} from './cacheMiddleware';
|
|
10
10
|
export {default as verifyGoogleAppMiddleware} from './verifyGoogleAppMiddleware';
|
|
11
11
|
export {default as recaptchaMiddleware} from './recaptchaMiddleware';
|
|
12
|
+
export {default as uploadMiddleware} from './uploadMiddleware';
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import _ from 'lodash';
|
|
2
|
+
import multer from 'multer';
|
|
3
|
+
|
|
4
|
+
import {ErrorException, FILE_TYPE} from '@azteam/error';
|
|
5
|
+
|
|
6
|
+
export default function (fieldName, options = {}) {
|
|
7
|
+
const opts = {
|
|
8
|
+
isMultiple: false,
|
|
9
|
+
maxFile: 5,
|
|
10
|
+
limitFileSize: 5, // 5MB
|
|
11
|
+
allowedMimes: [],
|
|
12
|
+
storageDir: process.env.TEMPS_DIR,
|
|
13
|
+
|
|
14
|
+
callBackFileName(req, file, cb) {
|
|
15
|
+
cb(null, file.originalname);
|
|
16
|
+
},
|
|
17
|
+
...options,
|
|
18
|
+
},
|
|
19
|
+
{isMultiple, allowedMimes, maxFile, storageDir, callBackFileName, limitFileSize} = opts,
|
|
20
|
+
tempsStorage = multer.diskStorage({
|
|
21
|
+
destination(req, file, cb) {
|
|
22
|
+
cb(null, storageDir);
|
|
23
|
+
},
|
|
24
|
+
filename: callBackFileName,
|
|
25
|
+
}),
|
|
26
|
+
upload = multer({
|
|
27
|
+
storage: tempsStorage,
|
|
28
|
+
limits: {
|
|
29
|
+
files: 1,
|
|
30
|
+
fileSize: limitFileSize * 1024 * 1024,
|
|
31
|
+
},
|
|
32
|
+
fileFilter: (req, file, cb) => {
|
|
33
|
+
if (_.includes(allowedMimes, file.mimetype)) {
|
|
34
|
+
cb(null, true);
|
|
35
|
+
} else {
|
|
36
|
+
cb(
|
|
37
|
+
new ErrorException(FILE_TYPE, {
|
|
38
|
+
mime: file.mimetype,
|
|
39
|
+
})
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
if (isMultiple) {
|
|
46
|
+
return upload.array(fieldName, maxFile);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return upload.single(fieldName);
|
|
50
|
+
}
|