summaryrefslogtreecommitdiffstats
path: root/server/utils/limit-queue.js
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2024-11-26 09:28:28 +0100
committerDaniel Baumann <daniel@debian.org>2024-11-26 12:25:58 +0100
commita1882b67c41fe9901a0cd8059b5cc78a5beadec0 (patch)
tree2a24507c67aa99a15416707b2f7e645142230ed8 /server/utils/limit-queue.js
parentInitial commit. (diff)
downloaduptime-kuma-upstream.tar.xz
uptime-kuma-upstream.zip
Adding upstream version 2.0.0~beta.0+dfsg.upstream/2.0.0_beta.0+dfsgupstream
Signed-off-by: Daniel Baumann <daniel@debian.org>
Diffstat (limited to 'server/utils/limit-queue.js')
-rw-r--r--server/utils/limit-queue.js48
1 files changed, 48 insertions, 0 deletions
diff --git a/server/utils/limit-queue.js b/server/utils/limit-queue.js
new file mode 100644
index 0000000..9da6d41
--- /dev/null
+++ b/server/utils/limit-queue.js
@@ -0,0 +1,48 @@
+const { ArrayWithKey } = require("./array-with-key");
+
+/**
+ * Limit Queue
+ * The first element will be removed when the length exceeds the limit
+ */
+class LimitQueue extends ArrayWithKey {
+
+ /**
+ * The limit of the queue after which the first element will be removed
+ * @private
+ * @type {number}
+ */
+ __limit;
+ /**
+ * The callback function when the queue exceeds the limit
+ * @private
+ * @callback onExceedCallback
+ * @param {{key:K,value:V}|nul} item
+ */
+ __onExceed = null;
+
+ /**
+ * @param {number} limit The limit of the queue after which the first element will be removed
+ */
+ constructor(limit) {
+ super();
+ this.__limit = limit;
+ }
+
+ /**
+ * @inheritDoc
+ */
+ push(key, value) {
+ super.push(key, value);
+ if (this.length() > this.__limit) {
+ let item = this.shift();
+ if (this.__onExceed) {
+ this.__onExceed(item);
+ }
+ }
+ }
+
+}
+
+module.exports = {
+ LimitQueue
+};