@things-factory/attachment-base 4.3.40 → 4.3.59
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-server/attachment-const.js +2 -1
- package/dist-server/attachment-const.js.map +1 -1
- package/dist-server/awb-storage-s3.js +42 -0
- package/dist-server/awb-storage-s3.js.map +1 -0
- package/dist-server/index.js +1 -0
- package/dist-server/index.js.map +1 -1
- package/dist-server/util/index.js +14 -0
- package/dist-server/util/index.js.map +1 -0
- package/dist-server/util/upload-awb.js +12 -0
- package/dist-server/util/upload-awb.js.map +1 -0
- package/package.json +4 -4
- package/server/attachment-const.ts +1 -0
- package/server/awb-storage-s3.ts +44 -0
- package/server/index.ts +1 -0
- package/server/util/index.ts +1 -0
- package/server/util/upload-awb.ts +11 -0
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ATTACHMENT_PATH = exports.STORAGE = void 0;
|
|
3
|
+
exports.ATTACHMENT_PATH = exports.AWBSTORAGE = exports.STORAGE = void 0;
|
|
4
4
|
const env_1 = require("@things-factory/env");
|
|
5
5
|
exports.STORAGE = env_1.config.get('storage');
|
|
6
|
+
exports.AWBSTORAGE = env_1.config.get('awbFileStorage');
|
|
6
7
|
exports.ATTACHMENT_PATH = env_1.config.get('attachmentPath', 'attachment');
|
|
7
8
|
//# sourceMappingURL=attachment-const.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"attachment-const.js","sourceRoot":"","sources":["../server/attachment-const.ts"],"names":[],"mappings":";;;AAAA,6CAA4C;AAEjC,QAAA,OAAO,GAAQ,YAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"attachment-const.js","sourceRoot":"","sources":["../server/attachment-const.ts"],"names":[],"mappings":";;;AAAA,6CAA4C;AAEjC,QAAA,OAAO,GAAQ,YAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;AACpC,QAAA,UAAU,GAAQ,YAAM,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;AAC5C,QAAA,eAAe,GAAW,YAAM,CAAC,GAAG,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAA"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const client_s3_1 = require("@aws-sdk/client-s3");
|
|
4
|
+
const lib_storage_1 = require("@aws-sdk/lib-storage");
|
|
5
|
+
const env_1 = require("@things-factory/env");
|
|
6
|
+
const attachment_const_1 = require("./attachment-const");
|
|
7
|
+
if (attachment_const_1.AWBSTORAGE && attachment_const_1.AWBSTORAGE.type == 's3') {
|
|
8
|
+
const client = new client_s3_1.S3Client({
|
|
9
|
+
credentials: {
|
|
10
|
+
accessKeyId: attachment_const_1.AWBSTORAGE.accessKeyId,
|
|
11
|
+
secretAccessKey: attachment_const_1.AWBSTORAGE.secretAccessKey
|
|
12
|
+
},
|
|
13
|
+
region: attachment_const_1.AWBSTORAGE.region
|
|
14
|
+
});
|
|
15
|
+
/* upload file */
|
|
16
|
+
attachment_const_1.AWBSTORAGE.uploadFile = async ({ stream, filename }) => {
|
|
17
|
+
const upload = new lib_storage_1.Upload({
|
|
18
|
+
client,
|
|
19
|
+
params: {
|
|
20
|
+
Bucket: attachment_const_1.AWBSTORAGE.bucketName,
|
|
21
|
+
Key: `${filename}.pdf`,
|
|
22
|
+
Body: stream,
|
|
23
|
+
ContentType: 'application/pdf'
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
let result;
|
|
27
|
+
let url;
|
|
28
|
+
try {
|
|
29
|
+
result = (await upload.done());
|
|
30
|
+
url = `https://${attachment_const_1.AWBSTORAGE.bucketName}.s3.${attachment_const_1.AWBSTORAGE.region}.amazonaws.com/${filename}.pdf`;
|
|
31
|
+
}
|
|
32
|
+
catch (e) {
|
|
33
|
+
console.log(e);
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
result,
|
|
37
|
+
url
|
|
38
|
+
};
|
|
39
|
+
};
|
|
40
|
+
env_1.logger.info('operato-awb: S3 Bucket Storage is Ready.');
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=awb-storage-s3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"awb-storage-s3.js","sourceRoot":"","sources":["../server/awb-storage-s3.ts"],"names":[],"mappings":";;AAAA,kDAA6C;AAC7C,sDAA6C;AAC7C,6CAA4C;AAE5C,yDAA+C;AAE/C,IAAI,6BAAU,IAAI,6BAAU,CAAC,IAAI,IAAI,IAAI,EAAE;IACzC,MAAM,MAAM,GAAG,IAAI,oBAAQ,CAAC;QAC1B,WAAW,EAAE;YACX,WAAW,EAAE,6BAAU,CAAC,WAAW;YACnC,eAAe,EAAE,6BAAU,CAAC,eAAe;SAC5C;QACD,MAAM,EAAE,6BAAU,CAAC,MAAM;KAC1B,CAAC,CAAA;IAEF,iBAAiB;IACjB,6BAAU,CAAC,UAAU,GAAG,KAAK,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE;QACrD,MAAM,MAAM,GAAG,IAAI,oBAAM,CAAC;YACxB,MAAM;YACN,MAAM,EAAE;gBACN,MAAM,EAAE,6BAAU,CAAC,UAAU;gBAC7B,GAAG,EAAE,GAAG,QAAQ,MAAM;gBACtB,IAAI,EAAE,MAAM;gBACZ,WAAW,EAAE,iBAAiB;aAC/B;SACF,CAAC,CAAA;QAEF,IAAI,MAAM,CAAA;QACV,IAAI,GAAG,CAAA;QACP,IAAI;YACF,MAAM,GAAG,CAAC,MAAM,MAAM,CAAC,IAAI,EAAE,CAAQ,CAAA;YACrC,GAAG,GAAG,WAAW,6BAAU,CAAC,UAAU,OAAO,6BAAU,CAAC,MAAM,kBAAkB,QAAQ,MAAM,CAAA;SAC/F;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;SACf;QAED,OAAO;YACL,MAAM;YACN,GAAG;SACJ,CAAA;IACH,CAAC,CAAA;IAED,YAAM,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAA;CACxD"}
|
package/dist-server/index.js
CHANGED
|
@@ -23,4 +23,5 @@ Object.defineProperty(exports, "multipleUpload", { enumerable: true, get: functi
|
|
|
23
23
|
Object.defineProperty(exports, "singleUpload", { enumerable: true, get: function () { return attachment_mutation_1.singleUpload; } });
|
|
24
24
|
require("./routes");
|
|
25
25
|
__exportStar(require("./attachment-const"), exports);
|
|
26
|
+
__exportStar(require("./util"), exports);
|
|
26
27
|
//# sourceMappingURL=index.js.map
|
package/dist-server/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../server/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qDAAkC;AAClC,+CAA4B;AAC5B,4CAAyB;AACzB,gFAOiD;AAN/C,uHAAA,gBAAgB,OAAA;AAChB,wHAAA,iBAAiB,OAAA;AACjB,uHAAA,gBAAgB,OAAA;AAChB,6HAAA,sBAAsB,OAAA;AACtB,qHAAA,cAAc,OAAA;AACd,mHAAA,YAAY,OAAA;AAGd,oBAAiB;AAEjB,qDAAkC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../server/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,qDAAkC;AAClC,+CAA4B;AAC5B,4CAAyB;AACzB,gFAOiD;AAN/C,uHAAA,gBAAgB,OAAA;AAChB,wHAAA,iBAAiB,OAAA;AACjB,uHAAA,gBAAgB,OAAA;AAChB,6HAAA,sBAAsB,OAAA;AACtB,qHAAA,cAAc,OAAA;AACd,mHAAA,YAAY,OAAA;AAGd,oBAAiB;AAEjB,qDAAkC;AAClC,yCAAsB"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
+
}) : (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
o[k2] = m[k];
|
|
8
|
+
}));
|
|
9
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
+
};
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
__exportStar(require("./upload-awb"), exports);
|
|
14
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../server/util/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+CAA4B"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.uploadAwb = void 0;
|
|
4
|
+
require("../awb-storage-s3");
|
|
5
|
+
const attachment_const_1 = require("../attachment-const");
|
|
6
|
+
async function uploadAwb(param) {
|
|
7
|
+
const { content, title } = param;
|
|
8
|
+
let result = await attachment_const_1.AWBSTORAGE.uploadFile({ stream: content, filename: title });
|
|
9
|
+
return result;
|
|
10
|
+
}
|
|
11
|
+
exports.uploadAwb = uploadAwb;
|
|
12
|
+
//# sourceMappingURL=upload-awb.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload-awb.js","sourceRoot":"","sources":["../../server/util/upload-awb.ts"],"names":[],"mappings":";;;AAAA,6BAA0B;AAE1B,0DAAgD;AAEzC,KAAK,UAAU,SAAS,CAAC,KAAU;IACxC,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,KAAK,CAAA;IAEhC,IAAI,MAAM,GAAG,MAAM,6BAAU,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAA;IAE9E,OAAO,MAAM,CAAA;AACf,CAAC;AAND,8BAMC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@things-factory/attachment-base",
|
|
3
|
-
"version": "4.3.
|
|
3
|
+
"version": "4.3.59",
|
|
4
4
|
"main": "dist-server/index.js",
|
|
5
5
|
"browser": "client/index.js",
|
|
6
6
|
"things-factory": true,
|
|
@@ -28,11 +28,11 @@
|
|
|
28
28
|
"@aws-sdk/lib-storage": "^3.46.0",
|
|
29
29
|
"@aws-sdk/s3-presigned-post": "^3.46.0",
|
|
30
30
|
"@koa/multer": "^3.0.0",
|
|
31
|
-
"@things-factory/auth-base": "^4.3.
|
|
32
|
-
"@things-factory/env": "^4.3.
|
|
31
|
+
"@things-factory/auth-base": "^4.3.47",
|
|
32
|
+
"@things-factory/env": "^4.3.47",
|
|
33
33
|
"memfs": "^3.0.1",
|
|
34
34
|
"mime": "^2.4.4",
|
|
35
35
|
"multer": "^1.3.0"
|
|
36
36
|
},
|
|
37
|
-
"gitHead": "
|
|
37
|
+
"gitHead": "923ea2407895243b6e4030e75580aaa87b17e9dc"
|
|
38
38
|
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { S3Client } from '@aws-sdk/client-s3'
|
|
2
|
+
import { Upload } from '@aws-sdk/lib-storage'
|
|
3
|
+
import { logger } from '@things-factory/env'
|
|
4
|
+
|
|
5
|
+
import { AWBSTORAGE } from './attachment-const'
|
|
6
|
+
|
|
7
|
+
if (AWBSTORAGE && AWBSTORAGE.type == 's3') {
|
|
8
|
+
const client = new S3Client({
|
|
9
|
+
credentials: {
|
|
10
|
+
accessKeyId: AWBSTORAGE.accessKeyId,
|
|
11
|
+
secretAccessKey: AWBSTORAGE.secretAccessKey
|
|
12
|
+
},
|
|
13
|
+
region: AWBSTORAGE.region
|
|
14
|
+
})
|
|
15
|
+
|
|
16
|
+
/* upload file */
|
|
17
|
+
AWBSTORAGE.uploadFile = async ({ stream, filename }) => {
|
|
18
|
+
const upload = new Upload({
|
|
19
|
+
client,
|
|
20
|
+
params: {
|
|
21
|
+
Bucket: AWBSTORAGE.bucketName,
|
|
22
|
+
Key: `${filename}.pdf`,
|
|
23
|
+
Body: stream,
|
|
24
|
+
ContentType: 'application/pdf'
|
|
25
|
+
}
|
|
26
|
+
})
|
|
27
|
+
|
|
28
|
+
let result
|
|
29
|
+
let url
|
|
30
|
+
try {
|
|
31
|
+
result = (await upload.done()) as any
|
|
32
|
+
url = `https://${AWBSTORAGE.bucketName}.s3.${AWBSTORAGE.region}.amazonaws.com/${filename}.pdf`
|
|
33
|
+
} catch (e) {
|
|
34
|
+
console.log(e)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return {
|
|
38
|
+
result,
|
|
39
|
+
url
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
logger.info('operato-awb: S3 Bucket Storage is Ready.')
|
|
44
|
+
}
|
package/server/index.ts
CHANGED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './upload-awb'
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import '../awb-storage-s3'
|
|
2
|
+
|
|
3
|
+
import { AWBSTORAGE } from '../attachment-const'
|
|
4
|
+
|
|
5
|
+
export async function uploadAwb(param: any) {
|
|
6
|
+
const { content, title } = param
|
|
7
|
+
|
|
8
|
+
let result = await AWBSTORAGE.uploadFile({ stream: content, filename: title })
|
|
9
|
+
|
|
10
|
+
return result
|
|
11
|
+
}
|