wok-server 0.4.1 → 0.4.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.
package/dist/lock/index.js
CHANGED
|
@@ -67,7 +67,7 @@ class ServerLockManager {
|
|
|
67
67
|
* @param opts
|
|
68
68
|
*/
|
|
69
69
|
async waitLock(opts) {
|
|
70
|
-
let
|
|
70
|
+
let start = Date.now();
|
|
71
71
|
while (true) {
|
|
72
72
|
const info = this.lockMap.get(opts.key);
|
|
73
73
|
// 锁不存在或已经过期
|
|
@@ -82,21 +82,20 @@ class ServerLockManager {
|
|
|
82
82
|
if (info.value === opts.value) {
|
|
83
83
|
return true;
|
|
84
84
|
}
|
|
85
|
-
if (
|
|
85
|
+
if (Date.now() - start > opts.waitSeconds * 1000) {
|
|
86
86
|
break;
|
|
87
87
|
}
|
|
88
|
-
milliseconds = milliseconds + 100;
|
|
89
88
|
await this.sleep();
|
|
90
89
|
}
|
|
91
90
|
return false;
|
|
92
91
|
}
|
|
93
92
|
/**
|
|
94
|
-
* 沉睡
|
|
93
|
+
* 沉睡
|
|
95
94
|
* @returns
|
|
96
95
|
*/
|
|
97
96
|
sleep() {
|
|
98
97
|
return new Promise((resolve, reject) => {
|
|
99
|
-
setTimeout(resolve,
|
|
98
|
+
setTimeout(resolve, 0);
|
|
100
99
|
});
|
|
101
100
|
}
|
|
102
101
|
}
|
|
@@ -161,7 +161,11 @@ class StaticHandler {
|
|
|
161
161
|
await this.endRespWithBuffer(response, file.bufferOrPath);
|
|
162
162
|
}
|
|
163
163
|
else {
|
|
164
|
-
|
|
164
|
+
const path = file.bufferOrPath;
|
|
165
|
+
await new Promise((resolve, reject) => {
|
|
166
|
+
response.once('finish', resolve).once('error', reject);
|
|
167
|
+
(0, fs_1.createReadStream)(path).pipe((0, zlib_1.createGzip)()).pipe(response);
|
|
168
|
+
});
|
|
165
169
|
}
|
|
166
170
|
return true;
|
|
167
171
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "wok-server",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.3",
|
|
4
4
|
"packageManager": "pnpm@8.9.0",
|
|
5
5
|
"description": "一个基于 NodeJs 和 TypeScript 的后端框架,轻量级、克制、简洁。A lightweight, restrained, and concise backend framework based on Node.js and TypeScript.",
|
|
6
6
|
"scripts": {
|