143 lines
3.6 KiB
JavaScript
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
|