From f7177dbd70d057b51fdcf14d399e462e09878806 Mon Sep 17 00:00:00 2001 From: SebClem Date: Mon, 14 Feb 2022 11:39:04 +0100 Subject: [PATCH] :hammer: Add "Create Backup Timeout" in addon settings #111 --- nextcloud_backup/config.json | 10 ++++++---- nextcloud_backup/rootfs/opt/nextcloud_backup/app.js | 5 +++++ .../opt/nextcloud_backup/tools/hassioApiTools.js | 3 ++- 3 files changed, 13 insertions(+), 5 deletions(-) diff --git a/nextcloud_backup/config.json b/nextcloud_backup/config.json index 82e8973d..519f72ad 100644 --- a/nextcloud_backup/config.json +++ b/nextcloud_backup/config.json @@ -2,7 +2,7 @@ "name": "Nextcloud Backup", "version": "dev", "slug": "nextcloud_backup", - "description": "Easily backup your Home Assistant snapshots to Nextcloud", + "description": "Easily upload your Home Assistant backups to Nextcloud", "url": "https://github.com/Sebclem/hassio-nextcloud-backup", "webui": "[PROTO:ssl]://[HOST]:[PORT:3000]/", "ingress": true, @@ -24,15 +24,17 @@ "hassio_role": "admin", "homeassistant_api": true, "options": { - "log_level": "info" + "log_level": "info", + "create_backup_timeout": 5400000 }, "schema": { - "log_level": "match(^(trace|debug|info|notice|warning|error|fatal)$)?" + "log_level": "list(trace|debug|info|notice|warning|error|fatal)", + "create_backup_timeout": "int" }, "ports": { "3000/tcp": null }, "ports_description": { - "3000/tcp": "Web interface (Not required for Hass.io Ingress)" + "3000/tcp": "Web interface (Not required for Home Assistant Ingress)" } } diff --git a/nextcloud_backup/rootfs/opt/nextcloud_backup/app.js b/nextcloud_backup/rootfs/opt/nextcloud_backup/app.js index 115aa006..a19d77ad 100644 --- a/nextcloud_backup/rootfs/opt/nextcloud_backup/app.js +++ b/nextcloud_backup/rootfs/opt/nextcloud_backup/app.js @@ -70,8 +70,13 @@ app.use(function (err, req, res, next) { Init app ---------------------------------------------------------- */ + const fs = require("fs"); const newlog = require("./config/winston"); + +newlog.info(`Log level: ${ process.env.LOG_LEVEL }`); +newlog.info(`Backup timeout: ${ parseInt(process.env.CREATE_BACKUP_TIMEOUT) || ( 90 * 60 * 1000 ) }`) + if (!fs.existsSync("/data")) fs.mkdirSync("/data"); const statusTools = require("./tools/status"); statusTools.init(); diff --git a/nextcloud_backup/rootfs/opt/nextcloud_backup/tools/hassioApiTools.js b/nextcloud_backup/rootfs/opt/nextcloud_backup/tools/hassioApiTools.js index bcea5a92..3d695601 100644 --- a/nextcloud_backup/rootfs/opt/nextcloud_backup/tools/hassioApiTools.js +++ b/nextcloud_backup/rootfs/opt/nextcloud_backup/tools/hassioApiTools.js @@ -11,7 +11,8 @@ const statusTools = require("./status"); const settingsTools = require("./settingsTools"); const logger = require("../config/winston"); -const create_snap_timeout = 90 * 60 * 1000; +// Default timout to 90min +const create_snap_timeout = parseInt(process.env.CREATE_BACKUP_TIMEOUT) || ( 90 * 60 * 1000 ); function getVersion() {