]> git.ipfire.org Git - thirdparty/systemd.git/log
thirdparty/systemd.git
21 months agotest-resolve: add basic test for SVCB/HTTPS RRs 30661/head
Ronan Pigott [Sat, 6 Jan 2024 20:29:42 +0000 (13:29 -0700)] 
test-resolve: add basic test for SVCB/HTTPS RRs

21 months agoresolvectl: add SVCB and HTTPS json format
Ronan Pigott [Fri, 29 Dec 2023 18:30:38 +0000 (11:30 -0700)] 
resolvectl: add SVCB and HTTPS json format

21 months agoresolvectl: implement SVCB and HTTPS presentation format
Ronan Pigott [Fri, 29 Dec 2023 18:30:18 +0000 (11:30 -0700)] 
resolvectl: implement SVCB and HTTPS presentation format

21 months agoescape: introduce decescape
Ronan Pigott [Thu, 4 Jan 2024 01:53:28 +0000 (18:53 -0700)] 
escape: introduce decescape

This 3-digit decimal escape style is useful when presenting DNS RR
information in zone-file presentation format.

21 months agoresolved: enable RFC9460 SVCB and HTTPS records
Ronan Pigott [Fri, 29 Dec 2023 18:29:13 +0000 (11:29 -0700)] 
resolved: enable RFC9460 SVCB and HTTPS records

21 months agodns: add svcparam iana enum constants
Ronan Pigott [Fri, 29 Dec 2023 18:28:08 +0000 (11:28 -0700)] 
dns: add svcparam iana enum constants

22 months agotmpfiles: add --purge switch
Luca Boccassi [Wed, 12 Oct 2022 22:46:28 +0000 (23:46 +0100)] 
tmpfiles: add --purge switch

Any file/directory created by a tmpfiles.d will be deleted. Useful for
purge/factory reset patterns.

22 months agoMerge pull request #30744 from poettering/logind-trivial-tweaks
Lennart Poettering [Thu, 4 Jan 2024 15:02:20 +0000 (16:02 +0100)] 
Merge pull request #30744 from poettering/logind-trivial-tweaks

logind: 3 trivial cleanups

22 months agologind: do TTY idle logic only for sessions marked as "tty"
Lennart Poettering [Wed, 29 Nov 2023 10:09:20 +0000 (11:09 +0100)] 
logind: do TTY idle logic only for sessions marked as "tty"

Otherwise things might be weird, because background sessions might
become "idle", wich doesn#t really make much sense.

This shouldn't change much in 99% of the cases, but slightly corrects
behaviour as it ensures only "primary"/"foreground" sessions get the
idle logic, i.e. where a user exists that could actually make it
non-idle.

22 months agoupdate TODO
Lennart Poettering [Fri, 24 Nov 2023 12:24:49 +0000 (13:24 +0100)] 
update TODO

22 months agologind: don't make idle action timer accuracy more coarse than timeout
Lennart Poettering [Wed, 29 Nov 2023 10:07:08 +0000 (11:07 +0100)] 
logind: don't make idle action timer accuracy more coarse than timeout

If we allow the timer accuracy to grow larger then the timeout itself
things are very confusing, because people might set a 1s time-out and we
turn that into 30s.

Hence, let's just cut off the 30s accuracy to the time-out itself, so
that we stay close to what users configured.

22 months agoMerge pull request #30739 from poettering/pam-util-many
Yu Watanabe [Thu, 4 Jan 2024 14:28:34 +0000 (23:28 +0900)] 
Merge pull request #30739 from poettering/pam-util-many

pam-util: add pam_get_item_many() to shorten some code

22 months agohomed: when empty username is passed to bus calls, operate on client's UID
Lennart Poettering [Fri, 13 May 2022 22:03:01 +0000 (00:03 +0200)] 
homed: when empty username is passed to bus calls, operate on client's UID

22 months agohomed: fix home_count_bad_authentication() counting
Lennart Poettering [Tue, 28 Nov 2023 08:52:17 +0000 (09:52 +0100)] 
homed: fix home_count_bad_authentication() counting

We want to cover not only regular bad password entries, but also bad
recovery key entries. Hence let's move the list of errors into the
function, and add more.

22 months agohomed: tone down log message about bad passwords a bit
Lennart Poettering [Tue, 28 Nov 2023 08:59:30 +0000 (09:59 +0100)] 
homed: tone down log message about bad passwords a bit

We usually start out out authentication cycles with an "empty" password
attempt, to give homed the chance to authenticated via any plugged in
tokens. Hence frequently the first attempt will just fail, which is no
reason to complain about.

