Skip to content

Commit

Permalink
Mamalisz/fix chage shadow (#500)
Browse files Browse the repository at this point in the history
* Check shadow file inside the installChroot, not setupChroot
  • Loading branch information
MateuszMalisz authored and PawelWMS committed Dec 29, 2020
1 parent 153dedb commit 0abb891
Showing 1 changed file with 10 additions and 8 deletions.
18 changes: 10 additions & 8 deletions toolkit/tools/imagegen/installutils/installutils.go
Original file line number Diff line number Diff line change
Expand Up @@ -862,8 +862,9 @@ func addUsers(installChroot *safechroot.Chroot, users []configuration.User) (err
if !rootUserAdded {
logger.Log.Debugf("No root user entry found in config file. Setting root password to never expire.")

// Ignore updating if there is no shadow file to update
if exists, ferr := file.PathExists(shadowFile); ferr != nil {
// Ignore updating if there is no shadow file to update in the target image
installChrootShadowFile := filepath.Join(installChroot.RootDir(), shadowFile)
if exists, ferr := file.PathExists(installChrootShadowFile); ferr != nil {
logger.Log.Error("Error accessing shadow file.")
return ferr
} else if !exists {
Expand All @@ -887,10 +888,11 @@ func createUserWithPassword(installChroot *safechroot.Chroot, user configuration
)

var (
hashedPassword string
stdout string
stderr string
salt string
hashedPassword string
stdout string
stderr string
salt string
installChrootShadowFile = filepath.Join(installChroot.RootDir(), shadowFile)
)

// Get the hashed password for the user
Expand Down Expand Up @@ -926,7 +928,7 @@ func createUserWithPassword(installChroot *safechroot.Chroot, user configuration
logger.Log.Warnf("Ignoring UID for (%s) user, using default", rootUser)
}

if exists, ferr := file.PathExists(shadowFile); ferr != nil {
if exists, ferr := file.PathExists(installChrootShadowFile); ferr != nil {
logger.Log.Error("Error accessing shadow file.")
err = ferr
return
Expand Down Expand Up @@ -961,7 +963,7 @@ func createUserWithPassword(installChroot *safechroot.Chroot, user configuration
// Update password expiration
if user.PasswordExpiresDays != 0 {
// Ignore updating if there is no shadow file to update
if exists, ferr := file.PathExists(shadowFile); ferr != nil {
if exists, ferr := file.PathExists(installChrootShadowFile); ferr != nil {
logger.Log.Error("Error accessing shadow file.")
err = ferr
return
Expand Down

0 comments on commit 0abb891

Please sign in to comment.