diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-27 18:24:20 +0000 |
commit | 483eb2f56657e8e7f419ab1a4fab8dce9ade8609 (patch) | |
tree | e5d88d25d870d5dedacb6bbdbe2a966086a0a5cf /src/pybind/mgr/dashboard/services/cephfs.py | |
parent | Initial commit. (diff) | |
download | ceph-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.py | 77 |
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) |