NetworkManager/src
Thomas Haller 4ca7c9057a
glib-aux: rework random number utils
Heavily inspired by systemd ([1]).

We now also have nm_random_get_bytes{,_full}() and
nm_random_get_crypto_bytes(), like systemd's random_bytes()
and crypto_random_bytes(), respectively.

Differences:

- instead of systemd's random_bytes(), our nm_random_get_bytes_full()
  also estimates whether the output is of high quality. The caller
  may find that interesting. Due to that, we will first try to call
  getrandom(GRND_NONBLOCK) before getrandom(GRND_INSECURE). That is
  reversed from systemd's random_bytes(), because we want to find
  out whether we can get good random numbers. In most cases, kernel
  should have entropy already, and it makes no difference.

Otherwise, heavily rework the code. It should be easy to understand
and correct.

There is also a major bugfix here. Previously, if getrandom() failed
with ENOSYS and we fell back to /dev/urandom, we would assume that we
have high quality random numbers. That assumption is not warranted.
Now instead poll on /dev/random to find out.

[1] a268e7f402/src/basic/random-util.c (L81)

(cherry picked from commit d20343c9d0)
2022-08-05 19:41:01 +02:00
..
c-list src/c-list: reimport 2021-10-01 16:18:06 +02:00
c-rbtree c-rbtree: fix alignment assertion on m64k 2022-05-18 12:01:11 +02:00
c-siphash c-siphash: re-import git-subtree for 'src/c-siphash' 2021-10-01 16:07:26 +02:00
c-stdaux src/c-stdaux: reimport 2021-10-01 15:57:23 +02:00
contrib all: adjust glib-mkenums annotations for automated formatting 2022-02-08 11:14:01 +01:00
core glib-aux: rework random number utils 2022-08-05 19:41:01 +02:00
libnm-base libnm: don't depend nm-crypto on "nm-error.h" 2022-03-29 11:56:03 +02:00
libnm-client-aux-extern format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
libnm-client-impl libnm: fix timestamp in LIBNM_CLIENT_DEBUG debug logging 2022-07-04 17:27:21 +02:00
libnm-client-public libnm: move dependency to libnm-crypto out of libnm-core's "nm-utils.c" 2022-03-29 11:56:04 +02:00
libnm-client-test build/meson: add dependency libnm_client_public_dep for "libnm-client-test" 2022-05-04 09:07:46 +02:00
libnm-core-aux-extern format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
libnm-core-aux-intern format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
libnm-core-impl crypto: support EC private keys 2022-08-04 10:03:05 +02:00
libnm-core-intern libnm: add nm_setting_8021x_scheme_vtable_by_setting_key() helper 2022-03-28 18:27:36 +02:00
libnm-core-public libnm: move dependency to libnm-crypto out of libnm-core's "nm-utils.c" 2022-03-29 11:56:04 +02:00
libnm-crypto crypto: support EC private keys 2022-08-04 10:03:05 +02:00
libnm-glib-aux glib-aux: rework random number utils 2022-08-05 19:41:01 +02:00
libnm-log-core format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
libnm-log-null all: add some README.md files describing the purpose of our sources 2021-08-19 17:51:11 +02:00
libnm-platform platform: avoid struct alignment issue for NMPlatformIP4Address 2022-05-19 16:14:36 +02:00
libnm-std-aux std-aux: cast NM_IN_SET_SET() operands to "int" for "-Wbitwise-instead-of-logical" warning 2022-03-16 00:57:17 +01:00
libnm-systemd-core systemd: drop "nm-sd-utils-core.h" and nm_sd_utils_id128_get_machine() 2022-05-18 08:47:19 +02:00
libnm-systemd-shared systemd: merge branch systemd into main 2022-04-05 15:04:07 +02:00
libnm-udev-aux format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
libnmc-base libnmc: Remove verbose logging 2022-03-04 18:09:02 +01:00
libnmc-setting core: change the priority order in static "ipv6.addresses" 2022-05-03 12:18:35 +02:00
libnmt-newt format: reformat source tree with clang-format 13.0 2021-11-29 09:31:09 +00:00
linux-headers linux-headers: add nl80211-vnd-intel.h kernel header 2022-03-07 10:55:33 +02:00
n-acd n-acd: fix handling of N_ACD_E_DROPPED 2021-09-30 15:10:17 +02:00
n-dhcp4 n-dhcp4/probe: forget lease after a NAK 2022-05-06 13:54:19 +02:00
nm-cloud-setup cloud-setup: only pass config-iface-data as user-data for async functions 2022-05-05 08:37:29 +02:00
nm-daemon-helper all: add some README.md files describing the purpose of our sources 2021-08-19 17:51:11 +02:00
nm-dispatcher all: suppress wrong gcc-12 warning "-Wdangling-pointer" 2022-02-21 19:50:52 +01:00
nm-initrd-generator initrd: add support for rd.znet_ifnames 2022-01-25 14:57:22 +01:00
nm-online nm-online: set the timeout upper limit to 2073600 seconds 2022-03-07 14:47:30 +01:00
nm-priv-helper priv-helper: remove D-Bus Alias for "nm-priv-helper.service" 2022-02-09 18:47:14 +01:00
nmcli nmcli-completion: fix support for embedded quote characters 2022-08-04 10:03:01 +02:00
nmtui clients: bulk removal of g_assert*() statements 2022-03-28 13:51:44 +02:00
tests cli: correct active connection details header in nmcli output 2022-01-03 12:24:46 +01:00
meson.build build: move nm-crypto to separate directory "src/libnm-crypto" 2022-03-29 11:56:04 +02:00
README.md nm-sudo: rename to nm-priv-helper 2022-01-11 21:46:55 +01:00