22 months agoMerge pull request #30610 from YHNdnzj/logind-serialize-pidref
Yu Watanabe [Thu, 4 Jan 2024 14:25:18 +0000 (23:25 +0900)] 
Merge pull request #30610 from YHNdnzj/logind-serialize-pidref

logind: serialize session leader pidfd to fdstore

22 months agonetwork/route: make the route section invalid when an invalid MTUBytes= is specified
Yu Watanabe [Tue, 2 Jan 2024 19:42:22 +0000 (04:42 +0900)] 
network/route: make the route section invalid when an invalid MTUBytes= is specified

We usually set the invalid flag for a section if a setting in the section has
an invalid value. Let's also do the same thing for MTUBytes= in [Route].

22 months agoMerge pull request #30578 from bluca/polkit-varlink
Lennart Poettering [Thu, 4 Jan 2024 14:15:45 +0000 (15:15 +0100)] 
Merge pull request #30578 from bluca/polkit-varlink

varlink: add glue to allow authenticating varlink connections via polkit

22 months agoupdate-man-rules: skip over standard-conf.xml
Frantisek Sumsal [Thu, 4 Jan 2024 10:31:11 +0000 (11:31 +0100)] 
update-man-rules: skip over standard-conf.xml

bc6fdcbf5d switched its doctype to refentry, so the script started
picking it up and complaining that it's missing required stuff. Since
this file is only included from other man pages, let's skip it when
putting together a list of valid targets.

Resolves: #30715
Follow-up for: bc6fdcbf5d

22 months agoMerge pull request #30736 from YHNdnzj/loginctl-self
Lennart Poettering [Thu, 4 Jan 2024 14:02:05 +0000 (15:02 +0100)] 
Merge pull request #30736 from YHNdnzj/loginctl-self

man/loginctl: some improvements

22 months agohomed: add missing bus call to homed access policy
Lennart Poettering [Mon, 27 Nov 2023 16:10:35 +0000 (17:10 +0100)] 
homed: add missing bus call to homed access policy

22 months agopam_systemd: drop unnecessary strempty() of 'tty' variable
Lennart Poettering [Mon, 27 Nov 2023 16:22:54 +0000 (17:22 +0100)] 
pam_systemd: drop unnecessary strempty() of 'tty' variable

This probably predates our introduction of streq_ptr(). Let's drop this
now however, as we actually want this to be NULL, further down, and
handle that just fine. In particular as all the special cases we have
explicitly set this to NULL anyway.

No real change in behaviour, just some normalization of handling.

22 months agoexecute: make sure Type=exec and PAMName= work together
Lennart Poettering [Wed, 29 Nov 2023 11:49:37 +0000 (12:49 +0100)] 
execute: make sure Type=exec and PAMName= work together

If PAMName= is used we'll spawn a PAM session for the service, and leave
a process around that closes the PAM session eventually. That process
must close the "exec_fd" that we use to implement Type=exec. After all
the logic relies on the fact that execve() will implicitly close the
exec_fd, and the EOF seen on it is hence indication for the service
manager that execve() has worked. But if we keep an fd open in the PAM
service process, then this is not going to work.

Hence close the fd explicitly so that it definitely doesn't stay pinned
in the child.

22 months agoFix typo in verb_make_policy explanation
Alberto Planas [Thu, 4 Jan 2024 12:32:59 +0000 (13:32 +0100)] 
Fix typo in verb_make_policy explanation

Signed-off-by: Alberto Planas <aplanas@suse.com>
22 months agoMerge pull request #30725 from YHNdnzj/string-util
Mike Yuan [Thu, 4 Jan 2024 12:34:41 +0000 (20:34 +0800)] 
Merge pull request #30725 from YHNdnzj/string-util

string-util,strv: follow-ups

22 months agonetwork/netdev: call done() per netdev kind before freeing netdev name or so
Yu Watanabe [Wed, 3 Jan 2024 19:10:31 +0000 (04:10 +0900)] 
network/netdev: call done() per netdev kind before freeing netdev name or so

Otherwise, log_netdev_xyz() does not provide netdev name if it is called
in done(). It is hard to debug.

This should not change any effective behavior, at least with the current
implementation of done() per netdev kind.

22 months agotpm2-generator: sort includes
Mike Yuan [Thu, 4 Jan 2024 08:53:45 +0000 (16:53 +0800)] 
tpm2-generator: sort includes

22 months agologind: use FOREACH_ARRAY() where appropriate
Lennart Poettering [Mon, 27 Nov 2023 15:55:31 +0000 (16:55 +0100)] 
logind: use FOREACH_ARRAY() where appropriate

