@teambit/express 0.0.484 → 0.0.485
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/middlewares/error.ts +29 -0
- package/middlewares/index.ts +1 -0
- package/package-tar/teambit-express-0.0.485.tgz +0 -0
- package/package.json +6 -21
- package/types/asset.d.ts +29 -0
- package/types/index.ts +4 -0
- package/types/next.ts +3 -0
- package/types/request.ts +1 -0
- package/types/response.ts +3 -0
- package/types/route.ts +24 -0
- package/types/style.d.ts +42 -0
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import * as express from 'express';
|
|
2
|
+
import logger from '@teambit/legacy/dist/logger/logger';
|
|
3
|
+
|
|
4
|
+
interface ResponseError {
|
|
5
|
+
status?: number;
|
|
6
|
+
message?: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const catchErrors = (action: any) => (req: express.Request, res: express.Response, next: express.NextFunction) =>
|
|
10
|
+
// TODO: @guy please take care of it
|
|
11
|
+
// eslint-disable-next-line promise/no-callback-in-promise
|
|
12
|
+
action(req, res, next).catch((error: ResponseError) => errorHandle(error, req, res, next));
|
|
13
|
+
|
|
14
|
+
export function errorHandle(
|
|
15
|
+
err: ResponseError,
|
|
16
|
+
req: express.Request,
|
|
17
|
+
res: express.Response,
|
|
18
|
+
// TODO: Do not remove unused next, it's needed for express to catch errors!
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
20
|
+
next: express.NextFunction
|
|
21
|
+
) {
|
|
22
|
+
logger.error(`express.errorHandle, url ${req.url}, error:`, err);
|
|
23
|
+
err.status = err.status || 500;
|
|
24
|
+
res.status(err.status);
|
|
25
|
+
return res.jsonp({
|
|
26
|
+
message: err.message,
|
|
27
|
+
error: err,
|
|
28
|
+
});
|
|
29
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { catchErrors, errorHandle } from './error';
|
|
Binary file
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@teambit/express",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.485",
|
|
4
4
|
"homepage": "https://bit.dev/teambit/harmony/express",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"componentId": {
|
|
7
7
|
"scope": "teambit.harmony",
|
|
8
8
|
"name": "express",
|
|
9
|
-
"version": "0.0.
|
|
9
|
+
"version": "0.0.485"
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
12
|
"@teambit/harmony": "0.2.11",
|
|
@@ -15,8 +15,8 @@
|
|
|
15
15
|
"lodash": "4.17.21",
|
|
16
16
|
"@babel/runtime": "7.12.18",
|
|
17
17
|
"core-js": "^3.0.0",
|
|
18
|
-
"@teambit/cli": "0.0.
|
|
19
|
-
"@teambit/logger": "0.0.
|
|
18
|
+
"@teambit/cli": "0.0.395",
|
|
19
|
+
"@teambit/logger": "0.0.481"
|
|
20
20
|
},
|
|
21
21
|
"devDependencies": {
|
|
22
22
|
"@types/express": "4.17.9",
|
|
@@ -29,7 +29,7 @@
|
|
|
29
29
|
"@types/node": "12.20.4"
|
|
30
30
|
},
|
|
31
31
|
"peerDependencies": {
|
|
32
|
-
"@teambit/legacy": "1.0.
|
|
32
|
+
"@teambit/legacy": "1.0.181",
|
|
33
33
|
"react-dom": "^16.8.0 || ^17.0.0",
|
|
34
34
|
"react": "^16.8.0 || ^17.0.0"
|
|
35
35
|
},
|
|
@@ -57,27 +57,12 @@
|
|
|
57
57
|
"react": "-"
|
|
58
58
|
},
|
|
59
59
|
"peerDependencies": {
|
|
60
|
-
"@teambit/legacy": "1.0.
|
|
60
|
+
"@teambit/legacy": "1.0.181",
|
|
61
61
|
"react-dom": "^16.8.0 || ^17.0.0",
|
|
62
62
|
"react": "^16.8.0 || ^17.0.0"
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
65
|
},
|
|
66
|
-
"files": [
|
|
67
|
-
"dist",
|
|
68
|
-
"!dist/tsconfig.tsbuildinfo",
|
|
69
|
-
"**/*.md",
|
|
70
|
-
"**/*.mdx",
|
|
71
|
-
"**/*.js",
|
|
72
|
-
"**/*.json",
|
|
73
|
-
"**/*.sass",
|
|
74
|
-
"**/*.scss",
|
|
75
|
-
"**/*.less",
|
|
76
|
-
"**/*.css",
|
|
77
|
-
"**/*.css",
|
|
78
|
-
"**/*.jpeg",
|
|
79
|
-
"**/*.gif"
|
|
80
|
-
],
|
|
81
66
|
"private": false,
|
|
82
67
|
"engines": {
|
|
83
68
|
"node": ">=12.22.0"
|
package/types/asset.d.ts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
declare module '*.png' {
|
|
2
|
+
const value: any;
|
|
3
|
+
export = value;
|
|
4
|
+
}
|
|
5
|
+
declare module '*.svg' {
|
|
6
|
+
import type { FunctionComponent, SVGProps } from 'react';
|
|
7
|
+
|
|
8
|
+
export const ReactComponent: FunctionComponent<SVGProps<SVGSVGElement> & { title?: string }>;
|
|
9
|
+
const src: string;
|
|
10
|
+
export default src;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
// @TODO Gilad
|
|
14
|
+
declare module '*.jpg' {
|
|
15
|
+
const value: any;
|
|
16
|
+
export = value;
|
|
17
|
+
}
|
|
18
|
+
declare module '*.jpeg' {
|
|
19
|
+
const value: any;
|
|
20
|
+
export = value;
|
|
21
|
+
}
|
|
22
|
+
declare module '*.gif' {
|
|
23
|
+
const value: any;
|
|
24
|
+
export = value;
|
|
25
|
+
}
|
|
26
|
+
declare module '*.bmp' {
|
|
27
|
+
const value: any;
|
|
28
|
+
export = value;
|
|
29
|
+
}
|
package/types/index.ts
ADDED
package/types/next.ts
ADDED
package/types/request.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type { Request } from 'express';
|
package/types/route.ts
ADDED
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { NextFunction } from './next';
|
|
2
|
+
import { Request } from './request';
|
|
3
|
+
import { Response } from './response';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* define express Middleware
|
|
7
|
+
*/
|
|
8
|
+
export type Middleware = (req: Request, res: Response, next: NextFunction) => Promise<any>;
|
|
9
|
+
|
|
10
|
+
export enum Verb {
|
|
11
|
+
WRITE = 'write',
|
|
12
|
+
READ = 'read',
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* express new Route
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
export interface Route {
|
|
20
|
+
method: string;
|
|
21
|
+
route: string | RegExp;
|
|
22
|
+
verb?: Verb;
|
|
23
|
+
middlewares: Middleware[];
|
|
24
|
+
}
|
package/types/style.d.ts
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
declare module '*.module.css' {
|
|
2
|
+
const classes: { readonly [key: string]: string };
|
|
3
|
+
export default classes;
|
|
4
|
+
}
|
|
5
|
+
declare module '*.module.scss' {
|
|
6
|
+
const classes: { readonly [key: string]: string };
|
|
7
|
+
export default classes;
|
|
8
|
+
}
|
|
9
|
+
declare module '*.module.sass' {
|
|
10
|
+
const classes: { readonly [key: string]: string };
|
|
11
|
+
export default classes;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
declare module '*.module.less' {
|
|
15
|
+
const classes: { readonly [key: string]: string };
|
|
16
|
+
export default classes;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
declare module '*.less' {
|
|
20
|
+
const classes: { readonly [key: string]: string };
|
|
21
|
+
export default classes;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
declare module '*.css' {
|
|
25
|
+
const classes: { readonly [key: string]: string };
|
|
26
|
+
export default classes;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
declare module '*.sass' {
|
|
30
|
+
const classes: { readonly [key: string]: string };
|
|
31
|
+
export default classes;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
declare module '*.scss' {
|
|
35
|
+
const classes: { readonly [key: string]: string };
|
|
36
|
+
export default classes;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
declare module '*.mdx' {
|
|
40
|
+
const component: any;
|
|
41
|
+
export default component;
|
|
42
|
+
}
|