diff options
| -rw-r--r-- | configure.ac | 18 | ||||
| -rw-r--r-- | man/systemd-firstboot.xml | 10 | ||||
| -rw-r--r-- | src/basic/fs-util.c | 23 | ||||
| -rw-r--r-- | src/basic/khash.c | 2 | ||||
| -rw-r--r-- | src/hostname/hostnamed.c | 4 | ||||
| -rw-r--r-- | src/test/test-fs-util.c | 7 | 
6 files changed, 42 insertions, 22 deletions
| diff --git a/configure.ac b/configure.ac index 48c71ce340..b9143d28ca 100644 --- a/configure.ac +++ b/configure.ac @@ -601,6 +601,15 @@ AC_ARG_WITH([nobody-group],  AC_SUBST(NOBODY_GROUP_NAME)  AC_DEFINE_UNQUOTED(NOBODY_GROUP_NAME, ["$NOBODY_GROUP_NAME"], [The name of the nobody group (the one with GID 65534)]) +AC_ARG_WITH([fallback-hostname], +        AS_HELP_STRING([--with-fallback-hostname=NAME], +                [specify the hostname used if none configured]), +        [FALLBACK_HOSTNAME="$withval"], +        [FALLBACK_HOSTNAME=localhost]) + +AC_SUBST(FALLBACK_HOSTNAME) +AC_DEFINE_UNQUOTED(FALLBACK_HOSTNAME, ["$FALLBACK_HOSTNAME"], [The hostname used if none configured]) +  # ------------------------------------------------------------------------------  have_xz=no  AC_ARG_ENABLE(xz, AS_HELP_STRING([--disable-xz], [disable optional XZ support])) @@ -1715,12 +1724,13 @@ AC_MSG_RESULT([          Wheel group:                       ${have_wheel_group}          Debug shell:                       ${SUSHELL} @ ${DEBUGTTY}          TTY GID:                           ${TTY_GID} -        Maximum System UID:                ${SYSTEM_UID_MAX} -        Maximum System GID:                ${SYSTEM_GID_MAX} +        Maximum system UID:                ${SYSTEM_UID_MAX} +        Maximum system GID:                ${SYSTEM_GID_MAX}          Certificate root:                  ${CERTIFICATEROOT}          Support URL:                       ${SUPPORT_URL} -        Nobody User Name:                  ${NOBODY_USER_NAME} -        Nobody Group Name:                 ${NOBODY_GROUP_NAME} +        nobody user name:                  ${NOBODY_USER_NAME} +        nobody group name:                 ${NOBODY_GROUP_NAME} +        Fallback hostname:                 ${FALLBACK_HOSTNAME}          CFLAGS:   ${OUR_CFLAGS} ${CFLAGS}          CPPFLAGS: ${OUR_CPPFLAGS} ${CPPFLAGS} diff --git a/man/systemd-firstboot.xml b/man/systemd-firstboot.xml index 8cdc297a0e..539422ab98 100644 --- a/man/systemd-firstboot.xml +++ b/man/systemd-firstboot.xml @@ -63,8 +63,14 @@      <para><command>systemd-firstboot</command> initializes the most      basic system settings interactively on the first boot, or -    optionally non-interactively when a system image is created. The -    following settings may be set up:</para> +    optionally non-interactively when a system image is created. +    The service is started if <varname>ConditionFirstBoot=yes</varname> +    is satisfied. This essentially means that <filename>/etc</filename> +    is empty, see +    <citerefentry><refentrytitle>systemd.unit</refentrytitle><manvolnum>5</manvolnum></citerefentry> +    for details.</para> + +    <para>The following settings may be set up:</para>      <itemizedlist>        <listitem><para>The system locale, more specifically the two diff --git a/src/basic/fs-util.c b/src/basic/fs-util.c index e31fa2711a..8fe19ee4e4 100644 --- a/src/basic/fs-util.c +++ b/src/basic/fs-util.c @@ -723,6 +723,8 @@ int chase_symlinks(const char *path, const char *original_root, unsigned flags,                          return -errno;                  if (S_ISLNK(st.st_mode)) { +                        char *joined; +                          _cleanup_free_ char *destination = NULL;                          /* This is a symlink, in this case read the destination. But let's make sure we don't follow @@ -746,9 +748,6 @@ int chase_symlinks(const char *path, const char *original_root, unsigned flags,                                  if (fd < 0)                                          return -errno; -                                free_and_replace(buffer, destination); - -                                todo = buffer;                                  free(done);                                  /* Note that we do not revalidate the root, we take it as is. */ @@ -760,19 +759,17 @@ int chase_symlinks(const char *path, const char *original_root, unsigned flags,                                                  return -ENOMEM;                                  } -                        } else { -                                char *joined; +                        } -                                /* A relative destination. If so, this is what we'll prefix what's left to do with what -                                 * we just read, and start the loop again, but remain in the current directory. */ +                        /* Prefix what's left to do with what we just read, and start the loop again, +                         * but remain in the current directory. */ -                                joined = strjoin("/", destination, todo); -                                if (!joined) -                                        return -ENOMEM; +                        joined = strjoin("/", destination, todo); +                        if (!joined) +                                return -ENOMEM; -                                free(buffer); -                                todo = buffer = joined; -                        } +                        free(buffer); +                        todo = buffer = joined;                          continue;                  } diff --git a/src/basic/khash.c b/src/basic/khash.c index 9a2a3edb75..84648dc1c9 100644 --- a/src/basic/khash.c +++ b/src/basic/khash.c @@ -143,7 +143,7 @@ int khash_dup(khash *h, khash **ret) {          copy->fd = -1;          copy->algorithm = strdup(h->algorithm); -        if (!copy) +        if (!copy->algorithm)                  return -ENOMEM;          copy->fd = accept4(h->fd, NULL, 0, SOCK_CLOEXEC); diff --git a/src/hostname/hostnamed.c b/src/hostname/hostnamed.c index 74256e4444..4657cf8c77 100644 --- a/src/hostname/hostnamed.c +++ b/src/hostname/hostnamed.c @@ -283,7 +283,7 @@ static int context_update_kernel_hostname(Context *c) {          /* ... and the ultimate fallback */          else -                hn = "localhost"; +                hn = FALLBACK_HOSTNAME;          if (sethostname_idempotent(hn) < 0)                  return -errno; @@ -419,7 +419,7 @@ static int method_set_hostname(sd_bus_message *m, void *userdata, sd_bus_error *                  name = c->data[PROP_STATIC_HOSTNAME];          if (isempty(name)) -                name = "localhost"; +                name = FALLBACK_HOSTNAME;          if (!hostname_is_valid(name, false))                  return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Invalid hostname '%s'", name); diff --git a/src/test/test-fs-util.c b/src/test/test-fs-util.c index ae68587be9..4cb465d0d2 100644 --- a/src/test/test-fs-util.c +++ b/src/test/test-fs-util.c @@ -186,6 +186,13 @@ static void test_chase_symlinks(void) {          r = chase_symlinks(p, NULL, CHASE_NONEXISTENT, &result);          assert_se(r == -ENOENT); +        p = strjoina(temp, "/target"); +        q = strjoina(temp, "/top"); +        assert_se(symlink(q, p) >= 0); +        p = strjoina(temp, "/target/idontexist"); +        r = chase_symlinks(p, NULL, 0, &result); +        assert_se(r == -ENOENT); +          assert_se(rm_rf(temp, REMOVE_ROOT|REMOVE_PHYSICAL) >= 0);  } | 