22 months agopam_systemd_home: minor coding style adjustment 30744/head
Lennart Poettering [Tue, 28 Nov 2023 14:42:08 +0000 (15:42 +0100)] 
pam_systemd_home: minor coding style adjustment

22 months agohomed: add some function parameter assert()s
Lennart Poettering [Mon, 27 Nov 2023 16:10:14 +0000 (17:10 +0100)] 
homed: add some function parameter assert()s

22 months agologind: cast various calls that return errors we ignore to (void)
Lennart Poettering [Wed, 29 Nov 2023 10:06:36 +0000 (11:06 +0100)] 
logind: cast various calls that return errors we ignore to (void)

22 months agopam_systemd_home: port over to pam_get_item_many() 30739/head
Lennart Poettering [Tue, 28 Nov 2023 08:31:04 +0000 (09:31 +0100)] 
pam_systemd_home: port over to pam_get_item_many()

22 months agopam_systemd: move over to pam_get_item_many()
Lennart Poettering [Tue, 28 Nov 2023 08:30:32 +0000 (09:30 +0100)] 
pam_systemd: move over to pam_get_item_many()

22 months agoman/loginctl: document "self" and "auto" special session IDs 30736/head
Mike Yuan [Thu, 4 Jan 2024 11:08:38 +0000 (19:08 +0800)] 
man/loginctl: document "self" and "auto" special session IDs

session-status automatically uses "auto" if no ID is specified,
but show-session shows the manager's properties. Let's document
these special values so that users of show-session can benefit too.

22 months agopam-util: add pam_get_item_many() helper that gets many PAM items at once
Lennart Poettering [Tue, 28 Nov 2023 08:29:58 +0000 (09:29 +0100)] 
pam-util: add pam_get_item_many() helper that gets many PAM items at once

Just to shorten a bit of code.

22 months agoman/loginctl: use <literal> to quote possible values of --kill-whom=
Mike Yuan [Thu, 4 Jan 2024 10:59:38 +0000 (18:59 +0800)] 
man/loginctl: use <literal> to quote possible values of --kill-whom=

22 months agoTEST-35-LOGIN: enable FileDescriptorStorePreserve= for coldplug test 30610/head
Mike Yuan [Thu, 4 Jan 2024 09:02:17 +0000 (17:02 +0800)] 
TEST-35-LOGIN: enable FileDescriptorStorePreserve= for coldplug test

22 months agoMerge pull request #30513 from rpigott/resolved-ede
Lennart Poettering [Thu, 4 Jan 2024 08:59:19 +0000 (09:59 +0100)] 
Merge pull request #30513 from rpigott/resolved-ede

resolved: support RFC 8914 EDE error codes

22 months agostrv: rename strv_endswith to endswith_strv and dedup ENDSWITH_SET 30725/head
Mike Yuan [Thu, 4 Jan 2024 08:45:54 +0000 (16:45 +0800)] 
strv: rename strv_endswith to endswith_strv and dedup ENDSWITH_SET

22 months agostring-util: move startswith_strv to strv
Mike Yuan [Thu, 4 Jan 2024 08:44:15 +0000 (16:44 +0800)] 
string-util: move startswith_strv to strv

22 months agostring-util: use strneq
Mike Yuan [Thu, 4 Jan 2024 08:48:42 +0000 (16:48 +0800)] 
string-util: use strneq

22 months agostring-util-fundamental: postfix -> suffix, use streq
Mike Yuan [Thu, 4 Jan 2024 08:30:10 +0000 (16:30 +0800)] 
string-util-fundamental: postfix -> suffix, use streq

22 months agologind-session: watch pidfd in session_set_leader_consume
Mike Yuan [Sun, 24 Dec 2023 11:06:01 +0000 (19:06 +0800)] 
logind-session: watch pidfd in session_set_leader_consume

22 months agologind: serialize session leader pidfd to fdstore
Mike Yuan [Tue, 21 Nov 2023 09:25:23 +0000 (17:25 +0800)] 
logind: serialize session leader pidfd to fdstore

22 months agoprocess-util: ensure pidref_is_alive only return ESRCH if not set
Mike Yuan [Sat, 23 Dec 2023 11:08:22 +0000 (19:08 +0800)] 
process-util: ensure pidref_is_alive only return ESRCH if not set

22 months agologind-session: use one_zero where appropriate
Mike Yuan [Wed, 3 Jan 2024 04:13:42 +0000 (12:13 +0800)] 
logind-session: use one_zero where appropriate

