Add mount and chrootCall utilities to libcalamares + Python wrappers.
This commit is contained in:
parent
e3a333e6e6
commit
63534f7154
@ -22,6 +22,7 @@ set( libSources
|
|||||||
kdsingleapplicationguard/kdlockedsharedmemorypointer.cpp
|
kdsingleapplicationguard/kdlockedsharedmemorypointer.cpp
|
||||||
|
|
||||||
utils/CalamaresUtils.cpp
|
utils/CalamaresUtils.cpp
|
||||||
|
utils/CalamaresUtilsSystem.cpp
|
||||||
utils/Logger.cpp
|
utils/Logger.cpp
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -27,13 +27,22 @@
|
|||||||
|
|
||||||
#undef slots
|
#undef slots
|
||||||
#include <boost/python.hpp>
|
#include <boost/python.hpp>
|
||||||
|
#include <boost/python/args.hpp>
|
||||||
|
|
||||||
#include "PythonJobApi.h"
|
#include "PythonJobApi.h"
|
||||||
|
|
||||||
|
|
||||||
namespace bp = boost::python;
|
namespace bp = boost::python;
|
||||||
|
|
||||||
|
BOOST_PYTHON_FUNCTION_OVERLOADS( mount_overloads,
|
||||||
|
CalamaresPython::mount,
|
||||||
|
2, 4 );
|
||||||
|
BOOST_PYTHON_FUNCTION_OVERLOADS( chroot_call_str_overloads,
|
||||||
|
CalamaresPython::chroot_call,
|
||||||
|
1, 3 );
|
||||||
|
BOOST_PYTHON_FUNCTION_OVERLOADS( chroot_call_list_overloads,
|
||||||
|
CalamaresPython::chroot_call,
|
||||||
|
1, 3 );
|
||||||
BOOST_PYTHON_MODULE( libcalamares )
|
BOOST_PYTHON_MODULE( libcalamares )
|
||||||
{
|
{
|
||||||
bp::scope().attr( "ORGANIZATION_NAME" ) = CALAMARES_ORGANIZATION_NAME;
|
bp::scope().attr( "ORGANIZATION_NAME" ) = CALAMARES_ORGANIZATION_NAME;
|
||||||
@ -42,8 +51,6 @@ BOOST_PYTHON_MODULE( libcalamares )
|
|||||||
bp::scope().attr( "VERSION" ) = CALAMARES_VERSION;
|
bp::scope().attr( "VERSION" ) = CALAMARES_VERSION;
|
||||||
bp::scope().attr( "VERSION_SHORT" ) = CALAMARES_VERSION_SHORT;
|
bp::scope().attr( "VERSION_SHORT" ) = CALAMARES_VERSION_SHORT;
|
||||||
|
|
||||||
bp::def( "debug", &CalamaresPython::debug );
|
|
||||||
|
|
||||||
bp::class_< CalamaresPython::PythonJobInterface >( "Job", bp::init< Calamares::PythonJob* >() )
|
bp::class_< CalamaresPython::PythonJobInterface >( "Job", bp::init< Calamares::PythonJob* >() )
|
||||||
.def_readonly( "module_name", &CalamaresPython::PythonJobInterface::moduleName )
|
.def_readonly( "module_name", &CalamaresPython::PythonJobInterface::moduleName )
|
||||||
.def_readonly( "pretty_name", &CalamaresPython::PythonJobInterface::prettyName )
|
.def_readonly( "pretty_name", &CalamaresPython::PythonJobInterface::prettyName )
|
||||||
@ -58,6 +65,51 @@ BOOST_PYTHON_MODULE( libcalamares )
|
|||||||
.def( "keys", &Calamares::GlobalStorage::python_keys )
|
.def( "keys", &Calamares::GlobalStorage::python_keys )
|
||||||
.def( "remove", &Calamares::GlobalStorage::python_remove )
|
.def( "remove", &Calamares::GlobalStorage::python_remove )
|
||||||
.def( "value", &Calamares::GlobalStorage::python_value );
|
.def( "value", &Calamares::GlobalStorage::python_value );
|
||||||
|
|
||||||
|
// libcalamares.utils submodule starts here
|
||||||
|
bp::object submodule( bp::borrowed( PyImport_AddModule( "utils" ) ) );
|
||||||
|
bp::scope().attr( "utils" ) = submodule;
|
||||||
|
bp::scope utilsScope = submodule;
|
||||||
|
Q_UNUSED( utilsScope );
|
||||||
|
|
||||||
|
bp::def( "debug", &CalamaresPython::debug );
|
||||||
|
bp::def( "mount",
|
||||||
|
&CalamaresPython::mount,
|
||||||
|
mount_overloads( bp::args( "device_path",
|
||||||
|
"mount_point",
|
||||||
|
"filesystem_name",
|
||||||
|
"options" ),
|
||||||
|
"Runs the mount utility with the specified parameters.\n"
|
||||||
|
"Returns the program's exit code, or:\n"
|
||||||
|
"-1 = QProcess crash\n"
|
||||||
|
"-2 = QProcess cannot start\n"
|
||||||
|
"-3 = bad arguments" ) );
|
||||||
|
bp::def( "chroot_call",
|
||||||
|
static_cast< int (*)( const std::string&,
|
||||||
|
const std::string&,
|
||||||
|
int ) >( &CalamaresPython::chroot_call ),
|
||||||
|
chroot_call_str_overloads( bp::args( "command",
|
||||||
|
"stdin",
|
||||||
|
"timeout" ),
|
||||||
|
"Runs the specified command in the chroot of the target system.\n"
|
||||||
|
"Returns the program's exit code, or:\n"
|
||||||
|
"-1 = QProcess crash\n"
|
||||||
|
"-2 = QProcess cannot start\n"
|
||||||
|
"-3 = bad arguments\n"
|
||||||
|
"-4 = QProcess timeout" ) );
|
||||||
|
bp::def( "chroot_call",
|
||||||
|
static_cast< int (*)( const bp::list&,
|
||||||
|
const std::string&,
|
||||||
|
int ) >( &CalamaresPython::chroot_call ),
|
||||||
|
chroot_call_list_overloads( bp::args( "args",
|
||||||
|
"stdin",
|
||||||
|
"timeout" ),
|
||||||
|
"Runs the specified command in the chroot of the target system.\n"
|
||||||
|
"Returns the program's exit code, or:\n"
|
||||||
|
"-1 = QProcess crash\n"
|
||||||
|
"-2 = QProcess cannot start\n"
|
||||||
|
"-3 = bad arguments\n"
|
||||||
|
"-4 = QProcess timeout" ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -20,12 +20,57 @@
|
|||||||
|
|
||||||
#include "PythonHelper.h"
|
#include "PythonHelper.h"
|
||||||
#include "utils/Logger.h"
|
#include "utils/Logger.h"
|
||||||
|
#include "utils/CalamaresUtilsSystem.h"
|
||||||
|
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
|
|
||||||
|
#undef slots
|
||||||
|
#include <boost/python/extract.hpp>
|
||||||
|
|
||||||
|
|
||||||
namespace CalamaresPython
|
namespace CalamaresPython
|
||||||
{
|
{
|
||||||
|
|
||||||
|
int
|
||||||
|
mount( const std::string& device_path,
|
||||||
|
const std::string& mount_point,
|
||||||
|
const std::string& filesystem_name,
|
||||||
|
const std::string& options )
|
||||||
|
{
|
||||||
|
return CalamaresUtils::mount( QString::fromStdString( device_path ),
|
||||||
|
QString::fromStdString( mount_point ),
|
||||||
|
QString::fromStdString( filesystem_name ),
|
||||||
|
QString::fromStdString( options ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
chroot_call( const std::string& command,
|
||||||
|
const std::string& stdin,
|
||||||
|
int timeout )
|
||||||
|
{
|
||||||
|
return CalamaresUtils::chrootCall( QString::fromStdString( command ),
|
||||||
|
QString::fromStdString( stdin ),
|
||||||
|
timeout );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int
|
||||||
|
chroot_call( const boost::python::list& args,
|
||||||
|
const std::string& stdin,
|
||||||
|
int timeout )
|
||||||
|
{
|
||||||
|
QStringList list;
|
||||||
|
for ( int i = 0; i < boost::python::len( args ); ++i )
|
||||||
|
{
|
||||||
|
list.append( QString::fromStdString(
|
||||||
|
boost::python::extract< std::string >( args[ i ] ) ) );
|
||||||
|
}
|
||||||
|
return CalamaresUtils::chrootCall( list.join( ' ' ),
|
||||||
|
QString::fromStdString( stdin ),
|
||||||
|
timeout );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
debug( const std::string& s )
|
debug( const std::string& s )
|
||||||
@ -51,4 +96,5 @@ PythonJobInterface::setprogress( qreal progress )
|
|||||||
m_parent->emitProgress( progress );
|
m_parent->emitProgress( progress );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,19 @@
|
|||||||
namespace CalamaresPython
|
namespace CalamaresPython
|
||||||
{
|
{
|
||||||
|
|
||||||
|
int mount( const std::string& device_path,
|
||||||
|
const std::string& mount_point,
|
||||||
|
const std::string& filesystem_name = std::string(),
|
||||||
|
const std::string& options = std::string() );
|
||||||
|
|
||||||
|
int chroot_call( const std::string& command,
|
||||||
|
const std::string& stdin = std::string(),
|
||||||
|
int timeout = 0 );
|
||||||
|
|
||||||
|
int chroot_call( const boost::python::list& args,
|
||||||
|
const std::string& stdin = std::string(),
|
||||||
|
int timeout = 0 );
|
||||||
|
|
||||||
void debug( const std::string& s );
|
void debug( const std::string& s );
|
||||||
|
|
||||||
class PythonJobInterface
|
class PythonJobInterface
|
||||||
|
95
src/libcalamares/utils/CalamaresUtilsSystem.cpp
Normal file
95
src/libcalamares/utils/CalamaresUtilsSystem.cpp
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Teo Mrnjavac <teo@kde.org>
|
||||||
|
*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "CalamaresUtilsSystem.h"
|
||||||
|
|
||||||
|
#include "JobQueue.h"
|
||||||
|
#include "GlobalStorage.h"
|
||||||
|
|
||||||
|
#include <QDir>
|
||||||
|
#include <QProcess>
|
||||||
|
|
||||||
|
namespace CalamaresUtils
|
||||||
|
{
|
||||||
|
|
||||||
|
int mount( const QString& devicePath,
|
||||||
|
const QString& mountPoint,
|
||||||
|
const QString& filesystemName,
|
||||||
|
const QString& options )
|
||||||
|
{
|
||||||
|
if ( devicePath.isEmpty() || mountPoint.isEmpty() )
|
||||||
|
return -3;
|
||||||
|
|
||||||
|
QDir mountPointDir( mountPoint );
|
||||||
|
if ( !mountPointDir.exists() )
|
||||||
|
{
|
||||||
|
bool ok = mountPointDir.mkpath( mountPoint );
|
||||||
|
if ( !ok )
|
||||||
|
return -3;
|
||||||
|
}
|
||||||
|
|
||||||
|
QString program( "mount" );
|
||||||
|
QStringList args = { devicePath, mountPoint };
|
||||||
|
|
||||||
|
if ( !filesystemName.isEmpty() )
|
||||||
|
args << "-t" << filesystemName;
|
||||||
|
|
||||||
|
if ( !options.isEmpty() )
|
||||||
|
args << "-o" << options;
|
||||||
|
|
||||||
|
return QProcess::execute( program, args );
|
||||||
|
}
|
||||||
|
|
||||||
|
int chrootCall( const QString& command,
|
||||||
|
const QString& stdInput,
|
||||||
|
int timeoutSec )
|
||||||
|
{
|
||||||
|
Calamares::GlobalStorage* gs = Calamares::JobQueue::instance()->globalStorage();
|
||||||
|
if ( !gs->contains( "rootMountPoint" ) )
|
||||||
|
return -3;
|
||||||
|
|
||||||
|
QString destDir = gs->value( "rootMountPoint" ).toString();
|
||||||
|
if ( !QDir( destDir ).exists() )
|
||||||
|
return -3;
|
||||||
|
|
||||||
|
QString program( "chroot" );
|
||||||
|
QStringList args = { destDir, command };
|
||||||
|
|
||||||
|
QProcess process;
|
||||||
|
process.setProgram( program );
|
||||||
|
process.setArguments( args );
|
||||||
|
|
||||||
|
if ( !process.waitForStarted() )
|
||||||
|
return -2;
|
||||||
|
|
||||||
|
if ( !stdInput.isEmpty() )
|
||||||
|
{
|
||||||
|
process.write( stdInput.toLocal8Bit() );
|
||||||
|
process.closeWriteChannel();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !process.waitForFinished( timeoutSec ? ( timeoutSec * 1000 ) : 30000 ) )
|
||||||
|
return -4;
|
||||||
|
|
||||||
|
if ( process.exitStatus() == QProcess::CrashExit )
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return process.exitCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
52
src/libcalamares/utils/CalamaresUtilsSystem.h
Normal file
52
src/libcalamares/utils/CalamaresUtilsSystem.h
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
/* === This file is part of Calamares - <http://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Teo Mrnjavac <teo@kde.org>
|
||||||
|
*
|
||||||
|
* 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/>.
|
||||||
|
*/
|
||||||
|
#ifndef CALAMARESUTILSSYSTEM_H
|
||||||
|
#define CALAMARESUTILSSYSTEM_H
|
||||||
|
|
||||||
|
#include "DllMacro.h"
|
||||||
|
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
namespace CalamaresUtils
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Runs the mount utility with the specified parameters.
|
||||||
|
* @returns the program's exit code, or:
|
||||||
|
* -1 = QProcess crash
|
||||||
|
* -2 = QProcess cannot start
|
||||||
|
* -3 = bad arguments
|
||||||
|
*/
|
||||||
|
DLLEXPORT int mount( const QString& devicePath,
|
||||||
|
const QString& mountPoint,
|
||||||
|
const QString& filesystemName = QString(),
|
||||||
|
const QString& options = QString() );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs the specified command in the chroot of the target system.
|
||||||
|
* @returns the program's exit code, or:
|
||||||
|
* -1 = QProcess crash
|
||||||
|
* -2 = QProcess cannot start
|
||||||
|
* -3 = bad arguments
|
||||||
|
* -4 = QProcess timeout
|
||||||
|
*/
|
||||||
|
DLLEXPORT int chrootCall( const QString& command,
|
||||||
|
const QString& stdInput = QString(),
|
||||||
|
int timeoutSec = 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // CALAMARESUTILSSYSTEM_H
|
Loading…
Reference in New Issue
Block a user