[pve-devel] [PATCH storage v2] Diskmanage: add flag for encrypted osds

Dominik Csapak d.csapak at proxmox.com
Fri Jul 12 12:15:15 CEST 2019


we can only do this here, since the ceph cluster is not aware of
osd encryption, only the local node is (via ceph-volume and lv tags)

this way, we are able to show an 'encrypted' flag in the disk gui at least

Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
changes from v1:
* use the same logic like blustore
* add one test and fix the rest
 PVE/Diskmanage.pm                             | 6 ++++++
 test/disk_tests/usages/disklist_expected.json | 4 ++++
 test/disk_tests/usages/lvs                    | 2 +-
 3 files changed, 11 insertions(+), 1 deletion(-)

diff --git a/PVE/Diskmanage.pm b/PVE/Diskmanage.pm
index 196eee5..2a0a015 100644
--- a/PVE/Diskmanage.pm
+++ b/PVE/Diskmanage.pm
@@ -292,6 +292,9 @@ sub get_ceph_volume_infos {
 	    if (($type eq 'block' || $type eq 'data') && $fields->[2] =~ m/ceph.osd_id=([^,]+)/) {
 		$result->{$dev}->{osdid} = $1;
 		$result->{$dev}->{bluestore} = ($type eq 'block');
+		if ($fields->[2] =~ m/ceph\.encrypted=1/) {
+		    $result->{$dev}->{encrypted} = 1;
+		}
 	    } else {
 		# undef++ becomes '1' (see `perldoc perlop`: Auto-increment)
 		$result->{$dev}->{$type}++;
@@ -582,6 +585,7 @@ sub get_disks {
 
 	my $osdid = -1;
 	my $bluestore = 0;
+	my $osdencrypted = 0;
 
 	my $journal_count = 0;
 	my $db_count = 0;
@@ -638,6 +642,7 @@ sub get_disks {
 	    if (defined($ceph_volume->{osdid})) {
 		$osdid = $ceph_volume->{osdid};
 		$bluestore = 1 if $ceph_volume->{bluestore};
+		$osdencrypted = 1 if $ceph_volume->{encrypted};
 	    }
 	}
 
@@ -656,6 +661,7 @@ sub get_disks {
 	$disklist->{$dev}->{osdid} = $osdid;
 	$disklist->{$dev}->{journals} = $journal_count if $journal_count;
 	$disklist->{$dev}->{bluestore} = $bluestore if $osdid != -1;
+	$disklist->{$dev}->{osdencrypted} = $osdencrypted if $osdid != -1;
 	$disklist->{$dev}->{db} = $db_count if $db_count;
 	$disklist->{$dev}->{wal} = $wal_count if $wal_count;
     });
diff --git a/test/disk_tests/usages/disklist_expected.json b/test/disk_tests/usages/disklist_expected.json
index b179cd6..b2e37c0 100644
--- a/test/disk_tests/usages/disklist_expected.json
+++ b/test/disk_tests/usages/disklist_expected.json
@@ -4,6 +4,7 @@
 	"rpm" : 0,
 	"size" : 1536000,
 	"type" : "hdd",
+	"osdencrypted": 0,
 	"osdid" : "444",
 	"bluestore" : "0",
 	"health" : "UNKNOWN",
@@ -104,6 +105,7 @@
 	"rpm" : 0,
 	"type" : "hdd",
 	"bluestore": 1,
+	"osdencrypted": 0,
 	"osdid" : 1
     },
     "sdh" : {
@@ -152,6 +154,7 @@
 	"rpm" : 0,
 	"bluestore": 0,
 	"type" : "hdd",
+	"osdencrypted": 1,
 	"osdid" : 0
     },
     "sdk" : {
@@ -168,6 +171,7 @@
 	"rpm" : 0,
 	"bluestore": 0,
 	"type" : "hdd",
+	"osdencrypted": 0,
 	"osdid" : 230
     },
     "sdl" : {
diff --git a/test/disk_tests/usages/lvs b/test/disk_tests/usages/lvs
index 8d640e1..3720a80 100644
--- a/test/disk_tests/usages/lvs
+++ b/test/disk_tests/usages/lvs
@@ -1,6 +1,6 @@
 /dev/sdg(0);osd-block-01234;ceph.osd_id=1
 /dev/sdh(0);osd-journal-01234;ceph.osd_id=1
 /dev/sdi(0);osd-db-01234;ceph.osd_id=1,dasdf
-/dev/sdj(0);osd-data-01234;ceph.osd_id=0,asfd
+/dev/sdj(0);osd-data-01234;ceph.osd_id=0,asfd,ceph.encrypted=1
 /dev/sdk(0);osd-data-231231;ceph.osd_id=230,ceph.fsid=test
 /dev/sdl(0);osd-data-234132;ceph.osd_id=,bar
-- 
2.20.1





More information about the pve-devel mailing list