@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 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 { MarketdataAPIServer } from './schemas/marketdata'
28
+ import { MarketdataServer } from './schemas/marketdata'
29
29
  import { getMarkets, getMarket } from './markets'
30
30
 
31
- const api: MarketdataAPIServer = {
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 instanceof Array ? options.pre : options.pre ? [options.pre] : [];
34
- preUsings.forEach((pre) => router.use(pre));
35
- Object.entries(api).forEach(([url, methods]) => {
36
- Object.entries(methods).forEach(([method, route]) => {
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 [code, body] = await route.handler(req);
40
- res.status(code).send(body);
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 instanceof Array ? route.pre : route.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, req, res, _next) => {
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 instanceof Array ? options.pre : options.pre ? [options.pre] : [];
13
- preUsings.forEach((pre) => router.use(pre));
14
- Object.entries(api).forEach(([url, methods]) => {
15
- Object.entries(methods).forEach(([method, route]) => {
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 [code, body] = await route.handler(req);
19
- res.status(code).send(body);
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 instanceof Array ? route.pre : route.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, req, res, _next) => {
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": "0.1.0",
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": "eslint \"src/**/*.ts*\"",
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": "2.0.15",
19
+ "@types/supertest": "6.0.2",
20
20
  "express": "4.18.2",
21
- "supertest": "6.3.3",
21
+ "supertest": "6.3.4",
22
22
  "tsconfig": "*"
23
23
  },
24
24
  "dependencies": {