2014-06-30 15:03:29 +02:00
|
|
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
|
|
|
*
|
2016-03-04 19:11:31 +01:00
|
|
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
|
|
|
* Copyright 2015-2016, Teo Mrnjavac <teo@kde.org>
|
2014-06-30 15:03:29 +02:00
|
|
|
*
|
|
|
|
* Calamares 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.
|
|
|
|
*
|
|
|
|
* Calamares 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 Calamares. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2015-09-18 15:41:07 +02:00
|
|
|
#include "core/KPMHelpers.h"
|
2014-06-30 15:03:29 +02:00
|
|
|
|
2015-07-02 13:49:21 +02:00
|
|
|
#include "core/PartitionInfo.h"
|
|
|
|
#include "core/PartitionIterator.h"
|
2014-07-23 18:14:27 +02:00
|
|
|
|
2015-07-02 13:49:21 +02:00
|
|
|
// KPMcore
|
2017-09-03 21:45:24 +02:00
|
|
|
#include <kpmcore/core/device.h>
|
2015-07-02 13:49:21 +02:00
|
|
|
#include <kpmcore/core/partition.h>
|
|
|
|
#include <kpmcore/fs/filesystemfactory.h>
|
2015-07-03 17:03:33 +02:00
|
|
|
#include <kpmcore/backend/corebackendmanager.h>
|
2016-04-22 16:01:31 +02:00
|
|
|
#include <kpmcore/fs/luks.h>
|
2015-07-03 17:03:33 +02:00
|
|
|
|
|
|
|
#include <QDebug>
|
|
|
|
|
2014-06-30 15:03:29 +02:00
|
|
|
|
2015-09-18 15:41:07 +02:00
|
|
|
namespace KPMHelpers
|
2014-06-30 15:03:29 +02:00
|
|
|
{
|
|
|
|
|
2015-07-03 17:03:33 +02:00
|
|
|
static bool s_KPMcoreInited = false;
|
|
|
|
|
|
|
|
bool
|
|
|
|
initKPMcore()
|
|
|
|
{
|
|
|
|
if ( s_KPMcoreInited )
|
|
|
|
return true;
|
|
|
|
|
|
|
|
QByteArray backendName = qgetenv( "KPMCORE_BACKEND" );
|
2017-07-11 21:02:29 +02:00
|
|
|
if ( !CoreBackendManager::self()->load( backendName.isEmpty() ? CoreBackendManager::defaultBackendName() : backendName ) )
|
2015-07-03 17:03:33 +02:00
|
|
|
{
|
|
|
|
qWarning() << "Failed to load backend plugin" << backendName;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
s_KPMcoreInited = true;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
|
2015-05-22 18:14:53 +02:00
|
|
|
bool
|
|
|
|
isPartitionFreeSpace( Partition* partition )
|
2014-06-30 15:03:29 +02:00
|
|
|
{
|
2014-07-01 16:29:00 +02:00
|
|
|
return partition->roles().has( PartitionRole::Unallocated );
|
2014-06-30 15:03:29 +02:00
|
|
|
}
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
|
2015-05-22 18:14:53 +02:00
|
|
|
bool
|
|
|
|
isPartitionNew( Partition* partition )
|
2014-07-15 17:32:55 +02:00
|
|
|
{
|
|
|
|
return partition->state() == Partition::StateNew;
|
|
|
|
}
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
|
2014-07-23 18:14:27 +02:00
|
|
|
Partition*
|
|
|
|
findPartitionByMountPoint( const QList< Device* >& devices, const QString& mountPoint )
|
|
|
|
{
|
|
|
|
for ( auto device : devices )
|
|
|
|
for ( auto it = PartitionIterator::begin( device ); it != PartitionIterator::end( device ); ++it )
|
|
|
|
if ( PartitionInfo::mountPoint( *it ) == mountPoint )
|
|
|
|
return *it;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
|
|
|
|
Partition*
|
|
|
|
findPartitionByPath( const QList< Device* >& devices, const QString& path )
|
|
|
|
{
|
2016-03-10 12:43:00 +01:00
|
|
|
if ( path.simplified().isEmpty() )
|
|
|
|
return nullptr;
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
for ( auto device : devices )
|
|
|
|
for ( auto it = PartitionIterator::begin( device ); it != PartitionIterator::end( device ); ++it )
|
|
|
|
if ( ( *it )->partitionPath() == path.simplified() )
|
|
|
|
return *it;
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-05-22 18:14:53 +02:00
|
|
|
QList< Partition* >
|
|
|
|
findPartitions( const QList< Device* >& devices,
|
|
|
|
std::function< bool ( Partition* ) > criterionFunction )
|
|
|
|
{
|
|
|
|
QList< Partition* > results;
|
|
|
|
for ( auto device : devices )
|
|
|
|
for ( auto it = PartitionIterator::begin( device ); it != PartitionIterator::end( device ); ++it )
|
|
|
|
if ( criterionFunction( *it ) )
|
|
|
|
results.append( *it );
|
|
|
|
return results;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-08-04 18:16:05 +02:00
|
|
|
Partition*
|
2016-03-04 19:11:31 +01:00
|
|
|
createNewPartition( PartitionNode* parent,
|
|
|
|
const Device& device,
|
|
|
|
const PartitionRole& role,
|
|
|
|
FileSystem::Type fsType,
|
|
|
|
qint64 firstSector,
|
|
|
|
qint64 lastSector,
|
|
|
|
PartitionTable::Flags flags )
|
2014-08-04 18:16:05 +02:00
|
|
|
{
|
2017-09-03 21:45:24 +02:00
|
|
|
FileSystem* fs = FileSystemFactory::create( fsType, firstSector, lastSector
|
|
|
|
#ifdef WITH_KPMCORE22
|
|
|
|
,device.logicalSize()
|
|
|
|
#endif
|
|
|
|
);
|
2014-08-04 18:16:05 +02:00
|
|
|
return new Partition(
|
2014-08-05 09:54:30 +02:00
|
|
|
parent,
|
|
|
|
device,
|
|
|
|
role,
|
|
|
|
fs, fs->firstSector(), fs->lastSector(),
|
|
|
|
QString() /* path */,
|
|
|
|
PartitionTable::FlagNone /* availableFlags */,
|
|
|
|
QString() /* mountPoint */,
|
|
|
|
false /* mounted */,
|
2016-03-04 19:11:31 +01:00
|
|
|
flags /* activeFlags */,
|
2014-08-05 09:54:30 +02:00
|
|
|
Partition::StateNew
|
|
|
|
);
|
2014-08-04 18:16:05 +02:00
|
|
|
}
|
|
|
|
|
2014-09-25 16:49:13 +02:00
|
|
|
|
2016-04-22 16:01:31 +02:00
|
|
|
Partition*
|
|
|
|
createNewEncryptedPartition( PartitionNode* parent,
|
|
|
|
const Device& device,
|
|
|
|
const PartitionRole& role,
|
|
|
|
FileSystem::Type fsType,
|
|
|
|
qint64 firstSector,
|
|
|
|
qint64 lastSector,
|
|
|
|
const QString& passphrase,
|
|
|
|
PartitionTable::Flags flags )
|
|
|
|
{
|
|
|
|
PartitionRole::Roles newRoles = role.roles();
|
|
|
|
if ( !role.has( PartitionRole::Luks ) )
|
|
|
|
newRoles |= PartitionRole::Luks;
|
|
|
|
|
|
|
|
FS::luks* fs = dynamic_cast< FS::luks* >(
|
|
|
|
FileSystemFactory::create( FileSystem::Luks,
|
|
|
|
firstSector,
|
2017-09-03 21:45:24 +02:00
|
|
|
lastSector
|
|
|
|
#ifdef WITH_KPMCORE22
|
|
|
|
,device.logicalSize()
|
|
|
|
#endif
|
|
|
|
) );
|
2016-12-13 12:16:12 +01:00
|
|
|
if ( !fs )
|
|
|
|
{
|
|
|
|
qDebug() << "ERROR: cannot create LUKS filesystem. Giving up.";
|
|
|
|
return nullptr;
|
|
|
|
}
|
|
|
|
|
2016-04-22 16:01:31 +02:00
|
|
|
fs->createInnerFileSystem( fsType );
|
|
|
|
fs->setPassphrase( passphrase );
|
|
|
|
Partition* p = new Partition( parent,
|
|
|
|
device,
|
|
|
|
PartitionRole( newRoles ),
|
|
|
|
fs, fs->firstSector(), fs->lastSector(),
|
|
|
|
QString() /* path */,
|
|
|
|
PartitionTable::FlagNone /* availableFlags */,
|
|
|
|
QString() /* mountPoint */,
|
|
|
|
false /* mounted */,
|
|
|
|
flags /* activeFlags */,
|
|
|
|
Partition::StateNew );
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-08-07 12:59:24 +02:00
|
|
|
Partition*
|
|
|
|
clonePartition( Device* device, Partition* partition )
|
|
|
|
{
|
|
|
|
FileSystem* fs = FileSystemFactory::create(
|
|
|
|
partition->fileSystem().type(),
|
|
|
|
partition->firstSector(),
|
|
|
|
partition->lastSector()
|
2017-09-03 21:45:24 +02:00
|
|
|
#ifdef WITH_KPMCORE22
|
|
|
|
,device->logicalSize()
|
|
|
|
#endif
|
2014-08-07 12:59:24 +02:00
|
|
|
);
|
2016-03-04 19:11:31 +01:00
|
|
|
return new Partition( partition->parent(),
|
|
|
|
*device,
|
|
|
|
partition->roles(),
|
|
|
|
fs,
|
|
|
|
fs->firstSector(),
|
|
|
|
fs->lastSector(),
|
|
|
|
partition->partitionPath(),
|
|
|
|
partition->activeFlags() );
|
2014-08-07 12:59:24 +02:00
|
|
|
}
|
|
|
|
|
2015-12-16 15:46:32 +01:00
|
|
|
|
|
|
|
QString
|
|
|
|
prettyNameForFileSystemType( FileSystem::Type t )
|
|
|
|
{
|
|
|
|
switch ( t )
|
|
|
|
{
|
|
|
|
case FileSystem::Unknown:
|
|
|
|
return QObject::tr( "unknown" );
|
|
|
|
case FileSystem::Extended:
|
|
|
|
return QObject::tr( "extended" );
|
|
|
|
case FileSystem::Unformatted:
|
|
|
|
return QObject::tr( "unformatted" );
|
|
|
|
case FileSystem::LinuxSwap:
|
2016-04-22 16:01:31 +02:00
|
|
|
return QObject::tr( "swap" );
|
2015-12-16 15:46:32 +01:00
|
|
|
case FileSystem::Fat16:
|
|
|
|
case FileSystem::Fat32:
|
|
|
|
case FileSystem::Ntfs:
|
|
|
|
case FileSystem::Xfs:
|
|
|
|
case FileSystem::Jfs:
|
|
|
|
case FileSystem::Hfs:
|
|
|
|
case FileSystem::Ufs:
|
|
|
|
case FileSystem::Hpfs:
|
|
|
|
case FileSystem::Luks:
|
|
|
|
case FileSystem::Ocfs2:
|
|
|
|
case FileSystem::Zfs:
|
|
|
|
case FileSystem::Nilfs2:
|
|
|
|
return FileSystem::nameForType( t ).toUpper();
|
|
|
|
case FileSystem::ReiserFS:
|
|
|
|
return "ReiserFS";
|
|
|
|
case FileSystem::Reiser4:
|
|
|
|
return "Reiser4";
|
|
|
|
case FileSystem::HfsPlus:
|
|
|
|
return "HFS+";
|
|
|
|
case FileSystem::Btrfs:
|
|
|
|
return "Btrfs";
|
|
|
|
case FileSystem::Exfat:
|
|
|
|
return "exFAT";
|
|
|
|
case FileSystem::Lvm2_PV:
|
|
|
|
return "LVM PV";
|
|
|
|
default:
|
|
|
|
return FileSystem::nameForType( t );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-06-30 15:03:29 +02:00
|
|
|
} // namespace
|