zutils/dist/index.js
2024-01-17 15:56:17 +08:00

143 lines
3.6 KiB
JavaScript

var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __decorateClass = (decorators, target, key, kind) => {
var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
for (var i = decorators.length - 1, decorator; i >= 0; i--)
if (decorator = decorators[i])
result = (kind ? decorator(target, key, result) : decorator(result)) || result;
if (kind && result)
__defProp(target, key, result);
return result;
};
// src/common/ZError.ts
var ZError = class {
constructor(statusCode, message) {
this.statusCode = statusCode;
this.message = message;
}
};
// src/decorators/singleton.ts
var SINGLETON_KEY = Symbol();
var singleton = (classTarget) => new Proxy(classTarget, {
construct(target, argumentsList, newTarget) {
if (target.prototype !== newTarget.prototype) {
return Reflect.construct(target, argumentsList, newTarget);
}
if (!target[SINGLETON_KEY]) {
target[SINGLETON_KEY] = Reflect.construct(target, argumentsList, newTarget);
}
return target[SINGLETON_KEY];
}
});
// src/common/SyncLocker.ts
var SyncLocker = class {
constructor() {
this.map = /* @__PURE__ */ new Map();
}
lock(req) {
const key = `${req.method}:${req.url}:${req.user?.id || ""}`;
if (this.map.has(key)) {
return false;
}
this.map.set(key, true);
return true;
}
unlock(req) {
const key = `${req.method}:${req.url}:${req.user?.id || ""}`;
this.map.delete(key);
}
checkLock(req) {
const key = `${req.method}:${req.url}:${req.user?.id || ""}`;
if (this.map.has(key)) {
throw new ZError(100, "request too fast");
}
this.lock(req);
return true;
}
isLocked(req) {
const key = `${req.method}:${req.url}:${req.user?.id || ""}`;
return this.map.has(key);
}
};
SyncLocker = __decorateClass([
singleton
], SyncLocker);
// src/common/AsyncQueue.ts
function createAsyncQueue(opts = { dedupeConcurrent: false }) {
const { dedupeConcurrent } = opts;
let queue = [];
let running;
let nextPromise = new DeferredPromise();
const push = (task) => {
let taskPromise = new DeferredPromise();
if (dedupeConcurrent) {
queue = [];
if (nextPromise.started)
nextPromise = new DeferredPromise();
taskPromise = nextPromise;
}
queue.push(() => {
taskPromise.started = true;
task().then(taskPromise.resolve).catch(taskPromise.reject);
return taskPromise.promise;
});
if (!running)
running = start();
return taskPromise.promise;
};
const start = async () => {
while (queue.length) {
const task = queue.shift();
await task().catch(() => {
});
}
running = void 0;
};
return {
push,
flush: () => running || Promise.resolve(),
get size() {
return queue.length;
}
};
}
var createAsyncQueues = (opts = { dedupeConcurrent: false }) => {
const queues = {};
const push = (queueId, task) => {
if (!queues[queueId])
queues[queueId] = createAsyncQueue(opts);
return queues[queueId].push(task);
};
const flush = (queueId) => {
if (!queues[queueId])
queues[queueId] = createAsyncQueue(opts);
return queues[queueId].flush();
};
return { push, flush };
};
var DeferredPromise = class {
constructor() {
this.started = false;
this.resolve = () => {
};
this.reject = () => {
};
this.promise = new Promise((res, rej) => {
this.resolve = res;
this.reject = rej;
});
}
};
export {
SINGLETON_KEY,
SyncLocker,
ZError,
createAsyncQueue,
createAsyncQueues,
singleton
};
//# sourceMappingURL=index.js.map