2020-11-11 12:39:56 +01:00
|
|
|
Copy also skeleton files from /usr/etc/skel (boo#1173321)
|
|
|
|
|
|
|
|
---
|
|
|
|
etc/useradd | 1 +
|
|
|
|
src/useradd.c | 37 +++++++++++++++++++++++++++++++++++++
|
|
|
|
2 files changed, 38 insertions(+)
|
|
|
|
|
2020-11-12 11:32:46 +01:00
|
|
|
Index: etc/useradd
|
|
|
|
===================================================================
|
|
|
|
--- etc/useradd.orig
|
|
|
|
+++ etc/useradd
|
2020-11-11 12:39:56 +01:00
|
|
|
@@ -5,4 +5,5 @@ INACTIVE=-1
|
|
|
|
EXPIRE=
|
|
|
|
SHELL=/bin/bash
|
|
|
|
SKEL=/etc/skel
|
|
|
|
+USRSKEL=/usr/etc/skel
|
|
|
|
CREATE_MAIL_SPOOL=yes
|
2020-11-12 11:32:46 +01:00
|
|
|
Index: src/useradd.c
|
|
|
|
===================================================================
|
|
|
|
--- src/useradd.c.orig
|
|
|
|
+++ src/useradd.c
|
2020-11-11 12:39:56 +01:00
|
|
|
@@ -78,6 +78,9 @@
|
|
|
|
#ifndef SKEL_DIR
|
|
|
|
#define SKEL_DIR "/etc/skel"
|
|
|
|
#endif
|
|
|
|
+#ifndef USRSKELDIR
|
|
|
|
+#define USRSKELDIR "/usr/etc/skel"
|
|
|
|
+#endif
|
|
|
|
#ifndef USER_DEFAULTS_FILE
|
|
|
|
#define USER_DEFAULTS_FILE "/etc/default/useradd"
|
|
|
|
#define NEW_USER_FILE "/etc/default/nuaddXXXXXX"
|
|
|
|
@@ -101,6 +104,7 @@ static const char *def_gname = "other";
|
|
|
|
static const char *def_home = "/home";
|
|
|
|
static const char *def_shell = "";
|
|
|
|
static const char *def_template = SKEL_DIR;
|
|
|
|
+static const char *def_usrtemplate = USRSKELDIR;
|
|
|
|
static const char *def_create_mail_spool = "no";
|
|
|
|
|
|
|
|
static long def_inactive = -1;
|
|
|
|
@@ -202,6 +206,7 @@ static bool home_added = false;
|
|
|
|
#define DINACT "INACTIVE="
|
|
|
|
#define DEXPIRE "EXPIRE="
|
|
|
|
#define DSKEL "SKEL="
|
|
|
|
+#define DUSRSKEL "USRSKEL="
|
|
|
|
#define DCREATE_MAIL_SPOOL "CREATE_MAIL_SPOOL="
|
|
|
|
|
|
|
|
/* local function prototypes */
|
|
|
|
@@ -469,6 +474,29 @@ static void get_defaults (void)
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
+ * Default Usr Skeleton information
|
|
|
|
+ */
|
|
|
|
+ else if (MATCH (buf, DUSRSKEL)) {
|
|
|
|
+ if ('\0' == *cp) {
|
|
|
|
+ cp = USRSKELDIR; /* XXX warning: const */
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ if(prefix[0]) {
|
|
|
|
+ size_t len;
|
|
|
|
+ int wlen;
|
|
|
|
+ char* _def_usrtemplate; /* avoid const warning */
|
|
|
|
+
|
|
|
|
+ len = strlen(prefix) + strlen(cp) + 2;
|
|
|
|
+ _def_usrtemplate = xmalloc(len);
|
|
|
|
+ wlen = snprintf(_def_usrtemplate, len, "%s/%s", prefix, cp);
|
|
|
|
+ assert (wlen == (int) len -1);
|
|
|
|
+ def_usrtemplate = _def_usrtemplate;
|
|
|
|
+ }
|
|
|
|
+ else {
|
|
|
|
+ def_usrtemplate = xstrdup (cp);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ /*
|
|
|
|
* Create by default user mail spool or not ?
|
|
|
|
*/
|
|
|
|
else if (MATCH (buf, DCREATE_MAIL_SPOOL)) {
|
|
|
|
@@ -500,6 +528,7 @@ static void show_defaults (void)
|
|
|
|
printf ("EXPIRE=%s\n", def_expire);
|
|
|
|
printf ("SHELL=%s\n", def_shell);
|
|
|
|
printf ("SKEL=%s\n", def_template);
|
|
|
|
+ printf ("USRSKEL=%s\n", def_usrtemplate);
|
|
|
|
printf ("CREATE_MAIL_SPOOL=%s\n", def_create_mail_spool);
|
|
|
|
}
|
|
|
|
|
|
|
|
@@ -526,6 +555,7 @@ static int set_defaults (void)
|
|
|
|
bool out_expire = false;
|
|
|
|
bool out_shell = false;
|
|
|
|
bool out_skel = false;
|
|
|
|
+ bool out_usrskel = false;
|
|
|
|
bool out_create_mail_spool = false;
|
|
|
|
size_t len;
|
|
|
|
int ret = -1;
|
|
|
|
@@ -620,6 +650,9 @@ static int set_defaults (void)
|
|
|
|
} else if (!out_skel && MATCH (buf, DSKEL)) {
|
|
|
|
fprintf (ofp, DSKEL "%s\n", def_template);
|
|
|
|
out_skel = true;
|
|
|
|
+ } else if (!out_usrskel && MATCH (buf, DUSRSKEL)) {
|
|
|
|
+ fprintf (ofp, DUSRSKEL "%s\n", def_usrtemplate);
|
|
|
|
+ out_usrskel = true;
|
|
|
|
} else if (!out_create_mail_spool
|
|
|
|
&& MATCH (buf, DCREATE_MAIL_SPOOL)) {
|
|
|
|
fprintf (ofp,
|
|
|
|
@@ -649,6 +682,8 @@ static int set_defaults (void)
|
|
|
|
fprintf (ofp, DSHELL "%s\n", def_shell);
|
|
|
|
if (!out_skel)
|
|
|
|
fprintf (ofp, DSKEL "%s\n", def_template);
|
|
|
|
+ if (!out_usrskel)
|
|
|
|
+ fprintf (ofp, DUSRSKEL "%s\n", def_usrtemplate);
|
|
|
|
|
|
|
|
if (!out_create_mail_spool)
|
|
|
|
fprintf (ofp, DCREATE_MAIL_SPOOL "%s\n", def_create_mail_spool);
|
2020-11-12 11:32:46 +01:00
|
|
|
@@ -2507,6 +2542,8 @@ int main (int argc, char **argv)
|
2020-11-11 12:39:56 +01:00
|
|
|
if (home_added) {
|
|
|
|
copy_tree (def_template, prefix_user_home, false, false,
|
|
|
|
(uid_t)-1, user_id, (gid_t)-1, user_gid);
|
2020-11-12 11:32:46 +01:00
|
|
|
+ copy_tree (def_usrtemplate, prefix_user_home, false, false,
|
|
|
|
+ (uid_t)-1, user_id, (gid_t)-1, user_gid);
|
2020-11-11 12:39:56 +01:00
|
|
|
} else {
|
2020-11-12 11:32:46 +01:00
|
|
|
fprintf (stderr,
|
|
|
|
_("%s: warning: the home directory %s already exists.\n"
|
|
|
|
Index: libmisc/copydir.c
|
|
|
|
===================================================================
|
|
|
|
--- libmisc/copydir.c.orig
|
|
|
|
+++ libmisc/copydir.c
|
|
|
|
@@ -416,6 +416,14 @@ static int copy_entry (const char *src,
|
|
|
|
old_uid, new_uid, old_gid, new_gid);
|
|
|
|
}
|
|
|
|
|
|
|
|
+ /*
|
|
|
|
+ * If the destination already exists do nothing.
|
|
|
|
+ * This is after the copy_dir above to still iterate into subdirectories.
|
|
|
|
+ */
|
|
|
|
+ if (LSTAT (dst, &sb) != -1) {
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
#ifdef S_IFLNK
|
|
|
|
/*
|
|
|
|
* Copy any symbolic links
|
|
|
|
@@ -477,6 +485,7 @@ static int copy_dir (const char *src, co
|
|
|
|
gid_t old_gid, gid_t new_gid)
|
|
|
|
{
|
|
|
|
int err = 0;
|
|
|
|
+ struct stat dst_sb;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Create a new target directory, make it owned by
|
|
|
|
@@ -488,6 +497,16 @@ static int copy_dir (const char *src, co
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
#endif /* WITH_SELINUX */
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * If the destination is already a directory, don't change it
|
|
|
|
+ * but copy into it (recursively).
|
|
|
|
+ */
|
|
|
|
+ if (LSTAT (dst, &dst_sb) == 0 && S_ISDIR(dst_sb.st_mode)) {
|
|
|
|
+ return (copy_tree (src, dst, false, reset_selinux,
|
|
|
|
+ old_uid, new_uid, old_gid, new_gid) != 0);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
if ( (mkdir (dst, statp->st_mode) != 0)
|
|
|
|
|| (chown_if_needed (dst, statp,
|
|
|
|
old_uid, new_uid, old_gid, new_gid) != 0)
|