[users] Expand configuration-parsing for home-permissions

This commit is contained in:
Adriaan de Groot 2024-10-22 17:21:47 +02:00
parent 206dfce409
commit c9e9043e9d

View File

@ -928,6 +928,30 @@ tidy( QStringList& l )
l.removeDuplicates(); l.removeDuplicates();
} }
static QString
unscrambleYAML( const QVariant& v )
{
if ( Calamares::isIntegerVariantType( v ) )
{
// YAML takes a string like "0755" and makes it an integer **anyway**
const auto number = v.toLongLong();
if ( number < 0 )
{
return QString();
}
// Since YAML has parsed it as a decimal number,
// turn it back into the string representation of
// that decimal number, even though we intended it
// to be octal (e.g. "755" written down becomes
// seven-hundred-fifty-five, needs to be the string
// "755" again, even though we meant octal 755 which
// is four-hundred-ninety-three.
if ( number > 777 ) { return QString(); }
return QString::number( number );
}
return v.toString();
}
void void
Config::setConfigurationMap( const QVariantMap& configurationMap ) Config::setConfigurationMap( const QVariantMap& configurationMap )
{ {
@ -951,11 +975,12 @@ Config::setConfigurationMap( const QVariantMap& configurationMap )
const auto permissionKey = QStringLiteral( "home_permissions" ); const auto permissionKey = QStringLiteral( "home_permissions" );
if ( userSettings.contains( permissionKey ) ) if ( userSettings.contains( permissionKey ) )
{ {
const auto value = Calamares::getString( userSettings, permissionKey ); const auto value = unscrambleYAML( userSettings.value( permissionKey ) );
m_homeDirPermissions = Calamares::parseFileMode( value ); m_homeDirPermissions = Calamares::parseFileMode( value );
if ( m_homeDirPermissions < 0 ) if ( m_homeDirPermissions < 0 )
{ {
cWarning() << "Setting for" << permissionKey << '(' << value << userSettings[permissionKey] << ") is invalid."; cWarning() << "Setting for" << permissionKey << '(' << value << userSettings[ permissionKey ]
<< ") is invalid.";
} }
} }
else else