nextlove 2.1.9 → 2.2.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/chunk-7JYJ5SIL.mjs +144 -0
- package/dist/generators/index.js +937 -549
- package/dist/generators/index.mjs +945 -557
- package/dist/index.d.ts +1 -1
- package/dist/index.js +144 -13
- package/dist/index.mjs +17 -8
- package/dist/nextjs-exception-middleware/index.d.ts +83 -0
- package/dist/nextjs-exception-middleware/index.js +164 -0
- package/dist/nextjs-exception-middleware/index.mjs +20 -0
- package/exception-middleware.d.ts +1 -0
- package/package.json +23 -13
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { NextApiRequest, NextApiResponse } from 'next';
|
|
2
|
+
|
|
3
|
+
interface WithExceptionHandlingOptions {
|
|
4
|
+
getErrorContext?: (req: NextApiRequest, error: Error) => Record<string, unknown>;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
interface WithOkStatusOptions {
|
|
8
|
+
addIf?: (req: NextApiRequest) => boolean;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
declare type HttpExceptionMetadata = {
|
|
12
|
+
type: string;
|
|
13
|
+
message: string;
|
|
14
|
+
data?: Record<string, unknown>;
|
|
15
|
+
} & Record<string, unknown>;
|
|
16
|
+
interface ThrowingOptions {
|
|
17
|
+
json?: boolean;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Throw HttpExceptions inside API endpoints to generate nice error messages
|
|
21
|
+
*
|
|
22
|
+
* @example
|
|
23
|
+
* ```
|
|
24
|
+
* if (bad_soups.includes(soup_param)) {
|
|
25
|
+
* throw new HttpException(400, {
|
|
26
|
+
* type: "cant_make_soup",
|
|
27
|
+
* message: "Soup was too difficult, please specify a different soup"
|
|
28
|
+
* })
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*
|
|
32
|
+
**/
|
|
33
|
+
declare class HttpException extends Error {
|
|
34
|
+
status: number;
|
|
35
|
+
metadata: HttpExceptionMetadata;
|
|
36
|
+
options: ThrowingOptions;
|
|
37
|
+
constructor(status: number, metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
38
|
+
toString(): string;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Throw BadRequestException inside API endpoints that were provided incorrect
|
|
42
|
+
* parameters or body
|
|
43
|
+
*
|
|
44
|
+
* @example
|
|
45
|
+
* ```
|
|
46
|
+
* if (bad_soups.includes(soup_param)) {
|
|
47
|
+
* throw new BadRequestException({
|
|
48
|
+
* type: "cant_make_soup",
|
|
49
|
+
* message: "Soup was too difficult, please specify a different soup",
|
|
50
|
+
* })
|
|
51
|
+
* }
|
|
52
|
+
* ```
|
|
53
|
+
*
|
|
54
|
+
**/
|
|
55
|
+
declare class BadRequestException extends HttpException {
|
|
56
|
+
metadata: HttpExceptionMetadata;
|
|
57
|
+
constructor(metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
58
|
+
}
|
|
59
|
+
declare class UnauthorizedException extends HttpException {
|
|
60
|
+
metadata: HttpExceptionMetadata;
|
|
61
|
+
constructor(metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
62
|
+
}
|
|
63
|
+
declare class NotFoundException extends HttpException {
|
|
64
|
+
metadata: HttpExceptionMetadata;
|
|
65
|
+
constructor(metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
66
|
+
}
|
|
67
|
+
declare class MethodNotAllowedException extends HttpException {
|
|
68
|
+
metadata: HttpExceptionMetadata;
|
|
69
|
+
constructor(metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
70
|
+
}
|
|
71
|
+
declare class InternalServerErrorException extends HttpException {
|
|
72
|
+
metadata: HttpExceptionMetadata;
|
|
73
|
+
constructor(metadata: HttpExceptionMetadata, options?: ThrowingOptions);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
interface ExceptionHandlingOptions {
|
|
77
|
+
addOkStatus?: boolean;
|
|
78
|
+
okStatusOptions?: WithOkStatusOptions;
|
|
79
|
+
exceptionHandlingOptions?: WithExceptionHandlingOptions;
|
|
80
|
+
}
|
|
81
|
+
declare const withExceptionHandling: ({ addOkStatus, okStatusOptions, exceptionHandlingOptions, }?: ExceptionHandlingOptions) => (next: (req: NextApiRequest, res: NextApiResponse) => Promise<void>) => (req: NextApiRequest, res: NextApiResponse) => Promise<void>;
|
|
82
|
+
|
|
83
|
+
export { BadRequestException, ExceptionHandlingOptions, HttpException, HttpExceptionMetadata, InternalServerErrorException, MethodNotAllowedException, NotFoundException, ThrowingOptions, UnauthorizedException, withExceptionHandling };
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/nextjs-exception-middleware/index.ts
|
|
21
|
+
var nextjs_exception_middleware_exports = {};
|
|
22
|
+
__export(nextjs_exception_middleware_exports, {
|
|
23
|
+
BadRequestException: () => BadRequestException,
|
|
24
|
+
HttpException: () => HttpException,
|
|
25
|
+
InternalServerErrorException: () => InternalServerErrorException,
|
|
26
|
+
MethodNotAllowedException: () => MethodNotAllowedException,
|
|
27
|
+
NotFoundException: () => NotFoundException,
|
|
28
|
+
UnauthorizedException: () => UnauthorizedException,
|
|
29
|
+
withExceptionHandling: () => withExceptionHandling2
|
|
30
|
+
});
|
|
31
|
+
module.exports = __toCommonJS(nextjs_exception_middleware_exports);
|
|
32
|
+
|
|
33
|
+
// src/nextjs-exception-middleware/http-exceptions.ts
|
|
34
|
+
var HttpException = class extends Error {
|
|
35
|
+
constructor(status, metadata, options) {
|
|
36
|
+
super(metadata.message);
|
|
37
|
+
this.status = status;
|
|
38
|
+
this.metadata = metadata;
|
|
39
|
+
if (Error.captureStackTrace) {
|
|
40
|
+
Error.captureStackTrace(this, this.constructor);
|
|
41
|
+
}
|
|
42
|
+
this.options = options != null ? options : { json: true };
|
|
43
|
+
}
|
|
44
|
+
toString() {
|
|
45
|
+
return `HttpException: ${this.status}, ${this.metadata.message} (${this.metadata.type})`;
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
var BadRequestException = class extends HttpException {
|
|
49
|
+
constructor(metadata, options) {
|
|
50
|
+
super(400, metadata, options);
|
|
51
|
+
this.metadata = metadata;
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
var UnauthorizedException = class extends HttpException {
|
|
55
|
+
constructor(metadata, options) {
|
|
56
|
+
super(401, metadata, options);
|
|
57
|
+
this.metadata = metadata;
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
var NotFoundException = class extends HttpException {
|
|
61
|
+
constructor(metadata, options) {
|
|
62
|
+
super(404, metadata, options);
|
|
63
|
+
this.metadata = metadata;
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
var MethodNotAllowedException = class extends HttpException {
|
|
67
|
+
constructor(metadata, options) {
|
|
68
|
+
super(405, metadata, options);
|
|
69
|
+
this.metadata = metadata;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
var InternalServerErrorException = class extends HttpException {
|
|
73
|
+
constructor(metadata, options) {
|
|
74
|
+
super(500, metadata, options);
|
|
75
|
+
this.metadata = metadata;
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
// src/nextjs-exception-middleware/with-exception-handling.ts
|
|
80
|
+
var withExceptionHandling = (options = {}) => (next) => async (req, res) => {
|
|
81
|
+
try {
|
|
82
|
+
await next(req, res);
|
|
83
|
+
} catch (error) {
|
|
84
|
+
let errorContext = {};
|
|
85
|
+
if (error instanceof Error) {
|
|
86
|
+
errorContext.stack = error.stack;
|
|
87
|
+
}
|
|
88
|
+
errorContext = options.getErrorContext ? options.getErrorContext(req, errorContext) : errorContext;
|
|
89
|
+
if (error instanceof HttpException) {
|
|
90
|
+
if (error.options.json) {
|
|
91
|
+
res.status(error.status).json({
|
|
92
|
+
error: {
|
|
93
|
+
...error.metadata,
|
|
94
|
+
...errorContext
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
return;
|
|
98
|
+
} else {
|
|
99
|
+
res.status(error.status).end(error.metadata.message);
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
} else {
|
|
103
|
+
const formattedError = new HttpException(500, {
|
|
104
|
+
type: "internal_server_error",
|
|
105
|
+
message: error instanceof Error ? error.message : "Unknown error"
|
|
106
|
+
});
|
|
107
|
+
res.status(500).json({
|
|
108
|
+
error: {
|
|
109
|
+
...formattedError.metadata,
|
|
110
|
+
...errorContext
|
|
111
|
+
}
|
|
112
|
+
});
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
};
|
|
117
|
+
var with_exception_handling_default = withExceptionHandling;
|
|
118
|
+
|
|
119
|
+
// src/nextjs-exception-middleware/with-ok-status.ts
|
|
120
|
+
var withOkStatus = (options = {}) => (next) => async (req, res) => {
|
|
121
|
+
const originalJson = res.json;
|
|
122
|
+
res.json = function(data) {
|
|
123
|
+
const ok = res.statusCode >= 200 && res.statusCode < 300;
|
|
124
|
+
const shouldIncludeStatus = options.addIf ? options.addIf(req) : true;
|
|
125
|
+
if (shouldIncludeStatus) {
|
|
126
|
+
originalJson.call(this, {
|
|
127
|
+
...data,
|
|
128
|
+
ok
|
|
129
|
+
});
|
|
130
|
+
} else {
|
|
131
|
+
originalJson.call(this, data);
|
|
132
|
+
}
|
|
133
|
+
};
|
|
134
|
+
await next(req, res);
|
|
135
|
+
};
|
|
136
|
+
var with_ok_status_default = withOkStatus;
|
|
137
|
+
|
|
138
|
+
// src/nextjs-exception-middleware/index.ts
|
|
139
|
+
var withExceptionHandling2 = ({
|
|
140
|
+
addOkStatus = false,
|
|
141
|
+
okStatusOptions,
|
|
142
|
+
exceptionHandlingOptions
|
|
143
|
+
} = {}) => (next) => (req, res) => {
|
|
144
|
+
if (addOkStatus) {
|
|
145
|
+
return with_ok_status_default(okStatusOptions)(
|
|
146
|
+
with_exception_handling_default(exceptionHandlingOptions)(next)
|
|
147
|
+
)(req, res);
|
|
148
|
+
}
|
|
149
|
+
return with_exception_handling_default(exceptionHandlingOptions)(next)(
|
|
150
|
+
req,
|
|
151
|
+
res
|
|
152
|
+
);
|
|
153
|
+
};
|
|
154
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
155
|
+
0 && (module.exports = {
|
|
156
|
+
BadRequestException,
|
|
157
|
+
HttpException,
|
|
158
|
+
InternalServerErrorException,
|
|
159
|
+
MethodNotAllowedException,
|
|
160
|
+
NotFoundException,
|
|
161
|
+
UnauthorizedException,
|
|
162
|
+
withExceptionHandling
|
|
163
|
+
});
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/nextjs-exception-middleware/index.ts", "../../src/nextjs-exception-middleware/http-exceptions.ts", "../../src/nextjs-exception-middleware/with-exception-handling.ts", "../../src/nextjs-exception-middleware/with-ok-status.ts"],
  "sourcesContent": ["import { NextApiRequest, NextApiResponse } from \"next\"\nimport unwrappedWithExceptionHandling, {\n  WithExceptionHandlingOptions,\n} from \"./with-exception-handling\"\nimport withOkStatus, { WithOkStatusOptions } from \"./with-ok-status\"\n\nexport interface ExceptionHandlingOptions {\n  addOkStatus?: boolean\n  okStatusOptions?: WithOkStatusOptions\n  exceptionHandlingOptions?: WithExceptionHandlingOptions\n}\n\nexport const withExceptionHandling =\n  ({\n    addOkStatus = false,\n    okStatusOptions,\n    exceptionHandlingOptions,\n  }: ExceptionHandlingOptions = {}) =>\n  (next: (req: NextApiRequest, res: NextApiResponse) => Promise<void>) =>\n  (req: NextApiRequest, res: NextApiResponse) => {\n    if (addOkStatus) {\n      return withOkStatus(okStatusOptions)(\n        unwrappedWithExceptionHandling(exceptionHandlingOptions)(next)\n      )(req, res)\n    }\n\n    return unwrappedWithExceptionHandling(exceptionHandlingOptions)(next)(\n      req,\n      res\n    )\n  }\n\nexport * from \"./http-exceptions\"\n", "export type HttpExceptionMetadata = {\n  type: string\n  message: string\n  data?: Record<string, unknown>\n} & Record<string, unknown>\n\nexport interface ThrowingOptions {\n  json?: boolean\n}\n\n/**\n * Throw HttpExceptions inside API endpoints to generate nice error messages\n *\n * @example\n * ```\n * if (bad_soups.includes(soup_param)) {\n *   throw new HttpException(400, {\n *      type: \"cant_make_soup\",\n *      message: \"Soup was too difficult, please specify a different soup\"\n *    })\n * }\n * ```\n *\n **/\nexport class HttpException extends Error {\n  options: ThrowingOptions\n\n  constructor(\n    public status: number,\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(metadata.message)\n\n    if (Error.captureStackTrace) {\n      Error.captureStackTrace(this, this.constructor)\n    }\n\n    this.options = options ?? { json: true }\n  }\n\n  toString() {\n    return `HttpException: ${this.status}, ${this.metadata.message} (${this.metadata.type})`\n  }\n}\n\n/**\n * Throw BadRequestException inside API endpoints that were provided incorrect\n * parameters or body\n *\n * @example\n * ```\n * if (bad_soups.includes(soup_param)) {\n *   throw new BadRequestException({\n *     type: \"cant_make_soup\",\n *     message: \"Soup was too difficult, please specify a different soup\",\n *   })\n * }\n * ```\n *\n **/\nexport class BadRequestException extends HttpException {\n  constructor(\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(400, metadata, options)\n  }\n}\n\nexport class UnauthorizedException extends HttpException {\n  constructor(\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(401, metadata, options)\n  }\n}\n\nexport class NotFoundException extends HttpException {\n  constructor(\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(404, metadata, options)\n  }\n}\n\nexport class MethodNotAllowedException extends HttpException {\n  constructor(\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(405, metadata, options)\n  }\n}\n\nexport class InternalServerErrorException extends HttpException {\n  constructor(\n    public metadata: HttpExceptionMetadata,\n    options?: ThrowingOptions\n  ) {\n    super(500, metadata, options)\n  }\n}\n", "import { NextApiRequest, NextApiResponse } from \"next\"\nimport { HttpException } from \"./http-exceptions\"\n\nexport interface WithExceptionHandlingOptions {\n  getErrorContext?: (\n    req: NextApiRequest,\n    error: Error\n  ) => Record<string, unknown>\n}\n\nconst withExceptionHandling =\n  (options: WithExceptionHandlingOptions = {}) =>\n  (next: (req: NextApiRequest, res: NextApiResponse) => Promise<void>) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    try {\n      await next(req, res)\n    } catch (error: unknown) {\n      let errorContext: any = {}\n\n      if (error instanceof Error) {\n        errorContext.stack = error.stack\n      }\n\n      errorContext = options.getErrorContext\n        ? options.getErrorContext(req, errorContext)\n        : errorContext\n\n      if (error instanceof HttpException) {\n        if (error.options.json) {\n          res.status(error.status).json({\n            error: {\n              ...error.metadata,\n              ...errorContext,\n            },\n          })\n          return\n        } else {\n          res.status(error.status).end(error.metadata.message)\n          return\n        }\n      } else {\n        const formattedError = new HttpException(500, {\n          type: \"internal_server_error\",\n          message: error instanceof Error ? error.message : \"Unknown error\",\n        })\n\n        res.status(500).json({\n          error: {\n            ...formattedError.metadata,\n            ...errorContext,\n          },\n        })\n        return\n      }\n    }\n  }\n\nexport default withExceptionHandling\n", "import { NextApiRequest, NextApiResponse } from \"next\"\n\nexport interface WithOkStatusOptions {\n  addIf?: (req: NextApiRequest) => boolean\n}\n\nconst withOkStatus =\n  (options: WithOkStatusOptions = {}) =>\n  (next: (req: NextApiRequest, res: NextApiResponse) => Promise<void>) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    // Patch .json()\n    const originalJson = res.json\n\n    res.json = function (data) {\n      const ok = res.statusCode >= 200 && res.statusCode < 300\n      const shouldIncludeStatus = options.addIf ? options.addIf(req) : true\n\n      if (shouldIncludeStatus) {\n        originalJson.call(this, {\n          ...data,\n          ok,\n        })\n      } else {\n        originalJson.call(this, data)\n      }\n    }\n\n    await next(req, res)\n  }\n\nexport default withOkStatus\n"],
  "mappings": "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",
  "names": ["withExceptionHandling", "withExceptionHandling"]
}

|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import {
|
|
2
|
+
BadRequestException,
|
|
3
|
+
HttpException,
|
|
4
|
+
InternalServerErrorException,
|
|
5
|
+
MethodNotAllowedException,
|
|
6
|
+
NotFoundException,
|
|
7
|
+
UnauthorizedException,
|
|
8
|
+
withExceptionHandling
|
|
9
|
+
} from "../chunk-7JYJ5SIL.mjs";
|
|
10
|
+
import "../chunk-2HL2TLDY.mjs";
|
|
11
|
+
export {
|
|
12
|
+
BadRequestException,
|
|
13
|
+
HttpException,
|
|
14
|
+
InternalServerErrorException,
|
|
15
|
+
MethodNotAllowedException,
|
|
16
|
+
NotFoundException,
|
|
17
|
+
UnauthorizedException,
|
|
18
|
+
withExceptionHandling
|
|
19
|
+
};
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from "./dist/nextjs-exception-middleware"
|
package/package.json
CHANGED
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nextlove",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "2.2.0",
|
|
4
4
|
"private": false,
|
|
5
5
|
"repository": "https://github.com/seamapi/nextlove",
|
|
6
6
|
"files": [
|
|
7
7
|
"dist",
|
|
8
|
-
"generators.d.ts"
|
|
8
|
+
"generators.d.ts",
|
|
9
|
+
"exception-middleware.d.ts"
|
|
9
10
|
],
|
|
10
11
|
"publishConfig": {
|
|
11
12
|
"access": "public",
|
|
@@ -28,50 +29,59 @@
|
|
|
28
29
|
"types": "./dist/generators/index.d.ts",
|
|
29
30
|
"import": "./dist/generators/index.mjs",
|
|
30
31
|
"require": "./dist/generators/index.js"
|
|
32
|
+
},
|
|
33
|
+
"./exception-middleware": {
|
|
34
|
+
"types": "./dist/nextjs-exception-middleware/index.d.ts",
|
|
35
|
+
"import": "./dist/nextjs-exception-middleware/index.mjs",
|
|
36
|
+
"require": "./dist/nextjs-exception-middleware/index.js"
|
|
31
37
|
}
|
|
32
38
|
},
|
|
33
39
|
"scripts": {
|
|
34
|
-
"test": "npm run typecheck",
|
|
40
|
+
"test": "npm run typecheck && npm run ava",
|
|
35
41
|
"typecheck": "tsc --noEmit",
|
|
36
|
-
"
|
|
42
|
+
"ava": "ava",
|
|
43
|
+
"build": "tsup --dts --sourcemap inline src/index.ts src/generators/index.ts src/nextjs-exception-middleware/index.ts --format cjs,esm",
|
|
37
44
|
"yalc": "npm run build && yalc push"
|
|
38
45
|
},
|
|
39
46
|
"peerDependencies": {
|
|
40
47
|
"esbuild-register": ">=3",
|
|
41
48
|
"next": ">=12",
|
|
49
|
+
"nextjs-server-modules": ">=1",
|
|
50
|
+
"prettier": "^2.0.0 || ^3.0.0",
|
|
42
51
|
"react": ">=18",
|
|
43
52
|
"react-dom": ">=18",
|
|
44
|
-
"
|
|
45
|
-
"zod": "^3.0.0",
|
|
46
|
-
"prettier": "^2.0.0 || ^3.0.0"
|
|
53
|
+
"zod": "^3.0.0"
|
|
47
54
|
},
|
|
48
55
|
"dependencies": {
|
|
49
|
-
"@anatine/zod-openapi": "^2.0.1",
|
|
50
56
|
"lodash": "^4.17.21",
|
|
51
|
-
"nextjs-exception-middleware": "^2.0.1",
|
|
52
57
|
"nextjs-middleware-wrappers": "^1.3.0",
|
|
53
58
|
"openapi3-ts": "^4.1.2",
|
|
54
59
|
"zod-to-ts": "^1.1.4"
|
|
55
60
|
},
|
|
56
61
|
"devDependencies": {
|
|
62
|
+
"@anatine/zod-openapi": "^2.0.1",
|
|
57
63
|
"@types/lodash": "^4.14.182",
|
|
58
64
|
"@types/node": "18.0.0",
|
|
59
65
|
"@types/prettier": "^2.7.1",
|
|
60
|
-
"@types/react": "18.0.14",
|
|
61
66
|
"@types/react-dom": "18.0.5",
|
|
67
|
+
"@types/react": "18.0.14",
|
|
68
|
+
"@types/sinon": "10.0.8",
|
|
69
|
+
"ava": "^5.3.1",
|
|
62
70
|
"chalk": "^5.3.0",
|
|
63
|
-
"esbuild": "^0.14.7",
|
|
64
71
|
"esbuild-register": "^3.3.3",
|
|
65
72
|
"esbuild-runner": "^2.2.1",
|
|
66
|
-
"
|
|
73
|
+
"esbuild": "^0.14.7",
|
|
67
74
|
"eslint-config-next": "12.2.0",
|
|
75
|
+
"eslint": "8.18.0",
|
|
68
76
|
"expect-type": "^0.15.0",
|
|
77
|
+
"globby": "^13.2.2",
|
|
69
78
|
"next": "12.2.0",
|
|
70
79
|
"nextjs-middleware-wrappers": "^1.3.0",
|
|
71
80
|
"nextjs-server-modules": "^2.1.0",
|
|
72
81
|
"prettier": "^2.7.1",
|
|
73
|
-
"react": "18.2.0",
|
|
74
82
|
"react-dom": "18.2.0",
|
|
83
|
+
"react": "18.2.0",
|
|
84
|
+
"sinon": "^15.2.0",
|
|
75
85
|
"ts-toolbelt": "^9.6.0",
|
|
76
86
|
"tsup": "^5.6.3",
|
|
77
87
|
"turbo": "^1.3.1",
|