users: Drop dependency on chfn. (#260)

Pass the full name directly to useradd instead, using the "-c" (comment)
parameter, which is "currently used as the field for the user's full
name" according to the documentation.

The chfn utility is no longer installed by default on current Fedora
releases due to its dependency on libuser. (They split out chfn and chsh
from util-linux into an optional subpackage.) It could be added as a
dependency of Calamares, but since it is needed inside the chroot, it
has to be on the base live image, not the overlay. Thus, to allow
testing Calamares with a simple "dnf install calamares" again, the
dependency needs to go away. And it is unnecessary anyway.
This commit is contained in:
Kevin Kofler 2016-09-16 07:55:04 +02:00 committed by Philip
parent 3edf1bb162
commit b6f8d6ae92

View File

@ -155,6 +155,8 @@ CreateUserJob::exec()
"-U", "-U",
"-G", "-G",
defaultGroups, defaultGroups,
"-c",
m_fullName,
m_userName } ); m_userName } );
if ( ec ) if ( ec )
return Calamares::JobResult::error( tr( "Cannot create user %1." ) return Calamares::JobResult::error( tr( "Cannot create user %1." )
@ -162,13 +164,6 @@ CreateUserJob::exec()
tr( "useradd terminated with error code %1." ) tr( "useradd terminated with error code %1." )
.arg( ec ) ); .arg( ec ) );
ec = CalamaresUtils::System::instance()->targetEnvCall( { "chfn", "-f", m_fullName, m_userName } );
if ( ec )
return Calamares::JobResult::error( tr( "Cannot set full name for user %1." )
.arg( m_userName ),
tr( "chfn terminated with error code %1." )
.arg( ec ) );
ec = CalamaresUtils::System::instance()-> ec = CalamaresUtils::System::instance()->
targetEnvCall( { "chown", targetEnvCall( { "chown",
"-R", "-R",