@waline/vercel 1.30.1 → 1.30.3

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 (61) hide show
  1. package/package.json +9 -6
  2. package/src/config/adapter.js +20 -8
  3. package/src/config/config.js +4 -2
  4. package/src/controller/db.js +18 -0
  5. package/dist/404.html +0 -39
  6. package/dist/500.html +0 -275
  7. package/dist/index.js +0 -58521
  8. package/dist/package.json +0 -55
  9. package/dist/src/config/adapter.js +0 -170
  10. package/dist/src/config/config.js +0 -134
  11. package/dist/src/config/extend.js +0 -38
  12. package/dist/src/config/middleware.js +0 -67
  13. package/dist/src/config/router.js +0 -1
  14. package/dist/src/controller/article.js +0 -88
  15. package/dist/src/controller/comment.js +0 -736
  16. package/dist/src/controller/db.js +0 -71
  17. package/dist/src/controller/index.js +0 -36
  18. package/dist/src/controller/oauth.js +0 -136
  19. package/dist/src/controller/rest.js +0 -60
  20. package/dist/src/controller/token/2fa.js +0 -67
  21. package/dist/src/controller/token.js +0 -76
  22. package/dist/src/controller/user/password.js +0 -53
  23. package/dist/src/controller/user.js +0 -290
  24. package/dist/src/controller/verification.js +0 -35
  25. package/dist/src/extend/controller.js +0 -26
  26. package/dist/src/extend/think.js +0 -104
  27. package/dist/src/locales/en.json +0 -19
  28. package/dist/src/locales/index.js +0 -12
  29. package/dist/src/locales/zh-CN.json +0 -19
  30. package/dist/src/locales/zh-TW.json +0 -19
  31. package/dist/src/logic/article.js +0 -27
  32. package/dist/src/logic/base.js +0 -165
  33. package/dist/src/logic/comment.js +0 -317
  34. package/dist/src/logic/db.js +0 -81
  35. package/dist/src/logic/oauth.js +0 -10
  36. package/dist/src/logic/token/2fa.js +0 -28
  37. package/dist/src/logic/token.js +0 -53
  38. package/dist/src/logic/user/password.js +0 -11
  39. package/dist/src/logic/user.js +0 -117
  40. package/dist/src/middleware/dashboard.js +0 -23
  41. package/dist/src/middleware/version.js +0 -6
  42. package/dist/src/service/akismet.js +0 -42
  43. package/dist/src/service/avatar.js +0 -36
  44. package/dist/src/service/markdown/highlight.js +0 -32
  45. package/dist/src/service/markdown/index.js +0 -64
  46. package/dist/src/service/markdown/katex.js +0 -50
  47. package/dist/src/service/markdown/mathCommon.js +0 -156
  48. package/dist/src/service/markdown/mathjax.js +0 -78
  49. package/dist/src/service/markdown/utils.js +0 -11
  50. package/dist/src/service/markdown/xss.js +0 -44
  51. package/dist/src/service/notify.js +0 -538
  52. package/dist/src/service/storage/base.js +0 -31
  53. package/dist/src/service/storage/cloudbase.js +0 -222
  54. package/dist/src/service/storage/deta.js +0 -309
  55. package/dist/src/service/storage/github.js +0 -379
  56. package/dist/src/service/storage/leancloud.js +0 -432
  57. package/dist/src/service/storage/mongodb.js +0 -180
  58. package/dist/src/service/storage/mysql.js +0 -123
  59. package/dist/src/service/storage/postgresql.js +0 -84
  60. package/dist/src/service/storage/sqlite.js +0 -11
  61. package/dist/src/service/storage/tidb.js +0 -3
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@waline/vercel",
3
- "version": "1.30.1",
3
+ "version": "1.30.3",
4
4
  "description": "vercel server for waline comment system",
