[systemd-commits] 2 commits - man/tmpfiles.d.xml src/tmpfiles.c TODO

Lennart Poettering lennart at kemper.freedesktop.org
Mon Jul 11 18:57:05 PDT 2011


 TODO               |   14 ++++----------
 man/tmpfiles.d.xml |    5 +++++
 src/tmpfiles.c     |   46 ++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 55 insertions(+), 10 deletions(-)

New commits:
commit ee17ee7c5cc22c286f943578918beaa78bbc86db
Author: Lennart Poettering <lennart at poettering.net>
Date:   Tue Jul 12 03:56:56 2011 +0200

    tmpfiles: allow creation of named pipes with tmpfiles

diff --git a/TODO b/TODO
index ff8ee5f..36a57f4 100644
--- a/TODO
+++ b/TODO
@@ -28,8 +28,6 @@ Features:
 
 * add conditions for file executability
 
-* allow creating fifos with tmpfiles
-
 * implement Register= switch in .socket units to enable registration
   in Avahi, RPC and other socket registration services.
 
diff --git a/man/tmpfiles.d.xml b/man/tmpfiles.d.xml
index abc74ef..7f4c45c 100644
--- a/man/tmpfiles.d.xml
+++ b/man/tmpfiles.d.xml
@@ -113,6 +113,11 @@ d    /run/user 0755 root root 10d</programlisting>
                                 </varlistentry>
 
                                 <varlistentry>
+                                        <term><varname>p</varname></term>
+                                        <listitem><para>Create a named pipe (FIFO) if it doesn't exist yet</para></listitem>
+                                </varlistentry>
+
+                                <varlistentry>
                                         <term><varname>x</varname></term>
                                         <listitem><para>Ignore a path
                                         during cleaning. Use this type
diff --git a/src/tmpfiles.c b/src/tmpfiles.c
index 4394f0d..feb2a21 100644
--- a/src/tmpfiles.c
+++ b/src/tmpfiles.c
@@ -56,6 +56,7 @@ enum {
         TRUNCATE_FILE = 'F',
         CREATE_DIRECTORY = 'd',
         TRUNCATE_DIRECTORY = 'D',
+        CREATE_FIFO = 'p',
 
         /* These ones take globs */
         IGNORE_PATH = 'x',
@@ -505,6 +506,48 @@ static int create_item(Item *i) {
                         }
 
                 break;
+
+        case CREATE_FIFO:
+
+                u = umask(0);
+                r = mkfifo(i->path, i->mode);
+                umask(u);
+
+                if (r < 0 && errno != EEXIST) {
+                        log_error("Failed to create fifo %s: %m", i->path);
+                        r = -errno;
+                        goto finish;
+                }
+
+                if (stat(i->path, &st) < 0) {
+                        log_error("stat(%s) failed: %m", i->path);
+                        r = -errno;
+                        goto finish;
+                }
+
+                if (!S_ISFIFO(st.st_mode)) {
+                        log_error("%s is not a fifo.", i->path);
+                        r = -EEXIST;
+                        goto finish;
+                }
+
+                if (i->mode_set)
+                        if (chmod(i->path, i->mode) < 0) {
+                                log_error("chmod(%s) failed: %m", i->path);
+                                r = -errno;
+                                goto finish;
+                        }
+
+                if (i->uid_set || i->gid_set)
+                        if (chown(i->path,
+                                   i->uid_set ? i->uid : (uid_t) -1,
+                                   i->gid_set ? i->gid : (gid_t) -1) < 0) {
+                                log_error("chown(%s) failed: %m", i->path);
+                                r = -errno;
+                                goto finish;
+                        }
+
+                break;
         }
 
         if ((r = label_fix(i->path, false)) < 0)
@@ -529,6 +572,7 @@ static int remove_item(Item *i, const char *instance) {
         case CREATE_FILE:
         case TRUNCATE_FILE:
         case CREATE_DIRECTORY:
+        case CREATE_FIFO:
         case IGNORE_PATH:
                 break;
 
@@ -562,6 +606,7 @@ static int remove_item_glob(Item *i) {
         case CREATE_FILE:
         case TRUNCATE_FILE:
         case CREATE_DIRECTORY:
+        case CREATE_FIFO:
         case IGNORE_PATH:
                 break;
 
@@ -689,6 +734,7 @@ static int parse_line(const char *fname, unsigned line, const char *buffer) {
             i->type != TRUNCATE_FILE &&
             i->type != CREATE_DIRECTORY &&
             i->type != TRUNCATE_DIRECTORY &&
+            i->type != CREATE_FIFO &&
             i->type != IGNORE_PATH &&
             i->type != REMOVE_PATH &&
             i->type != RECURSIVE_REMOVE_PATH) {

commit 97f73ffb04947acf0a5854e3a7bdbb7a0105f6fa
Author: Lennart Poettering <lennart at poettering.net>
Date:   Tue Jul 12 03:42:44 2011 +0200

    update TODO

diff --git a/TODO b/TODO
index 2bade7b..ff8ee5f 100644
--- a/TODO
+++ b/TODO
@@ -20,6 +20,10 @@ F15 External:
 
 Features:
 
+* logind: spawn user at ..service on login
+
+* logind: implement shutdown service
+
 * possibly apply systemd-sysctl per network device subtrees on hotplug
 
 * add conditions for file executability
@@ -37,8 +41,6 @@ Features:
 
 * make sure systemd-ask-password-wall does not shutdown systemd-ask-password-console too early
 
-* add loginctl, i.e. a systemctl for logind introspection
-
 * support presets
 
 * kernel: add /proc/sys file exposing CAP_LAST_CAP?
@@ -70,8 +72,6 @@ Features:
 
 * detect LXC with $container=lxc
 
-* add prefix match to sysctl, tmpfiles, ...
-
 * drop /.readahead on bigger upgrades with yum
 
 * add inode stat() check to readahead to suppress preloading changed files
@@ -206,10 +206,6 @@ Features:
   be killed very late after the rootfs is read only? If implement pass
   this to shutdown binary via command line argument.
 
-* use pivot_root on shutdown so that we can unmount the root directory.
-   - copy binaries to, and pivot_root() to the "shutdown tmpfs"
-   - solve "mdadm --wait-clean" problem that way
-
 * dot output for --test showing the 'initial transaction'
 
 * calendar time support in timer, iCalendar semantics for the timer stuff (RFC2445)



More information about the systemd-commits mailing list