22 months agologind-session: be tolerant if we failed to remove leader from hashmap
Mike Yuan [Tue, 26 Dec 2023 06:20:36 +0000 (14:20 +0800)] 
logind-session: be tolerant if we failed to remove leader from hashmap

If something wrong happened before hashmap_put(), session_free()
may be called through gc logic, and the assertion is triggered.

22 months agologind: use RET_GATHER more, return first error
Mike Yuan [Tue, 21 Nov 2023 10:00:48 +0000 (18:00 +0800)] 
logind: use RET_GATHER more, return first error

22 months agoresolved: add transaction result for upstream failures 30513/head
Ronan Pigott [Fri, 22 Dec 2023 04:50:45 +0000 (21:50 -0700)] 
resolved: add transaction result for upstream failures

This new transaction result is emitted when the upstream server
indicates a fatal error that we will not try to recover from.

Currently, it is emitted when a validating recursive resolver reports an
error validating dnssec records for a domain. The extended error message
should help give context to the admin.

22 months agoresolved: support RFC 8914 EDE error codes
Ronan Pigott [Mon, 18 Dec 2023 05:33:31 +0000 (22:33 -0700)] 
resolved: support RFC 8914 EDE error codes

If the server is able to indicate an extended error to us, using a
degraded feature set is unlikely to help.

22 months agoresolved: delay server feature detection
Ronan Pigott [Wed, 20 Dec 2023 22:16:41 +0000 (15:16 -0700)] 
resolved: delay server feature detection

Some fields of the DnsPacket are not populated until we extract an
answer, like p->opt, despite being referenced by macros like
DNS_PACKET_RCODE. We can reorder some of the basic checks to follow
dns_packet_extract.

22 months agodns: remove some magic numbers
Ronan Pigott [Mon, 18 Dec 2023 04:30:03 +0000 (21:30 -0700)] 
dns: remove some magic numbers

Let's use enum values for the EDNS codes now that we have them, for
readability.

22 months agodns: introduce more EDNS codes from IANA
Ronan Pigott [Mon, 18 Dec 2023 00:41:47 +0000 (17:41 -0700)] 
dns: introduce more EDNS codes from IANA

22 months agoMerge pull request #26663 from poettering/vpick
Lennart Poettering [Wed, 3 Jan 2024 21:17:32 +0000 (22:17 +0100)] 
Merge pull request #26663 from poettering/vpick

add new "vpick" concept for automatically picking newest resource from .v/ dir containing versioned files

22 months agoMerge pull request #28797 from Werkov/eff_limits
Yu Watanabe [Wed, 3 Jan 2024 20:38:06 +0000 (05:38 +0900)] 
Merge pull request #28797 from Werkov/eff_limits

Add MemoryMaxEffective=, MemoryHighEffective= and TasksMaxEff…  …ective= properties

22 months agologind: don't setup idle session watch for lock-screen and greeter
Michal Sekletar [Tue, 12 Dec 2023 18:03:39 +0000 (19:03 +0100)] 
logind: don't setup idle session watch for lock-screen and greeter

Reason to skip the idle session logic for these session classes is that
they are idle by default.

22 months agobasic: fix overflow detection in sigbus_pop
Rose [Tue, 2 Jan 2024 15:13:27 +0000 (10:13 -0500)] 
basic: fix overflow detection in sigbus_pop

The current check checks for n_sigbus_queue
being greater than or equal to SIGBUS_QUEUE_MAX,
when it should be just greater than as
n_sigbus_queue being SIGBUS_QUEUE_MAX indicates
that the queue is full, but not overflowed.

22 months agoMerge pull request #30710 from YHNdnzj/logind-ret-gather
Yu Watanabe [Wed, 3 Jan 2024 20:25:41 +0000 (05:25 +0900)] 
Merge pull request #30710 from YHNdnzj/logind-ret-gather

logind-session: modernization

22 months agotest: temporarily adjust the default mount rate limit
Frantisek Sumsal [Wed, 3 Jan 2024 18:00:39 +0000 (19:00 +0100)] 
test: temporarily adjust the default mount rate limit

(Hopefully) a temporary workaround for #30573 where starting a user
session when PID 1 is rate limited stalls even after it leaves the rate
limited state:

[   11.658201] H systemd[1]: Sent message type=signal sender=n/a destination=n/a path=/org/freedesktop/systemd1 interface=org.freedesktop.systemd1.Manager member=UnitRemoved cookie=4208 reply_cookie=0 signature=so error-name=n/a error-mes>
[   11.658233] H systemd[1]: Event source 0x559babdd8bb0 (mount-monitor-dispatch) left rate limit state.
[  101.562697] H busctl[784]: Failed to get credentials: Transport endpoint is not connected
[  101.563480] H systemd[1]: systemd-journald.service: Got notification message from PID 300 (WATCHDOG=1)
[  101.563725] H testsuite-74.sh[784]: BusAddress=unixexec:path=systemd-run,argv1=-M.host,argv2=-PGq,argv3=--wait,argv4=-pUser%3dtestuser,argv5=-pPAMName%3dlogin,argv6=systemd-stdio-bridge,argv7=-punix:path%3d%24%7bXDG_RUNTIME_DIR%7d/bus
[  101.564136] H systemd[1]: Successfully forked off '(sd-expire)' as PID 787.
[  101.564754] H systemd[1]: Successfully forked off '(sd-expire)' as PID 788.
[  101.564831] H testsuite-74.sh[381]: + echo 'Subtest /usr/lib/systemd/tests/testdata/units/testsuite-74.busctl.sh failed'

The issue appeared after ee07fff03b which does a bunch of mounts/umounts
that get PID 1 into a rate limited state, and is frequent enough to be
annoying, so let's temporarily bump the rate limit to alleviate that.

22 months agotest: install correct kpartx udev rules on Debian
Frantisek Sumsal [Wed, 3 Jan 2024 16:24:03 +0000 (17:24 +0100)] 
test: install correct kpartx udev rules on Debian

Resolves: #30703

22 months agoMerge pull request #30532 from yuwata/udev-extend-timeout-kill-worker
Yu Watanabe [Wed, 3 Jan 2024 20:21:50 +0000 (05:21 +0900)] 
Merge pull request #30532 from yuwata/udev-extend-timeout-kill-worker

udev: extend timeout to prevent kill worker

22 months agoMerge pull request #28836 from msekletar/aux-scope
Yu Watanabe [Wed, 3 Jan 2024 19:52:39 +0000 (04:52 +0900)] 
Merge pull request #28836 from msekletar/aux-scope

core/manager: add dbus API to create auxiliary scope from running service

22 months agoFix KeepCarrier tun/tap device option
Dmitry Konishchev [Sat, 16 Dec 2023 16:41:57 +0000 (19:41 +0300)] 
Fix KeepCarrier tun/tap device option

When KeepCarrier is set, networkd doesn't close tun/tap file descriptor
preserving the active interface state, but doesn't disable its queue
which makes kernel to think that it's still active and send packets to
it.

This patch disables the created queue right after tun/tap interface
creation.

Here is the steps to reproduce the bug:

Having:

systemd/network/10-tun-test.netdev:

    [NetDev]
    Name=tun-test
    Kind=tun

    [Tun]
    MultiQueue=yes
    KeepCarrier=yes

systemd/network/10-tun-test.network:

    [Match]
    Name=tun-test

    [Network]
    DHCP=no
    IPv6AcceptRA=false

    LLMNR=false
    MulticastDNS=false

    Address=172.31.0.1/24

app.c:

    #include <fcntl.h>
    #include <stdio.h>
    #include <string.h>
    #include <unistd.h>
    #include <linux/if.h>
    #include <sys/ioctl.h>
    #include <linux/if_tun.h>

    int main() {
        int fd;
        struct ifreq ifr;

        memset(&ifr, 0, sizeof ifr);
        strcpy(ifr.ifr_name, "tun-test");
        ifr.ifr_flags = IFF_TUN | IFF_NO_PI | IFF_MULTI_QUEUE;

        if((fd = open("/dev/net/tun", O_RDWR)) < 0) {
            perror("Open error");
            return 1;
        }

        if(ioctl(fd, TUNSETIFF, &ifr)) {
            perror("Configure error");
            return 1;
        }

        puts("Ready.");

        char buf[1500];

        while(1) {
            int size = read(fd, buf, sizeof buf);
            if(size < 0) {
                perror("Read error");
                return 1;
            }
            printf("Read %d bytes.\n", size);
        }

        return 0;
    }

Run:
* gcc -o app app.c && ./app
* ping -I tun-test 172.31.0.2

Before the patch the app shows no pings, but after it works properly.

22 months agoupdate TODO 26663/head
Lennart Poettering [Fri, 3 Mar 2023 17:55:18 +0000 (18:55 +0100)] 
update TODO

22 months agotests: add integration tests for vpick logic
Lennart Poettering [Thu, 16 Nov 2023 15:40:54 +0000 (16:40 +0100)] 
tests: add integration tests for vpick logic

22 months agoman: document the new vpick concept
Lennart Poettering [Thu, 16 Nov 2023 10:31:02 +0000 (11:31 +0100)] 
man: document the new vpick concept