5
5
  "keywords": [
6
6
  "waline",
@@ -15,18 +15,18 @@
15
15
  "license": "MIT",
16
16
  "author": "lizheming <i@imnerd.org>",
17
17
  "dependencies": {
18
- "@cloudbase/node-sdk": "^2.9.1",
18
+ "@cloudbase/node-sdk": "^2.10.0",
19
19
  "@koa/cors": "^4.0.0",
20
20
  "akismet": "^2.0.7",
21
21
  "deta": "^1.1.0",
22
- "dompurify": "^3.0.1",
22
+ "dompurify": "^3.0.2",
23
23
  "dy-node-ip2region": "^1.0.1",
24
24
  "fast-csv": "^4.3.6",
25
25
  "form-data": "^4.0.0",
26
26
  "jsdom": "^21.1.1",
27
27
  "jsonwebtoken": "^9.0.0",
28
- "katex": "^0.16.4",
29
- "leancloud-storage": "^4.14.0",
28
+ "katex": "^0.16.6",
29
+ "leancloud-storage": "^4.15.0",
30
30
  "markdown-it": "^13.0.1",
31
31
  "markdown-it-emoji": "^2.0.2",
32
32
  "markdown-it-sub": "^1.0.0",
@@ -34,7 +34,7 @@
34
34
  "mathjax-full": "^3.2.2",
35
35
  "node-fetch": "^2.6.9",
36
36
  "nodemailer": "^6.9.1",
37
- "nunjucks": "^3.2.3",
37
+ "nunjucks": "^3.2.4",
38
38
  "phpass": "^0.1.1",
39
39
  "prismjs": "^1.29.0",
40
40
  "speakeasy": "^2.0.0",
@@ -52,5 +52,8 @@
52
52
  },
53
53
  "engines": {
54
54
  "node": ">=14"
55
+ },
56
+ "publishConfig": {
57
+ "provenance": true
55
58
  }
56
59
  }
@@ -31,12 +31,19 @@ const {
31
31
  SQLITE_DB,
32
32
  SQLITE_PREFIX,
33
33
  PG_DB,
34
+ POSTGRES_DATABASE,
34
35
  PG_HOST,
36
+ POSTGRES_HOST,
35
37
  PG_PASSWORD,
38
+ POSTGRES_PASSWORD,
36
39
  PG_PORT,
40
+ POSTGRES_PORT,
37
41
  PG_PREFIX,
42
+ POSTGRES_PREFIX,
38
43
  PG_USER,
44
+ POSTGRES_USER,
39
45
  PG_SSL,
46
+ POSTGRES_SSL,
40
47
  MONGO_AUTHSOURCE,
41
48
  MONGO_DB,
42
49
  MONGO_HOST,
@@ -64,7 +71,7 @@ if (MONGO_DB) {
64
71
  mongoOpt[key] = process.env[envKeys];
65
72
  }
66
73
  }
