@middy/http-response-serializer 5.0.0-alpha.0 → 5.0.0-alpha.1

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.
Files changed (4) hide show
  1. package/README.md +3 -2
  2. package/index.js +65 -54
  3. package/package.json +5 -11
  4. 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://lgtm.com/projects/g/middyjs/middy/context:javascript">
23
- <img src="https://img.shields.io/lgtm/grade/javascript/g/middyjs/middy.svg?logo=lgtm&logoWidth=18" alt="Language grade: JavaScript" style="max-width:100%;">
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
@@ -1,59 +1,70 @@
1
- import { normalizeHttpResponse } from '@middy/util';
2
- import Accept from '@hapi/accept';
1
+ import { normalizeHttpResponse } from '@middy/util'
2
+ import Accept from '@hapi/accept'
3
+
3
4
  const defaults = {
4
- serializers: [],
5
- defaultContentType: undefined
6
- };
7
- const httpResponseSerializerMiddleware = (opts = {})=>{
8
- const { serializers , defaultContentType } = {
9
- ...defaults,
10
- ...opts
11
- };
12
- const httpResponseSerializerMiddlewareAfter = async (request)=>{
13
- normalizeHttpResponse(request);
14
- if (request.response.headers['Content-Type'] ?? request.response.headers['content-type']) {
15
- return;
5
+ serializers: [],
6
+ defaultContentType: undefined
7
+ }
8
+
9
+ const httpResponseSerializerMiddleware = (opts = {}) => {
10
+ const { serializers, defaultContentType } = { ...defaults, ...opts }
11
+ const httpResponseSerializerMiddlewareAfter = async (request) => {
12
+ normalizeHttpResponse(request)
13
+
14
+ // skip serialization when Content-Type or content-type is already set
15
+ if (
16
+ request.response.headers['Content-Type'] ??
17
+ request.response.headers['content-type']
18
+ ) {
19
+ return
20
+ }
21
+
22
+ // find accept value(s)
23
+ let types
24
+
25
+ if (request.event.requiredContentType) {
26
+ types = [request.event.requiredContentType]
27
+ } else {
28
+ const acceptHeader =
29
+ request.event.headers.Accept ?? request.event.headers.accept
30
+ types = [
31
+ ...((acceptHeader && Accept.mediaTypes(acceptHeader)) ?? []),
32
+ request.event.preferredContentType,
33
+ defaultContentType
34
+ ]
35
+ }
36
+
37
+ for (const type of types) {
38
+ let breakTypes
39
+ for (const s of serializers) {
40
+ if (!s.regex.test(type)) {
41
+ continue
16
42
  }
17
- let types;
18
- if (request.event.requiredContentType) {
19
- types = [
20
- request.event.requiredContentType
21
- ];
43
+
44
+ request.response.headers['Content-Type'] = type
45
+ const result = s.serializer(request.response)
46
+ if (typeof result === 'object' && 'body' in result) {
47
+ request.response = result
22
48
  } else {
23
- const acceptHeader = request.event.headers.Accept ?? request.event.headers.accept;
24
- types = [
25
- ...(acceptHeader && Accept.mediaTypes(acceptHeader)) ?? [],
26
- request.event.preferredContentType,
27
- defaultContentType
28
- ];
29
- }
30
- for (const type of types){
31
- let breakTypes;
32
- for (const s of serializers){
33
- if (!s.regex.test(type)) {
34
- continue;
35
- }
36
- request.response.headers['Content-Type'] = type;
37
- const result = s.serializer(request.response);
38
- if (typeof result === 'object' && 'body' in result) {
39
- request.response = result;
40
- } else {
41
- request.response.body = result;
42
- }
43
- breakTypes = true;
44
- break;
45
- }
46
- if (breakTypes) break;
49
+ // otherwise only replace the body attribute
50
+ request.response.body = result
47
51
  }
48
- };
49
- const httpResponseSerializerMiddlewareOnError = async (request)=>{
50
- if (request.response === undefined) return;
51
- return httpResponseSerializerMiddlewareAfter(request);
52
- };
53
- return {
54
- after: httpResponseSerializerMiddlewareAfter,
55
- onError: httpResponseSerializerMiddlewareOnError
56
- };
57
- };
58
- export default httpResponseSerializerMiddleware;
59
52
 
53
+ breakTypes = true
54
+ break
55
+ }
56
+ if (breakTypes) break
57
+ }
58
+ }
59
+
60
+ const httpResponseSerializerMiddlewareOnError = async (request) => {
61
+ if (request.response === undefined) return
62
+ await httpResponseSerializerMiddlewareAfter(request)
63
+ }
64
+ return {
65
+ after: httpResponseSerializerMiddlewareAfter,
66
+ onError: httpResponseSerializerMiddlewareOnError
67
+ }
68
+ }
69
+
70
+ export default httpResponseSerializerMiddleware
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@middy/http-response-serializer",
3
- "version": "5.0.0-alpha.0",
3
+ "version": "5.0.0-alpha.1",
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.1",
73
- "@middy/util": "5.0.0-alpha.0"
66
+ "@hapi/accept": "6.0.2",
67
+ "@middy/util": "5.0.0-alpha.1"
74
68
  },
75
69
  "devDependencies": {
76
- "@middy/core": "5.0.0-alpha.0"
70
+ "@middy/core": "5.0.0-alpha.1"
77
71
  },
78
- "gitHead": "08c35e3dba9efdad0b86666ce206ce302cc65d07"
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
-