libstorage-ng
Mountable.h
1 /*
2  * Copyright (c) [2014-2015] Novell, Inc.
3  * Copyright (c) [2016-2020] SUSE LLC
4  *
5  * All Rights Reserved.
6  *
7  * This program is free software; you can redistribute it and/or modify it
8  * under the terms of version 2 of the GNU General Public License as published
9  * by the Free Software Foundation.
10  *
11  * This program is distributed in the hope that it will be useful, but WITHOUT
12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13  * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
14  * more details.
15  *
16  * You should have received a copy of the GNU General Public License along
17  * with this program; if not, contact Novell, Inc.
18  *
19  * To contact Novell about this file by physical or electronic mail, you may
20  * find current contact information at www.novell.com.
21  */
22 
23 
24 #ifndef STORAGE_MOUNTABLE_H
25 #define STORAGE_MOUNTABLE_H
26 
27 
28 #include <vector>
29 
30 #include "storage/Devices/Device.h"
31 #include "storage/Utils/Swig.h"
32 
33 
34 namespace storage
35 {
36 
37  class MountPoint;
38  class Filesystem;
39 
40 
41  enum class FsType {
42  UNKNOWN, AUTO, REISERFS, EXT2, EXT3, EXT4, BTRFS, VFAT, XFS, JFS, HFS, NTFS,
43  SWAP, HFSPLUS, NFS, NFS4, TMPFS, ISO9660, UDF, NILFS2, MINIX, NTFS3G, F2FS,
44  EXFAT, BITLOCKER, VBOXSF
45  };
46 
47 
53  std::string get_fs_type_name(FsType fs_type);
54 
55 
60  enum class MountByType {
61 
66  DEVICE,
67 
71  UUID,
72 
76  LABEL,
77 
81  ID,
82 
86  PATH
87  };
88 
89 
95  std::string get_mount_by_name(MountByType mount_by_type);
96 
97 
98  // abstract class
99 
100  class Mountable : public Device
101  {
102  public:
103 
107  static std::vector<Mountable*> get_all(Devicegraph* devicegraph);
108 
112  static std::vector<const Mountable*> get_all(const Devicegraph* devicegraph);
113 
123  bool supports_mount() const;
124 
130  MountPoint* create_mount_point(const std::string& path);
131 
135  bool has_mount_point() const;
136 
141 
145  const MountPoint* get_mount_point() const;
146 
152  void remove_mount_point();
153 
157  bool has_filesystem() const;
158 
164 
168  const Filesystem* get_filesystem() const;
169 
170  MountByType get_mount_by() const ST_DEPRECATED;
171  void set_mount_by(MountByType mount_by) ST_DEPRECATED;
172 
173  const std::vector<std::string>& get_mount_opts() const ST_DEPRECATED;
174  void set_mount_opts(const std::vector<std::string>& mount_opts) ST_DEPRECATED;
175 
176  const std::vector<std::string>& get_fstab_options() const ST_DEPRECATED;
177  void set_fstab_options(const std::vector<std::string>& mount_opts) ST_DEPRECATED;
178 
179  public:
180 
181  class Impl;
182 
183  Impl& get_impl();
184  const Impl& get_impl() const;
185 
186  protected:
187 
188  Mountable(Impl* impl);
189 
190  };
191 
192 
198  bool is_mountable(const Device* device);
199 
206  Mountable* to_mountable(Device* device);
207 
211  const Mountable* to_mountable(const Device* device);
212 
213 }
214 
215 #endif
Filesystem label.
One of the links in /dev/disk/by-id.
bool has_filesystem() const
Checks whether the mountable has a filesystem.
Filesystem * get_filesystem()
Return the filesystem of the mountable.
MountPoint * create_mount_point(const std::string &path)
Create a new mount point for the mountable with path.
bool has_mount_point() const
Checks whether the mountable has a mount point.
The main container of the libstorage-ng.
Definition: Devicegraph.h:169
Definition: Mountable.h:100
bool supports_mount() const
Checks whether the library supports mounting the mountable.
bool is_mountable(const Device *device)
Checks whether device points to a Mountable.
Class to represent a mount point.
Definition: MountPoint.h:48
MountPoint * get_mount_point()
Returns the mount point of the mountable.
One of the links in /dev/disk/by-path.
An abstract base class for storage devices.
Definition: Device.h:81
std::string get_mount_by_name(MountByType mount_by_type)
Convert the MountByType mount_by_type to a string.
Definition: Filesystem.h:40
static std::vector< Mountable * > get_all(Devicegraph *devicegraph)
Get all Mountables.
The storage namespace.
Definition: Actiongraph.h:38
std::string get_fs_type_name(FsType fs_type)
Convert the FsType fs_type to a string.
The kernel device name or a link in /dev (but not in /dev/disk).
Mountable * to_mountable(Device *device)
Converts pointer to Device to pointer to Mountable.
void remove_mount_point()
Removes the mount point from the mountable.
MountByType
The key by which the mount program identifies a mountable.
Definition: Mountable.h:60