TODO revision edb2935c5c5b95c42b8679086f60da5eafad74cb
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* enabling an instance unit creates a pointless link, and
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots the unit will be started with getty@getty.service:
63d012ee193ba8c768b2a2aade99081422759213Luke Smith $ systemctl enable getty@.service
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots ln -s '/usr/lib/systemd/system/getty@.service' '/etc/systemd/system/getty.target.wants/getty@.service'
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Dangling symlinks of .automount unit files in .wants/ directories, set up
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots automount points even when the original .automount file did not exist
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots anymore. Only the .mount unit was still around.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* properly handle .mount unit state tracking when two mount points are stacked one on top of another on the exact same mount point.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* shorten the message to sane length:
cb4f4f79feb7498d1f3406b88fb62209e5f5a444Adam Moore Cannot add dependency job for unit display-manager.service, ignoring: Unit display-manager.service failed to load: No such file or directory. See system logs and 'systemctl status display-manager.service' for details.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* systemctl --root=container/ set-default ... is totally borked.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Fedora: when installing fedora with yum --installroot /var/run is a directory, not a symlink
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots https://bugzilla.redhat.com/show_bug.cgi?id=975864
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Fedora: add an rpmlint check that verifies that all unit files in the RPM are listed in %systemd_post macros.
63d012ee193ba8c768b2a2aade99081422759213Luke Smith* Fedora: post FPC ticket to move add %tmpfiles_create to the packaging guidelines
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* add bus api to query unit file's X fields.
63d012ee193ba8c768b2a2aade99081422759213Luke Smith* consider adding RuntimeDirectoryUser= + RuntimeDirectoryGroup=
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* sd-event: define more intervals where we will shift wakeup intervals around in, 1h, 6h, 24h, ...
63d012ee193ba8c768b2a2aade99081422759213Luke Smith* maybe add DefaultTimerAccuracySec= as global config option to set AccuracySec='s default value in .timer units
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* mount /sys/fs/cgroup read-only (but leave the subdirs writable)
63d012ee193ba8c768b2a2aade99081422759213Luke Smith* gpt-auto-generator:
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith - Support LUKS for root devices
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith - Define new partition type for encrypted swap? Support probed LUKS for encrypted swap?
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith - Make /home automount rather than mount?
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* improve journalctl performance by loading journal files
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots lazily. Encode just enough information in the file name, so that we
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots don't have to open it to know that it is not interesting for us, for
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots the most common operations.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* support transient mount units
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Imply DevicePolicy=closed when PrivateDevices= is used
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* add an "input" group to udev logic and add all input devices to it
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* libsystemd-login: implement getpeer_unit(), get_peer_slice(), ...
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* machined: provide calls GetMachineByAddress() on the manager
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots interface to get the machine for a local IP address, and
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots GetAddress() on the Machine interface to get the Address for a
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots machine. Implement via forking off child process which quickly joins
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots the cotnainer and passes data to parent. Show this in "machinectl
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots status", and use it to implement NSS module to provide automatic
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith name resolution for containers.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* add generator that pulls in systemd-network from containers when
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots CAP_NET_ADMIN is set, more than the loopback device is defined, even
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots when it is otherwise off
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* MessageQueueMessageSize= and RLimitFSIZE= (and suchlike) should use parse_iec_size().
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* "busctl status" works only as root on dbus1, since we cannot read
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* systemctl (and possibly related tools): support a new switch that
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith allows enumerating units in local containers recursively. "systemctl
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots list-units -R" or so should not only lists on the host, but also the
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots services in all containers in a pretty way, to give an overview of
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots the entire system.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* implement Distribute= in socket units to allow running multiple
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots service instances processing the listening socket, and open this up
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots for ReusePort=
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* socket units: support creating sockets in different namespace,
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots opening it up for JoinsNamespaceOf=. This would require to fork off
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots a tiny process that joins the namespace and creates/binds the socket
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots and passes this back to PID1 via SCM_RIGHTS. This also could be used
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots to allow Chown/chgrp on sockets without requiring NSS in PID 1.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* New service property: maximum CPU and wallclock runtime for a service
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* introduce bus call FreezeUnit(s, b), as well as "systemctl freeze
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots $UNIT" and "systemctl thaw $UNIT" as wrappers around this. The calls
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots should SIGSTOP all unit processes in a loop until all processes of
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots it are fully stopped. This can later be used for app management by
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots desktop UIs such as gnome-shell to freeze apps that are not visible
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots on screen, not unlike how job control works on the shell
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* completions:
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - busctl zsh completion is outdated
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - systemd-nspawn -Z/-L/-q is missing for zsh
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - manager property enumeration was broken when systemd moved to /usr/lib/
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - implement per-slice CPUFairScheduling=1 switch
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - handle jointly mounted controllers correctly
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - introduce high-level settings for RT budget, swappiness
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - how to reset dynamically changed unit cgroup attributes sanely?
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - when reloading configuration, apply new cgroup configuration
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - when recursively showing the cgroup hierarchy, optionally also show
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots the hierarchies of child processes
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* transient units:
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - allow creating auxiliary units with the same call
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - add field to transient units that indicate whether systemd or somebody else saves/restores its settings, for integration with libvirt
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - ensure scope units may be started only a single time
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Automatically configure swap partition to use for hibernation by looking for largest swap partition on the root disk?
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* when we detect low battery and no AC on boot, show pretty splash and refuse boot
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* machined, localed: when we try to kill an empty cgroup, generate an ESRCH error over the bus
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* libsystemd-journal, libsystemd-login, libudev: add calls to easily attach these objects to sd-event event loops
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* be more careful what we export on the bus as (usec_t) 0 and (usec_t) -1
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* unify dispatch table in systemctl_main() and friends
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* Automatically configure swap partition to use for hibernation by looking for largest swap partition on the root disk?
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* socket-proxyd: Use sd-resolve to resolve the server address
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* rfkill,backlight: we probably should run the load tools inside of the udev rules so that the state is properly initialized by the time other software sees it
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* After coming back from hibernation reset hibernation swap partition using the /dev/snapshot ioctl APIs
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* If we try to find a unit via a dangling symlink, generate a clean
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith error. Currently, we just ignore it and read the unit from the search
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith path anyway.
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* refuse boot if /etc/os-release is missing or /etc/machine-id cannot be set up
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* given that logind now lets PID 1 do all nasty work, we can
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith probably reduce the capability set it retains substantially.
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith (we need CAP_SYS_ADMIN for drmSetMaster(), so maybe not worth it)
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* btrfs raid assembly: some .device jobs stay stuck in the queue
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* make sure gdm doesn't use multi-user-x but the new default X configuration file, and then remove multi-user-x from systemd
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* man: the documentation of Restart= currently is very misleading and suggests the tools from ExecStartPre= might get restarted.
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* load .d/*.conf dropins for device units
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith* gparted needs to disable auto-activation of mount units somehow, or
37afd8be00b8e92463a3fdcaa6fc1b2809b8256eLuke Smith maybe we should stop doing auto-activation of this after boot
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots entirely. https://bugzilla.gnome.org/show_bug.cgi?id=701676
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots Maybe take a BSD lock at the disk device node and teach udev to
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots check for that and suppress event handling.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* allow implementation of InaccessibleDirectories=/ plus
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots ReadOnlyDirectories=... for whitelisting files for a service.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - when kdbus doesn't take our message without memfds, try again with memfds
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - implement monitor logic
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - see if we can drop more message validation on the sending side
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - add API to clone sd_bus_message objects
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - systemd-bus-proxyd needs to enforce good old XML policy
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - upload minimal kdbus policy into the kernel at boot
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - kdbus: matches against source or destination pids for an "strace -p"-like feel. Problem: The PID info needs to be available in userspace too...
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - longer term: priority inheritance
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - check sender of response messages
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - dbus spec updates:
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - kdbus mapping
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - "const" properties (posted)
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - path escaping
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - port exit-on-idle logic to byebye ioctl
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - update systemd.special(7) to mention that dbus.socket is only about the compatibility socket now
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - allow updating attach flags during runtime
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - pid1: peek into activating message when activating a service
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - test bloom filter generation indexes
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - introduce sd_bus_emit_object_added()/sd_bus_emit_object_removed() that automatically includes the build-in interfaces in the list
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - port to sd-resolve for connecting to TCP dbus servers
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - constructors for bus messages should probably not be OK with a NULL bus pointer
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - .busname units should not use get_user_creds()/get_cgroup_creds() but instead do NSS only in temporarily forked off child
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - allow multiple signal handlers per signal?
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* in the final killing spree, detect processes from the root directory, and
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots complain loudly if they have argv[0][0] == '@' set.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots https://bugzilla.redhat.com/show_bug.cgi?id=961044
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* investigate endianness issues of UUID vs. GUID
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* dbus: when a unit failed to load (i.e. is in UNIT_ERROR state), we
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots should be able to safely try another attempt when the bus call LoadUnit() is invoked.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* add a pam module that passes the hdd passphrase into the PAM stack and then expires it, for usage by gdm auto-login.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* add a pam module that on password changes updates any LUKS slot where the password matches
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* maybe add a generator that looks for "systemd.run=" on the kernel cmdline for container usercases...
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* timedatctl, localectl: possibly make some commands work without the daemon, for chroot situations...
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* timedatectl: print a nicer message when enabling ntp fails because ntpd/chrony are not installed
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* cgtop: make cgtop useful in a container
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - add 'set -e' to scripts in test/
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots - make stuff in test/ work with separate output dir
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* systemctl delete x.snapshot leaves no trace in logs (at least at default level).
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* make the coredump collector tool move itself into the user's cgroup
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots so that the coredump is properly written to the user's own journal
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* seems that when we follow symlinks to units we prefer the symlink
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots destination path over /etc and /usr. We shouldn't do that. Instead
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots /etc should always override /run+/usr and also any symlink
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots destination.
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* when isolating, try to figure out a way how we implicitly can order
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots all units we stop before the isolating unit...
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* teach ConditionKernelCommandLine= globs or regexes (in order to match foobar={no,0,off})
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* after all byte-wise realloc() is slow, even on glibc, so i guess we
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots need manual exponential loops after all
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots* BootLoaderSpec: drop allowing ext234 for $BOOT. Clarify that the
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots kernel has to be in $BOOT. Clarify that the boot loader should be
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots installed to the ESP. Define a way how an installer can figure out
85e08d7420a5c71ffdd9517a3179d29b9a32b1dfTodd Kloots whether a BLS compliant boot loader is installed.
* systemd-inhibit: make taking delay locks useful: support sending SIGINT or SIGTERM on PrepareForSleep()
* journal-or-kmsg is currently broken? See reverted commit 4a01181e460686d8b4a543b1dfa7f77c9e3c5ab8.
* remove any syslog support from log.c -- we probably can't do this before split-off udev is gone for good
* think about window-manager-run-as-user-service problem: exit 0 → activate shutdown.target; exit != 0 → restart service
* timedate: have global on/off switches for auto-time (NTP), and auto-timezone that connman can subscribe to.
- change bootctl to be backed by systemd-bootd to control temporary and persistent default boot goal plus efi variables
* fstab: add new mount option x-systemd-after=/foobar/waldo to allow manual dependencies to other mount points
* print a nicer explanation if people use variable/specifier expansion in ExecStart= for the first word
* mount: turn dependency information from /proc/self/mountinfo into dependency information between systemd units.
- logind: optionally, ignore idle-hint logic for autosuspend, block suspend as long as a session is around
- When we update the kernel all kind of hibernation should be prohibited until shutdown/reboot
- logind: wakelock/opportunistic suspend support
- we should probably handle SIGTERM/SIGINT to not leave dot files around, just in case
- session scopes/user unit: add RequiresMountsFor for the home directory of the user
- add Suspend() bus calls which take timestamps to fix double suspend issues when somebody hits suspend and closes laptop quickly.
* exec: when deinitializating a tty device fix the perms and group, too, not only when initializing. Set access mode/gid to 0620/tty.
- journal: when waiting for journal additions in the client always sleep at least 1s or so, in order to minimize wakeups
- add API to close/reopen/get fd for journal client fd in libsystemd-journal.
- fallback to /dev/log based logging in libsystemd-journal, if we can't log natively?
- check if we can make journalctl by default use --follow mode inside of less if called without args?
- journal: add a setgid "systemd-journal" utility to invoke from libsystemd-journal, which passes fds via STDOUT and does PK access
- journactl: support negative filtering, i.e. FOOBAR!="waldo",
- journal: send out marker messages every now and then, and immediately sync with fdatasync() afterwards, in order to have hourly guaranteed syncs.
- journal-send.c, log.c: when the log socket is clogged, and we drop, count this and write a message about this when it gets unclogged again.
- journal: sanely deal with entries which are larger than the individual file size, but where the components would fit
- tmpfiles: when applying ownership to /run/log/journal, also do this for the journal fails contained in it
- man: clarify that time-sync.target is not only sysv compat but also useful otherwise. Same for similar targets
- add a man page containing packaging guidelines and recommending usage of things like Documentation=, PrivateTmp=, PrivateNetwork= and ReadOnlyDirectories=/etc /usr.
- document systemd-journal-flush.service properly
- documentation: recommend to connect the timer units of a service to the service via Also= in [Install]
- man: extend runlevel(8) to mention that runlevels suck, and are dead. Maybe add runlevel(7) with a note about that too
- print nice message from systemctl --failed if there are no entries shown, and hook that into ExecStartPre of rescue.service/emergency.service
- add new command to systemctl: "systemctl system-reexec" which reexecs as many daemons as virtually possible
- systemctl enable: improve the success messages (i.e. more human readable, less shell-like)
- systemctl enable: fail if target to alias into doesn't exist? maybe show how many units are enabled afterwards?
- systemctl list-unit-files should list generated files (and probably with a new state "generated" for them, or so)
* introduce ntp.service (or suchlike) as symlink that is used to arbitrate between various NTP implementations
* deal with sendmail/postfix exclusivity
- when parsing calendar timestamps support the UTC timezone (even if we won't support arbitrary timezone specs, support UTC itself certainly makes sense), also support syntaxes such as +0200
- DST/timezone changes && ntp is active && RTC-in-localtime (never do it without ntp)
logs-show.c. Alternatively: use libelfutil, which seems to be the
* If we show an error about a unit (such as not showing up) and it has no Description string, then show a description string generated form the reverse of unit_name_mangle().
* clean up date formatting and parsing so that all absolute/relative timestamps we format can also be parsed
* on shutdown: move utmp, wall, audit logic all into PID 1 (or logind?), get rid of systemd-update-utmp-runlevel
- instructions shipped by packages and stored in /usr/lib/
* hostnamed: before returning information from /etc/machine-info.conf check the modification data and reread. Similar for localed, ...
* currently x-systemd.timeout is lost in the initrd, since crypttab is copied into dracut, but fstab isn't
- nspawn: make it work for dwalsh and shared /usr containers -- tmpfs mounts as command line parameters
- refuses to boot containers without /etc/machine-id (OK?), and with empty /etc/machine-id (not OK).
- generate predictable mac addresses for the netdev we create (host0), maybe based on guest's machine
- support rd.luks.allow-discards= kernel cmdline params in cryptsetup generator
* after deserializing sockets in socket.c we should reapply sockopts and things
* come up with a nice way to write queue/read_ahead_kb for a block device without interfering with readahead
* move PID 1 segfaults to /var/lib/systemd/coredump?
* create /sbin/init symlinks from the build system
* properly handle loop back mounts via fstab, especially regards to fsck/passno
* initialize the hostname from the fs label of /, if /etc/hostname does not exist?
* when breaking cycles drop sysv services first, then services from /run, then from /etc, then from /usr
* ExecOnFailure=/usr/bin/foo
- remove src/udev/udev-builtin-firmware.c (CONFIG_FW_LOADER_USER_HELPER=n)
- add trigger --subsystem-match=usb/usb_device device
* when a service has the same env var set twice we actually store it twice and return that in systemctl show -p... We should only show the last setting
* add option to sockets to avoid activation. Instead just drop packets/connections, see http://cyberelk.net/tim/2012/02/15/portreserve-systemd-solution/
* save coredump in Windows/Mozilla minidump format
* support crash reporting operation modes (https://live.gnome.org/GnomeOS/Design/Whiteboards/ProblemReporting)
* default to actual 32bit PIDs, via /proc/sys/kernel/pid_max
* when a bus name of a service disappears from the bus make sure to queue further activation requests
* hide PAM/TCPWrap options in fragment parser when compile time disabled
* support sd_notify() style notification when reload begins (RELOADING=1), reload is finished (READY=1), and add ReloadSignal= then to use in combination
* support sd_notify() style notification when shutting down, to make auto-exit bus services work (STOPPING=1)
- readahead: make use of EXT4_IOC_MOVE_EXT, as used by http://e4rat.sourceforge.net/
* add support for /bin/mount -s
- init=/bin/sh vs. "emergency" mode, vs. "rescue" mode, vs. "multi-user" mode, vs. "graphical" mode, and the debug shell
- hooking a script into various stages of shutdown/rearly booot
* support systemd.mask= on the kernel command line.
- add documentation to systemd.daemon
- add proper initrd support (in particular generate .network/.link files based on /proc/cmdline)
- change LL address generation and make it predictable like get_mac() (link-config.c)
- teach dbus to activate all services it finds in /etc/systemd/services/org-*.service
* dbus upstream still refers to dbus.target and shouldn't
* /usr/bin/service should actually show the new command line
* fedora: suggest auto-restart on failure, but not on success and not on coredump. also, ask people to think about changing the start limit logic. Also point people to RestartPreventExitStatus=, SuccessExitStatus=
* fedora: F20: go timer units all the way, leave cron.daily for cron
* fedora: update policy to declare access mode and ownership of unit files to root:root 0644, and add an rpmlint check for it
* set_put(), hashmap_put() return values check. i.e. == 0 doesn't free()!