2020-07-09 14:15:49 +03:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Dietmar Maurer <dietmar@proxmox.com>
|
|
|
|
Date: Thu, 9 Jul 2020 12:53:08 +0200
|
|
|
|
Subject: [PATCH] PVE: fixup pbs backup, add compress and encrypt options
|
|
|
|
|
|
|
|
---
|
|
|
|
block/monitor/block-hmp-cmds.c | 4 +++-
|
|
|
|
pve-backup.c | 13 ++++++++++++-
|
|
|
|
qapi/block-core.json | 6 ++++++
|
|
|
|
3 files changed, 21 insertions(+), 2 deletions(-)
|
|
|
|
|
|
|
|
diff --git a/block/monitor/block-hmp-cmds.c b/block/monitor/block-hmp-cmds.c
|
2021-02-11 19:11:11 +03:00
|
|
|
index 056d14deee..46c63b1cf9 100644
|
2020-07-09 14:15:49 +03:00
|
|
|
--- a/block/monitor/block-hmp-cmds.c
|
|
|
|
+++ b/block/monitor/block-hmp-cmds.c
|
2021-02-11 19:11:11 +03:00
|
|
|
@@ -1039,7 +1039,9 @@ void hmp_backup(Monitor *mon, const QDict *qdict)
|
2020-07-09 14:15:49 +03:00
|
|
|
false, NULL, // PBS fingerprint
|
|
|
|
false, NULL, // PBS backup-id
|
|
|
|
false, 0, // PBS backup-time
|
|
|
|
- false, false, // PBS incremental
|
|
|
|
+ false, false, // PBS use-dirty-bitmap
|
|
|
|
+ false, false, // PBS compress
|
|
|
|
+ false, false, // PBS encrypt
|
|
|
|
true, dir ? BACKUP_FORMAT_DIR : BACKUP_FORMAT_VMA,
|
|
|
|
false, NULL, false, NULL, !!devlist,
|
|
|
|
devlist, qdict_haskey(qdict, "speed"), speed, &error);
|
|
|
|
diff --git a/pve-backup.c b/pve-backup.c
|
2020-09-28 18:48:32 +03:00
|
|
|
index 1cd9d31d7c..bfb648d6b5 100644
|
2020-07-09 14:15:49 +03:00
|
|
|
--- a/pve-backup.c
|
|
|
|
+++ b/pve-backup.c
|
|
|
|
@@ -567,6 +567,10 @@ typedef struct QmpBackupTask {
|
|
|
|
const char *firewall_file;
|
|
|
|
bool has_devlist;
|
|
|
|
const char *devlist;
|
|
|
|
+ bool has_compress;
|
|
|
|
+ bool compress;
|
|
|
|
+ bool has_encrypt;
|
|
|
|
+ bool encrypt;
|
|
|
|
bool has_speed;
|
|
|
|
int64_t speed;
|
|
|
|
Error **errp;
|
2020-09-28 18:48:32 +03:00
|
|
|
@@ -690,6 +694,7 @@ static void coroutine_fn pvebackup_co_prepare(void *opaque)
|
2020-07-09 14:15:49 +03:00
|
|
|
|
|
|
|
bool use_dirty_bitmap = task->has_use_dirty_bitmap && task->use_dirty_bitmap;
|
|
|
|
|
|
|
|
+
|
|
|
|
char *pbs_err = NULL;
|
|
|
|
pbs = proxmox_backup_new(
|
|
|
|
task->backup_file,
|
2020-09-28 18:48:32 +03:00
|
|
|
@@ -699,8 +704,10 @@ static void coroutine_fn pvebackup_co_prepare(void *opaque)
|
2020-07-09 14:15:49 +03:00
|
|
|
task->has_password ? task->password : NULL,
|
|
|
|
task->has_keyfile ? task->keyfile : NULL,
|
|
|
|
task->has_key_password ? task->key_password : NULL,
|
|
|
|
+ task->has_compress ? task->compress : true,
|
|
|
|
+ task->has_encrypt ? task->encrypt : task->has_keyfile,
|
|
|
|
task->has_fingerprint ? task->fingerprint : NULL,
|
|
|
|
- &pbs_err);
|
|
|
|
+ &pbs_err);
|
|
|
|
|
|
|
|
if (!pbs) {
|
|
|
|
error_set(task->errp, ERROR_CLASS_GENERIC_ERROR,
|
2020-09-28 18:48:32 +03:00
|
|
|
@@ -939,6 +946,8 @@ UuidInfo *qmp_backup(
|
2020-07-09 14:15:49 +03:00
|
|
|
bool has_backup_id, const char *backup_id,
|
|
|
|
bool has_backup_time, int64_t backup_time,
|
|
|
|
bool has_use_dirty_bitmap, bool use_dirty_bitmap,
|
|
|
|
+ bool has_compress, bool compress,
|
|
|
|
+ bool has_encrypt, bool encrypt,
|
|
|
|
bool has_format, BackupFormat format,
|
|
|
|
bool has_config_file, const char *config_file,
|
|
|
|
bool has_firewall_file, const char *firewall_file,
|
2020-09-28 18:48:32 +03:00
|
|
|
@@ -967,6 +976,8 @@ UuidInfo *qmp_backup(
|
2020-07-09 14:15:49 +03:00
|
|
|
.firewall_file = firewall_file,
|
|
|
|
.has_devlist = has_devlist,
|
|
|
|
.devlist = devlist,
|
|
|
|
+ .has_compress = has_compress,
|
|
|
|
+ .has_encrypt = has_encrypt,
|
|
|
|
.has_speed = has_speed,
|
|
|
|
.speed = speed,
|
|
|
|
.errp = errp,
|
|
|
|
diff --git a/qapi/block-core.json b/qapi/block-core.json
|
2021-02-11 19:11:11 +03:00
|
|
|
index d4e1c98c50..0fda1e3fd3 100644
|
2020-07-09 14:15:49 +03:00
|
|
|
--- a/qapi/block-core.json
|
|
|
|
+++ b/qapi/block-core.json
|
2021-02-11 19:11:11 +03:00
|
|
|
@@ -823,6 +823,10 @@
|
2020-07-09 14:15:49 +03:00
|
|
|
#
|
|
|
|
# @use-dirty-bitmap: use dirty bitmap to detect incremental changes since last job (optional for format 'pbs')
|
|
|
|
#
|
|
|
|
+# @compress: use compression (optional for format 'pbs', defaults to true)
|
|
|
|
+#
|
|
|
|
+# @encrypt: use encryption ((optional for format 'pbs', defaults to true if there is a keyfile)
|
|
|
|
+#
|
|
|
|
# Returns: the uuid of the backup job
|
|
|
|
#
|
|
|
|
##
|
2021-02-11 19:11:11 +03:00
|
|
|
@@ -834,6 +838,8 @@
|
2020-07-09 14:15:49 +03:00
|
|
|
'*backup-id': 'str',
|
|
|
|
'*backup-time': 'int',
|
|
|
|
'*use-dirty-bitmap': 'bool',
|
|
|
|
+ '*compress': 'bool',
|
|
|
|
+ '*encrypt': 'bool',
|
|
|
|
'*format': 'BackupFormat',
|
|
|
|
'*config-file': 'str',
|
|
|
|
'*firewall-file': 'str',
|