@middy/http-response-serializer 5.0.0-alpha.0 → 5.0.0-alpha.2
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/README.md +3 -2
- package/index.js +5 -2
- package/package.json +5 -11
- package/index.cjs +0 -72
package/README.md
CHANGED
|
@@ -19,8 +19,9 @@
|
|
|
19
19
|
<a href="https://snyk.io/test/github/middyjs/middy">
|
|
20
20
|
<img src="https://snyk.io/test/github/middyjs/middy/badge.svg" alt="Known Vulnerabilities" data-canonical-src="https://snyk.io/test/github/middyjs/middy" style="max-width:100%;">
|
|
21
21
|
</a>
|
|
22
|
-
<a href="https://
|
|
23
|
-
<img src="https://
|
|
22
|
+
<a href="https://github.com/middyjs/middy/actions/workflows/sast.yml">
|
|
23
|
+
<img src="https://github.com/middyjs/middy/actions/workflows/sast.yml/badge.svg
|
|
24
|
+
?branch=main&event=push" alt="CodeQL" style="max-width:100%;">
|
|
24
25
|
</a>
|
|
25
26
|
<a href="https://bestpractices.coreinfrastructure.org/projects/5280">
|
|
26
27
|
<img src="https://bestpractices.coreinfrastructure.org/projects/5280/badge" alt="Core Infrastructure Initiative (CII) Best Practices" style="max-width:100%;">
|
package/index.js
CHANGED
|
@@ -5,15 +5,17 @@ const defaults = {
|
|
|
5
5
|
defaultContentType: undefined
|
|
6
6
|
};
|
|
7
7
|
const httpResponseSerializerMiddleware = (opts = {})=>{
|
|
8
|
-
const { serializers
|
|
8
|
+
const { serializers, defaultContentType } = {
|
|
9
9
|
...defaults,
|
|
10
10
|
...opts
|
|
11
11
|
};
|
|
12
12
|
const httpResponseSerializerMiddlewareAfter = async (request)=>{
|
|
13
13
|
normalizeHttpResponse(request);
|
|
14
|
+
// skip serialization when Content-Type or content-type is already set
|
|
14
15
|
if (request.response.headers['Content-Type'] ?? request.response.headers['content-type']) {
|
|
15
16
|
return;
|
|
16
17
|
}
|
|
18
|
+
// find accept value(s)
|
|
17
19
|
let types;
|
|
18
20
|
if (request.event.requiredContentType) {
|
|
19
21
|
types = [
|
|
@@ -38,6 +40,7 @@ const httpResponseSerializerMiddleware = (opts = {})=>{
|
|
|
38
40
|
if (typeof result === 'object' && 'body' in result) {
|
|
39
41
|
request.response = result;
|
|
40
42
|
} else {
|
|
43
|
+
// otherwise only replace the body attribute
|
|
41
44
|
request.response.body = result;
|
|
42
45
|
}
|
|
43
46
|
breakTypes = true;
|
|
@@ -48,7 +51,7 @@ const httpResponseSerializerMiddleware = (opts = {})=>{
|
|
|
48
51
|
};
|
|
49
52
|
const httpResponseSerializerMiddlewareOnError = async (request)=>{
|
|
50
53
|
if (request.response === undefined) return;
|
|
51
|
-
|
|
54
|
+
await httpResponseSerializerMiddlewareAfter(request);
|
|
52
55
|
};
|
|
53
56
|
return {
|
|
54
57
|
after: httpResponseSerializerMiddlewareAfter,
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@middy/http-response-serializer",
|
|
3
|
-
"version": "5.0.0-alpha.
|
|
3
|
+
"version": "5.0.0-alpha.2",
|
|
4
4
|
"description": "The Http Serializer middleware lets you define serialization mechanisms based on the current content negotiation.",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"engines": {
|
|
@@ -10,24 +10,18 @@
|
|
|
10
10
|
"publishConfig": {
|
|
11
11
|
"access": "public"
|
|
12
12
|
},
|
|
13
|
-
"main": "./index.cjs",
|
|
14
13
|
"module": "./index.js",
|
|
15
14
|
"exports": {
|
|
16
15
|
".": {
|
|
17
16
|
"import": {
|
|
18
17
|
"types": "./index.d.ts",
|
|
19
18
|
"default": "./index.js"
|
|
20
|
-
},
|
|
21
|
-
"require": {
|
|
22
|
-
"types": "./index.d.ts",
|
|
23
|
-
"default": "./index.cjs"
|
|
24
19
|
}
|
|
25
20
|
}
|
|
26
21
|
},
|
|
27
22
|
"types": "index.d.ts",
|
|
28
23
|
"files": [
|
|
29
24
|
"index.js",
|
|
30
|
-
"index.cjs",
|
|
31
25
|
"index.d.ts"
|
|
32
26
|
],
|
|
33
27
|
"scripts": {
|
|
@@ -69,11 +63,11 @@
|
|
|
69
63
|
"url": "https://github.com/sponsors/willfarrell"
|
|
70
64
|
},
|
|
71
65
|
"dependencies": {
|
|
72
|
-
"@hapi/accept": "6.0.
|
|
73
|
-
"@middy/util": "5.0.0-alpha.
|
|
66
|
+
"@hapi/accept": "6.0.2",
|
|
67
|
+
"@middy/util": "5.0.0-alpha.2"
|
|
74
68
|
},
|
|
75
69
|
"devDependencies": {
|
|
76
|
-
"@middy/core": "5.0.0-alpha.
|
|
70
|
+
"@middy/core": "5.0.0-alpha.2"
|
|
77
71
|
},
|
|
78
|
-
"gitHead": "
|
|
72
|
+
"gitHead": "ebce8d5df8783077fa49ba62ee9be20e8486a7f1"
|
|
79
73
|
}
|
package/index.cjs
DELETED
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", {
|
|
3
|
-
value: true
|
|
4
|
-
});
|
|
5
|
-
Object.defineProperty(module, "exports", {
|
|
6
|
-
enumerable: true,
|
|
7
|
-
get: ()=>_default
|
|
8
|
-
});
|
|
9
|
-
const _util = require("@middy/util");
|
|
10
|
-
const _accept = _interopRequireDefault(require("@hapi/accept"));
|
|
11
|
-
function _interopRequireDefault(obj) {
|
|
12
|
-
return obj && obj.__esModule ? obj : {
|
|
13
|
-
default: obj
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
const defaults = {
|
|
17
|
-
serializers: [],
|
|
18
|
-
defaultContentType: undefined
|
|
19
|
-
};
|
|
20
|
-
const httpResponseSerializerMiddleware = (opts = {})=>{
|
|
21
|
-
const { serializers , defaultContentType } = {
|
|
22
|
-
...defaults,
|
|
23
|
-
...opts
|
|
24
|
-
};
|
|
25
|
-
const httpResponseSerializerMiddlewareAfter = async (request)=>{
|
|
26
|
-
(0, _util.normalizeHttpResponse)(request);
|
|
27
|
-
if (request.response.headers['Content-Type'] ?? request.response.headers['content-type']) {
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
let types;
|
|
31
|
-
if (request.event.requiredContentType) {
|
|
32
|
-
types = [
|
|
33
|
-
request.event.requiredContentType
|
|
34
|
-
];
|
|
35
|
-
} else {
|
|
36
|
-
const acceptHeader = request.event.headers.Accept ?? request.event.headers.accept;
|
|
37
|
-
types = [
|
|
38
|
-
...(acceptHeader && _accept.default.mediaTypes(acceptHeader)) ?? [],
|
|
39
|
-
request.event.preferredContentType,
|
|
40
|
-
defaultContentType
|
|
41
|
-
];
|
|
42
|
-
}
|
|
43
|
-
for (const type of types){
|
|
44
|
-
let breakTypes;
|
|
45
|
-
for (const s of serializers){
|
|
46
|
-
if (!s.regex.test(type)) {
|
|
47
|
-
continue;
|
|
48
|
-
}
|
|
49
|
-
request.response.headers['Content-Type'] = type;
|
|
50
|
-
const result = s.serializer(request.response);
|
|
51
|
-
if (typeof result === 'object' && 'body' in result) {
|
|
52
|
-
request.response = result;
|
|
53
|
-
} else {
|
|
54
|
-
request.response.body = result;
|
|
55
|
-
}
|
|
56
|
-
breakTypes = true;
|
|
57
|
-
break;
|
|
58
|
-
}
|
|
59
|
-
if (breakTypes) break;
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
const httpResponseSerializerMiddlewareOnError = async (request)=>{
|
|
63
|
-
if (request.response === undefined) return;
|
|
64
|
-
return httpResponseSerializerMiddlewareAfter(request);
|
|
65
|
-
};
|
|
66
|
-
return {
|
|
67
|
-
after: httpResponseSerializerMiddlewareAfter,
|
|
68
|
-
onError: httpResponseSerializerMiddlewareOnError
|
|
69
|
-
};
|
|
70
|
-
};
|
|
71
|
-
const _default = httpResponseSerializerMiddleware;
|
|
72
|
-
|