kpmcore/src/fs/luks.h

225 lines
7.2 KiB
C
Raw Normal View History

2020-09-28 00:45:21 +01:00
/*
SPDX-FileCopyrightText: 2010 Volker Lanz <vl@fidra.de>
SPDX-FileCopyrightText: 2012-2018 Andrius Štikonas <andrius@stikonas.eu>
SPDX-FileCopyrightText: 2015 Chris Campbell <c.j.campbell@ed.ac.uk>
SPDX-FileCopyrightText: 2015-2016 Teo Mrnjavac <teo@kde.org>
SPDX-FileCopyrightText: 2016 Chantara Tith <tith.chantara@gmail.com>
SPDX-FileCopyrightText: 2020 Arnaud Ferraris <arnaud.ferraris@collabora.com>
SPDX-FileCopyrightText: 2020 Gaël PORTAY <gael.portay@collabora.com>
SPDX-License-Identifier: GPL-3.0-or-later
*/
2018-04-09 15:14:34 +01:00
#ifndef 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:
luks(qint64 firstsector, qint64 lastsector, qint64 sectorsused, const QString& label, const QVariantMap& features = {}, FileSystem::Type t = FileSystem::Type::Luks);
2017-09-11 00:29:30 +01:00
~luks() override;
2015-07-13 15:16:36 +01:00
2018-04-09 15:14:34 +01:00
enum class 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;
2018-04-09 15:14:34 +01:00
luks::KeyLocation m_KeyLocation = KeyLocation::unknown;
2015-07-13 15:16:36 +01:00
};
}
#endif