summaryrefslogtreecommitdiffstats
path: root/server/remote-browser.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/remote-browser.js
parentInitial commit. (diff)
downloaduptime-kuma-a1882b67c41fe9901a0cd8059b5cc78a5beadec0.tar.xz
uptime-kuma-a1882b67c41fe9901a0cd8059b5cc78a5beadec0.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/remote-browser.js')
-rw-r--r--server/remote-browser.js74
1 files changed, 74 insertions, 0 deletions
diff --git a/server/remote-browser.js b/server/remote-browser.js
new file mode 100644
index 0000000..da8e9a5
--- /dev/null
+++ b/server/remote-browser.js
@@ -0,0 +1,74 @@
+const { R } = require("redbean-node");
+
+class RemoteBrowser {
+
+ /**
+ * Gets remote browser from ID
+ * @param {number} remoteBrowserID ID of the remote browser
+ * @param {number} userID ID of the user who created the remote browser
+ * @returns {Promise<Bean>} Remote Browser
+ */
+ static async get(remoteBrowserID, userID) {
+ let bean = await R.findOne("remote_browser", " id = ? AND user_id = ? ", [ remoteBrowserID, userID ]);
+
+ if (!bean) {
+ throw new Error("Remote browser not found");
+ }
+
+ return bean;
+ }
+
+ /**
+ * Save a Remote Browser
+ * @param {object} remoteBrowser Remote Browser to save
+ * @param {?number} remoteBrowserID ID of the Remote Browser to update
+ * @param {number} userID ID of the user who adds the Remote Browser
+ * @returns {Promise<Bean>} Updated Remote Browser
+ */
+ static async save(remoteBrowser, remoteBrowserID, userID) {
+ let bean;
+
+ if (remoteBrowserID) {
+ bean = await R.findOne("remote_browser", " id = ? AND user_id = ? ", [ remoteBrowserID, userID ]);
+
+ if (!bean) {
+ throw new Error("Remote browser not found");
+ }
+
+ } else {
+ bean = R.dispense("remote_browser");
+ }
+
+ bean.user_id = userID;
+ bean.name = remoteBrowser.name;
+ bean.url = remoteBrowser.url;
+
+ await R.store(bean);
+
+ return bean;
+ }
+
+ /**
+ * Delete a Remote Browser
+ * @param {number} remoteBrowserID ID of the Remote Browser to delete
+ * @param {number} userID ID of the user who created the Remote Browser
+ * @returns {Promise<void>}
+ */
+ static async delete(remoteBrowserID, userID) {
+ let bean = await R.findOne("remote_browser", " id = ? AND user_id = ? ", [ remoteBrowserID, userID ]);
+
+ if (!bean) {
+ throw new Error("Remote Browser not found");
+ }
+
+ // Delete removed remote browser from monitors if exists
+ await R.exec("UPDATE monitor SET remote_browser = null WHERE remote_browser = ?", [ remoteBrowserID ]);
+
+ await R.trash(bean);
+ }
+
+}
+
+module.exports = {
+ RemoteBrowser,
+};