src/

Most of the subdirectories are static helper libraries, which get linked into one of the final build artifacts (like libnm, nmcli or NetworkManager). Static libraries are internal API.

The only public API is libnm, which is a shared library provided client implementations.

Our own clients (like nmcli and nmtui) also use libnm, the shared library. But they also use additional static helper libraries.

The daemon statically links against a part of libnm, the part that provides connection profiles. That is libnm-core. libnm-core is thus statically linked with libnm and the daemon. It does not get linked by clients that already link with libnm (like nmtui).

Read the individual README.md files in the subdirectories for details:

Directory Description
core/ the NetworkManager daemon
nmcli/ nmcli application, a command line client for NetworkManager
nmtui/ nmtui application, a text UI client for NetworkManager
nm-cloud-setup/ service to automatically configure NetworkManager in cloud environment
nm-initrd-generator/ generates NetworkManager configuration by parsing kernel command line options for dracut/initrd
nm-dispatcher/ NetworkManager-dispatcher service to run user scripts
nm-online/ application which checks whether NetworkManager is done, for implementing NetworkManager-wait-online.service
nm-priv-helper/ internal service for privileged operations
nm-daemon-helper/ internal helper binary spawned by NetworkManager
libnm-std-aux/ internal helper library for standard C
libnm-glib-aux/ internal helper library for glib
libnm-log-null/ internal helper library with dummy (null) logging backend
libnm-log-core/ internal helper library with logging backend (syslog) used by daemon
libnm-base/ internal helper library with base definitions
libnm-platform/ internal helper library for netlink and other platform/kernel API
libnm-udev-aux/ internal helper library for libudev
libnm-core-public/ public API of libnm (libnm-core part)
libnm-core-intern/ internal API of libnm-core, used by libnm and daemon
libnm-core-impl/ implementation of libnm-core
libnm-core-aux-intern/ internal helper library on top of libnm-core (used by libnm-core itself)
libnm-core-aux-extern/ internal helper library on top of libnm-core (not used by libnm-core)
libnm-client-public/ public API of libnm (NMClient part)
libnm-client-impl/ implementation of libnm (NMClient)
libnm-client-aux-extern/ internal helper library on top of libnm (not used by libnm itself)
libnmc-base/ internal helper library for libnm clients
libnmc-setting/ internal helper library for setting connection profiles (used by nmcli)
libnmt-newt/ internal helper library for libnewt for nmtui
linux-headers/ extra Linux kernel UAPI headers
contrib/ sources that are not used by NetworkManager itself
tests/ unit tests that are not specific to one of the other directories
libnm-client-test/ internal helper library with test utils for libnm
c-list/ fork of c-util helper library for intrusive, doubly linked list
c-rbtree/ fork of c-util helper library for intrusive Red-Black Tree
c-siphash/ fork of c-util helper library for SIPHash24
c-stdaux/ fork of c-util general purpose helpers for standard C
n-acd/ fork of nettools IPv4 ACD library
n-dhcp4/ fork of nettools DHCPv4 library
libnm-systemd-core/ fork of systemd code as network library
libnm-systemd-shared/ fork of systemd code as general purpose library