1Bugfixes: 2 3* Many manager configuration settings that are only applicable to user 4 manager or system manager can be always set. It would be better to reject 5 them when parsing config. 6 7* Jun 01 09:43:02 krowka systemd[1]: Unit user@1000.service has alias user@.service. 8 Jun 01 09:43:02 krowka systemd[1]: Unit user@6.service has alias user@.service. 9 Jun 01 09:43:02 krowka systemd[1]: Unit user-runtime-dir@6.service has alias user-runtime-dir@.service. 10 11External: 12 13* Fedora: add an rpmlint check that verifies that all unit files in the RPM are listed in %systemd_post macros. 14 15* dbus: 16 - natively watch for dbus-*.service symlinks (PENDING) 17 - teach dbus to activate all services it finds in /etc/systemd/services/org-*.service 18 19* kernel: add device_type = "fb", "fbcon" to class "graphics" 20 21* /usr/bin/service should actually show the new command line 22 23* 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= 24 25* neither pkexec nor sudo initialize environ[] from the PAM environment? 26 27* fedora: update policy to declare access mode and ownership of unit files to root:root 0644, and add an rpmlint check for it 28 29* register catalog database signature as file magic 30 31* zsh shell completion: 32 - <command> <verb> -<TAB> should complete options, but currently does not 33 - systemctl add-wants,add-requires 34 - systemctl reboot --boot-loader-entry= 35 36* systemctl status should know about 'systemd-analyze calendar ... --iterations=' 37* If timer has just OnInactiveSec=..., it should fire after a specified time 38 after being started. 39 40* write blog stories about: 41 - hwdb: what belongs into it, lsusb 42 - enabling dbus services 43 - how to make changes to sysctl and sysfs attributes 44 - remote access 45 - how to pass throw-away units to systemd, or dynamically change properties of existing units 46 - testing with Harald's awesome test kit 47 - auto-restart 48 - how to develop against journal browsing APIs 49 - the journal HTTP iface 50 - non-cgroup resource management 51 - dynamic resource management with cgroups 52 - refreshed, longer missions statement 53 - calendar time events 54 - init=/bin/sh vs. "emergency" mode, vs. "rescue" mode, vs. "multi-user" mode, vs. "graphical" mode, and the debug shell 55 - how to create your own target 56 - instantiated apache, dovecot and so on 57 - hooking a script into various stages of shutdown/rearly booot 58 59Regularly: 60 61* look for close() vs. close_nointr() vs. close_nointr_nofail() 62 63* check for strerror(r) instead of strerror(-r) 64 65* pahole 66 67* set_put(), hashmap_put() return values check. i.e. == 0 does not free()! 68 69* use secure_getenv() instead of getenv() where appropriate 70 71* link up selected blog stories from man pages and unit files Documentation= fields 72 73Janitorial Clean-ups: 74 75* Rearrange tests so that the various test-xyz.c match a specific src/basic/xyz.c again 76 77* rework mount.c and swap.c to follow proper state enumeration/deserialization 78 semantics, like we do for device.c now 79 80Features: 81 82* homed/userdb: maybe define a "companion" dir for home directories where apps 83 can safely put privileged stuff in. Would not be writable by the user, but 84 still conceptually belong to the user. Would be included in user's quota if 85 possible, even if files are not owned by UID of user. Usecase: container 86 images that owned by arbitrary UIDs, and are owned/managed by the users, but 87 are not directly belonging to the user's UID. Goal: we shouldn't place more 88 privileged dirs inside of unprivileged dirs, and thus containers really 89 should not be placed inside of traditional UNIX home dirs (which are owned by 90 users themselves) but somewhere else, that is separate, but still close 91 by. Inform user code about path to this companion dir via env var, so that 92 container managers find it. the ~/.identity file is also a candidate for a 93 file to move there, since it is managed by privileged code (i.e. homed) and 94 not unprivileged code. 95 96* given that /etc/ssh/ssh_config.d/ is a thing now, ship a drop-in for that 97 that hooks up userbdctl ssh-key stuff. 98 99* allow embedding a signature blob for PCR hashes into separate section in 100 unified kernel binaries. This section should be picked up by sd-stub, and 101 passed in a file to the booted kernel (via initrd cpio, as usual). Usecase: 102 this way we can implement disk encryption policies that bind to specific 103 kernel PCR state, without breaking things on every kernel update. As long as 104 the kernel includes the PCR signature blob we should be good, as disk 105 encryption can then pass the signature to the TPM to unlock their secrets. 106 Why do this via a separate PE section? That's because the PCR state depends 107 on the measured kernel/initrd of course, thus we cannot put the signature 108 into the kernel/initrd itself, because that would require a time machine. 109 Hence we have to find a separate place. A simple solution is a PE section 110 of its own, because then it is next to the kernel and initrd which after all 111 are stored in PE sections of their own too. Building a unified kernel would 112 thus mean, calculating PCR values for the raw kernel image, and raw initrd 113 image, then signing those PCR values with a vendor key, and then combining 114 sd-stub, raw kernel image, raw initrd, and PCR signature into a unified 115 kernel image. 116 117* a new tool "systemd-trust" or so, that can calculate PCR hashes offline, and 118 optionally sign them. for that we should extend our syntax for specifying pcr 119 policies (e.g. the string like "4+7+9") so that it can also include explicit 120 hash values, i.e. 121 4=sha256:0ef149998289474e4bb31813edda6ad7f3c991b2d8dec6e8fe4db7a1f039f2d1+7=sha256:87428fc522803d31065e7bce3cf03fe475096631e5e07bbd7a0fde60c4cf25c7+9=sha256:0263829989b6fd954f72baaf2fc64bc2e2f01d692d4de72986ea808f6e99813f 122 and file names to calculate hashes from, i.e. 123 4=file:/boot/vmlinuz+7=file:/boot/initrd/+9=file:/etc/fstab" 124 The systemd-trust tool should then be able to resolve any "underspecifed" 125 form into the form with explicit hash values. 126 127* maybe add support for binding and connecting AF_UNIX sockets in the file 128 system outside of the 108ch limit. When connecting, open O_PATH fd to socket 129 inode first, then connect to /proc/self/fd/XYZ. When binding, create symlink 130 to target dir in /tmp, and bind through it. 131 132* tmpfiles: for f/F/w lines, if the argument columns is left unspecified, look 133 for a service credential named after the file path to write to, and load 134 contents to write from there. Usecase: provision arbitrary files from 135 credentials. Example use: with a line like "f /root/.ssh/authorized-keys 136 0644 root root" in a tmpfiles.d/ snippet add 137 LoadCredential=root.ssh.authorized-keys via drop-in to 138 systemd-tmpfiles.service, and then provision an SSH access key through 139 nspawn's --load-credential=, through qemu's fw_cfg, or via systemd-stub's 140 credntial pick-up. The latter is particularly interesting to implement SSH 141 access to an initrd. 142 143* systemd-homed: when initializing, look for a credential sysemd.homed.register 144 or so with JSON user records to automatically register if not registered yet. 145 Usecase: deploy a system, and add an account one can directly log into. 146 147* add a proper concept of a "developer" mode, i.e. where cryptographic 148 protections of the root OS are weakened after interactive confirmation, to 149 allow hackers to allow their own stuff. idea: allow entering developer mode 150 only via explicit choice in boot menu: i.e. add explicit boot menu item for 151 it. when developer mode is entered generate a key pair in the TPM2, and add 152 the public part of it automatically to keychain of valid code signature keys 153 on subsequent boots. Then provide a tool to sign code with the key in the 154 TPM2. Ensure that boot menu item is only way to enter developer mode, by 155 binding it to locality/PCRs so that that keys cannot be generated otherwise. 156 157* services: add support for cryptographically unlocking per-service directories 158 via TPM2. Specifically, for StateDirectory= (and related dirs) use fscrypt to 159 set up the directory so that it can only be accessed if host and app are in 160 order. 161 162* TPM2: add auth policy for signed PCR values to make updates easy. i.e. do 163 what tpm2_policyauthorize tool does. To be truly useful scheme needs to be a 164 bit more elaborate though: policy probably must take some nvram based 165 generation counter into account that can only monotonically increase and can 166 be used to invalidate old PCR signatures. Otherwise people could downgrade to 167 old signed PCR sets whenever they want. Usecase: encrypt the rootfs with LUKS 168 with a key that can only be unlocked via a pristine pre-built Fedora 169 kernel+initrd. 170 171* update HACKING.md to suggest developing systemd with the ideas from: 172 https://0pointer.net/blog/testing-my-system-code-in-usr-without-modifying-usr.html 173 https://0pointer.net/blog/running-an-container-off-the-host-usr.html 174 175* add a clear concept how the initrd can make up credentials on their own to 176 pass to the system when transitioning into the host OS. usecase: things like 177 cloud-init/ignitation and similar can parameterize the host with data they 178 acquire. 179 180* Add ConditionCredentialExists= or so, that allows conditionalizing services 181 depending on whether a specific system credential is set. Usecase: a service 182 similar to the ssh keygen service that installs any SSH host key supplied via 183 system credentials into /etc/ssh. 184 185* drop support for kernels that lack ambient capabilities support (i.e. make 186 4.3 new baseline). Then drop support for "!!" modifier for ExecStart= which 187 is only supported for such old kernels 188 189* sd-event: compat wd reuse in inotify code: keep a set of removed watch 190 descriptors, and clear this set piecemeal when we see the IN_IGNORED event 191 for it, or when read() returns EAGAIN or on IN_Q_OVERFLOW. Then, whenever we 192 see an inotify wd event check against this set, and if it is contained ignore 193 the event. (to be fully correct this would have to count the occurrences, in 194 case the same wd is reused multiple times before we start processing 195 IN_IGNORED again) 196 197* sd-stub: set efi var indicating stub features, i.e. whether they pick up 198 creds, sysexts and so on. similar to existing variable of sd-boot 199 200* sd-stub: set efi vars declaring TPM PCRs we measured creds/cmdline + sysext 201 into (even if we hardcode them) 202 203* systemd-fstab-generator: support addition mount specifications via kernel 204 cmdline. Usecase: invoke a VM, and mount a host homedir into it via 205 virtio-fs. 206 207* for vendor-built signed initrds: 208 - make sysext run in the initrd 209 - sysext should pick up sysext images from /.extra/ in the initrd, and insist 210 on verification if in secureboot mode 211 - kernel-install should be able to install pre-built unified kernel images in 212 type #2 drop-in dir in the ESP. 213 - kernel-install should be able install encrypted creds automatically for 214 machine id, root pw, rootfs uuid, resume partition uuid, and place next to 215 EFI kernel, for sd-stub to pick them up. These creds should be locked to 216 the TPM, and bind to the right PCR the kernel is measured to. 217 - kernel-install should be able to pick up initrd sysexts automatically and 218 place them next to EFI kernel, for sd-stub to pick them up. 219 - systemd-fstab-generator should look for rootfs device to mount in creds 220 - pid 1 should look for machine ID in creds 221 - systemd-resume-generator should look for resume partition uuid in creds 222 - sd-stub: automatically pick up microcode from ESP (/loader/microcode/*) 223 and synthesize initrd from it, and measure it. Signing is not necessary, as 224 microcode does that on its own. Pass as first initrd to kernel. 225 - sd-stub should measure the kernel/initrd/… into a separate PCR, so that we 226 have one PCR we can bind the encrypted creds to that is not effected by 227 anything else but what we drop in via kernel-install, i.e. by earlier EFI 228 code running (i.e. like PCR 4) 229 230* Add a new service type very similar to Type=notify, that goes one step 231 further and extends the protocol to cover reloads. Specifically, SIGHUP will 232 become the official way to reload, and daemon has to respond with sd_notify() 233 to report when it starts reloading, and when it is complete reloading. Care 234 must be taken to remove races from this model. I.e. PID 1 needs to take 235 CLOCK_MONOTONIC, then send SIGHUP, then wait for at least one RELOADING=1 236 message that comes with a newer timestamp, then wait for a READY=1 message. 237 while we are at it, also maybe extend the logic to require handling of some 238 specific SIGRT signal for setting debug log level, that carries the level via 239 the sigqueue() data parameter. With that we extended with minimal logic the 240 service runtime logic quite substantially. 241 242* firstboot: maybe just default to C.UTF-8 locale if nothing is set, so that we 243 don't query this unnecessarily in entirely uninitialized 244 containers. (i.e. containers with empty /etc). 245 246* beef up sd_notify() to support AV_VSOCK in $NOTIFY_SOCKET, so that VM 247 managers can get ready notifications from VMs, just like container managers 248 from their payload. Also pick up address from qemu/fw_cfg if set there. 249 (which has benefits, given SecureBoot and kernel cmdline are not necessarily 250 friends.) 251 252* mirroring this: maybe support binding to AV_VSOCK in Type=notify services, 253 then passing $NOTIFY_SOCKET and $NOTIFY_GUESTCID with PID1's cid (typically 254 fixed to "2", i.e. the official host cid) and the expected guest cid, for the 255 two sides of the channel. The latter env var could then be used in an 256 appropriate qemu cmdline. That way qemu payloads could talk sd_notify() 257 directly to host service manager. 258 259* maybe write a tool that binds an AF_VFSOCK socket, then invokes qemu, 260 extending the command line to enable vsock on the VM, and using fw_cfg to 261 configure socket address. 262 263* sd-boot: rework random seed handling following recent kernel changes: always 264 pass seed to kernel, but credit only if secure boot is used 265 266* sd-boot: hash data from GetNextHighMonotonicCount() into updated random seed, 267 so that we might even open up up the random seed logic to non-SecureBoot 268 systems? 269 270* sd-boot: also include the hyperv "vm generation id" in the random seed hash, 271 to cover nicely for machine clones. It's found in the ACPI tables, which 272 should be easily accessible from UEFI. 273 274* sd-boot: add menu item for shutdown? or hotkey? 275 276* sd-device has an API to create an sd_device object from a device id, but has 277 no api to query the device id 278 279* sd-device should return the devnum type (i.e. 'b' or 'c') via some API for an 280 sd_device object, so that data passed into sd_device_new_from_devnum() can 281 also be queried. 282 283* sd-event: optionally, if per-event source rate limit is hit, downgrade 284 priority, but leave enabled, and once ratelimit window is over, upgrade 285 priority again. That way we can combat event source starvation without 286 stopping processing events from one source entirely. 287 288* sd-event: similar to existing inotify support add fanotify support (given 289 that apparently new features in this area are only going to be added to the 290 latter). 291 292* sd-event: add 1st class event source for clock changes 293 294* sd-event: add 1st class event source for timezone changes 295 296* support uefi/http boots with sd-boot: instead of looking for dropin files in 297 /loader/entries/ dir, look for a file /loader/entries/SHA256SUMS and use that 298 as directory manifest. The file would be a standard directory listing as 299 generated by GNU sha256sums. 300 301* sd-boot: maybe add support for embedding the various auxiliary resources we 302 look for right in the sd-boot binary. i.e. take inspiration from sd-stub 303 logic: allow combining sd-boot via objcopy with kernels to enumerate, .conf 304 files, drivers, keys to enroll and so on. Then, add whatever we find that way 305 to the menu. Usecase: allow building a single PE image you can boot into via 306 UEFI HTTP boot. 307 308* maybe add a new UEFI stub binary "sd-http". It works similar to sd-stub, but 309 all it does is download a file from a http server, and execute it, after 310 optionally checking its hash sum. idea would be: combine this "sd-http" stub 311 binary with some minimal info about an URL + hash sum, plus .osrel data, and 312 drop it into the unified kernel dir in the ESP. And bam you have something 313 that is tiny, feels a lot like a unified kernel, but all it does is chainload 314 the real kernel. benefit: downloading these stubs would be tiny and quick, 315 hence cheap for enumeration. 316 317* initialize machine ID from systemd credential picked up from the ESP via 318 sd-stub, so that machine ID is stable even on systems where unified kernels 319 are used, and hence kernel cmdline cannot be modified locally 320 321* in gpt-auto-generator: check partition uuids against such uuids supplied via 322 sd-stub credentials. That way, we can support parallel OS installations with 323 pre-built kernels. 324 325* sysext: measure all activated sysext into a TPM PCR 326 327* maybe add a "syscfg" concept, that is almost entirely identical to "sysext", 328 but operates on /etc/ instead of /usr/ and /opt/. Use case would be: trusted, 329 authenticated, atomic, additive configuration management primitive: drop in a 330 configuration bundle, and activate it, so that it is instantly visible, 331 comprehensively. 332 333* systemd-dissect: show available versions inside of a disk image, i.e. if 334 multiple versions are around of the same resource, show which ones. (in other 335 words: show partition labels). 336 337* systemd-nspawn: make boot assessment do something sensible in a 338 container. i.e send an sd_notify() from payload to container manager once 339 boot-up is completed successfully, and use that in nspawn for dealing with 340 boot counting, implemented in the partition table labels and directory names. 341 342* maybe add a generator that reads /proc/cmdline, looks for 343 systemd.pull-raw-portable=, systemd-pull-raw-sysext= and similar switches 344 that take an URL as parameter. It then generates service units for 345 systemd-pull calls that download these URLs if not installed yet. usecase: 346 invoke a VM or nspawn container in a way it automatically deploys/runs these 347 images as OS payloads. i.e. have a generic OS image you can point to any 348 payload you like, which is then downloaded, securely verified and run. 349 350* improve scope units to support creation by pidfd instead of by PID 351 352* deprecate cgroupsv1 further (print log message at boot) 353 354* systemd-dissect: add --cat switch for dumping files such as /etc/os-release 355 356* per-service sandboxing option: ProtectIds=. If used, will overmount 357 /etc/machine-id and /proc/sys/kernel/random/boot_id with synthetic files, to 358 make it harder for the service to identify the host. Depending on the user 359 setting it should be fully randomized at invocation time, or a hash of the 360 real thing, keyed by the unit name or so. Of course, there are other ways to 361 get these IDs (e.g. journal) or similar ids (e.g. MAC addresses, DMI ids, CPU 362 ids), so this knob would only be useful in combination with other lockdown 363 options. Particularly useful for portable services, and anything else that 364 uses RootDirectory= or RootImage=. (Might also over-mount 365 /sys/class/dmi/id/*{uuid,serial} with /dev/null). 366 367* journalctl/timesyncd: whenever timesyncd acquires a synchronization from NTP, 368 create a structured log entry that contains boot ID, monotonic clock and 369 realtime clock (I mean, this requires no special work, as these three fields 370 are implicit). Then in journalctl when attempting to display the realtime 371 timestamp of a log entry, first search for the closest later log entry 372 of this kinda that has a matching boot id, and convert the monotonic clock 373 timestamp of the entry to the realtime clock using this info. This way we can 374 retroactively correct the wallclock timestamps, in particular for systems 375 without RTC, i.e. where initially wallclock timestamps carry rubbish, until 376 an NTP sync is acquired. 377 378* kernel-install: 379 - add --all switch for rerunning kernel-install for all installed kernels 380 - maybe add env var that shortcuts kernel-install for installers that want to 381 call it at the end only 382 383* doc: prep a document explaining resolved's internal objects, i.e. Query 384 vs. Question vs. Transaction vs. Stream and so on. 385 386* doc: prep a document explaining PID 1's internal logic, i.e. transactions, 387 jobs, units 388 389* bootspec: remove tries counter from boot entry ids 390 391* bootspec: bring UEFI and userspace enumeration of bootspec entries back into 392 sync, i.e. parse out tries in both 393 394* automatically ignore threaded cgroups in cg_xyz(). 395 396* add linker script that implicitly adds symbol for build ID and new coredump 397 json package metadata, and use that when logging 398 399* systemd-dissect: show GPT disk UUID in output 400 401* Enable RestricFileSystems= for all our long-running services (similar: 402 RestrictNetworkInterfaces=) 403 404* Add systemd-analyze security checks for RestrictFileSystems= and 405 RestrictNetworkInterfaces= 406 407* cryptsetup/homed: implement TOTP authentication backed by TPM2 and its 408 internal clock. 409 410* nspawn: optionally set up nftables/iptables routes that forward UDP/TCP 411 traffic on port 53 to resolved stub 127.0.0.54 412 413* man: rework os-release(5), and clearly separate our extension-release.d/ and 414 initrd-release parts, i.e. list explicitly which fields are about what. 415 416* sysext: before applying a sysext, do a superficial validation run so that 417 things are not rearranged to wildy. I.e. protect against accidental fuckups, 418 such as masking out /usr/lib/ or so. We should probably refuse if existing 419 inodes are replaced by other types of inodes or so. 420 421* sysext: ensure one can build a sysext that can safely apply to *any* system 422 (because it contains only static go binaries in /opt/ or so) 423 424* userdb: when synthesizing NSS records, pick "best" password from defined 425 passwords, not just the first. i.e. if there are multiple defined, prefer 426 unlocked over locked and prefer non-empty over empty. 427 428* maybe add a tool inspired by the GPT auto discovery spec that runs in the 429 initrd and rearranges the rootfs hierarchy via bind mounts, if 430 enabled. Specifically in some top-level dir /@auto/ it will look for 431 dirs/symlinks/subvolumes that are named after their purpose, and optionally 432 encode a version as well as assessment counters, and then mount them into the 433 file system tree to boot into, similar to how we do that for the gpt auto 434 logic. Maybe then bind mount the original root into /.superior or something 435 like that (so that update tools can look there). Further discussion in this 436 thread: 437 https://lists.freedesktop.org/archives/systemd-devel/2021-November/047059.html 438 The GPT dissection logic should automatically enable this tool whenever we 439 detect a specially marked root fs (i.e introduce a new generic root gpt type 440 for this, that is arch independent). The also implement this in the image 441 dissection logic, so that nspawn/RootImage= and so on grok it. Maybe make 442 generic enough so that it can also work for ostrees arrangements. 443 444* if a path ending in ".auto.d/" is set for RootDirectory=/RootImage= then do a 445 strverscmp() of everything inside that dir and use that. i.e. implement very 446 simple version control. Also use this in systemd-nspawn --image= and so on. 447 448* homed: while a home dir is not activated generate slightly different NSS 449 records for it, that reports the home dir as "/" and the shell as some binary 450 provided by us. Then, when an SSH login happens and SSH permits it our binary 451 is invoked. This binary can then talk to homed and activate the homedir if 452 it's not around yet, prompting the user for a password. Once that succeeded 453 we'll switch to the real user record, i.e. home dir and shell, and our tool 454 exec()s the latter. Net effect: ssh'ing into a homed account will just work: 455 we'll neatly prompt for the homedir's password if its needed. –– Building on 456 this we could take this even further: since this tool will potentially have 457 access to the client's ssh-agent (if ssh-agent forwarding is enabled) we 458 could implement SSH unlocking of a homedir with that: when enrolling a new 459 ssh pubkey in a user record we'd ask the ssh-agent to sign some random value 460 with the privkey, then use that as luks key to unlock the home dir. Will not 461 work for ECDSA keys since their signatures contain a random component, but 462 will work for RSA and Ed25519 keys. 463 464* add tiny service that decrypts encrypted user records passed via initrd 465 credential logic and drops them into /run where nss-systemd can pick them up, 466 similar to /run/host/userdb/. Usecase: drop a root user JSON record there, 467 and use it in the initrd to log in as root with locally selected password, 468 for debugging purposes. Other usecase: boot into qemu with regular user 469 mounted from host. maybe put this in systemd-user-sessions.service? 470 471* drop dependency on libcap, replace by direct syscalls based on 472 CapabilityQuintet we already have. (This likely allows us drop drop libcap 473 dep in the base OS image) 474 475* sysext: automatically activate sysext images dropped in via new sd-stub 476 sysext pickup logic. 477 478* add concept for "exitrd" as inverse of "initrd", that we can transition to at 479 shutdown, and has similar security semantics. This should then take the place 480 of dracut's shutdown logic. Should probably support sysexts too. Care needs 481 to be taken that the resulting logic ends up in RAM, i.e. is copied out of 482 on-disk storage. 483 484* userdbd: implement an additional varlink service socket that provides the 485 host user db in restricted form, then allow this to be bind mounted into 486 sandboxed environments that want the host database in minimal form. All 487 records would be stripped of all meta info, except the basic UID/name 488 info. Then use this in portabled environments that do not use PrivateUsers=1. 489 490* logind introduce two types of sessions: "heavy" and "light". The former would 491 be our current sessions. But the latter would be a new type of session that 492 is mostly the same but does not pull in user@.service or wait for it. Then, 493 allow configuration which type of session is desired via pam_systemd 494 parameters, and then make user@.service's session one of these "light" ones. 495 People could then choose to make FTP sessions and suchlike "light" if they 496 don't want the service manager to be started for that. 497 498* /etc/veritytab: allow that the roothash column can be specified as fs path 499 including a path to an AF_UNIX path, similar to how we do things with the 500 keys of /etc/crypttab. That way people can store/provide the roothash 501 externally and provide to us on demand only. 502 503* add high-level lockdown level for GPT dissection logic: e.g. an enum that can 504 be ANY (to mount anything), TRUSTED (to require that /usr is on signed 505 verity, but rest doesn't matter), LOCKEDDOWN (to require that everything is 506 on signed verity, except for ESP), SUPERLOCKDOWN (like LOCKEDDOWN but ESP not 507 allowed). And then maybe some flavours of that that declare what is expected 508 from home/srv/var… Then, add a new cmdline flag to all tools that parse such 509 images, to configure this. Also, add a kernel cmdline option for this, to be 510 honoured by the gpt auto generator. 511 512* nspawn: maybe optionally insert .nspawn file as GPT partition into images, so 513 that such container images are entirely stand-alone and can be updated as 514 one. 515 516* we probably should extend the root verity hash of the root fs into some PCR 517 on boot. (i.e. maybe add a crypttab option tpm2-measure=8 or so to measure it 518 into PCR 8) 519 520* add a "policy" to the dissection logic. i.e. a bit mask what is OK to mount, 521 what must be read-only, what requires encryption, and what requires 522 authentication. 523 524* in uefi stub: query firmware regarding which PCRs are being used, store that 525 in EFI var. then use this when enrolling TPM2 in cryptsetup to verify that 526 the selected PCRs actually are used by firmware. 527 528* rework recursive read-only remount to use new mount API 529 530* PAM: pick up authentication token from credentials 531 532* when mounting disk images: if IMAGE_ID/IMAGE_VERSION is set in os-release 533 data in the image, make sure the image filename actually matches this, so 534 that images cannot be misused. 535 536* New udev block device symlink names: 537 /dev/disk/by-parttypelabel/<pttype>-<ptlabel>. Use case: if pt label is used 538 as partition image version string, this is a safe way to reference a specific 539 version of a specific partition type, in particular where related partitions 540 are processed (e.g. verity + rootfs both named "LennartOS_0.7"). 541 542* sysupdate: 543 - add fuzzing to the pattern parser 544 - support casync as download mechanism 545 - direct TPM2 PCR change handling, possible renrolling LUKS2 media if needed. 546 - "systemd-sysupdate update --all" support, that iterates through all components 547 defined on the host, plus all images installed into /var/lib/machines/, 548 /var/lib/portable/ and so on. 549 - figure out what to do about system extensions (i.e. they need to imply an 550 update component, since otherwise system extenion' sysupdate.d/ files would 551 override the host's update files.) 552 - Allow invocation with a single transfer definition, i.e. with 553 --definitions= pointing to a file rather than a dir. 554 - add ability to disable implicit decompression of downloaded artifacts, 555 i.e. a Compress=no option in the transfer definitions 556 557* in sd-id128: also parse UUIDs in RFC4122 URN syntax (i.e. chop off urn:uuid: prefix) 558 559* DynamicUser= + StateDirectory= → use uid mapping mounts, too, in order to 560 make dirs appear under right UID. 561 562* systemd-sysext: optionally, run it in initrd already, before transitioning 563 into host, to open up possibility for services shipped like that. 564 565* maybe add a tool that displays most recent journal logs as QR code to scan 566 off screen and run it automatically on boot failures, emergency logs and 567 such. Use DRM APIs directly, see 568 https://github.com/dvdhrm/docs/blob/master/drm-howto/modeset.c for an example 569 for doing that. 570 571* introduce /dev/disk/root/* symlinks that allow referencing partitions on the 572 disk the rootfs is on in a reasonably secure way. (or maybe: add 573 /dev/gpt-auto-{home,srv,boot,…} similar in style to /dev/gpt-auto-root as we 574 already have it. 575 576* whenever we receive fds via SCM_RIGHTS make sure none got dropped due to the 577 reception limit the kernel silently enforces. 578 579* add an Open= setting to service unit files that can open arbitrary file 580 system paths at service startup time and pass them to the service process via 581 our usual socket activation protocol. If passed path refers to AF_UNIX 582 socket: connect() to it. 583 584* Similar, ConnectStream= which takes IP addresses and connects to them. 585 586* Similar, Load= which takes literal data in text or base64 format, and puts it 587 into a memfd, and passes that. This enables some fun stuff, such as embedding 588 bash scripts in unit files, by combining Load= with ExecStart=/bin/bash 589 /proc/self/fd/3 590 591* add a ConnectSocket= setting to service unit files, that may reference a 592 socket unit, and which will connect to the socket defined therein, and pass 593 the resulting fd to the service program via socket activation proto. 594 595* Add a concept of ListenStream=anonymous to socket units: listen on a socket 596 that is deleted in the fs. Usecase would be with ConnectSocket= above. 597 598* importd: support image signature verification with PKCS#7 + OpenBSD signify 599 logic, as alternative to crummy gpg 600 601* add "systemd-analyze debug" + AttachDebugger= in unit files: The former 602 specifies a command to execute; the latter specifies that an already running 603 "systemd-analyze debug" instance shall be contacted and execution paused 604 until it gives an OK. That way, tools like gdb or strace can be safely be 605 invoked on processes forked off PID 1. 606 607* expose MS_NOSYMFOLLOW in various places 608 609* credentials system: 610 - acquire from EFI variable? 611 - acquire via via ask-password? 612 - acquire creds via keyring? 613 - pass creds via keyring? 614 - pass creds via memfd? 615 - acquire + decrypt creds from pkcs11? 616 - make systemd-cryptsetup acquire pw via creds logic 617 - make PAMName= acquire pw via creds logic 618 - make macsec/wireguard code in networkd read key via creds logic 619 - make gatwayd/remote read key via creds logic 620 - add sd_notify() command for flushing out creds not needed anymore 621 - make user manager instances create and use a user-specific key (the one in 622 /var/lib is root-only) and add --user switch to systemd-creds to use it 623 624* add tpm.target or so which is delayed until TPM2 device showed up in case 625 firmware indicates there is one. 626 627* Add concept for upgrading TPM2 enrollments, maybe a new switch 628 --pcrs=4:<hash> or so, i.e. select a PCR to include in the hash, and then 629 override its hash 630 631* TPM2: auto-reenroll in cryptsetup, as fallback for hosed firmware upgrades 632 and such 633 634* introduce a new group to own TPM devices 635 636* cryptsetup: if only recovery keys are registered and no regular passphrases, 637 ask user for "recovery key", not "passphrase" 638 639* cyptsetup: add option for automatically removing empty password slot on boot 640 641* cryptsetup: optionally, when run during boot-up and password is never 642 entered, and we are on battery power (or so), power off machine again 643 644* cryptsetup: when waiting for FIDO2/PKCS#11 token, tell plymouth that, and 645 allow plymouth to abort the waiting and enter pw instead 646 647* make cryptsetup lower --iter-time 648 649* cryptsetup: allow encoding key directly in /etc/crypttab, maybe with a 650 "base64:" prefix. Useful in particular for pkcs11 mode. 651 652* cryptsetup: reimplement the mkswap/mke2fs in cryptsetup-generator to use 653 systemd-makefs.service instead. 654 655* cryptsetup: 656 - cryptsetup-generator: allow specification of passwords in crypttab itself 657 - support rd.luks.allow-discards= kernel cmdline params in cryptsetup generator 658 659* when configuring loopback netif, and it fails due to EPERM, eat up error if 660 it happens to be set up alright already. 661 662* at boot: check if battery above some threshold, if not power off again after explanation 663 664* userdb: add field for ambient caps, so that a user can have CAP_WAKE_ALARM 665 for example. And add code that resets ambient caps for all services by 666 default. 667 668* sd-bus: when connecting to some dbus server socker, set originating AF_UNIX 669 socket name in abstract namespace to include "description" string, and pick 670 it up from there in sd_bus_creds logic. i.e. we can use the socket peer 671 address as conduit for some minimal connection metainfo, and use it to 672 restore the "description" logic that kdbus used to have. 673 674* systemd-analyze netif that explains predictable interface (or networkctl) 675 676* Add service setting to run a service within the specified VRF. i.e. do the 677 equivalent of "ip vrf exec". 678 679* change SwitchRoot() implementation in PID 1 to use pivot_root(".", "."), as 680 documented in the pivot_root(2) man page, so that we can drop the /oldroot 681 temporary dir. 682 683* special case some calls of chase_symlinks() to use openat2() internally, so 684 that the kernel does what we otherwise do. 685 686* add a new flag to chase_symlinks() that stops chasing once the first missing 687 component is found and then allows the caller to create the rest. 688 689* make use of new glibc 2.32 APIs sigabbrev_np() and strerrorname_np(). 690 691* if /usr/bin/swapoff fails due to OOM, log a friendly explanatory message about it 692 693* Remove any support for booting without /usr pre-mounted in the initrd entirely. 694 Update INITRD_INTERFACE.md accordingly. 695 696* pid1: Move to tracking of main pid/control pid of units per pidfd 697 698* pid1: support new clone3() fork-into-cgroup feature 699 700* pid1: also remove PID files of a service when the service starts, not just 701 when it exits 702 703* make us use dynamically fewer deps for containers in general purpose distros: 704 o turn into dlopen() deps: 705 - p11-kit-trust (always) 706 - kmod-libs (only when called from PID 1) 707 - libblkid (only in RootImage= handling in PID 1, but not elsewhere) 708 - libpam (only when called from PID 1) 709 - bzip2, xz, lz4 (always — gzip and zstd should probably stay static deps the way they are, 710 since they are so basic and our defaults) 711 o move into separate libsystemd-shared-iptables.so .so 712 - iptables-libs (only used by nspawn + networkd) 713 714* seccomp: maybe use seccomp_merge() to merge our filters per-arch if we can. 715 Apparently kernel performance is much better with fewer larger seccomp 716 filters than with more smaller seccomp filters. 717 718* systemd-path: add ESP and XBOOTLDR path. Add "private" runtime/state/cache dir enum, 719 mapping to $RUNTIME_DIRECTORY, $STATE_DIRECTORY and such 720 721* All tools that support --root= should also learn --image= so that they can 722 operate on disk images directly. Specifically: bootctl, systemctl, 723 coredumpctl. (Already done: systemd-nspawn, systemd-firstboot, 724 systemd-repart, systemd-tmpfiles, systemd-sysusers, journalctl) 725 726* seccomp: by default mask x32 ABI system wide on x86-64. it's on its way out 727 728* seccomp: don't install filters for ABIs that are masked anyway for the 729 specific service 730 731* busctl: maybe expose a verb "ping" for pinging a dbus service to see if it 732 exists and responds. 733 734* Maybe add a separate GPT partition type to the discoverable partition spec 735 for "hibernate" partitions, that are exactly like swap partitions but only 736 activated right before hibernation and thus never used for regular swapping. 737 738* socket units: allow creating a udev monitor socket with ListenDevices= or so, 739 with matches, then activate app through that passing socket over 740 741* unify on openssl: 742 - kill gnutls support in resolved 743 - figure out what to do about libmicrohttpd, which has a hard dependency on 744 gnutls 745 - port fsprg over to a dlopen lib, then switch it to openssl 746 747* add growvol and makevol options for /etc/crypttab, similar to 748 x-systemd.growfs and x-systemd-makefs. 749 750* userdb: allow username prefix searches in varlink API, allow realname and 751 realname substr searches in varlink API 752 753* userdb: allow uid/gid range checks 754 755* userdb: allow existence checks 756 757* pid1: activation by journal search expression 758 759* when switching root from initrd to host, set the machine_id env var so that 760 if the host has no machine ID set yet we continue to use the random one the 761 initrd had set. 762 763* sd-event: add native support for P_ALL waitid() watching, then move PID 1 to 764 it for reaping assigned but unknown children. This needs to some special care 765 to operate somewhat sensibly in light of priorities: P_ALL will return 766 arbitrary processes, regardless of the priority we want to watch them with, 767 hence on each event loop iteration check all processes which we shall watch 768 with higher prio explicitly, and then watch the entire rest with P_ALL. 769 770* tweak sd-event's child watching: keep a prioq of children to watch and use 771 waitid() only on the children with the highest priority until one is waitable 772 and ignore all lower-prio ones from that point on 773 774* maybe introduce xattrs that can be set on the root dir of the root fs 775 partition that declare the volatility mode to use the image in. Previously I 776 thought marking this via GPT partition flags but that's not ideal since 777 that's outside of the LUKS encryption/verity verification, and we probably 778 shouldn't operate in a volatile mode unless we got told so from a trusted 779 source. 780 781* coredump: maybe when coredumping read a new xattr from /proc/$PID/exe that 782 may be used to mark a whole binary as non-coredumpable. Would fix: 783 https://bugs.freedesktop.org/show_bug.cgi?id=69447 784 785* teach parse_timestamp() timezones like the calendar spec already knows it 786 787* beef up hibernation to optionally do swapon/swapoff immediately before/after 788 the hibernation 789 790* beef up s2h to implement a battery watch loop: instead of entering 791 hibernation unconditionally after coming back from resume make a decision 792 based on the battery load level: if battery level is above a specific 793 threshold, go to suspend again, only hibernate if below it. This means we'd 794 stick to suspend usually, but fall back to hibernation only when battery runs 795 empty (well, subject to our sampling interval). Related to this, check if we 796 can make ACPI _BTP (i.e. /sys/class/power_supply/*/alarm) work for us too, 797 i.e. see if it can wake up machines from suspend, so that we could resume 798 automatically when the system is low on power and move automatically to 799 hibernation mode. (see 800 https://uefi.org/sites/default/files/resources/ACPI%206_2_A_Sept29.pdf 801 section 10.2.2.8 and 802 https://docs.microsoft.com/en-us/windows-hardware/design/device-experiences/modern-standby-wake-sources 803 at the end). 804 805* We should probably replace /etc/rc.d/README with a symlink to doc 806 content. After all it is constant vendor data. 807 808* maybe add kernel cmdline params: to force random seed crediting 809 810* introduce a new per-process uuid, similar to the boot id, the machine id, the 811 invocation id, that is derived from process creds, specifically a hashed 812 combination of AT_RANDOM + getpid() + the starttime from 813 /proc/self/status. Then add these ids implicitly when logging. Deriving this 814 uuid from these three things has the benefit that it can be derived easily 815 from /proc/$PID/ in a stable, and unique way that changes on both fork() and 816 exec(). 817 818* let's not GC a unit while its ratelimits are still pending 819 820* when killing due to service watchdog timeout maybe detect whether target 821 process is under ptracing and then log loudly and continue instead. 822 823* make rfkill uaccess controllable by default, i.e. steal rule from 824 gnome-bluetooth and friends 825 826* make MAINPID= message reception checks even stricter: if service uses User=, 827 then check sending UID and ignore message if it doesn't match the user or 828 root. 829 830* maybe trigger a uevent "change" on a device if "systemctl reload xyz.device" 831 is issued. 832 833* when importing an fs tree with machined, optionally apply userns-rec-chown 834 835* when importing an fs tree with machined, complain if image is not an OS 836 837* Maybe introduce a helper safe_exec() or so, which is to execve() which 838 safe_fork() is to fork(). And then make revert the RLIMIT_NOFILE soft limit 839 to 1K implicitly, unless explicitly opted-out. 840 841* rework seccomp/nnp logic that even if User= is used in combination with 842 a seccomp option we don't have to set NNP. For that, change uid first whil 843 keeping CAP_SYS_ADMIN, then apply seccomp, the drop cap. 844 845* when no locale is configured, default to UEFI's PlatformLang variable 846 847* add a new syscall group "@esoteric" for more esoteric stuff such as bpf() and 848 usefaultd() and make systemd-analyze check for it. 849 850* paranoia: whenever we process passwords, call mlock() on the memory 851 first. i.e. look for all places we use free_and_erasep() and 852 augment them with mlock(). Also use MADV_DONTDUMP. 853 Alternatively (preferably?) use memfd_secret(). 854 855* Move RestrictAddressFamily= to the new cgroup create socket 856 857* maybe implicitly attach monotonic+realtime timestamps to outgoing messages in 858 log.c and sd-journal-send 859 860* optionally: turn on cgroup delegation for per-session scope units 861 862* introduce per-unit (i.e. per-slice, per-service) journal log size limits. 863 864* sd-boot: optionally, show boot menu when previous default boot item has 865 non-zero "tries done" count 866 867* augment CODE_FILE=, CODE_LINE= with something like CODE_BASE= or so which 868 contains some identifier for the project, which allows us to include 869 clickable links to source files generating these log messages. The identifier 870 could be some abberviated URL prefix or so (taking inspiration from Go 871 imports). For example, for systemd we could use 872 CODE_BASE=github.com/systemd/systemd/blob/98b0b1123cc or so which is 873 sufficient to build a link by prefixing "http://" and suffixing the 874 CODE_FILE. 875 876* Augment MESSAGE_ID with MESSAGE_BASE, in a similar fashion so that we can 877 make clickable links from log messages carrying a MESSAGE_ID, that lead to 878 some explanatory text online. 879 880* maybe extend .path units to expose fanotify() per-mount change events 881 882* When reloading configuration PID 1 should reset all its properties to the 883 original defaults before calling parse_config() 884 885* hibernate/s2h: make this robust and safe to enable in Fedora by default. 886 Specifically: 887 888 1. add resume_offset support to the resume code (i.e. support swap files 889 properly) 890 2. check if swap is on weird storage and refuse if so 891 3. add auto-detection of hibernation images 892 893* cgroups: use inotify to get notified when somebody else modifies cgroups 894 owned by us, then log a friendly warning. 895 896* beef up log.c with support for stripping ANSI sequences from strings, so that 897 it is OK to include them in log strings. This would be particularly useful so 898 that our log messages could contain clickable links for example for unit 899 files and suchlike we operate on. 900 901* importd: add ability download images for portabled + sysext 902 903* add support for "portablectl attach http://foobar.com/waaa.raw (i.e. importd integration) 904 905* sync dynamic uids/gids between host+portable srvice (i.e. if DynamicUser=1 is set for a service, make sure that the 906 selected user is resolvable in the service even if it ships its own /etc/passwd) 907 908* Fix DECIMAL_STR_MAX or DECIMAL_STR_WIDTH. One includes a trailing NUL, the 909 other doesn't. What a disaster. Probably to exclude it. 910 911* Check that users of inotify's IN_DELETE_SELF flag are using it properly, as 912 usually IN_ATTRIB is the right way to watch deleted files, as the former only 913 fires when a file is actually removed from disk, i.e. the link count drops to 914 zero and is not open anymore, while the latter happens when a file is 915 unlinked from any dir. 916 917* port systemctl, busctl, … over to format-table.[ch]'s table formatters 918 919* pid1: lock image configured with RootDirectory=/RootImage= using the usual nspawn semantics while the unit is up 920 921* add --vacuum-xyz options to coredumpctl, matching those journalctl already has. 922 923* introduce Ephemeral= unit file switch, that creates an ephemeral copy of all 924 files and directories that are left writable for a unit, and which are 925 removed after the unit goes down again. A bit like --ephemeral for 926 systemd-nspawn but for system services. If used together with RootImage= this 927 should reflink the image file itself. 928 929 Related: add Ephemeral=<path1> <path2> … which would allow marking 930 specific paths only like this. 931 932* add CopyFile= or so as unit file setting that may be used to copy files or 933 directory trees from the host to the services RootImage= and RootDirectory= 934 environment. Which we can use for /etc/machine-id and in particular 935 /etc/resolv.conf. Should be smart and do something useful on read-only 936 images, for example fall back to read-only bind mounting the file instead. 937 938* show invocation ID in systemd-run output 939 940* bypass SIGTERM state in unit files if KillSignal is SIGKILL 941 942* add proper dbus APIs for the various sd_notify() commands, such as MAINPID=1 943 and so on, which would mean we could report errors and such. 944 945* introduce DefaultSlice= or so in system.conf that allows changing where we 946 place our units by default, i.e. change system.slice to something 947 else. Similar, ManagerSlice= should exist so that PID1's own scope unit could 948 be moved somewhere else too. Finally machined and logind should get similar 949 options so that it is possible to move user session scopes and machines to a 950 different slice too by default. Usecase: people who want to put resources on 951 the entire system, with the exception of one specific service. See: 952 https://lists.freedesktop.org/archives/systemd-devel/2018-February/040369.html 953 954* maybe rework get_user_creds() to query the user database if $SHELL is used 955 for root, but only then. 956 957* be stricter with fds we receive for the fdstore: close them asynchronously 958 959* calenderspec: add support for week numbers and day numbers within a 960 year. This would allow us to define "bi-weekly" triggers safely. 961 962* sd-bus: add vtable flag, that may be used to request client creds implicitly 963 and asynchronously before dispatching the operation 964 965* sd-bus: parse addresses given in sd_bus_set_addresses immediately and not 966 only when used. Add unit tests. 967 968* make use of ethtool veth peer info in machined, for automatically finding out 969 host-side interface pointing to the container. 970 971* add some special mode to LogsDirectory=/StateDirectory=… that allows 972 declaring these directories without necessarily pulling in deps for them, or 973 creating them when starting up. That way, we could declare that 974 systemd-journald writes to /var/log/journal, which could be useful when we 975 doing disk usage calculations and so on. 976 977* deprecate RootDirectoryStartOnly= in favour of a new ExecStart= prefix char 978 979* add a new RuntimeDirectoryPreserve= mode that defines a similar lifecycle for 980 the runtime dir as we maintain for the fdstore: i.e. keep it around as long 981 as the unit is running or has a job queued. 982 983* support projid-based quota in machinectl for containers 984 985* add a way to lock down cgroup migration: a boolean, which when set for a unit 986 makes sure the processes in it can never migrate out of it 987 988* blog about fd store and restartable services 989 990* document Environment=SYSTEMD_LOG_LEVEL=debug drop-in in debugging document 991 992* rework ExecOutput and ExecInput enums so that EXEC_OUTPUT_NULL loses its 993 magic meaning and is no longer upgraded to something else if set explicitly. 994 995* in the long run: permit a system with /etc/machine-id linked to /dev/null, to 996 make it lose its identity, i.e. be anonymous. For this we'd have to patch 997 through the whole tree to make all code deal with the case where no machine 998 ID is available. 999 1000* optionally, collect cgroup resource data, and store it in per-unit RRD files, 1001 suitable for processing with rrdtool. Add bus API to access this data, and 1002 possibly implement a CPULoad property based on it. 1003 1004* beef up pam_systemd to take unit file settings such as cgroups properties as 1005 parameters 1006 1007* maybe hook up xfs/ext4 quotactl() with services? i.e. automatically manage 1008 the quota of the user indicated in User= via unit file settings, like the 1009 other resource management concepts. Would mix nicely with DynamicUser=1. Or 1010 alternatively, do this with projids, so that we can also cover services 1011 running as root. Quota should probably cover all the special dirs such as 1012 StateDirectory=, LogsDirectory=, CacheDirectory=, as well as RootDirectory= if it 1013 is set, plus the whole disk space any image configured with RootImage=. 1014 1015* In DynamicUser= mode: before selecting a UID, use disk quota APIs on relevant 1016 disks to see if the UID is already in use. 1017 1018* expose IO accounting data on the bus, show it in systemd-run --wait and log 1019 about it in the resource log message 1020 1021* Add AddUser= setting to unit files, similar to DynamicUser=1 which however 1022 creates a static, persistent user rather than a dynamic, transient user. We 1023 can leverage code from sysusers.d for this. 1024 1025* add some optional flag to ReadWritePaths= and friends, that has the effect 1026 that we create the dir in question when the service is started. Example: 1027 1028 ReadWritePaths=:/var/lib/foobar 1029 1030* Add ExecMonitor= setting. May be used multiple times. Forks off a process in 1031 the service cgroup, which is supposed to monitor the service, and when it 1032 exits the service is considered failed by its monitor. 1033 1034* track the per-service PAM process properly (i.e. as an additional control 1035 process), so that it may be queried on the bus and everything. 1036 1037* add a new "debug" job mode, that is propagated to unit_start() and for 1038 services results in two things: we raise SIGSTOP right before invoking 1039 execve() and turn off watchdog support. Then, use that to implement 1040 "systemd-gdb" for attaching to the start-up of any system service in its 1041 natural habitat. 1042 1043* gpt-auto logic: support encrypted swap, add kernel cmdline option to force it, and honour a gpt bit about it, plus maybe a configuration file 1044 1045* add a percentage syntax for TimeoutStopSec=, e.g. TimeoutStopSec=150%, and 1046 then use that for the setting used in user@.service. It should be understood 1047 relative to the configured default value. 1048 1049* enable LockMLOCK to take a percentage value relative to physical memory 1050 1051* Permit masking specific netlink APIs with RestrictAddressFamily= 1052 1053* define gpt header bits to select volatility mode 1054 1055* ProtectClock= (drops CAP_SYS_TIMES, adds seecomp filters for settimeofday, adjtimex), sets DeviceAllow o /dev/rtc 1056 1057* ProtectTracing= (drops CAP_SYS_PTRACE, blocks ptrace syscall, makes /sys/kernel/tracing go away) 1058 1059* ProtectMount= (drop mount/umount/pivot_root from seccomp, disallow fuse via DeviceAllow, imply Mountflags=slave) 1060 1061* ProtectKeyRing= to take keyring calls away 1062 1063* RemoveKeyRing= to remove all keyring entries of the specified user 1064 1065* ProtectReboot= that masks reboot() and kexec_load() syscalls, prohibits kill 1066 on PID 1 with the relevant signals, and makes relevant files in /sys and 1067 /proc (such as the sysrq stuff) unavailable 1068 1069* Support ReadWritePaths/ReadOnlyPaths/InaccessiblePaths in systemd --user instances 1070 via the new unprivileged Landlock LSM (https://landlock.io) 1071 1072* make sure the ratelimit object can deal with USEC_INFINITY as way to turn off things 1073 1074* in nss-systemd, if we run inside of RootDirectory= with PrivateUsers= set, 1075 find a way to map the User=/Group= of the service to the right name. This way 1076 a user/group for a service only has to exist on the host for the right 1077 mapping to work. 1078 1079* add bus API for creating unit files in /etc, reusing the code for transient units 1080 1081* add bus API to remove unit files from /etc 1082 1083* add bus API to retrieve current unit file contents (i.e. implement "systemctl cat" on the bus only) 1084 1085* rework fopen_temporary() to make use of open_tmpfile_linkable() (problem: the 1086 kernel doesn't support linkat() that replaces existing files, currently) 1087 1088* transient units: don't bother with actually setting unit properties, we 1089 reload the unit file anyway 1090 1091* optionally, also require WATCHDOG=1 notifications during service start-up and shutdown 1092 1093* cache sd_event_now() result from before the first iteration... 1094 1095* PID1: find a way how we can reload unit file configuration for 1096 specific units only, without reloading the whole of systemd 1097 1098* add an explicit parser for LimitRTPRIO= that verifies 1099 the specified range and generates sane error messages for incorrect 1100 specifications. 1101 1102* when we detect that there are waiting jobs but no running jobs, do something 1103 1104* PID 1 should send out sd_notify("WATCHDOG=1") messages (for usage in the --user mode, and when run via nspawn) 1105 1106* there's probably something wrong with having user mounts below /sys, 1107 as we have for debugfs. for example, src/core/mount.c handles mounts 1108 prefixed with /sys generally special. 1109 http://lists.freedesktop.org/archives/systemd-devel/2015-June/032962.html 1110 1111* fstab-generator: default to tmpfs-as-root if only usr= is specified on the kernel cmdline 1112 1113* initrd-parse-etc.service: can we skip daemon-reload if /sysroot/etc/fstab is missing? 1114 Note that we start initrd-fs.target and initrd-cleanup.target there, so a straightforward 1115 ConditionPathExists= is not enough. 1116 1117* docs: bring https://www.freedesktop.org/wiki/Software/systemd/MyServiceCantGetRealtime up to date 1118 1119* add a job mode that will fail if a transaction would mean stopping 1120 running units. Use this in timedated to manage the NTP service 1121 state. 1122 http://lists.freedesktop.org/archives/systemd-devel/2015-April/030229.html 1123 1124* The udev blkid built-in should expose a property that reflects 1125 whether media was sensed in USB CF/SD card readers. This should then 1126 be used to control SYSTEMD_READY=1/0 so that USB card readers aren't 1127 picked up by systemd unless they contain a medium. This would mirror 1128 the behaviour we already have for CD drives. 1129 1130* hostnamectl: show root image uuid 1131 1132* Find a solution for SMACK capabilities stuff: 1133 http://lists.freedesktop.org/archives/systemd-devel/2014-December/026188.html 1134 1135* synchronize console access with BSD locks: 1136 http://lists.freedesktop.org/archives/systemd-devel/2014-October/024582.html 1137 1138* as soon as we have sender timestamps, revisit coalescing multiple parallel daemon reloads: 1139 http://lists.freedesktop.org/archives/systemd-devel/2014-December/025862.html 1140 1141* figure out when we can use the coarse timers 1142 1143* maybe allow timer units with an empty Units= setting, so that they 1144 can be used for resuming the system but nothing else. 1145 1146* what to do about udev db binary stability for apps? (raw access is not an option) 1147 1148* exponential backoff in timesyncd when we cannot reach a server 1149 1150* timesyncd: add ugly bus calls to set NTP servers per-interface, for usage by NM 1151 1152* merge ~/.local/share and ~/.local/lib into one similar /usr/lib and /usr/share.... 1153 1154* add systemd.abort_on_kill or some other such flag to send SIGABRT instead of SIGKILL 1155 (throughout the codebase, not only PID1) 1156 1157* drop nss-myhostname in favour of nss-resolve? 1158 1159* resolved: 1160 - mDNS/DNS-SD 1161 - service registration 1162 - service/domain/types browsing 1163 - avahi compat 1164 - DNS-SD service registration from socket units 1165 - resolved should optionally register additional per-interface LLMNR 1166 names, so that for the container case we can establish the same name 1167 (maybe "host") for referencing the server, everywhere. 1168 - allow clients to request DNSSEC for a single lookup even if DNSSEC is off (?) 1169 - hook up resolved with machined-based address resolution 1170 1171* refcounting in sd-resolve is borked 1172 1173* add new gpt type for btrfs volumes 1174 1175* generator that automatically discovers btrfs subvolumes, identifies their purpose based on some xattr on them. 1176 1177* a way for container managers to turn off getty starting via $container_headless= or so... 1178 1179* figure out a nice way how we can let the admin know what child/sibling unit causes cgroup membership for a specific unit 1180 1181* For timer units: add some mechanisms so that timer units that trigger immediately on boot do not have the services 1182 they run added to the initial transaction and thus confuse Type=idle. 1183 1184* add bus api to query unit file's X fields. 1185 1186* gpt-auto-generator: 1187 - Define new partition type for encrypted swap? Support probed LUKS for encrypted swap? 1188 - Make /home automount rather than mount? 1189 1190* add generator that pulls in systemd-network from containers when 1191 CAP_NET_ADMIN is set, more than the loopback device is defined, even 1192 when it is otherwise off 1193 1194* MessageQueueMessageSize= (and suchlike) should use parse_iec_size(). 1195 1196* implement Distribute= in socket units to allow running multiple 1197 service instances processing the listening socket, and open this up 1198 for ReusePort= 1199 1200* cgroups: 1201 - implement per-slice CPUFairScheduling=1 switch 1202 - introduce high-level settings for RT budget, swappiness 1203 - how to reset dynamically changed unit cgroup attributes sanely? 1204 - when reloading configuration, apply new cgroup configuration 1205 - when recursively showing the cgroup hierarchy, optionally also show 1206 the hierarchies of child processes 1207 1208* transient units: 1209 - add field to transient units that indicate whether systemd or somebody else saves/restores its settings, for integration with libvirt 1210 1211* when we detect low battery and no AC on boot, show pretty splash and refuse boot 1212 1213* libsystemd-journal, libsystemd-login, libudev: add calls to easily attach these objects to sd-event event loops 1214 1215* be more careful what we export on the bus as (usec_t) 0 and (usec_t) -1 1216 1217* 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 1218 1219* After coming back from hibernation reset hibernation swap partition using the /dev/snapshot ioctl APIs 1220 1221* If we try to find a unit via a dangling symlink, generate a clean 1222 error. Currently, we just ignore it and read the unit from the search 1223 path anyway. 1224 1225* refuse boot if /usr/lib/os-release is missing or /etc/machine-id cannot be set up 1226 1227* man: the documentation of Restart= currently is very misleading and suggests the tools from ExecStartPre= might get restarted. 1228 1229* load .d/*.conf dropins for device units 1230 1231* There's currently no way to cancel fsck (used to be possible via C-c or c on the console) 1232 1233* add option to sockets to avoid activation. Instead just drop packets/connections, see http://cyberelk.net/tim/2012/02/15/portreserve-systemd-solution/ 1234 1235* make sure systemd-ask-password-wall does not shutdown systemd-ask-password-console too early 1236 1237* verify that the AF_UNIX sockets of a service in the fs still exist 1238 when we start a service in order to avoid confusion when a user 1239 assumes starting a service is enough to make it accessible 1240 1241* Make it possible to set the keymap independently from the font on 1242 the kernel cmdline. Right now setting one resets also the other. 1243 1244* and a dbus call to generate target from current state 1245 1246* investigate whether the gnome pty helper should be moved into systemd, to provide cgroup support. 1247 1248* dot output for --test showing the 'initial transaction' 1249 1250* be able to specify a forced restart of service A where service B depends on, in case B 1251 needs to be auto-respawned? 1252 1253* pid1: 1254 - When logging about multiple units (stopping BoundTo units, conflicts, etc.), 1255 log both units as UNIT=, so that journalctl -u triggers on both. 1256 - generate better errors when people try to set transient properties 1257 that are not supported... 1258 http://lists.freedesktop.org/archives/systemd-devel/2015-February/028076.html 1259 - maybe introduce WantsMountsFor=? Usecase: 1260 http://lists.freedesktop.org/archives/systemd-devel/2015-January/027729.html 1261 - recreate systemd's D-Bus private socket file on SIGUSR2 1262 - move PAM code into its own binary 1263 - when we automatically restart a service, ensure we restart its rdeps, too. 1264 - hide PAM options in fragment parser when compile time disabled 1265 - Support --test based on current system state 1266 - 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(). 1267 - after deserializing sockets in socket.c we should reapply sockopts and things 1268 - drop PID 1 reloading, only do reexecing (difficult: Reload() 1269 currently is properly synchronous, Reexec() is weird, because we 1270 cannot delay the response properly until we are back, so instead of 1271 being properly synchronous we just keep open the fd and close it 1272 when done. That means clients do not get a successful method reply, 1273 but much rather a disconnect on success. 1274 - when breaking cycles drop sysv services first, then services from /run, then from /etc, then from /usr 1275 - when a bus name of a service disappears from the bus make sure to queue further activation requests 1276 - maybe introduce CoreScheduling=yes/no to optionally set a PR_SCHED_CORE cookie, so that all 1277 processes in a service's cgroup share the same cookie and are guaranteed not to share SMT cores 1278 with other units https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/tree/Documentation/admin-guide/hw-vuln/core-scheduling.rst 1279 1280* unit files: 1281 - allow port=0 in .socket units 1282 - maybe introduce ExecRestartPre= 1283 - add ReloadSignal= for configuring a reload signal to use 1284 - implement Register= switch in .socket units to enable registration 1285 in Avahi, RPC and other socket registration services. 1286 - allow Type=simple with PIDFile= 1287 https://bugzilla.redhat.com/show_bug.cgi?id=723942 1288 - allow writing multiple conditions in unit files on one line 1289 - introduce Type=pid-file 1290 - add a concept of RemainAfterExit= to scope units 1291 - Allow multiple ExecStart= for all Type= settings, so that we can cover rescue.service nicely 1292 - add verification of [Install] section to systemd-analyze verify 1293 1294* timer units: 1295 - timer units should get the ability to trigger when DST changes 1296 - Modulate timer frequency based on battery state 1297 1298* add libsystemd-password or so to query passwords during boot using the password agent logic 1299 1300* clean up date formatting and parsing so that all absolute/relative timestamps we format can also be parsed 1301 1302* on shutdown: move utmp, wall, audit logic all into PID 1 (or logind?), get rid of systemd-update-utmp-runlevel 1303 1304* make repeated alt-ctrl-del presses printing a dump 1305 1306* currently x-systemd.timeout is lost in the initrd, since crypttab is copied into dracut, but fstab is not 1307 1308* add a pam module that passes the hdd passphrase into the PAM stack and then expires it, for usage by gdm auto-login. 1309 1310* add a pam module that on password changes updates any LUKS slot where the password matches 1311 1312* test/: 1313 - add unit tests for config_parse_device_allow() 1314 1315* seems that when we follow symlinks to units we prefer the symlink 1316 destination path over /etc and /usr. We should not do that. Instead 1317 /etc should always override /run+/usr and also any symlink 1318 destination. 1319 1320* when isolating, try to figure out a way how we implicitly can order 1321 all units we stop before the isolating unit... 1322 1323* teach ConditionKernelCommandLine= globs or regexes (in order to match foobar={no,0,off}) 1324 1325* Add ConditionDirectoryNotEmpty= handle non-absoute paths as a search path or add 1326 ConditionConfigSearchPathNotEmpty= or different syntax? See the discussion starting at 1327 https://github.com/systemd/systemd/pull/15109#issuecomment-607740136. 1328 1329* BootLoaderSpec: Define a way how an installer can figure out whether a BLS 1330 compliant boot loader is installed. 1331 1332* think about requeuing jobs when daemon-reload is issued? usecase: 1333 the initrd issues a reload after fstab from the host is accessible 1334 and we might want to requeue the mounts local-fs acquired through 1335 that automatically. 1336 1337* systemd-inhibit: make taking delay locks useful: support sending SIGINT or SIGTERM on PrepareForSleep() 1338 1339* remove any syslog support from log.c — we probably cannot do this before split-off udev is gone for good 1340 1341* shutdown logging: store to EFI var, and store to USB stick? 1342 1343* merge unit_kill_common() and unit_kill_context() 1344 1345* add a dependency on standard-conf.xml and other included files to man pages 1346 1347* MountFlags=shared acts as MountFlags=slave right now. 1348 1349* properly handle loop back mounts via fstab, especially regards to fsck/passno 1350 1351* initialize the hostname from the fs label of /, if /etc/hostname does not exist? 1352 1353* sd-bus: 1354 - EBADSLT handling 1355 - GetAllProperties() on a non-existing object does not result in a failure currently 1356 - port to sd-resolve for connecting to TCP dbus servers 1357 - see if we can introduce a new sd_bus_get_owner_machine_id() call to retrieve the machine ID of the machine of the bus itself 1358 - see if we can drop more message validation on the sending side 1359 - add API to clone sd_bus_message objects 1360 - longer term: priority inheritance 1361 - dbus spec updates: 1362 - NameLost/NameAcquired obsolete 1363 - GVariant 1364 - path escaping 1365 - update systemd.special(7) to mention that dbus.socket is only about the compatibility socket now 1366 1367* sd-event 1368 - allow multiple signal handlers per signal? 1369 - document chaining of signal handler for SIGCHLD and child handlers 1370 - define more intervals where we will shift wakeup intervals around in, 1h, 6h, 24h, ... 1371 - maybe support iouring as backend, so that we allow hooking read and write 1372 operations instead of IO ready events into event loops. See considerations 1373 here: 1374 http://blog.vmsplice.net/2020/07/rethinking-event-loop-integration-for.html 1375 1376* dbus: when a unit failed to load (i.e. is in UNIT_ERROR state), we 1377 should be able to safely try another attempt when the bus call LoadUnit() is invoked. 1378 1379* maybe do not install getty@tty1.service symlink in /etc but in /usr? 1380 1381* print a nicer explanation if people use variable/specifier expansion in ExecStart= for the first word 1382 1383* mount: turn dependency information from /proc/self/mountinfo into dependency information between systemd units. 1384 1385* firstboot: allow provisioning of /etc/hosts entries, so that we can via the 1386 credentials logic insert host name to resolve into containers/hosts. Usecase: 1387 fork a container, and make it ping some specific address which is defined by 1388 the host on invocation 1389 1390* systemd-firstboot: make sure to always use chase_symlinks() before 1391 reading/writing files 1392 1393* firstboot: make it useful to be run immediately after yum --installroot to set up a machine. (most specifically, make --copy-root-password work even if /etc/passwd already exists 1394 1395* sd-boot: define a drop-in dir in the ESP that may contain X.509 1396 certificates. If the firmware is detected to be in setup mode, automatically 1397 enroll them as PK/KEK/db, turn off setup mode and proceed. Optionally, 1398 instead of auto-enrolling them add them to the sd-boot menu, giving the user 1399 the option to manually enroll them, after selecting the menu entry. This way, 1400 installer images can just drop the certfiicates in the ESP, and on first boot 1401 can easily enroll the keys without ever booting up. 1402 1403* efi stub: optionally, load initrd from disk as a separate file, HMAC check it 1404 with key from TPM, bound to PCR, refusing if failing. This would then allow 1405 traditional distros that generate initrds locally to secure them with TPM: 1406 after generating the initrd, do the HMAC calculation, put result in initrd 1407 filename, done. This would then bind the validity of the initrd to the local 1408 host, and used kernel, and means people cannot change initrd or kernel 1409 without booting the kernel + initrd. 1410 1411* EFI: 1412 - honor language efi variables for default language selection (if there are any?) 1413 - honor timezone efi variables for default timezone selection (if there are any?) 1414 - change bootctl to be backed by systemd-bootd to control temporary and persistent default boot goal plus efi variables 1415* bootctl 1416 - recognize the case when not booted on EFI 1417 1418* bootctl,sd-boot: actually honour the "architecture" key 1419 1420* bootctl: 1421 - show whether UEFI audit mode is available 1422 - teach it to prepare an ESP wholesale, i.e. with mkfs.vfat invocation 1423 - teach it to copy in unified kernel images and maybe type #1 boot loader spec entries from host 1424 - make it operate on loopback files, dissecting enough to find ESP to operate on 1425 - bootspec: properly support boot attempt counters when parsing entry file names 1426 - support --quiet in is-installed, update 1427 1428* kernel-install: 1429 - optionally, support generating type #2 entries instead of type #1, including signing them 1430 1431* logind: 1432 - logind: optionally, ignore idle-hint logic for autosuspend, block suspend as long as a session is around 1433 - logind: wakelock/opportunistic suspend support 1434 - Add pretty name for seats in logind 1435 - logind: allow showing logout dialog from system? 1436 - add Suspend() bus calls which take timestamps to fix double suspend issues when somebody hits suspend and closes laptop quickly. 1437 - if pam_systemd is invoked by su from a process that is outside of a 1438 any session we should probably just become a NOP, since that's 1439 usually not a real user session but just some system code that just 1440 needs setuid(). 1441 - logind: make the Suspend()/Hibernate() bus calls wait for the for 1442 the job to be completed. before returning, so that clients can wait 1443 for "systemctl suspend" to finish to know when the suspending is 1444 complete. 1445 - logind: when the power button is pressed short, just popup a 1446 logout dialog. If it is pressed for 1s, do the usual 1447 shutdown. Inspiration are Macs here. 1448 - expose "Locked" property on logind session objects 1449 - maybe allow configuration of the StopTimeout for session scopes 1450 - rename session scope so that it includes the UID. THat way 1451 the session scope can be arranged freely in slices and we don't have 1452 make assumptions about their slice anymore. 1453 - follow PropertiesChanged state more closely, to deal with quick logouts and 1454 relogins 1455 - (optionally?) spawn seat-manager@$SEAT.service whenever a seat shows up that as CanGraphical set 1456 - expose details of boot entries on the bus. In particular, it should be possible 1457 to query the list of boot entry titles that bootctl / sd-boot would show. 1458 Currently we only expose their identifiers. 1459 1460* move multiseat vid/pid matches from logind udev rule to hwdb 1461 1462* logind: rework pam_logind to also do a bus call in case of invocation from 1463 user@.service, which returns the XDG_RUNTIME_DIR value, and make this 1464 behaviour selectable via pam module option. 1465 1466* delay activation of logind until somebody logs in, or when /dev/tty0 pulls it 1467 in or lingering is on (so that containers don't bother with it until PAM is used). also exit-on-idle 1468 1469* journal: 1470 - consider introducing implicit _TTY= + _PPID= + _EUID= + _EGID= + _FSUID= + _FSGID= fields 1471 - journald: also get thread ID from client, plus thread name 1472 - journal: when waiting for journal additions in the client always sleep at least 1s or so, in order to minimize wakeups 1473 - add API to close/reopen/get fd for journal client fd in libsystemd-journal. 1474 - fall back to /dev/log based logging in libsystemd-journal, if we cannot log natively? 1475 - declare the local journal protocol stable in the wiki interface chart 1476 - sd-journal: speed up sd_journal_get_data() with transparent hash table in bg 1477 - journald: when dropping msgs due to ratelimit make sure to write 1478 "dropped %u messages" not only when we are about to print the next 1479 message that works, but already after a short timeout 1480 - check if we can make journalctl by default use --follow mode inside of less if called without args? 1481 - maybe add API to send pairs of iovecs via sd_journal_send 1482 - journal: add a setgid "systemd-journal" utility to invoke from libsystemd-journal, which passes fds via STDOUT and does PK access 1483 - journactl: support negative filtering, i.e. FOOBAR!="waldo", 1484 and !FOOBAR for events without FOOBAR. 1485 - journal: store timestamp of journal_file_set_offline() in the header, 1486 so it is possible to display when the file was last synced. 1487 - 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. 1488 - journal: find a way to allow dropping history early, based on priority, other rules 1489 - journal: When used on NFS, check payload hashes 1490 - journald: add kernel cmdline option to disable ratelimiting for debug purposes 1491 - refuse taking lower-case variable names in sd_journal_send() and friends. 1492 - journald: we currently rotate only after MaxUse+MaxFilesize has been reached. 1493 - journal: deal nicely with byte-by-byte copied files, especially regards header 1494 - journal: sanely deal with entries which are larger than the individual file size, but where the components would fit 1495 - Replace utmp, wtmp, btmp, and lastlog completely with journal 1496 - journalctl: instead --after-cursor= maybe have a --cursor=XYZ+1 syntax? 1497 - when a kernel driver logs in a tight loop, we should ratelimit that too. 1498 - journald: optionally, log debug messages to /run but everything else to /var 1499 - journald: when we drop syslog messages because the syslog socket is 1500 full, make sure to write how many messages are lost as first thing 1501 to syslog when it works again. 1502 - journald: allow per-priority and per-service retention times when rotating/vacuuming 1503 - journald: make use of uid-range.h to managed uid ranges to split 1504 journals in. 1505 - journalctl: add the ability to look for the most recent process of a binary. journalctl /usr/bin/X11 --pid=-1 or so... 1506 - improve journalctl performance by loading journal files 1507 lazily. Encode just enough information in the file name, so that we 1508 do not have to open it to know that it is not interesting for us, for 1509 the most common operations. 1510 - man: document that corrupted journal files is nothing to act on 1511 - rework journald sigbus stuff to use mutex 1512 - Set RLIMIT_NPROC for systemd-journal-xyz, and all other of our 1513 services that run under their own user ids, and use User= (but only 1514 in a world where userns is ubiquitous since otherwise we cannot 1515 invoke those daemons on the host AND in a container anymore). Also, 1516 if LimitNPROC= is used without User= we should warn and refuse 1517 operation. 1518 - journalctl --verify: don't show files that are currently being 1519 written to as FAIL, but instead show that their are being written to. 1520 - add journalctl -H that talks via ssh to a remote peer and passes through 1521 binary logs data 1522 - add a version of --merge which also merges /var/log/journal/remote 1523 - journalctl: -m should access container journals directly by enumerating 1524 them via machined, and also watch containers coming and going. 1525 Benefit: nspawn --ephemeral would start working nicely with the journal. 1526 - assign MESSAGE_ID to log messages about failed services 1527 - check if loop in decompress_blob_xz() is necessary 1528 1529* journald: support RFC3164 fully for the incoming syslog transport, see 1530 https://github.com/systemd/systemd/issues/19251#issuecomment-816601955 1531 1532* Hook up journald's FSS logic with TPM2: seal the verification disk by 1533 time-based policy, so that the verification key can remain on host and ve 1534 validated via TPM. 1535 1536* build short web pages out of each catalog entry, build them along with man 1537 pages, and include hyperlinks to them in the journal output 1538 1539* journald: do journal file writing out-of-process, with one writer process per 1540 client UID, so that synthetic hash table collisions can slow down a specific 1541 user's journal stream down but not the others. 1542 1543* tweak journald context caching. In addition to caching per-process attributes 1544 keyed by PID, cache per-cgroup attributes (i.e. the various xattrs we read) 1545 keyed by cgroup path, and guarded by ctime changes. This should provide us 1546 with a nice speed-up on services that have many processes running in the same 1547 cgroup. 1548 1549* maybe add call sd_journal_set_block_timeout() or so to set SO_SNDTIMEO for 1550 the sd-journal logging socket, and, if the timeout is set to 0, sets 1551 O_NONBLOCK on it. That way people can control if and when to block for 1552 logging. 1553 1554* journalctl: make sure -f ends when the container indicated by -M terminates 1555 1556* journald: sigbus API via a signal-handler safe function that people may call 1557 from the SIGBUS handler 1558 1559* add a test if all entries in the catalog are properly formatted. 1560 (Adding dashes in a catalog entry currently results in the catalog entry 1561 being silently skipped. journalctl --update-catalog must warn about this, 1562 and we should also have a unit test to check that all our message are OK.) 1563 1564* homed: 1565 - when user tries to log into record signed by unrecognized key, automatically add key to our chain after polkit auth 1566 - rollback when resize fails mid-operation 1567 - GNOME's side for forget key on suspend (requires rework so that lock screen runs outside of uid) 1568 - update LUKS password on login if we find there's a password that unlocks the JSON record but not the LUKS device. 1569 - create on activate? 1570 - properties: icon url?, preferred session type?, administrator bool (which translates to 'wheel' membership)?, address?, telephone?, vcard?, samba stuff?, parental controls? 1571 - communicate clearly when usb stick is safe to remove. probably involves 1572 beefing up logind to make pam session close hook synchronous and wait until 1573 systemd --user is shut down. 1574 - logind: maybe keep a "busy fd" as long as there's a non-released session around or the user@.service 1575 - maybe make automatic, read-only, time-based reflink-copies of LUKS disk 1576 images (and btrfs snapshots of subvolumes) (think: time machine) 1577 - distinguish destroy / remove (i.e. currently we can unregister a user, unregister+remove their home directory, but not just remove their home directory) 1578 - in systemd's PAMName= logic: query passwords with ssh-askpassword, so that we can make "loginctl set-linger" mode work 1579 - fingerprint authentication, pattern authentication, … 1580 - make sure "classic" user records can also be managed by homed 1581 - make size of $XDG_RUNTIME_DIR configurable in user record 1582 - query password from kernel keyring first 1583 - update even if record is "absent" 1584 - move acct mgmt stuff from pam_systemd_home to pam_systemd? 1585 - when "homectl --pkcs11-token-uri=" is used, synthesize ssh-authorized-keys records for all keys we have private keys on the stick for 1586 - make slice for users configurable (requires logind rework) 1587 - logind: populate auto-login list bus property from PKCS#11 token 1588 - when determining state of a LUKS home directory, check DM suspended sysfs file 1589 - when homed is in use, maybe start the user session manager in a mount namespace with MS_SLAVE, 1590 so that mounts propagate down but not up - eg, user A setting up a backup volume 1591 doesn't mean user B sees it 1592 - use credentials logic/TPM2 logic to store homed signing key 1593 - permit multiple user record signing keys to be used locally, and pick 1594 the right one for signing records automatically depending on a pre-existing 1595 signature 1596 - add a way to "adopt" a home directory, i.e. strip foreign signatures 1597 and insert a local signature instead. 1598 - as an extension to the directory+subvolume backend: if located on 1599 especially marked fs, then sync down password into LUKS header of that fs, 1600 and always verify passwords against it too. Bootstrapping is a problem 1601 though: if no one is logged in (or no other user even exists yet), how do you 1602 unlock the volume in order to create the first user and add the first pw. 1603 - support new FS_IOC_ADD_ENCRYPTION_KEY ioctl for setting up fscrypt 1604 - maybe pre-create ~/.cache as subvol so that it can have separate quota 1605 easily? 1606 - add a switch to homectl (maybe called --first-boot) where it will check if 1607 any non-system users exist, and if not prompts interactively for basic user 1608 info, mimicking systemd-firstboot. Then, place this in a service that runs 1609 after systemd-homed, but before gdm and friends, as a simple, barebones 1610 fallback logic to get a regular user created on uninitialized systems. 1611 - store PKCS#11 + FIDO2 token info in LUKS2 header, compatible with 1612 systemd-cryptsetup, so that it can unlock homed volumes 1613 - maybe make all *.home files owned by `systemd-home` user or so, so that we 1614 can easily set overall quota for all users 1615 - on login, if we can't fallocate initially, but rebalance is on, then allow 1616 login in discard mode, then immediately rebalance, then turn off discard 1617 - extend user records with optional "bulk" data. Specifically, a user 1618 avatar/photo or so. This data should be stored along with the user record, 1619 but probably shouldn't be part of the record itself, since it might be 1620 large. 1621 1622* add a new switch --auto-definitions=yes/no or so to systemd-repart. If 1623 specified, synthesize a definition automatically if we can: enlarge last 1624 partition on disk, but only if it is marked for growing and not read-only. 1625 1626* systemd-repart: read LUKS encryption key from $CREDENTIALS_DIRECTORY 1627 1628* systemd-repart: add a switch to factory reset the partition table without 1629 immediately applying the new configuration again. i.e. --factory-reset=leave 1630 or so. (this is useful to factory reset an image, then putting it into 1631 another machine, ensuring that luks key is generated on new machine, not old) 1632 1633* systemd-repart: support setting up dm-integrity with HMAC 1634 1635* systemd-repart: maybe remove half-initialized image on failure. It fails 1636 if the output file exists, so a repeated invocation will usually fail if 1637 something goes wrong on the way. 1638 1639* systemd-repart: drop pager mode on normal operation? 1640 1641* systemd-repart: by default generate minimized partition tables (i.e. tables 1642 that only cover the space actually used, excluding any free space at the 1643 end), in order to maximize dd'ability. Requires libfdisk work, see 1644 https://github.com/karelzak/util-linux/issues/907 1645 1646* systemd-repart: MBR partition table support. Care needs to be taken regarding 1647 Type=, so that partition definitions can sanely apply to both the GPT and the 1648 MBR case. Idea: accept syntax "Type=gpt:home mbr:0x83" for setting the types 1649 for the two partition types explicitly. And provide an internal mapping so 1650 that "Type=linux-generic" maps to the right types for both partition tables 1651 automatically. 1652 1653* systemd-repart: allow sizing partitions as factor of available RAM, so that 1654 we can reasonably size swap partitions for hibernation. 1655 1656* systemd-repart: allow boolean option that ensures that if existing partition 1657 doesn't exist within the configured size bounds the whole command fails. This 1658 is useful to implement ESP vs. XBOOTLDR schemes in installers: have one set 1659 of repart files for the case where ESP is large enough and one where it isn't 1660 and XBOOTLDR is added in instead. Then apply the former first, and if it 1661 fails to apply use the latter. 1662 1663* systemd-repart: add per-partition option to never reuse existing partition 1664 and always create anew even if matching partition already exists. 1665 1666* systemd-repart: add per-partition option to fail if partition already exist, 1667 i.e. is not added new. Similar, add option to fail if partition does not exist yet. 1668 1669* systemd-repart: allow disabling growing of specific partitions, or making 1670 them (think ESP: we don't ever want to grow it, since we cannot resize vfat) 1671 1672* systemd-repart: make it a static checker during early boot for existence and 1673 absence of other partitions for trusted boot environments 1674 1675* document: 1676 - document that deps in [Unit] sections ignore Alias= fields in 1677 [Install] units of other units, unless those units are disabled 1678 - man: clarify that time-sync.target is not only sysv compat but also useful otherwise. Same for similar targets 1679 - document that service reload may be implemented as service reexec 1680 - add a man page containing packaging guidelines and recommending usage of things like Documentation=, PrivateTmp=, PrivateNetwork= and ReadOnlyDirectories=/etc /usr. 1681 - document systemd-journal-flush.service properly 1682 - documentation: recommend to connect the timer units of a service to the service via Also= in [Install] 1683 - man: document the very specific env the shutdown drop-in tools live in 1684 - man: add more examples to man pages, 1685 - in particular an example how to do the equivalent of switching runlevels 1686 - man: maybe sort directives in man pages, and take sections from --help and apply them to man too 1687 - document root=gpt-auto properly 1688 1689* systemctl: 1690 - add systemctl switch to dump transaction without executing it 1691 - Add a verbose mode to "systemctl start" and friends that explains what is being done or not done 1692 - "systemctl disable" on a static unit prints no message and does 1693 nothing. "systemctl enable" does nothing, and gives a bad message 1694 about it. Should fix both to print nice actionable messages. 1695 - print nice message from systemctl --failed if there are no entries shown, and hook that into ExecStartPre of rescue.service/emergency.service 1696 - add new command to systemctl: "systemctl system-reexec" which reexecs as many daemons as virtually possible 1697 - systemctl enable: fail if target to alias into does not exist? maybe show how many units are enabled afterwards? 1698 - systemctl: "Journal has been rotated since unit was started." message is misleading 1699 - systemctl status output should include list of triggering units and their status 1700 1701* introduce an option (or replacement) for "systemctl show" that outputs all 1702 properties as JSON, similar to busctl's new JSON output. In contrast to that 1703 it should skip the variant type string though. 1704 1705* add an explicit "vertical" mode to format-table, so that "systemctl 1706 status"-like outputs (i.e. with a series of field names left and values 1707 right) become genuine first class citizens, and we gain automatic, sane JSON 1708 output for them. 1709 1710* Add a "systemctl list-units --by-slice" mode or so, which rearranges the 1711 output of "systemctl list-units" slightly by showing the tree structure of 1712 the slices, and the units attached to them. 1713 1714* add "systemctl wait" or so, which does what "systemd-run --wait" does, but 1715 for all units. It should be both a way to pin units into memory as well as a 1716 wait to retrieve their exit data. 1717 1718* show whether a service has out-of-date configuration in "systemctl status" by 1719 using mtime data of ConfigurationDirectory=. 1720 1721* "systemctl preset-all" should probably order the unit files it 1722 operates on lexicographically before starting to work, in order to 1723 ensure deterministic behaviour if two unit files conflict (like DMs 1724 do, for example) 1725 1726* add "systemctl start -v foobar.service" that shows logs of a service 1727 while the start command runs. This is non-trivial to do without 1728 races though, since we should flush out all journal messages before 1729 returning from the "systemctl stop". 1730 1731* systemctl: if some operation fails, show log output? 1732 1733* Add a new verb "systemctl top" 1734 1735* unit install: 1736 - "systemctl mask" should find all names by which a unit is accessible 1737 (i.e. by scanning for symlinks to it) and link them all to /dev/null 1738 1739* nspawn: 1740 - emulate /dev/kmsg using CUSE and turn off the syslog syscall 1741 with seccomp. That should provide us with a useful log buffer that 1742 systemd can log to during early boot, and disconnect container logs 1743 from the kernel's logs. 1744 - as soon as networkd has a bus interface, hook up --network-interface=, 1745 --network-bridge= with networkd, to trigger netdev creation should an 1746 interface be missing 1747 - a nice way to boot up without machine id set, so that it is set at boot 1748 automatically for supporting --ephemeral. Maybe hash the host machine id 1749 together with the machine name to generate the machine id for the container 1750 - fix logic always print a final newline on output. 1751 https://github.com/systemd/systemd/pull/272#issuecomment-113153176 1752 - should optionally support receiving WATCHDOG=1 messages from its payload 1753 PID 1... 1754 - optionally automatically add FORWARD rules to iptables whenever nspawn is 1755 running, remove them when shut down. 1756 1757* nspawn: add support for sysext extensions, too. i.e. a new --extension= 1758 switch that takes one or more arguments, and applies the extensions already 1759 during startup. 1760 1761* when main nspawn supervisor process gets suspended due to SIGSTOP/SIGTTOU or 1762 so, freeze the payload too. 1763 1764* machined: add API to acquire UID range. add API to mount/dissect loopback 1765 file. Both protected by PK. Then make nspawn use these APIs to run 1766 unprivileged containers. i.e. push the truly privileged bits into machined, 1767 so that the client side can remain entirely unprivileged, with SUID or 1768 anything like that. 1769 1770* nspawn: support time namespaces 1771 1772* nspawn: on cgroupsv1 issue cgroup empty handler process based on host events, 1773 so that we make cgroup agent logic safe 1774 1775* nspawn/machined: add API to invoke binary in container, then use that as 1776 fallback in "machinectl shell" 1777 1778* nspawn: make nspawn suitable for shell pipelines: instead of triggering a 1779 hangup when input is finished, send ^D, which synthesizes an EOF. Then wait 1780 for hangup or ^D before passing on the EOF. 1781 1782* nspawn: greater control over selinux label? 1783 1784* nspawn: support that /proc, /sys/, /dev are pre-mounted 1785 1786* machined: 1787 - add an API so that libvirt-lxc can inform us about network interfaces being 1788 removed or added to an existing machine 1789 - "machinectl migrate" or similar to copy a container from or to a 1790 difference host, via ssh 1791 - introduce systemd-nspawn-ephemeral@.service, and hook it into 1792 "machinectl start" with a new --ephemeral switch 1793 - "machinectl status" should also show internal logs of the container in 1794 question 1795 - "machinectl history" 1796 - "machinectl diff" 1797 - "machinectl commit" that takes a writable snapshot of a tree, invokes a 1798 shell in it, and marks it read-only after use 1799 1800* udev: 1801 - move to LGPL 1802 - kill scsi_id 1803 - add trigger --subsystem-match=usb/usb_device device 1804 - reimport udev db after MOVE events for devices without dev_t 1805 1806* coredump: 1807 - save coredump in Windows/Mozilla minidump format 1808 - when truncating coredumps, also log the full size that the process had, and make a metadata field so we can report truncated coredumps 1809 1810* support crash reporting operation modes (https://live.gnome.org/GnomeOS/Design/Whiteboards/ProblemReporting) 1811 1812* tmpfiles: 1813 - apply "x" on "D" too (see patch from William Douglas) 1814 - instead of ignoring unknown fields, reject them. 1815 - creating new directories/subvolumes/fifos/device nodes 1816 should not follow symlinks. None of the other adjustment or creation 1817 calls follow symlinks. 1818 - add --test mode 1819 - teach tmpfiles.d q/Q logic something sensible in the context of XFS/ext4 1820 project quota 1821 1822* udev-link-config: 1823 - Make sure ID_PATH is always exported and complete for 1824 network devices where possible, so we can safely rely 1825 on Path= matching 1826 1827* sd-rtnl: 1828 - add support for more attribute types 1829 - inbuilt piping support (essentially degenerate async)? see loopback-setup.c and other places 1830 1831* networkd: 1832 - add more keys to [Route] and [Address] sections 1833 - add support for more DHCPv4 options (and, longer term, other kinds of dynamic config) 1834 - add reduced [Link] support to .network files 1835 - properly handle routerless dhcp leases 1836 - work with non-Ethernet devices 1837 - dhcp: do we allow configuring dhcp routes on interfaces that are not the one we got the dhcp info from? 1838 - the DHCP lease data (such as NTP/DNS) is still made available when 1839 a carrier is lost on a link. It should be removed instantly. 1840 - expose in the API the following bits: 1841 - option 15, domain name 1842 - option 12, hostname and/or option 81, fqdn 1843 - option 123, 144, geolocation 1844 - option 252, configure http proxy (PAC/wpad) 1845 - provide a way to define a per-network interface default metric value 1846 for all routes to it. possibly a second default for DHCP routes. 1847 - allow Name= to be specified repeatedly in the [Match] section. Maybe also 1848 support Name=foo*|bar*|baz ? 1849 - whenever uplink info changes, make DHCP server send out FORCERENEW 1850 1851* in networkd, when matching device types, fix up DEVTYPE rubbish the kernel passes to us 1852 1853* Figure out how to do unittests of networkd's state serialization 1854 1855* dhcp: 1856 - figure out how much we can increase Maximum Message Size 1857 1858* dhcp6: 1859 - add functions to set previously stored IPv6 addresses on startup and get 1860 them at shutdown; store them in client->ia_na 1861 - write more test cases 1862 - implement reconfigure support, see 5.3., 15.11. and 22.20. 1863 - implement support for temporary adressess (IA_TA) 1864 - implement dhcpv6 authentication 1865 - investigate the usefulness of Confirm messages; i.e. are there any 1866 situations where the link changes without any loss in carrier detection 1867 or interface down 1868 - some servers don't do rapid commit without a filled in IA_NA, verify 1869 this behavior 1870 - RouteTable= ? 1871