kpmcore/src/fs/luks.h

233 lines
7.9 KiB
C
Raw Normal View History

/*************************************************************************
* Copyright (C) 2012 by Volker Lanz <vl@fidra.de> *
2016-02-25 23:29:33 +00:00
* Copyright (C) 2013 by Andrius Štikonas <andrius@stikonas.eu> *
2016-04-15 14:43:21 +01:00
* Copyright (C) 2015-2016 by Teo Mrnjavac <teo@kde.org> *
* *
* This program is free software; you can redistribute it and/or *
* modify it under the terms of the GNU General Public License as *
* published by the Free Software Foundation; either version 3 of *
* the License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program. If not, see <http://www.gnu.org/licenses/>.*
*************************************************************************/
#if !defined(KPMCORE_LUKS_H)
#define KPMCORE_LUKS_H
2016-05-06 22:36:24 +01:00
#include "util/libpartitionmanagerexport.h"
2016-05-06 22:36:24 +01:00
#include "fs/filesystem.h"
#include <QtGlobal>
class Report;
class QString;
2018-03-31 16:30:53 +01:00
class QWidget;
namespace FS
{
2015-07-13 15:16:36 +01:00
/** A LUKS crypto file system.
2016-02-25 23:29:33 +00:00
@author Andrius Štikonas <andrius@stikonas.eu>
2015-07-13 15:16:36 +01:00
*/
class LIBKPMCORE_EXPORT luks : public FileSystem
{
public:
2018-04-07 19:54:30 +01:00
luks(qint64 firstsector, qint64 lastsector, qint64 sectorsused, const QString& label, FileSystem::Type t = FileSystem::Type::Luks);
2017-09-11 00:29:30 +01:00
~luks() override;
2015-07-13 15:16:36 +01:00
enum KeyLocation {
unknown,
dmcrypt,
keyring
};
2015-07-13 15:16:36 +01:00
public:
void init() override;
void scan(const QString& deviceNode) override;
2016-05-17 18:01:31 +01:00
qint64 readUsedCapacity(const QString& deviceNode) const override;
2015-07-13 15:16:36 +01:00
2016-05-17 18:01:31 +01:00
CommandSupportType supportGetUsed() const override {
2015-07-13 15:16:36 +01:00
return m_GetUsed;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportGetLabel() const override {
2015-07-13 15:16:36 +01:00
return m_GetLabel;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportCreate() const override {
2015-07-13 15:16:36 +01:00
return m_Create;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportGrow() const override {
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Grow && m_innerFs)
return m_innerFs->supportGrow();
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
}
CommandSupportType supportGrowOnline() const override {
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Grow && m_innerFs)
return m_innerFs->supportGrowOnline();
return cmdSupportNone;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportShrink() const override {
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Shrink && m_innerFs)
return m_innerFs->supportShrink();
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
}
CommandSupportType supportShrinkOnline() const override {
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Shrink && m_innerFs)
return m_innerFs->supportShrinkOnline();
return cmdSupportNone;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportMove() const override {
2016-05-18 00:46:08 +01:00
if (m_isCryptOpen)
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
return m_Move;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportCheck() const override {
2016-04-26 13:26:40 +01:00
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Check && m_innerFs)
2016-04-27 00:10:28 +01:00
return m_innerFs->supportCheck();
2016-04-26 13:26:40 +01:00
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
}
CommandSupportType supportCheckOnline() const override {
if (!m_isCryptOpen)
return cmdSupportNone;
if (m_Check && m_innerFs)
return m_innerFs->supportCheckOnline();
return cmdSupportNone;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportCopy() const override {
if (m_isCryptOpen)
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
return m_Copy;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportBackup() const override {
2015-07-13 15:16:36 +01:00
return m_Backup;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportSetLabel() const override {
if (m_Check && m_innerFs)
return m_innerFs->supportSetLabel();
return cmdSupportNone;
2015-07-13 15:16:36 +01:00
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportUpdateUUID() const override {
2015-07-13 15:16:36 +01:00
return m_UpdateUUID;
}
2016-05-17 18:01:31 +01:00
CommandSupportType supportGetUUID() const override {
2015-07-13 15:16:36 +01:00
return m_GetUUID;
}
2016-05-17 18:01:31 +01:00
bool check(Report& report, const QString& deviceNode) const override;
2016-09-05 12:10:56 +01:00
bool create(Report& report, const QString& deviceNode) override;
2016-05-17 18:01:31 +01:00
SupportTool supportToolName() const override;
bool supportToolFound() const override;
QString readUUID(const QString& deviceNode) const override;
bool updateUUID(Report& report, const QString& deviceNode) const override;
bool resize(Report& report, const QString& deviceNode, qint64 length) const override;
bool resizeOnline(Report& report, const QString& deviceNode, const QString& mountPoint, qint64 length) const override;
2016-05-17 18:01:31 +01:00
QString readLabel(const QString& deviceNode) const override;
bool writeLabel(Report& report, const QString& deviceNode, const QString& newLabel) override;
QString mountTitle() const override;
QString unmountTitle() const override;
QString cryptOpenTitle() const;
QString cryptCloseTitle() const;
void setPassphrase(const QString&);
2016-05-06 15:50:03 +01:00
QString passphrase() const;
2016-05-17 18:01:31 +01:00
bool canMount(const QString&, const QString&) const override;
bool canUnmount(const QString&) const override;
bool isMounted() const;
void setMounted(bool mounted);
bool canCryptOpen(const QString& deviceNode) const;
bool canCryptClose(const QString& deviceNode) const;
bool isCryptOpen() const;
void setCryptOpen(bool cryptOpen);
bool cryptOpen(QWidget* parent, const QString& deviceNode);
bool cryptClose(const QString& deviceNode);
2015-07-13 15:16:36 +01:00
void loadInnerFileSystem(const QString& mapperNode);
void createInnerFileSystem(Type type);
2016-05-17 18:01:31 +01:00
bool mount(Report& report, const QString& deviceNode, const QString& mountPoint) override;
bool unmount(Report& report, const QString& deviceNode) override;
2015-07-13 15:16:36 +01:00
2016-05-17 18:01:31 +01:00
FileSystem::Type type() const override;
QString suggestedMapperName(const QString& deviceNode) const;
void getMapperName(const QString& deviceNode);
virtual void getLuksInfo(const QString& deviceNode);
FileSystem* innerFS() const { return m_innerFs; }
2016-11-29 18:12:27 +00:00
QString outerUuid() const;
2016-11-29 18:12:27 +00:00
QString mapperName() const { return m_MapperName; }
QString cipherName() const { return m_CipherName; }
QString cipherMode() const { return m_CipherMode; }
QString hashName() const { return m_HashName; }
qint64 keySize() const { return m_KeySize; }
qint64 payloadOffset() const { return m_PayloadOffset; }
2015-07-13 15:16:36 +01:00
static bool canEncryptType(FileSystem::Type type);
void initLUKS();
2015-07-13 15:16:36 +01:00
bool testPassphrase(const QString& deviceNode, const QString& passphrase) const;
2016-05-05 13:15:39 +01:00
protected:
virtual QString readOuterUUID(const QString& deviceNode) const;
void setPayloadSize();
2016-05-05 13:15:39 +01:00
2015-07-13 15:16:36 +01:00
public:
static CommandSupportType m_GetUsed;
static CommandSupportType m_GetLabel;
static CommandSupportType m_Create;
static CommandSupportType m_Grow;
static CommandSupportType m_Shrink;
static CommandSupportType m_Move;
static CommandSupportType m_Check;
static CommandSupportType m_Copy;
static CommandSupportType m_Backup;
static CommandSupportType m_SetLabel;
static CommandSupportType m_UpdateUUID;
static CommandSupportType m_GetUUID;
2017-12-14 02:08:32 +00:00
protected:
2016-04-12 10:26:07 +01:00
mutable FileSystem* m_innerFs;
2016-04-12 10:26:07 +01:00
mutable bool m_isCryptOpen;
mutable bool m_cryptsetupFound;
QString m_passphrase;
bool m_isMounted;
QString m_MapperName;
QString m_CipherName;
QString m_CipherMode;
QString m_HashName;
qint64 m_KeySize;
qint64 m_PayloadOffset;
qint64 m_PayloadSize;
2016-11-29 18:12:27 +00:00
QString m_outerUuid;
luks::KeyLocation m_KeyLocation = unknown;
2015-07-13 15:16:36 +01:00
};
}
#endif