huxy-server 1.0.9 → 1.0.11

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