summaryrefslogtreecommitdiffstats
path: root/src/pybind/mgr/dashboard/services/cephfs.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-27 18:24:20 +0000
commit483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch)
treee5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/pybind/mgr/dashboard/services/cephfs.py
parentInitial commit. (diff)
downloadceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.tar.xz
ceph-483eb2f56657e8e7f419ab1a4fab8dce9ade8609.zip
Adding upstream version 14.2.21.upstream/14.2.21upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/pybind/mgr/dashboard/services/cephfs.py')
-rw-r--r--src/pybind/mgr/dashboard/services/cephfs.py77
1 files changed, 77 insertions, 0 deletions
diff --git a/src/pybind/mgr/dashboard/services/cephfs.py b/src/pybind/mgr/dashboard/services/cephfs.py
new file mode 100644
index 00000000..bb75b4e2
--- /dev/null
+++ b/src/pybind/mgr/dashboard/services/cephfs.py
@@ -0,0 +1,77 @@
+# -*- coding: utf-8 -*-
+from __future__ import absolute_import
+
+from contextlib import contextmanager
+
+import cephfs
+
+from .. import mgr, logger
+
+
+class CephFS(object):
+ @classmethod
+ def list_filesystems(cls):
+ fsmap = mgr.get("fs_map")
+ return [{'id': fs['id'], 'name': fs['mdsmap']['fs_name']}
+ for fs in fsmap['filesystems']]
+
+ def __init__(self, fs_name=None):
+ logger.debug("[CephFS] initializing cephfs connection")
+ self.cfs = cephfs.LibCephFS(rados_inst=mgr.rados)
+ logger.debug("[CephFS] mounting cephfs filesystem: %s", fs_name)
+ if fs_name:
+ self.cfs.mount(filesystem_name=fs_name)
+ else:
+ self.cfs.mount()
+ logger.debug("[CephFS] mounted cephfs filesystem")
+
+ def __del__(self):
+ logger.debug("[CephFS] shutting down cephfs filesystem")
+ self.cfs.shutdown()
+
+ @contextmanager
+ def opendir(self, dirpath):
+ d = None
+ try:
+ d = self.cfs.opendir(dirpath)
+ yield d
+ finally:
+ if d:
+ self.cfs.closedir(d)
+
+ def get_dir_list(self, dirpath, level):
+ logger.debug("[CephFS] get_dir_list dirpath=%s level=%s", dirpath,
+ level)
+ if level == 0:
+ return [dirpath]
+ logger.debug("[CephFS] opening dirpath=%s", dirpath)
+ with self.opendir(dirpath) as d:
+ dent = self.cfs.readdir(d)
+ paths = [dirpath]
+ while dent:
+ logger.debug("[CephFS] found entry=%s", dent.d_name)
+ if dent.d_name in ['.', '..']:
+ dent = self.cfs.readdir(d)
+ continue
+ if dent.is_dir():
+ logger.debug("[CephFS] found dir=%s", dent.d_name)
+ subdirpath = '{}{}/'.format(dirpath, dent.d_name)
+ paths.extend(self.get_dir_list(subdirpath, level-1))
+ dent = self.cfs.readdir(d)
+ return paths
+
+ def dir_exists(self, dirpath):
+ try:
+ with self.opendir(dirpath):
+ return True
+ except cephfs.ObjectNotFound:
+ return False
+
+ def mkdirs(self, dirpath):
+ if dirpath == '/':
+ raise Exception('Cannot create root directory "/"')
+ if self.dir_exists(dirpath):
+ return
+
+ logger.info("[CephFS] Creating directory: %s", dirpath)
+ self.cfs.mkdirs("{}".format(dirpath).encode('utf-8'), 0o755)