22 months agodiscover-image: add support for vpick
Lennart Poettering [Wed, 15 Nov 2023 17:36:24 +0000 (18:36 +0100)] 
discover-image: add support for vpick

22 months agoexecute: teach RootDirectory= and RootImage= the new vpick logic
Lennart Poettering [Mon, 13 Nov 2023 17:01:19 +0000 (18:01 +0100)] 
execute: teach RootDirectory= and RootImage= the new vpick logic

22 months agodissect: port to vpick for selecting image
Lennart Poettering [Tue, 20 Jun 2023 20:05:53 +0000 (22:05 +0200)] 
dissect: port to vpick for selecting image

22 months agonspawn: hook up --image=/--directory=/--template= with vpick logic
Lennart Poettering [Fri, 3 Mar 2023 17:25:37 +0000 (18:25 +0100)] 
nspawn: hook up --image=/--directory=/--template= with vpick logic

22 months agovpick: add new tool "systemd-vpick" which exposes vpick on the command line
Lennart Poettering [Fri, 3 Mar 2023 17:26:45 +0000 (18:26 +0100)] 
vpick: add new tool "systemd-vpick" which exposes vpick on the command line

Usecase:

    $ du $(systemd-vpick /srv/myimages.v/foo___.raw)

In order to determine size of newest image in /srv/myimages.v/

22 months agoshared: add new "vpick" concept for ".v/" directories that contain versioned resources
Lennart Poettering [Fri, 3 Mar 2023 17:18:05 +0000 (18:18 +0100)] 
shared: add new "vpick" concept for ".v/" directories that contain versioned resources

This adds a new concept for handling paths. At appropriate places, if a
path such as /foo/bar/baz.v/ is specified, we'll
automatically enumerate all entries in /foo/bar/baz.v/baz* and then
do a version sort and pick the newest file.

A slightly more complex syntax is available, too:

/foo/bar/baz.v/quux___waldo

if that's used, then we'll look for all files matching
/foo/bar/baz.v/quux*waldo, and split out the middle, and version sort
it, and pick the nwest.

The ___ wildcard indicates both a version string, and if needed an
architecture ID, in case per-arch entries shall be supported.

This is a very simple way to maintain versioned resources in a dir, and
make systemd's components automatically pick the newest. Example:

    /srv/myimages.v/foobar_1.32.65_x86-64.raw
    /srv/myimages.v/foobar_1.33.45_x86-64.raw
    /srv/myimages.v/foobar_1.31.5_x86-64.raw
    /srv/myimages.v/foobar_1.31.5_arm64.raw

If now nspawn is invoked like this:

    systemd-nspawn --image=/srv/myimages.v/foobar___.raw

Then it will automatically pick
/srv/myimages.v/foobar_1.33.45_x86-64.raw as the version to boot on
x86-64, and /srv/myimages.v/foobar_1.31.5_arm64.raw on arm64.

This commit only adds the basic implementation for picking files from a
dir, but no hook-up anywhere.

22 months agostat-util: add inode_type_from_string() helper
Lennart Poettering [Tue, 20 Jun 2023 14:18:37 +0000 (16:18 +0200)] 
stat-util: add inode_type_from_string() helper

22 months agostring-util: add strrstr() helper
Lennart Poettering [Fri, 3 Mar 2023 13:01:02 +0000 (14:01 +0100)] 
string-util: add strrstr() helper

22 months agostrv: add new strv_endswith() helper
Lennart Poettering [Wed, 15 Nov 2023 15:55:22 +0000 (16:55 +0100)] 
strv: add new strv_endswith() helper

22 months agoMerge pull request #29940 from poettering/stub-confext-pickup
Lennart Poettering [Wed, 3 Jan 2024 16:40:36 +0000 (17:40 +0100)] 
Merge pull request #29940 from poettering/stub-confext-pickup

stub/sysext: pick up confexts from ESP, too

22 months agoMerge pull request #30194 from poettering/tpm-target
Lennart Poettering [Wed, 3 Jan 2024 16:40:17 +0000 (17:40 +0100)] 
Merge pull request #30194 from poettering/tpm-target

units: add a tpm2.target synchronization point and small generator that pulls in

22 months agologind-session: use RET_GATHER more 30710/head
Mike Yuan [Wed, 3 Jan 2024 15:18:46 +0000 (23:18 +0800)] 
logind-session: use RET_GATHER more

22 months agologind-session-device: trivial modernizations
Mike Yuan [Wed, 3 Jan 2024 15:15:14 +0000 (23:15 +0800)] 
logind-session-device: trivial modernizations

