@sebspark/openapi-express 0.1.0 → 1.1.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/README.md +4 -4
- package/dist/index.js +25 -13
- package/dist/index.mjs +27 -15
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -25,15 +25,15 @@ Use [@sebspark/openapi-typegen](../packages/openapi-typegen)
|
|
|
25
25
|
```typescript
|
|
26
26
|
import express from 'express'
|
|
27
27
|
import { TypedRouter } from '@sebspark/openapi-express'
|
|
28
|
-
import {
|
|
28
|
+
import { MarketdataServer } from './schemas/marketdata'
|
|
29
29
|
import { getMarkets, getMarket } from './markets'
|
|
30
30
|
|
|
31
|
-
const api:
|
|
31
|
+
const api: MarketdataServer = {
|
|
32
32
|
'/markets': {
|
|
33
33
|
get: {
|
|
34
34
|
handler: async () => {
|
|
35
35
|
const markets = await getMarkets()
|
|
36
|
-
return [200, markets]
|
|
36
|
+
return [200, {data: markets}]
|
|
37
37
|
},
|
|
38
38
|
},
|
|
39
39
|
},
|
|
@@ -41,7 +41,7 @@ const api: MarketdataAPIServer = {
|
|
|
41
41
|
get: {
|
|
42
42
|
handler: async ({ params }) => {
|
|
43
43
|
const market = await getMarket(params.id)
|
|
44
|
-
return [200, market]
|
|
44
|
+
return [200, {data: market}]
|
|
45
45
|
},
|
|
46
46
|
},
|
|
47
47
|
},
|
package/dist/index.js
CHANGED
|
@@ -25,36 +25,48 @@ __export(src_exports, {
|
|
|
25
25
|
module.exports = __toCommonJS(src_exports);
|
|
26
26
|
|
|
27
27
|
// src/router.ts
|
|
28
|
-
var import_express = require("express");
|
|
29
28
|
var import_openapi_core = require("@sebspark/openapi-core");
|
|
29
|
+
var import_express = require("express");
|
|
30
30
|
var TypedRouter = (api, options = {}) => {
|
|
31
31
|
const router = (0, import_express.Router)();
|
|
32
32
|
router.use((0, import_express.json)());
|
|
33
|
-
const preUsings = options.pre
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
33
|
+
const preUsings = Array.isArray(options.pre) ? options.pre : options.pre ? [options.pre] : [];
|
|
34
|
+
for (const pre of preUsings) {
|
|
35
|
+
router.use(pre);
|
|
36
|
+
}
|
|
37
|
+
for (const [url, methods] of Object.entries(api)) {
|
|
38
|
+
for (const [method, route] of Object.entries(methods)) {
|
|
37
39
|
const handler = async (req, res, next) => {
|
|
38
40
|
try {
|
|
39
|
-
const [
|
|
40
|
-
|
|
41
|
+
const [status, response] = await route.handler(req);
|
|
42
|
+
const { headers, data } = response;
|
|
43
|
+
res.status(status);
|
|
44
|
+
if (headers) {
|
|
45
|
+
for (const [name, value] of Object.entries(headers)) {
|
|
46
|
+
res.setHeader(name, value);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (data)
|
|
50
|
+
res.send(data);
|
|
51
|
+
else
|
|
52
|
+
res.end();
|
|
41
53
|
} catch (error) {
|
|
42
54
|
next(error);
|
|
43
55
|
}
|
|
44
56
|
};
|
|
45
|
-
const pre = route.pre
|
|
57
|
+
const pre = Array.isArray(route.pre) ? route.pre : route.pre ? [route.pre] : [];
|
|
46
58
|
const handlers = pre.concat(handler);
|
|
47
59
|
router[method](url, ...handlers);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
50
62
|
router.use(errorHandler);
|
|
51
63
|
return router;
|
|
52
64
|
};
|
|
53
|
-
var errorHandler = (err,
|
|
65
|
+
var errorHandler = (err, _req, res, _next) => {
|
|
54
66
|
let error;
|
|
55
|
-
if (err.message && err.statusCode && err.toJSON)
|
|
67
|
+
if (err.message && err.statusCode && err.toJSON) {
|
|
56
68
|
error = err;
|
|
57
|
-
else {
|
|
69
|
+
} else {
|
|
58
70
|
const internal = err instanceof Error ? err : typeof err === "string" ? new Error(err) : void 0;
|
|
59
71
|
error = (0, import_openapi_core.createHttpError)(500, void 0, internal);
|
|
60
72
|
}
|
package/dist/index.mjs
CHANGED
|
@@ -1,39 +1,51 @@
|
|
|
1
1
|
// src/router.ts
|
|
2
|
+
import {
|
|
3
|
+
createHttpError
|
|
4
|
+
} from "@sebspark/openapi-core";
|
|
2
5
|
import {
|
|
3
6
|
Router,
|
|
4
7
|
json
|
|
5
8
|
} from "express";
|
|
6
|
-
import {
|
|
7
|
-
createHttpError
|
|
8
|
-
} from "@sebspark/openapi-core";
|
|
9
9
|
var TypedRouter = (api, options = {}) => {
|
|
10
10
|
const router = Router();
|
|
11
11
|
router.use(json());
|
|
12
|
-
const preUsings = options.pre
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
12
|
+
const preUsings = Array.isArray(options.pre) ? options.pre : options.pre ? [options.pre] : [];
|
|
13
|
+
for (const pre of preUsings) {
|
|
14
|
+
router.use(pre);
|
|
15
|
+
}
|
|
16
|
+
for (const [url, methods] of Object.entries(api)) {
|
|
17
|
+
for (const [method, route] of Object.entries(methods)) {
|
|
16
18
|
const handler = async (req, res, next) => {
|
|
17
19
|
try {
|
|
18
|
-
const [
|
|
19
|
-
|
|
20
|
+
const [status, response] = await route.handler(req);
|
|
21
|
+
const { headers, data } = response;
|
|
22
|
+
res.status(status);
|
|
23
|
+
if (headers) {
|
|
24
|
+
for (const [name, value] of Object.entries(headers)) {
|
|
25
|
+
res.setHeader(name, value);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (data)
|
|
29
|
+
res.send(data);
|
|
30
|
+
else
|
|
31
|
+
res.end();
|
|
20
32
|
} catch (error) {
|
|
21
33
|
next(error);
|
|
22
34
|
}
|
|
23
35
|
};
|
|
24
|
-
const pre = route.pre
|
|
36
|
+
const pre = Array.isArray(route.pre) ? route.pre : route.pre ? [route.pre] : [];
|
|
25
37
|
const handlers = pre.concat(handler);
|
|
26
38
|
router[method](url, ...handlers);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
29
41
|
router.use(errorHandler);
|
|
30
42
|
return router;
|
|
31
43
|
};
|
|
32
|
-
var errorHandler = (err,
|
|
44
|
+
var errorHandler = (err, _req, res, _next) => {
|
|
33
45
|
let error;
|
|
34
|
-
if (err.message && err.statusCode && err.toJSON)
|
|
46
|
+
if (err.message && err.statusCode && err.toJSON) {
|
|
35
47
|
error = err;
|
|
36
|
-
else {
|
|
48
|
+
} else {
|
|
37
49
|
const internal = err instanceof Error ? err : typeof err === "string" ? new Error(err) : void 0;
|
|
38
50
|
error = createHttpError(500, void 0, internal);
|
|
39
51
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sebspark/openapi-express",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.mjs",
|
|
@@ -11,14 +11,14 @@
|
|
|
11
11
|
"scripts": {
|
|
12
12
|
"build": "tsup-node src/index.ts --format esm,cjs --dts",
|
|
13
13
|
"dev": "tsc --watch --noEmit",
|
|
14
|
-
"lint": "
|
|
14
|
+
"lint": "biome check .",
|
|
15
15
|
"test": "vitest --passWithNoTests --coverage",
|
|
16
|
-
"typecheck": "vitest typecheck --passWithNoTests"
|
|
16
|
+
"typecheck": "vitest --typecheck.only --passWithNoTests"
|
|
17
17
|
},
|
|
18
18
|
"devDependencies": {
|
|
19
|
-
"@types/supertest": "
|
|
19
|
+
"@types/supertest": "6.0.2",
|
|
20
20
|
"express": "4.18.2",
|
|
21
|
-
"supertest": "6.3.
|
|
21
|
+
"supertest": "6.3.4",
|
|
22
22
|
"tsconfig": "*"
|
|
23
23
|
},
|
|
24
24
|
"dependencies": {
|