huxy-server 1.0.11 → 1.1.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 (2) hide show
  1. package/package.json +2 -2
  2. package/src/index.js +92 -101
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "huxy-server",
3
- "version": "1.0.11",
3
+ "version": "1.1.1",
4
4
  "description": "一个精炼、高性能的 Express.js 服务器模板,为现代 Node.js 应用程序设计,提供灵活的功能和最佳实践。",
5
5
  "type": "module",
6
6
  "module": "./src/index.js",
@@ -36,7 +36,7 @@
36
36
  },
37
37
  "dependencies": {
38
38
  "http-proxy-middleware": "^3.0.5",
39
- "huxy-node-server": "^1.0.7",
39
+ "huxy-node-server": "^1.1.1",
40
40
  "jsonwebtoken": "^9.0.3"
41
41
  },
42
42
  "engines": {
package/src/index.js CHANGED
@@ -1,117 +1,111 @@
1
1
  import {
2
2
  startServer as U,
3
3
  startStatic as X,
4
- logger as se,
5
- createLogger as oe,
6
- dateTime as ae,
7
- localIPs as ne,
8
- nodeArgs as ie,
9
- getEnvConfig as pe,
10
- checkPort as ce,
11
- getDirName as ue,
12
- resolvePath as le,
4
+ createLogger as se,
5
+ dateTime as oe,
6
+ localIPs as ae,
7
+ nodeArgs as ne,
8
+ getEnvConfig as ie,
9
+ checkPort as pe,
10
+ getDirName as ce,
11
+ resolvePath as ue,
13
12
  } from 'huxy-node-server';
14
- import {createProxyMiddleware as k, fixRequestBody as O} from 'http-proxy-middleware';
15
- import {dateTime as W} from 'huxy-node-server';
16
- import $ from 'jsonwebtoken';
17
- var d = (r, {secret: e = '', ...t} = {}) => $.verify(r, e, t);
18
- var m =
19
- (r = {}) =>
20
- (e, t, o) => {
13
+ import {createProxyMiddleware as S, fixRequestBody as k} from 'http-proxy-middleware';
14
+ import {dateTime as C} from 'huxy-node-server';
15
+ import j from 'jsonwebtoken';
16
+ var h = (t, {secret: e = '', ...r} = {}) => j.verify(t, e, r);
17
+ var d =
18
+ (t = {}) =>
19
+ (e, r, s) => {
21
20
  let i = e.headers.authorization;
22
- if (!i) return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u7F3A\u5C11\u8BA4\u8BC1\u4FE1\u606F'), t.status(401).json({message: '\u7F3A\u5C11\u8BA4\u8BC1\u4FE1\u606F'}));
21
+ if (!i) return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u7F3A\u5C11\u8BA4\u8BC1\u4FE1\u606F'), r.status(401).json({message: '\u7F3A\u5C11\u8BA4\u8BC1\u4FE1\u606F'}));
23
22
  if (!i.startsWith('Bearer '))
24
- return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u672A\u63D0\u4F9B\u6709\u6548\u8BA4\u8BC1\u4FE1\u606F'), t.status(401).json({message: '\u672A\u63D0\u4F9B\u6709\u6548\u8BA4\u8BC1\u4FE1\u606F'}));
23
+ return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u672A\u63D0\u4F9B\u6709\u6548\u8BA4\u8BC1\u4FE1\u606F'), r.status(401).json({message: '\u672A\u63D0\u4F9B\u6709\u6548\u8BA4\u8BC1\u4FE1\u606F'}));
25
24
  let a = i.split(' ')[1];
26
- if (!a) return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u8BBF\u95EE\u4EE4\u724C\u7F3A\u5931'), t.status(401).json({message: '\u8BBF\u95EE\u4EE4\u724C\u7F3A\u5931'}));
25
+ if (!a) return (e.log.warn('\u8BA4\u8BC1\u5931\u8D25: \u8BBF\u95EE\u4EE4\u724C\u7F3A\u5931'), r.status(401).json({message: '\u8BBF\u95EE\u4EE4\u724C\u7F3A\u5931'}));
27
26
  try {
28
- let s = d(a, r);
29
- (e.log.info(s, '\u8BA4\u8BC1\u6210\u529F'), (e.user = s), o());
30
- } catch (s) {
31
- let n = s.type || s.name;
27
+ let o = h(a, t);
28
+ (e.log.info(o, '\u8BA4\u8BC1\u6210\u529F'), (e.user = o), s());
29
+ } catch (o) {
30
+ let n = o.type || o.name;
32
31
  return n === 'TokenExpiredError'
33
- ? (e.log.warn({ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u4EE4\u724C\u5DF2\u8FC7\u671F'), t.status(401).json({message: '\u4EE4\u724C\u5DF2\u8FC7\u671F'}))
32
+ ? (e.log.warn({ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u4EE4\u724C\u5DF2\u8FC7\u671F'), r.status(401).json({message: '\u4EE4\u724C\u5DF2\u8FC7\u671F'}))
34
33
  : n === 'JsonWebTokenError'
35
- ? (e.log.warn({ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u65E0\u6548\u7684\u4EE4\u724C'), t.status(403).json({message: '\u65E0\u6548\u7684\u4EE4\u724C'}))
34
+ ? (e.log.warn({ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u65E0\u6548\u7684\u4EE4\u724C'), r.status(403).json({message: '\u65E0\u6548\u7684\u4EE4\u724C'}))
36
35
  : n === 'AuthorizationError'
37
- ? (e.log.warn({ip: e.ip}, `\u8BA4\u8BC1\u5931\u8D25: ${s.message}`), t.status(s.status).json({message: s.message}))
38
- : (e.log.warn({err: s, ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u5185\u90E8\u670D\u52A1\u5668\u9519\u8BEF'), t.status(500).json({message: '\u5185\u90E8\u670D\u52A1\u5668\u9519\u8BEF'}));
36
+ ? (e.log.warn({ip: e.ip}, `\u8BA4\u8BC1\u5931\u8D25: ${o.message}`), r.status(o.status).json({message: o.message}))
37
+ : (e.log.warn({err: o, ip: e.ip}, '\u8BA4\u8BC1\u5931\u8D25: \u5185\u90E8\u670D\u52A1\u5668\u9519\u8BEF'), r.status(500).json({message: '\u5185\u90E8\u670D\u52A1\u5668\u9519\u8BEF'}));
39
38
  }
40
39
  };
41
- var v = r => Object.prototype.toString.call(r).slice(8, -1).toLowerCase(),
42
- I = r => (v(r) === 'object' ? [r] : Array.isArray(r) ? r : []),
43
- f = (r, e) => I(r).map(t => ((t.prefix = `${e}${t.prefix ?? (t.name ? `/${t.name}` : '')}`.replace('//', '/')), t)),
44
- x = r => (Array.isArray(r) ? r : []).filter(Boolean),
45
- y = (r, e) => [...new Set(['/', '/health', e, ...(Array.isArray(r) ? r : [])])].filter(Boolean).map(t => `${e}${t}`.replace('//', '/'));
46
- var R =
47
- (r = {}) =>
48
- (e, t, o) => {
49
- if (e.method === 'OPTIONS') return o();
50
- let i = x(r.whiteAuthKeys);
51
- if (y(r.whitePathList, r.apiPrefix).includes(e.path)) return o();
52
- let {authToken: s} = r;
53
- if (s === !1 || s === 'false') return o();
40
+ var $ = t => Object.prototype.toString.call(t).slice(8, -1).toLowerCase(),
41
+ v = t => ($(t) === 'object' ? [t] : Array.isArray(t) ? t : []),
42
+ m = (t, e) => v(t).map(r => ((r.prefix = `${e}${r.prefix ?? (r.name ? `/${r.name}` : '')}`.replace('//', '/')), r)),
43
+ f = t => (Array.isArray(t) ? t : []).filter(Boolean),
44
+ x = (t, e) => [...new Set(['/', '/health', e, ...(Array.isArray(t) ? t : [])])].filter(Boolean).map(r => `${e}${r}`.replace('//', '/'));
45
+ var I =
46
+ (t = {}) =>
47
+ (e, r, s) => {
48
+ if (e.method === 'OPTIONS') return s();
49
+ let i = f(t.whiteAuthKeys);
50
+ if (x(t.whitePathList, t.apiPrefix).includes(e.path)) return s();
51
+ let {authToken: o} = t;
52
+ if (o === !1 || o === 'false') return s();
54
53
  let n = e.headers,
55
54
  p = n['x-huxy-auth'] || n['x-api-key'] || n.authorization?.split('Bearer ')[1];
56
- if ((p && p === s) || i.includes(p)) return o();
57
- let {secret: u, expiresIn: T, algorithm: j, issuer: H} = r;
58
- m({secret: u, expiresIn: T, algorithm: j, issuer: H})(e, t, o);
55
+ if ((p && p === o) || i.includes(p)) return s();
56
+ let {secret: c, expiresIn: g, algorithm: T, issuer: H} = t;
57
+ d({secret: c, expiresIn: g, algorithm: T, issuer: H})(e, r, s);
59
58
  },
60
- w = R;
59
+ y = I;
61
60
  var E = ['origin', 'referer', 'x-forwarded-for', 'x-real-ip', 'cf-connecting-ip', 'cf-ipcountry', 'cf-ray', 'x-huxy-auth'],
62
- S = ['x-powered-by', 'server'],
63
- A = (r, e) => {
64
- let t = new Headers(r);
65
- return (E.forEach(o => t.delete(o)), t.set('Host', e), t.set('User-Agent', 'IHUXY-API/1.0'), t);
61
+ R = ['x-powered-by', 'server'],
62
+ w = (t, e) => {
63
+ let r = new Headers(t);
64
+ return (E.forEach(s => r.delete(s)), r.set('Host', e), r.set('User-Agent', 'IHUXY-API/1.0'), r);
66
65
  },
67
- P = r => {
68
- let e = new Headers(r);
66
+ A = t => {
67
+ let e = new Headers(t);
69
68
  return (
70
- S.forEach(t => e.delete(t)),
69
+ R.forEach(r => e.delete(r)),
71
70
  e.set('Access-Control-Allow-Origin', '*'),
72
71
  e.set('X-Content-Type-Options', 'nosniff'),
73
72
  e.get('content-type')?.includes('text/event-stream') && ((e['Cache-Control'] = 'no-cache, no-transform'), (e.Connection = 'keep-alive'), (e['X-Accel-Buffering'] = 'no')),
74
73
  e
75
74
  );
76
75
  };
77
- var c = (r, e = '/') => {
78
- let t = {status: 'OK', message: `API \u670D\u52A1\u5668\u8FD0\u884C\u4E2D \u{1F449} ${e}`, timestamp: W(), uptime: process.uptime(), memoryUsage: process.memoryUsage()};
79
- (r.get(e, (o, i) => {
80
- i.status(200).json(t);
81
- }),
82
- r.get(`${e}/health`.replace('//', '/'), (o, i) => {
83
- i.status(200).json(t);
84
- }));
76
+ var O = (t, e = '/') => {
77
+ let r = {status: 'OK', message: `API \u670D\u52A1\u5668\u8FD0\u884C\u4E2D \u{1F449} ${e}`, timestamp: C(), uptime: process.uptime(), memoryUsage: process.memoryUsage()};
78
+ t.get(`${e}/health`.replace('//', '/'), (s, i) => {
79
+ i.status(200).json(r);
80
+ });
85
81
  },
86
- g = 0,
87
- B = ({target: r = 'http://', prefix: e, withPrefix: t, preserve: o = !0, ...i} = {}) => ({
88
- target: r,
82
+ P = 0,
83
+ W = ({target: t = 'http://', prefix: e, withPrefix: r, preserve: s = !0, ...i} = {}) => ({
84
+ target: t,
89
85
  changeOrigin: !0,
90
86
  selfHandleResponse: !1,
91
87
  on: {
92
- proxyReq: (a, s, n) => (!o && A(a.headers, r), O(a, s, n)),
93
- proxyRes: (a, s, n) => {
94
- !o && P(a.headers);
88
+ proxyReq: (a, o, n) => (!s && w(a.headers, t), k(a, o, n)),
89
+ proxyRes: (a, o, n) => {
90
+ !s && A(a.headers);
95
91
  },
96
- error: (a, s, n) => {
97
- (g || ((g = 1), s.log.error({err: a}, '\u4EE3\u7406\u9519\u8BEF')), n.headersSent || n.status(502).json({error: '\u7F51\u5173\u9519\u8BEF'}));
92
+ error: (a, o, n) => {
93
+ (P || ((P = 1), o.log.error({err: a}, '\u4EE3\u7406\u9519\u8BEF')), n.headersSent || n.status(502).json({error: '\u7F51\u5173\u9519\u8BEF'}));
98
94
  },
99
95
  },
100
96
  ...i,
101
97
  }),
102
- C = (r, e = {}, t) => {
103
- let {apiPrefix: o = '/', proxys: i = []} = e,
104
- a = f(i, o);
105
- if (a.length)
106
- return (
107
- t.info(`\u{1F4DD} API \u63A5\u53E3\u5730\u5740: ${e.protocol}://${e.host}:${e.port}${o}`),
108
- a.map(({prefix: s, target: n, withPrefix: p = !0, ...u}) => {
109
- ((n = p ? `${n}${s}` : n), r.use(s, w(e), k(B({prefix: s, target: n, withPrefix: p, ...u}))), t.info(`\u2705 \u4EE3\u7406\u4E2D ${s} \u{1F449} ${n}`));
110
- }),
111
- !0
112
- );
98
+ B = (t, e = {}, r) => {
99
+ let {apiPrefix: s = '/', proxys: i = []} = e,
100
+ a = m(i, s);
101
+ if (!a.length) return !1;
102
+ (r.info(`\u{1F4DD} API \u63A5\u53E3\u5730\u5740: ${e.protocol}://${e.host}:${e.port}${s}`),
103
+ a.map(({prefix: o, target: n, withPrefix: p = !0, ...c}) => {
104
+ ((n = p ? `${n}${o}` : n), t.use(o, y(e), S(W({prefix: o, target: n, withPrefix: p, ...c}))), r.info(`\u2705 \u4EE3\u7406\u4E2D ${o} \u{1F449} ${n}`));
105
+ }),
106
+ O(t, s));
113
107
  },
114
- l = C;
108
+ u = B;
115
109
  var M = {
116
110
  port: parseInt(process.env.PORT || '8080', 10),
117
111
  host: process.env.HOST || 'localhost',
@@ -124,32 +118,29 @@ var M = {
124
118
  expiresIn: process.env.JWT_EXPIRES_IN || '30d',
125
119
  issuer: process.env.JWT_ISSUER || 'huxyApp',
126
120
  },
127
- h = M;
128
- var _ = (r, e) =>
129
- U({...h, ...r}, async (t, o, i, a) => {
130
- let s = l(o, t, a);
131
- (await e?.(t, o, i, a), s && c(o, t.apiPrefix));
121
+ l = M;
122
+ var _ = (t, e) =>
123
+ U({...l, ...t}, async (r, s, i, a) => {
124
+ (u(s, r, a), await e?.(r, s, i, a));
132
125
  }),
133
- me = _,
134
- fe = (r, e) =>
135
- X({...h, ...r}, async (t, o, i, a) => {
136
- let s = l(o, t, a);
137
- (await e?.(t, o, i, a), c(o, t.apiPrefix), s && c(o, t.apiPrefix));
126
+ de = _,
127
+ me = (t, e) =>
128
+ X({...l, ...t}, async (r, s, i, a) => {
129
+ (u(s, r, a), await e?.(r, s, i, a));
138
130
  });
139
131
  export {
140
- l as appProxy,
141
- ce as checkPort,
142
- oe as createLogger,
143
- ae as dateTime,
144
- me as default,
145
- ue as getDirName,
146
- pe as getEnvConfig,
147
- ne as localIPs,
148
- se as logger,
149
- ie as nodeArgs,
150
- le as resolvePath,
132
+ u as appProxy,
133
+ pe as checkPort,
134
+ se as createLogger,
135
+ oe as dateTime,
136
+ de as default,
137
+ ce as getDirName,
138
+ ie as getEnvConfig,
139
+ ae as localIPs,
140
+ ne as nodeArgs,
141
+ ue as resolvePath,
151
142
  _ as startApp,
152
143
  U as startServer,
153
144
  X as startStatic,
154
- fe as startStaticApp,
145
+ me as startStaticApp,
155
146
  };