22 months agolabeler: add matches for login and logind
Mike Yuan [Wed, 3 Jan 2024 14:09:52 +0000 (22:09 +0800)] 
labeler: add matches for login and logind

22 months agoMerge pull request #30704 from yuwata/sd-dhcp-server-lease
Lennart Poettering [Wed, 3 Jan 2024 12:58:30 +0000 (13:58 +0100)] 
Merge pull request #30704 from yuwata/sd-dhcp-server-lease

dhcp-server: use sd_dhcp_client_id and split out lease handling to sd-dhcp-server-lease.[ch]

22 months agoMerge pull request #30697 from yuwata/network-address-remove-and-cancel
Lennart Poettering [Wed, 3 Jan 2024 12:55:26 +0000 (13:55 +0100)] 
Merge pull request #30697 from yuwata/network-address-remove-and-cancel

network/address: several cleanups for address removal

22 months agotpm2-util: handle TPMs gracefully that do not support ECC and return TPM2_RC_VALUES
Lennart Poettering [Tue, 2 Jan 2024 17:33:37 +0000 (18:33 +0100)] 
tpm2-util: handle TPMs gracefully that do not support ECC and return TPM2_RC_VALUES

If a TPM doesn't do ECC it could either return zero curves when asked
for it, or it could simply fail with TPM2_RC_VALUES because it doesn't
recognize the capability at all.

Handle both cases the same way.

Fixes: #30679
22 months agotests: add test for StartAuxiliaryScope() 28836/head
Michal Sekletar [Mon, 30 Oct 2023 11:12:28 +0000 (12:12 +0100)] 
tests: add test for StartAuxiliaryScope()

22 months agocore/manager: add dbus API to create auxiliary scope from running service
Michal Sekletar [Mon, 30 Oct 2023 11:08:59 +0000 (12:08 +0100)] 
core/manager: add dbus API to create auxiliary scope from running service

This commit introduces new D-Bus API, StartAuxiliaryScope(). It may be
used by services as part of the restart procedure. Service sends an
array of PID file descriptors corresponding to processes that are part
of the service and must continue running also after service restarts,
i.e. they haven't finished the job why they were spawned in the first
place (e.g. long running video transcoding job). Systemd creates new
scope unit for these processes and migrates them into it. Cgroup
properties of scope are copied from the service so it retains same
cgroup settings and limits as service had.

22 months agoupdate TODO 30194/head
Lennart Poettering [Fri, 24 Nov 2023 17:05:16 +0000 (18:05 +0100)] 
update TODO

22 months agounits: add a tpm2.target synchronization point and small generator that pulls in
Lennart Poettering [Fri, 24 Nov 2023 17:01:56 +0000 (18:01 +0100)] 
units: add a tpm2.target synchronization point and small generator that pulls in

Distributions apparently only compile a subset of TPM2 drivers into the
kernel. For those not compiled it but provided as kmod we need a
synchronization point: we must wait before the first TPM2 interaction
until the driver is available and accessible.

This adds a tpm2.target unit as such a synchronization point. It's
ordered after /dev/tpmrm0, and is pulled in by a generator whenever we
detect that the kernel reported a TPM2 to exist but we have no device
for it yet.

This should solve the issue, but might create problems: if there are TPM
devices supported by firmware that we don't have Linux drivers for we'll
hang for a bit. Hence let's add a kernel cmdline switch to disable (or
alternatively force) this logic.

Fixes: #30164
22 months agotest-64: only look at plugged devices, not all of them
Lennart Poettering [Wed, 29 Nov 2023 21:34:34 +0000 (22:34 +0100)] 
test-64: only look at plugged devices, not all of them

22 months agocgroup: Restrict effective limits with global resource provision 28797/head
Michal Koutný [Mon, 14 Aug 2023 17:59:57 +0000 (19:59 +0200)] 
cgroup: Restrict effective limits with global resource provision