67
- } else if (PG_DB) {
74
+ } else if (PG_DB || POSTGRES_DATABASE) {
68
75
  type = 'postgresql';
69
76
  } else if (SQLITE_PATH) {
70
77
  type = 'sqlite';
@@ -74,6 +81,11 @@ if (MONGO_DB) {
74
81
  type = 'tidb';
75
82
  }
76
83
 
84
+ const isVercelPostgres =
85
+ type === 'postgresql' &&
86
+ POSTGRES_HOST &&
87
+ POSTGRES_HOST.endsWith('vercel-storage.com');
88
+
77
89
  exports.model = {
78
90
  type,
79
91
  common: {
@@ -100,15 +112,15 @@ exports.model = {
100
112
 
101
113
  postgresql: {
102
114
  handle: Postgresql,
103
- user: PG_USER,
104
- password: PG_PASSWORD,
105
- database: PG_DB,
106
- host: PG_HOST || '127.0.0.1',
107
- port: PG_PORT || '3211',
115
+ user: PG_USER || POSTGRES_USER,
116
+ password: PG_PASSWORD || POSTGRES_PASSWORD,
117
+ database: PG_DB || POSTGRES_DATABASE,
118
+ host: PG_HOST || POSTGRES_HOST || '127.0.0.1',
119
+ port: PG_PORT || POSTGRES_PORT || (isVercelPostgres ? '5432' : '3211'),
108
120
  connectionLimit: 1,
109
- prefix: PG_PREFIX || 'wl_',
121
+ prefix: PG_PREFIX || POSTGRES_PREFIX || 'wl_',
110
122
  ssl:
111
- PG_SSL == 'true'
123
+ (PG_SSL || POSTGRES_SSL) == 'true' || isVercelPostgres
112
124
  ? {
113
125
  rejectUnauthorized: false,
114
126
  }
@@ -7,7 +7,9 @@ const {
7
7
  TIDB_PASSWORD,
8
8
  SQLITE_PATH,
9
9
  PG_DB,
10
+ POSTGRES_DATABASE,
10
11
  PG_PASSWORD,
12
+ POSTGRES_PASSWORD,
11
13
  MONGO_DB,
12
14
  MONGO_PASSWORD,
13
15
  FORBIDDEN_WORDS,
@@ -53,9 +55,9 @@ if (LEAN_KEY) {
53
55
  } else if (MONGO_DB) {
54
56
  storage = 'mongodb';
55
57
  jwtKey = jwtKey || MONGO_PASSWORD;
56
- } else if (PG_DB) {
58
+ } else if (PG_DB || POSTGRES_DATABASE) {
57
59
  storage = 'postgresql';
58
- jwtKey = jwtKey || PG_PASSWORD;
60
+ jwtKey = jwtKey || PG_PASSWORD || POSTGRES_PASSWORD;
59
61
  } else if (SQLITE_PATH) {
60
62
  storage = 'sqlite';
61
63
  } else if (MYSQL_DB) {
@@ -38,6 +38,24 @@ module.exports = class extends BaseRest {
38
38
  item.updatedAt && (item.updatedAt = new Date(item.updatedAt));
39
39
  }
40
40
 
41
+ if (storage === 'mysql') {
42
+ item.insertedAt &&
43
+ (item.insertedAt = think.datetime(
44
+ item.insertedAt,
45
+ 'YYYY-MM-DD HH:mm:ss'
46
+ ));
47
+ item.createdAt &&
48
+ (item.createdAt = think.datetime(
49
+ item.createdAt,
50
+ 'YYYY-MM-DD HH:mm:ss'
51
+ ));
52
+ item.updatedAt &&
53
+ (item.updatedAt = think.datetime(
54
+ item.updatedAt,
55
+ 'YYYY-MM-DD HH:mm:ss'
56
+ ));
57
+ }
58
+
41
59
  delete item.objectId;
42
60
  const resp = await model.add(item);
43
61
 
package/dist/404.html DELETED
@@ -1,39 +0,0 @@
1
- <!DOCTYPE html>
2
- <html>
3
- <head>
4
- <meta charset="utf-8">
5
- <title>Not Found - ThinkJS</title>
6
- <style type="text/css">
7
-
8
- body,code,dd,div,dl,dt,h1,h2,h3,h4,h5,h6,li,ol,pre,ul{margin:0;padding:0}a{text-decoration:none}.clearfix{clear:both;zoom:1}.clearfix:after{clear:both;content:"";display:block;height:0;visibility:hidden}body{background:#fff;font:12px/1.5 \5FAE\8F6F\96C5\9ED1,arial,sans-serif}.wrap{width:1000px;margin:0 auto}.header{position:relative;height:76px;background:#fff;border-bottom:1px solid #dfdfdf;box-shadow:0 1px 2px rgba(0,0,0,.1)}.logo{float:left;width:146px;height:55px;margin-top:10px}.headr{float:right;margin-top:20px}.headr a{font-size:16px;position:relative;top:10px;color:#888}.footer{border-top:1px solid #e8e8e8;margin-top:40px;text-align:center;line-height:40px;font-size:14px}.footer a{color:#428bca}h1{font-weight:400;font-size:26px;line-height:30px;height:30px}.error-msg,h1{text-align:center;margin-top:30px;color:#666}.error-msg{font-size:16px;min-height:80px;word-wrap:break-all}.wrap-bg{margin-top:20px;height:313px;background:url() top no-repeat}
9
-
10
- </style>
11
- </head>
12
- <body>
13
- <div class="header">
14
- <div class="wrap">
15
- <div class="logo">
16
- <a href="http://www.thinkjs.org/">
17
- </a><img src="" alt="ThinkJS">
18
- </div>
19
- <div class="headr">
20
- <a href="http://www.thinkjs.org/doc/error_handle.html#404" target="_blank">
21
- Why might this be happening?
22
- </a>
23
- </div>
24
- </div>
25
- </div>
26
- <div class="wrap">
27
- <div class="wrap-bg"></div>
28
- <h1>Not Found</h1>
29
- <div class="error-msg">
30
- <pre>{{errMsg}}</pre>
31
- </div>
32
- </div>
33
- <script type="text/javascript">
34
-
35
- !function(n){function t(e){if(r[e])return r[e].exports;var o=r[e]={i:e,l:!1,exports:{}};return n[e].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var r={};t.m=n,t.c=r,t.i=function(n){return n},t.d=function(n,r,e){t.o(n,r)||Object.defineProperty(n,r,{configurable:!1,enumerable:!0,get:e})},t.n=function(n){var r=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(r,"a",r),r},t.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},t.p="",t(t.s=4)}([function(n,t){},,,,function(n,t,r){"use strict";r(0)}]);
36
-
37
- </script>
38
- </body>
39
- </html>