aboutsummaryrefslogtreecommitdiff
path: root/src-qt5/core/libLumina/LFileInfo.h
blob: 94a113bceb6bf1bbc675f58db8af8d2e50bd2821 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
//===========================================
//  Lumina-DE source code
//  Copyright (c) 2013-2017, Ken Moore
//  Available under the 3-clause BSD license
//  See the LICENSE file for full details
//===========================================
// File Information simplification class (combine QFileInfo with XDGDesktop)
//  Need some extra information not usually available by a QFileInfo
// ========================
#ifndef _LUMINA_LIBRARY_FILE_INFO_H
#define _LUMINA_LIBRARY_FILE_INFO_H

#include <LuminaXDG.h>
#include <QString>
#include <QFileInfo>
#include <QJsonObject>

class LFileInfo : public QFileInfo{
private:
	QString mime, zfs_ds, zfs_dspath;
	QStringList iconList, zfs_perms;
	int c_uid;
	XDGDesktop *desk;

	void loadExtraInfo();
	bool zfsAvailable();
	void getZfsDataset(); //note: only run this if "zfsAvailable" is true
	bool goodZfsDataset(); //simplification of the two functions above

public:
	//Couple overloaded contructors
	LFileInfo();
	LFileInfo(QString filepath);
	LFileInfo(QFileInfo info);
	~LFileInfo();

	//Functions for accessing the extra information
	// -- Return the mimetype for the file
	QString mimetype();

	// -- Return the icon file to use for this file
	QString iconfile(); //Note: This string is auto-formatted for use in the LXDG::findIcon() routine.
	QIcon icon();

	// -- Check if this is an XDG desktop file
	bool isDesktopFile();

	// -- Allow access to the internal XDG desktop data structure
	XDGDesktop* XDG();

	//Other file type identification routines
	bool isImage(); //Is a readable image file (for thumbnail support)
	bool isVideo(); //Is a readable video file (for thumbnail support)
	bool isAVFile(); //Is an audio/video file

	//ZFS Information
	bool isZfsDataset(QString path = "");
	QString zfsPool();
	QStringList zfsSnapshots(); //Format: "snapshot name::::path/to/snapshot"
	QJsonObject zfsProperties();
	bool zfsSetProperty(QString property, QString value);

	//ZFS Permissions/Modifications
	bool canZFScreate();
	bool zfsCreateDataset(QString subdir);
	bool canZFSdestroy();
	bool zfsDestroyDataset(QString subdir);
	bool zfsDestroySnapshot(QString snapshot);
	bool canZFSclone();
	bool zfsCloneDataset(QString subdir, QString newsubdir);
	bool canZFSsnapshot();
	bool zfsSnapshot(QString snapname);
	bool canZFSrollback();
	bool zfsRollback(QString snapname);

};
typedef QList<LFileInfo> LFileInfoList;

#endif
bgstack15