Global resource (whole system or root cg's (e.g. in a container)) is
also a well-defined limit for memory and tasks, take it into account
when calculating effective limits.

22 months agotest: Add effective cgroup limits testing
Michal Koutný [Wed, 9 Aug 2023 20:43:31 +0000 (22:43 +0200)] 
test: Add effective cgroup limits testing

22 months agotest: Convert rlimit test to subtest of generic limit testing
Michal Koutný [Wed, 9 Aug 2023 20:42:36 +0000 (22:42 +0200)] 
test: Convert rlimit test to subtest of generic limit testing

No functional change intended. Preparation for new tests.

22 months agocgroup: Add EffectiveMemoryMax=, EffectiveMemoryHigh= and EffectiveTasksMax= properties
Michal Koutný [Fri, 11 Aug 2023 11:51:20 +0000 (13:51 +0200)] 
cgroup: Add EffectiveMemoryMax=, EffectiveMemoryHigh= and EffectiveTasksMax= properties

Users become perplexed when they run their workload in a unit with no
explicit limits configured (moreover, listing the limit property would
even show it's infinity) but they experience unexpected resource
limitation.

The memory and pid limits come as the most visible, therefore add new
unit read-only properties:
- EffectiveMemoryMax=,
- EffectiveMemoryHigh=,
- EffectiveTasksMax=.

These properties represent the most stringent limit systemd is aware of
for the given unit -- and that is typically(*) the effective value.

Implement the properties by simply traversing all parents in the
leaf-slice tree and picking the minimum value. Note that effective
limits are thus defined even for units that don't enable explicit
accounting (because of the hierarchy).

(*) The evasive case is when systemd runs in a cgroupns and cannot
reason about outer setup. Complete solution would need kernel support.

22 months agoresolve/mdns: do not append goodby packet entries to known answers section
Yu Watanabe [Tue, 2 Jan 2024 19:36:47 +0000 (04:36 +0900)] 
resolve/mdns: do not append goodby packet entries to known answers section

When we receive a goodby packet about a host, and we have a cache entry about
the host, we do not immediately remove the cache entry, but update it with TTL 1.
See RFC 6762 section 10.1 and 3755027c2cada70345c96787a9b5569994dd23ed.

If we receive a request soon after the goodby packet, previously the
entry was included in the known answers section of the reply. But such
information should not be appended.

Follow-up for 3755027c2cada70345c96787a9b5569994dd23ed.

22 months agovarlink: avoid logging content of message if it contains sensitive data 30578/head
Luca Boccassi [Fri, 22 Dec 2023 00:57:39 +0000 (01:57 +0100)] 
varlink: avoid logging content of message if it contains sensitive data

This is important now that creds are sent via varlink

 systemd-creds[463]: varlink-3: Sending message: {"parameters":{"data":"Zm9vYmFyCg=="}}
 systemd-creds[462]: varlink-3: New incoming message: {"method":"io.systemd.Credentials.Encrypt","parameters":{"data":"Zm9vYmFyCg=="}}

22 months agojson: add JSON_FORMAT_REFUSE_SENSITIVE to json_variant_format()
Luca Boccassi [Fri, 22 Dec 2023 22:23:20 +0000 (23:23 +0100)] 
json: add JSON_FORMAT_REFUSE_SENSITIVE to json_variant_format()

Returns -EPERM if any node in the variant is marked as sensitive,
useful to avoid leaking data to log messages and so on

22 months agocreds: open up access to clients via Polkit
Lennart Poettering [Thu, 23 Nov 2023 21:22:27 +0000 (22:22 +0100)] 
creds: open up access to clients via Polkit

Use auth_admin_keep, so that users don't have to re-auth interactively
again and again when encrypting/decrypting batches of credentials.

22 months agobus-polkit: port polkit_registry to use value destructors in hash_ops
Lennart Poettering [Fri, 24 Nov 2023 09:56:28 +0000 (10:56 +0100)] 
bus-polkit: port polkit_registry to use value destructors in hash_ops

22 months agobus-polkit: add support for authenticating varlink peers via polkit
Lennart Poettering [Thu, 23 Nov 2023 17:21:21 +0000 (18:21 +0100)] 
bus-polkit: add support for authenticating varlink peers via polkit

This extends our current polkit logic, so that we can in a very similar
fashion as we already can authenticate dbus peers authenticate varlink
connection peers.

polkit natively speaks dbus and can authentication dbus peers. To get
the same level of support for varlink we'll use authentication by
pidfd+uid. This requires polkit v124, and if that's not available it
will fallback to authorizing root only as before.

Co-authored-by: Luca Boccassi <bluca@debian.org>
22 months agoMerge pull request #30694 from yuwata/sd-netlink-move-macro-and-introduce-tos-getter
Mike Yuan [Wed, 3 Jan 2024 10:47:12 +0000 (18:47 +0800)] 
Merge pull request #30694 from yuwata/sd-netlink-move-macro-and-introduce-tos-getter

sd-netlink: two cleanups

22 months agoMerge pull request #30686 from poettering/uki-measured-check-imply-tpm2
Mike Yuan [Wed, 3 Jan 2024 10:39:22 +0000 (18:39 +0800)] 
Merge pull request #30686 from poettering/uki-measured-check-imply-tpm2

efi-loader: when detecting if we are booted in UKI measured boot mode, imply a check for TPM2