diff --git a/man/systemd.network.xml b/man/systemd.network.xml
index 9d4a4b3e1fc..ec270e5e962 100644
--- a/man/systemd.network.xml
+++ b/man/systemd.network.xml
@@ -2626,19 +2626,38 @@ Token=prefixstable:2002:da8:1::
- NextServer=
+ BootServerAddress=
- Takes an IPv4 address. Configures the next server used by e.g. PXE boot systems.
+ Takes an IPv4 address of the boot server used by e.g. PXE boot systems. When specified,
+ the address is set to the siaddr field of the DHCP message header. See
+ RFC 2131 for more details.
Defaults to unset.
- Filename=
+ BootServerName=
- Takes a path or url to a file loaded by e.g. a PXE boot loader. Defaults to unset.
+ Takes a name of the boot server used by e.g. PXE boot systems. When specified, the
+ server name is set to the DHCP option 66. See
+ RFC 2132 for more details.
+ Defaults to unset.
+ Note that typically one of
+ BootServerName=/BootServerAddress= is sufficient to be
+ set, but both can be set too, if desired.
+
+
+
+
+ BootFilename=
+
+
+ Takes a path or URL to a file loaded by e.g. a PXE boot loader. The specified path is
+ set to the DHCP option 67. See
+ RFC 2132 for more details.
+ Defaults to unset.
diff --git a/src/core/load-fragment.c b/src/core/load-fragment.c
index 50d1c86bb2a..92a52819e27 100644
--- a/src/core/load-fragment.c
+++ b/src/core/load-fragment.c
@@ -6173,7 +6173,6 @@ void unit_dump_config_items(FILE *f) {
{ config_parse_si_uint64, "SIZE" },
{ config_parse_bool, "BOOLEAN" },
{ config_parse_string, "STRING" },
- { config_parse_safe_string, "STRING" },
{ config_parse_path, "PATH" },
{ config_parse_unit_path_printf, "PATH" },
{ config_parse_colon_separated_paths, "PATH" },
diff --git a/src/core/main.c b/src/core/main.c
index a05c24dd03b..c13534e98a2 100644
--- a/src/core/main.c
+++ b/src/core/main.c
@@ -589,73 +589,73 @@ static int config_parse_oom_score_adjust(
static int parse_config_file(void) {
const ConfigTableItem items[] = {
- { "Manager", "LogLevel", config_parse_level2, 0, NULL },
- { "Manager", "LogTarget", config_parse_target, 0, NULL },
- { "Manager", "LogColor", config_parse_color, 0, NULL },
- { "Manager", "LogLocation", config_parse_location, 0, NULL },
- { "Manager", "LogTime", config_parse_time, 0, NULL },
- { "Manager", "DumpCore", config_parse_bool, 0, &arg_dump_core },
- { "Manager", "CrashChVT", /* legacy */ config_parse_crash_chvt, 0, &arg_crash_chvt },
- { "Manager", "CrashChangeVT", config_parse_crash_chvt, 0, &arg_crash_chvt },
- { "Manager", "CrashShell", config_parse_bool, 0, &arg_crash_shell },
- { "Manager", "CrashReboot", config_parse_bool, 0, &arg_crash_reboot },
- { "Manager", "ShowStatus", config_parse_show_status, 0, &arg_show_status },
- { "Manager", "StatusUnitFormat", config_parse_status_unit_format, 0, &arg_status_unit_format },
- { "Manager", "CPUAffinity", config_parse_cpu_affinity2, 0, &arg_cpu_affinity },
- { "Manager", "NUMAPolicy", config_parse_numa_policy, 0, &arg_numa_policy.type },
- { "Manager", "NUMAMask", config_parse_numa_mask, 0, &arg_numa_policy },
- { "Manager", "JoinControllers", config_parse_warn_compat, DISABLED_CONFIGURATION, NULL },
- { "Manager", "RuntimeWatchdogSec", config_parse_watchdog_sec, 0, &arg_runtime_watchdog },
- { "Manager", "RuntimeWatchdogPreSec", config_parse_watchdog_sec, 0, &arg_pretimeout_watchdog },
- { "Manager", "RebootWatchdogSec", config_parse_watchdog_sec, 0, &arg_reboot_watchdog },
- { "Manager", "ShutdownWatchdogSec", config_parse_watchdog_sec, 0, &arg_reboot_watchdog }, /* obsolete alias */
- { "Manager", "KExecWatchdogSec", config_parse_watchdog_sec, 0, &arg_kexec_watchdog },
- { "Manager", "WatchdogDevice", config_parse_path, 0, &arg_watchdog_device },
- { "Manager", "RuntimeWatchdogPreGovernor", config_parse_safe_string, 0, &arg_watchdog_pretimeout_governor },
- { "Manager", "CapabilityBoundingSet", config_parse_capability_set, 0, &arg_capability_bounding_set },
- { "Manager", "NoNewPrivileges", config_parse_bool, 0, &arg_no_new_privs },
+ { "Manager", "LogLevel", config_parse_level2, 0, NULL },
+ { "Manager", "LogTarget", config_parse_target, 0, NULL },
+ { "Manager", "LogColor", config_parse_color, 0, NULL },
+ { "Manager", "LogLocation", config_parse_location, 0, NULL },
+ { "Manager", "LogTime", config_parse_time, 0, NULL },
+ { "Manager", "DumpCore", config_parse_bool, 0, &arg_dump_core },
+ { "Manager", "CrashChVT", /* legacy */ config_parse_crash_chvt, 0, &arg_crash_chvt },
+ { "Manager", "CrashChangeVT", config_parse_crash_chvt, 0, &arg_crash_chvt },
+ { "Manager", "CrashShell", config_parse_bool, 0, &arg_crash_shell },
+ { "Manager", "CrashReboot", config_parse_bool, 0, &arg_crash_reboot },
+ { "Manager", "ShowStatus", config_parse_show_status, 0, &arg_show_status },
+ { "Manager", "StatusUnitFormat", config_parse_status_unit_format, 0, &arg_status_unit_format },
+ { "Manager", "CPUAffinity", config_parse_cpu_affinity2, 0, &arg_cpu_affinity },
+ { "Manager", "NUMAPolicy", config_parse_numa_policy, 0, &arg_numa_policy.type },
+ { "Manager", "NUMAMask", config_parse_numa_mask, 0, &arg_numa_policy },
+ { "Manager", "JoinControllers", config_parse_warn_compat, DISABLED_CONFIGURATION, NULL },
+ { "Manager", "RuntimeWatchdogSec", config_parse_watchdog_sec, 0, &arg_runtime_watchdog },
+ { "Manager", "RuntimeWatchdogPreSec", config_parse_watchdog_sec, 0, &arg_pretimeout_watchdog },
+ { "Manager", "RebootWatchdogSec", config_parse_watchdog_sec, 0, &arg_reboot_watchdog },
+ { "Manager", "ShutdownWatchdogSec", config_parse_watchdog_sec, 0, &arg_reboot_watchdog }, /* obsolete alias */
+ { "Manager", "KExecWatchdogSec", config_parse_watchdog_sec, 0, &arg_kexec_watchdog },
+ { "Manager", "WatchdogDevice", config_parse_path, 0, &arg_watchdog_device },
+ { "Manager", "RuntimeWatchdogPreGovernor", config_parse_string, CONFIG_PARSE_STRING_SAFE, &arg_watchdog_pretimeout_governor },
+ { "Manager", "CapabilityBoundingSet", config_parse_capability_set, 0, &arg_capability_bounding_set },
+ { "Manager", "NoNewPrivileges", config_parse_bool, 0, &arg_no_new_privs },
#if HAVE_SECCOMP
- { "Manager", "SystemCallArchitectures", config_parse_syscall_archs, 0, &arg_syscall_archs },
+ { "Manager", "SystemCallArchitectures", config_parse_syscall_archs, 0, &arg_syscall_archs },
#endif
- { "Manager", "TimerSlackNSec", config_parse_nsec, 0, &arg_timer_slack_nsec },
- { "Manager", "DefaultTimerAccuracySec", config_parse_sec, 0, &arg_default_timer_accuracy_usec },
- { "Manager", "DefaultStandardOutput", config_parse_output_restricted, 0, &arg_default_std_output },
- { "Manager", "DefaultStandardError", config_parse_output_restricted, 0, &arg_default_std_error },
- { "Manager", "DefaultTimeoutStartSec", config_parse_sec, 0, &arg_default_timeout_start_usec },
- { "Manager", "DefaultTimeoutStopSec", config_parse_sec, 0, &arg_default_timeout_stop_usec },
- { "Manager", "DefaultTimeoutAbortSec", config_parse_default_timeout_abort, 0, NULL },
- { "Manager", "DefaultRestartSec", config_parse_sec, 0, &arg_default_restart_usec },
- { "Manager", "DefaultStartLimitInterval", config_parse_sec, 0, &arg_default_start_limit_interval }, /* obsolete alias */
- { "Manager", "DefaultStartLimitIntervalSec", config_parse_sec, 0, &arg_default_start_limit_interval },
- { "Manager", "DefaultStartLimitBurst", config_parse_unsigned, 0, &arg_default_start_limit_burst },
- { "Manager", "DefaultEnvironment", config_parse_environ, 0, &arg_default_environment },
- { "Manager", "ManagerEnvironment", config_parse_environ, 0, &arg_manager_environment },
- { "Manager", "DefaultLimitCPU", config_parse_rlimit, RLIMIT_CPU, arg_default_rlimit },
- { "Manager", "DefaultLimitFSIZE", config_parse_rlimit, RLIMIT_FSIZE, arg_default_rlimit },
- { "Manager", "DefaultLimitDATA", config_parse_rlimit, RLIMIT_DATA, arg_default_rlimit },
- { "Manager", "DefaultLimitSTACK", config_parse_rlimit, RLIMIT_STACK, arg_default_rlimit },
- { "Manager", "DefaultLimitCORE", config_parse_rlimit, RLIMIT_CORE, arg_default_rlimit },
- { "Manager", "DefaultLimitRSS", config_parse_rlimit, RLIMIT_RSS, arg_default_rlimit },
- { "Manager", "DefaultLimitNOFILE", config_parse_rlimit, RLIMIT_NOFILE, arg_default_rlimit },
- { "Manager", "DefaultLimitAS", config_parse_rlimit, RLIMIT_AS, arg_default_rlimit },
- { "Manager", "DefaultLimitNPROC", config_parse_rlimit, RLIMIT_NPROC, arg_default_rlimit },
- { "Manager", "DefaultLimitMEMLOCK", config_parse_rlimit, RLIMIT_MEMLOCK, arg_default_rlimit },
- { "Manager", "DefaultLimitLOCKS", config_parse_rlimit, RLIMIT_LOCKS, arg_default_rlimit },
- { "Manager", "DefaultLimitSIGPENDING", config_parse_rlimit, RLIMIT_SIGPENDING, arg_default_rlimit },
- { "Manager", "DefaultLimitMSGQUEUE", config_parse_rlimit, RLIMIT_MSGQUEUE, arg_default_rlimit },
- { "Manager", "DefaultLimitNICE", config_parse_rlimit, RLIMIT_NICE, arg_default_rlimit },
- { "Manager", "DefaultLimitRTPRIO", config_parse_rlimit, RLIMIT_RTPRIO, arg_default_rlimit },
- { "Manager", "DefaultLimitRTTIME", config_parse_rlimit, RLIMIT_RTTIME, arg_default_rlimit },
- { "Manager", "DefaultCPUAccounting", config_parse_tristate, 0, &arg_default_cpu_accounting },
- { "Manager", "DefaultIOAccounting", config_parse_bool, 0, &arg_default_io_accounting },
- { "Manager", "DefaultIPAccounting", config_parse_bool, 0, &arg_default_ip_accounting },
- { "Manager", "DefaultBlockIOAccounting", config_parse_bool, 0, &arg_default_blockio_accounting },
- { "Manager", "DefaultMemoryAccounting", config_parse_bool, 0, &arg_default_memory_accounting },
- { "Manager", "DefaultTasksAccounting", config_parse_bool, 0, &arg_default_tasks_accounting },
- { "Manager", "DefaultTasksMax", config_parse_tasks_max, 0, &arg_default_tasks_max },
- { "Manager", "CtrlAltDelBurstAction", config_parse_emergency_action, 0, &arg_cad_burst_action },
- { "Manager", "DefaultOOMPolicy", config_parse_oom_policy, 0, &arg_default_oom_policy },
- { "Manager", "DefaultOOMScoreAdjust", config_parse_oom_score_adjust, 0, NULL },
+ { "Manager", "TimerSlackNSec", config_parse_nsec, 0, &arg_timer_slack_nsec },
+ { "Manager", "DefaultTimerAccuracySec", config_parse_sec, 0, &arg_default_timer_accuracy_usec },
+ { "Manager", "DefaultStandardOutput", config_parse_output_restricted, 0, &arg_default_std_output },
+ { "Manager", "DefaultStandardError", config_parse_output_restricted, 0, &arg_default_std_error },
+ { "Manager", "DefaultTimeoutStartSec", config_parse_sec, 0, &arg_default_timeout_start_usec },
+ { "Manager", "DefaultTimeoutStopSec", config_parse_sec, 0, &arg_default_timeout_stop_usec },
+ { "Manager", "DefaultTimeoutAbortSec", config_parse_default_timeout_abort, 0, NULL },
+ { "Manager", "DefaultRestartSec", config_parse_sec, 0, &arg_default_restart_usec },
+ { "Manager", "DefaultStartLimitInterval", config_parse_sec, 0, &arg_default_start_limit_interval }, /* obsolete alias */
+ { "Manager", "DefaultStartLimitIntervalSec", config_parse_sec, 0, &arg_default_start_limit_interval },
+ { "Manager", "DefaultStartLimitBurst", config_parse_unsigned, 0, &arg_default_start_limit_burst },
+ { "Manager", "DefaultEnvironment", config_parse_environ, 0, &arg_default_environment },
+ { "Manager", "ManagerEnvironment", config_parse_environ, 0, &arg_manager_environment },
+ { "Manager", "DefaultLimitCPU", config_parse_rlimit, RLIMIT_CPU, arg_default_rlimit },
+ { "Manager", "DefaultLimitFSIZE", config_parse_rlimit, RLIMIT_FSIZE, arg_default_rlimit },
+ { "Manager", "DefaultLimitDATA", config_parse_rlimit, RLIMIT_DATA, arg_default_rlimit },
+ { "Manager", "DefaultLimitSTACK", config_parse_rlimit, RLIMIT_STACK, arg_default_rlimit },
+ { "Manager", "DefaultLimitCORE", config_parse_rlimit, RLIMIT_CORE, arg_default_rlimit },
+ { "Manager", "DefaultLimitRSS", config_parse_rlimit, RLIMIT_RSS, arg_default_rlimit },
+ { "Manager", "DefaultLimitNOFILE", config_parse_rlimit, RLIMIT_NOFILE, arg_default_rlimit },
+ { "Manager", "DefaultLimitAS", config_parse_rlimit, RLIMIT_AS, arg_default_rlimit },
+ { "Manager", "DefaultLimitNPROC", config_parse_rlimit, RLIMIT_NPROC, arg_default_rlimit },
+ { "Manager", "DefaultLimitMEMLOCK", config_parse_rlimit, RLIMIT_MEMLOCK, arg_default_rlimit },
+ { "Manager", "DefaultLimitLOCKS", config_parse_rlimit, RLIMIT_LOCKS, arg_default_rlimit },
+ { "Manager", "DefaultLimitSIGPENDING", config_parse_rlimit, RLIMIT_SIGPENDING, arg_default_rlimit },
+ { "Manager", "DefaultLimitMSGQUEUE", config_parse_rlimit, RLIMIT_MSGQUEUE, arg_default_rlimit },
+ { "Manager", "DefaultLimitNICE", config_parse_rlimit, RLIMIT_NICE, arg_default_rlimit },
+ { "Manager", "DefaultLimitRTPRIO", config_parse_rlimit, RLIMIT_RTPRIO, arg_default_rlimit },
+ { "Manager", "DefaultLimitRTTIME", config_parse_rlimit, RLIMIT_RTTIME, arg_default_rlimit },
+ { "Manager", "DefaultCPUAccounting", config_parse_tristate, 0, &arg_default_cpu_accounting },
+ { "Manager", "DefaultIOAccounting", config_parse_bool, 0, &arg_default_io_accounting },
+ { "Manager", "DefaultIPAccounting", config_parse_bool, 0, &arg_default_ip_accounting },
+ { "Manager", "DefaultBlockIOAccounting", config_parse_bool, 0, &arg_default_blockio_accounting },
+ { "Manager", "DefaultMemoryAccounting", config_parse_bool, 0, &arg_default_memory_accounting },
+ { "Manager", "DefaultTasksAccounting", config_parse_bool, 0, &arg_default_tasks_accounting },
+ { "Manager", "DefaultTasksMax", config_parse_tasks_max, 0, &arg_default_tasks_max },
+ { "Manager", "CtrlAltDelBurstAction", config_parse_emergency_action, 0, &arg_cad_burst_action },
+ { "Manager", "DefaultOOMPolicy", config_parse_oom_policy, 0, &arg_default_oom_policy },
+ { "Manager", "DefaultOOMScoreAdjust", config_parse_oom_score_adjust, 0, NULL },
{}
};
diff --git a/src/journal-remote/journal-upload.c b/src/journal-remote/journal-upload.c
index 9ddca7ac500..6ccea604e68 100644
--- a/src/journal-remote/journal-upload.c
+++ b/src/journal-remote/journal-upload.c
@@ -569,11 +569,11 @@ finalize:
static int parse_config(void) {
const ConfigTableItem items[] = {
- { "Upload", "URL", config_parse_safe_string, 0, &arg_url },
- { "Upload", "ServerKeyFile", config_parse_path_or_ignore, 0, &arg_key },
- { "Upload", "ServerCertificateFile", config_parse_path_or_ignore, 0, &arg_cert },
- { "Upload", "TrustedCertificateFile", config_parse_path_or_ignore, 0, &arg_trust },
- { "Upload", "NetworkTimeoutSec", config_parse_sec, 0, &arg_network_timeout_usec },
+ { "Upload", "URL", config_parse_string, CONFIG_PARSE_STRING_SAFE, &arg_url },
+ { "Upload", "ServerKeyFile", config_parse_path_or_ignore, 0, &arg_key },
+ { "Upload", "ServerCertificateFile", config_parse_path_or_ignore, 0, &arg_cert },
+ { "Upload", "TrustedCertificateFile", config_parse_path_or_ignore, 0, &arg_trust },
+ { "Upload", "NetworkTimeoutSec", config_parse_sec, 0, &arg_network_timeout_usec },
{}
};
diff --git a/src/libsystemd-network/dhcp-protocol.h b/src/libsystemd-network/dhcp-protocol.h
index 11f4201ab2a..dd54bcf6ee9 100644
--- a/src/libsystemd-network/dhcp-protocol.h
+++ b/src/libsystemd-network/dhcp-protocol.h
@@ -73,15 +73,24 @@ enum {
};
enum {
- DHCP_DISCOVER = 1,
- DHCP_OFFER = 2,
- DHCP_REQUEST = 3,
- DHCP_DECLINE = 4,
- DHCP_ACK = 5,
- DHCP_NAK = 6,
- DHCP_RELEASE = 7,
- DHCP_INFORM = 8,
- DHCP_FORCERENEW = 9,
+ DHCP_DISCOVER = 1, /* [RFC2132] */
+ DHCP_OFFER = 2, /* [RFC2132] */
+ DHCP_REQUEST = 3, /* [RFC2132] */
+ DHCP_DECLINE = 4, /* [RFC2132] */
+ DHCP_ACK = 5, /* [RFC2132] */
+ DHCP_NAK = 6, /* [RFC2132] */
+ DHCP_RELEASE = 7, /* [RFC2132] */
+ DHCP_INFORM = 8, /* [RFC2132] */
+ DHCP_FORCERENEW = 9, /* [RFC3203] */
+ DHCPLEASEQUERY = 10, /* [RFC4388] */
+ DHCPLEASEUNASSIGNED = 11, /* [RFC4388] */
+ DHCPLEASEUNKNOWN = 12, /* [RFC4388] */
+ DHCPLEASEACTIVE = 13, /* [RFC4388] */
+ DHCPBULKLEASEQUERY = 14, /* [RFC6926] */
+ DHCPLEASEQUERYDONE = 15, /* [RFC6926] */
+ DHCPACTIVELEASEQUERY = 16, /* [RFC7724] */
+ DHCPLEASEQUERYSTATUS = 17, /* [RFC7724] */
+ DHCPTLS = 18, /* [RFC7724] */
};
enum {
diff --git a/src/libsystemd-network/dhcp-server-internal.h b/src/libsystemd-network/dhcp-server-internal.h
index bb41ad2c3dc..607f9f0c2fa 100644
--- a/src/libsystemd-network/dhcp-server-internal.h
+++ b/src/libsystemd-network/dhcp-server-internal.h
@@ -65,8 +65,9 @@ struct sd_dhcp_server {
char *timezone;
DHCPServerData servers[_SD_DHCP_LEASE_SERVER_TYPE_MAX];
- struct in_addr next_server;
- char *filename;
+ struct in_addr boot_server_address;
+ char *boot_server_name;
+ char *boot_filename;
OrderedSet *extra_options;
OrderedSet *vendor_options;
diff --git a/src/libsystemd-network/dhcp6-option.c b/src/libsystemd-network/dhcp6-option.c
index d25377d377d..735fd2cde2b 100644
--- a/src/libsystemd-network/dhcp6-option.c
+++ b/src/libsystemd-network/dhcp6-option.c
@@ -72,8 +72,8 @@ bool dhcp6_option_can_request(uint16_t option) {
return false;
case SD_DHCP6_OPTION_CLIENT_FQDN:
case SD_DHCP6_OPTION_PANA_AGENT:
- case SD_DHCP6_OPTION_NEW_POSIX_TIMEZONE:
- case SD_DHCP6_OPTION_NEW_TZDB_TIMEZONE:
+ case SD_DHCP6_OPTION_POSIX_TIMEZONE:
+ case SD_DHCP6_OPTION_TZDB_TIMEZONE:
return true;
case SD_DHCP6_OPTION_ERO:
case SD_DHCP6_OPTION_LQ_QUERY:
diff --git a/src/libsystemd-network/sd-dhcp-client.c b/src/libsystemd-network/sd-dhcp-client.c
index 84ae5cddd64..5456c85641a 100644
--- a/src/libsystemd-network/sd-dhcp-client.c
+++ b/src/libsystemd-network/sd-dhcp-client.c
@@ -145,11 +145,11 @@ static const uint8_t default_req_opts_anonymize[] = {
SD_DHCP_OPTION_ROUTER, /* 3 */
SD_DHCP_OPTION_DOMAIN_NAME_SERVER, /* 6 */
SD_DHCP_OPTION_DOMAIN_NAME, /* 15 */
- SD_DHCP_OPTION_ROUTER_DISCOVER, /* 31 */
+ SD_DHCP_OPTION_ROUTER_DISCOVERY, /* 31 */
SD_DHCP_OPTION_STATIC_ROUTE, /* 33 */
SD_DHCP_OPTION_VENDOR_SPECIFIC, /* 43 */
- SD_DHCP_OPTION_NETBIOS_NAMESERVER, /* 44 */
- SD_DHCP_OPTION_NETBIOS_NODETYPE, /* 46 */
+ SD_DHCP_OPTION_NETBIOS_NAME_SERVER, /* 44 */
+ SD_DHCP_OPTION_NETBIOS_NODE_TYPE, /* 46 */
SD_DHCP_OPTION_NETBIOS_SCOPE, /* 47 */
SD_DHCP_OPTION_CLASSLESS_STATIC_ROUTE, /* 121 */
SD_DHCP_OPTION_PRIVATE_CLASSLESS_STATIC_ROUTE, /* 249 */
diff --git a/src/libsystemd-network/sd-dhcp-lease.c b/src/libsystemd-network/sd-dhcp-lease.c
index 1f7978eb033..84f3199076b 100644
--- a/src/libsystemd-network/sd-dhcp-lease.c
+++ b/src/libsystemd-network/sd-dhcp-lease.c
@@ -709,7 +709,7 @@ int dhcp_lease_parse_options(uint8_t code, uint8_t len, const void *option, void
log_debug_errno(r, "Failed to parse static routes, ignoring: %m");
break;
- case SD_DHCP_OPTION_INTERFACE_MTU:
+ case SD_DHCP_OPTION_MTU_INTERFACE:
r = lease_parse_u16(option, len, &lease->mtu, 68);
if (r < 0)
log_debug_errno(r, "Failed to parse MTU, ignoring: %m");
@@ -729,7 +729,7 @@ int dhcp_lease_parse_options(uint8_t code, uint8_t len, const void *option, void
break;
- case SD_DHCP_OPTION_DOMAIN_SEARCH_LIST:
+ case SD_DHCP_OPTION_DOMAIN_SEARCH:
r = dhcp_lease_parse_search_domains(option, len, &lease->search_domains);
if (r < 0)
log_debug_errno(r, "Failed to parse Domain Search List, ignoring: %m");
@@ -750,13 +750,13 @@ int dhcp_lease_parse_options(uint8_t code, uint8_t len, const void *option, void
log_debug_errno(r, "Failed to parse root path, ignoring: %m");
break;
- case SD_DHCP_OPTION_RENEWAL_T1_TIME:
+ case SD_DHCP_OPTION_RENEWAL_TIME:
r = lease_parse_u32(option, len, &lease->t1, 1);
if (r < 0)
log_debug_errno(r, "Failed to parse T1 time, ignoring: %m");
break;
- case SD_DHCP_OPTION_REBINDING_T2_TIME:
+ case SD_DHCP_OPTION_REBINDING_TIME:
r = lease_parse_u32(option, len, &lease->t2, 1);
if (r < 0)
log_debug_errno(r, "Failed to parse T2 time, ignoring: %m");
@@ -768,7 +768,7 @@ int dhcp_lease_parse_options(uint8_t code, uint8_t len, const void *option, void
log_debug_errno(r, "Failed to parse classless routes, ignoring: %m");
break;
- case SD_DHCP_OPTION_NEW_TZDB_TIMEZONE: {
+ case SD_DHCP_OPTION_TZDB_TIMEZONE: {
_cleanup_free_ char *tz = NULL;
r = lease_parse_string(option, len, &tz);
diff --git a/src/libsystemd-network/sd-dhcp-server.c b/src/libsystemd-network/sd-dhcp-server.c
index 1636b838e14..b9ff27b9e1e 100644
--- a/src/libsystemd-network/sd-dhcp-server.c
+++ b/src/libsystemd-network/sd-dhcp-server.c
@@ -12,6 +12,7 @@
#include "alloc-util.h"
#include "dhcp-internal.h"
#include "dhcp-server-internal.h"
+#include "dns-domain.h"
#include "fd-util.h"
#include "in-addr-util.h"
#include "io-util.h"
@@ -163,7 +164,8 @@ static sd_dhcp_server *dhcp_server_free(sd_dhcp_server *server) {
sd_event_unref(server->event);
- free(server->filename);
+ free(server->boot_server_name);
+ free(server->boot_filename);
free(server->timezone);
for (sd_dhcp_lease_server_type_t i = 0; i < _SD_DHCP_LEASE_SERVER_TYPE_MAX; i++)
@@ -272,24 +274,40 @@ sd_event *sd_dhcp_server_get_event(sd_dhcp_server *server) {
return server->event;
}
-int sd_dhcp_server_set_next_server(sd_dhcp_server *server, const struct in_addr *next_server) {
+int sd_dhcp_server_set_boot_server_address(sd_dhcp_server *server, const struct in_addr *address) {
assert_return(server, -EINVAL);
- if (next_server)
- server->next_server = *next_server;
+ if (address)
+ server->boot_server_address = *address;
else
- server->next_server = (struct in_addr) {};
+ server->boot_server_address = (struct in_addr) {};
return 0;
}
-int sd_dhcp_server_set_filename(sd_dhcp_server *server, const char *filename) {
+int sd_dhcp_server_set_boot_server_name(sd_dhcp_server *server, const char *name) {
+ int r;
+
assert_return(server, -EINVAL);
- if (filename && !ascii_is_valid(filename))
+ if (name) {
+ r = dns_name_is_valid(name);
+ if (r < 0)
+ return r;
+ if (r == 0)
+ return -EINVAL;
+ }
+
+ return free_and_strdup(&server->boot_server_name, name);
+}
+
+int sd_dhcp_server_set_boot_filename(sd_dhcp_server *server, const char *filename) {
+ assert_return(server, -EINVAL);
+
+ if (filename && (!string_is_safe(filename) || !ascii_is_valid(filename)))
return -EINVAL;
- return free_and_strdup(&server->filename, filename);
+ return free_and_strdup(&server->boot_filename, filename);
}
int sd_dhcp_server_stop(sd_dhcp_server *server) {
@@ -561,7 +579,7 @@ static int server_send_offer_or_ack(
return r;
packet->dhcp.yiaddr = address;
- packet->dhcp.siaddr = server->next_server.s_addr;
+ packet->dhcp.siaddr = server->boot_server_address.s_addr;
lease_time = htobe32(req->lifetime);
r = dhcp_option_append(&packet->dhcp, req->max_optlen, &offset, 0,
@@ -585,18 +603,18 @@ static int server_send_offer_or_ack(
return r;
}
- if (server->filename) {
- /* The pxelinux magic option is marked as deprecated, but let's append it for older
- * implementations. */
+ if (server->boot_server_name) {
r = dhcp_option_append(&packet->dhcp, req->max_optlen, &offset, 0,
- SD_DHCP_OPTION_PXELINUX_MAGIC, 4,
- (const uint8_t[]) { 0xf1, 0x00, 0x74, 0x7e });
+ SD_DHCP_OPTION_BOOT_SERVER_NAME,
+ strlen(server->boot_server_name), server->boot_server_name);
if (r < 0)
return r;
+ }
+ if (server->boot_filename) {
r = dhcp_option_append(&packet->dhcp, req->max_optlen, &offset, 0,
- SD_DHCP_OPTION_CONFIGURATION_FILE,
- strlen(server->filename), server->filename);
+ SD_DHCP_OPTION_BOOT_FILENAME,
+ strlen(server->boot_filename), server->boot_filename);
if (r < 0)
return r;
}
@@ -628,7 +646,7 @@ static int server_send_offer_or_ack(
if (server->timezone) {
r = dhcp_option_append(
&packet->dhcp, req->max_optlen, &offset, 0,
- SD_DHCP_OPTION_NEW_TZDB_TIMEZONE,
+ SD_DHCP_OPTION_TZDB_TIMEZONE,
strlen(server->timezone), server->timezone);
if (r < 0)
return r;
diff --git a/src/libsystemd-network/test-dhcp-client.c b/src/libsystemd-network/test-dhcp-client.c
index d1d104196a0..dd95aaf5887 100644
--- a/src/libsystemd-network/test-dhcp-client.c
+++ b/src/libsystemd-network/test-dhcp-client.c
@@ -109,7 +109,7 @@ static void test_request_anonymize(sd_event *e) {
r = sd_dhcp_client_attach_event(client, e, 0);
assert_se(r >= 0);
- assert_se(sd_dhcp_client_set_request_option(client, SD_DHCP_OPTION_NETBIOS_NAMESERVER) == 0);
+ assert_se(sd_dhcp_client_set_request_option(client, SD_DHCP_OPTION_NETBIOS_NAME_SERVER) == 0);
/* This PRL option is not set when using Anonymize */
assert_se(sd_dhcp_client_set_request_option(client, SD_DHCP_OPTION_HOST_NAME) == 1);
assert_se(sd_dhcp_client_set_request_option(client, SD_DHCP_OPTION_PARAMETER_REQUEST_LIST) == -EINVAL);
diff --git a/src/network/netdev/netdev-gperf.gperf b/src/network/netdev/netdev-gperf.gperf
index 6dcc5a804f5..302b8a2cf88 100644
--- a/src/network/netdev/netdev-gperf.gperf
+++ b/src/network/netdev/netdev-gperf.gperf
@@ -179,14 +179,14 @@ Tun.OneQueue, config_parse_warn_compat,
Tun.MultiQueue, config_parse_bool, 0, offsetof(TunTap, multi_queue)
Tun.PacketInfo, config_parse_bool, 0, offsetof(TunTap, packet_info)
Tun.VNetHeader, config_parse_bool, 0, offsetof(TunTap, vnet_hdr)
-Tun.User, config_parse_safe_string, 0, offsetof(TunTap, user_name)
-Tun.Group, config_parse_safe_string, 0, offsetof(TunTap, group_name)
+Tun.User, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(TunTap, user_name)
+Tun.Group, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(TunTap, group_name)
Tap.OneQueue, config_parse_warn_compat, DISABLED_LEGACY, 0
Tap.MultiQueue, config_parse_bool, 0, offsetof(TunTap, multi_queue)
Tap.PacketInfo, config_parse_bool, 0, offsetof(TunTap, packet_info)
Tap.VNetHeader, config_parse_bool, 0, offsetof(TunTap, vnet_hdr)
-Tap.User, config_parse_safe_string, 0, offsetof(TunTap, user_name)
-Tap.Group, config_parse_safe_string, 0, offsetof(TunTap, group_name)
+Tap.User, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(TunTap, user_name)
+Tap.Group, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(TunTap, group_name)
Bond.Mode, config_parse_bond_mode, 0, offsetof(Bond, mode)
Bond.TransmitHashPolicy, config_parse_bond_xmit_hash_policy, 0, offsetof(Bond, xmit_hash_policy)
Bond.LACPTransmitRate, config_parse_bond_lacp_rate, 0, offsetof(Bond, lacp_rate)
diff --git a/src/network/networkd-dhcp-server.c b/src/network/networkd-dhcp-server.c
index 795ad686af9..515c9c44bee 100644
--- a/src/network/networkd-dhcp-server.c
+++ b/src/network/networkd-dhcp-server.c
@@ -416,13 +416,17 @@ static int dhcp4_server_configure(Link *link) {
return log_link_error_errno(link, r, "Failed to set default lease time for DHCPv4 server instance: %m");
}
- r = sd_dhcp_server_set_next_server(link->dhcp_server, &link->network->dhcp_server_next_server);
+ r = sd_dhcp_server_set_boot_server_address(link->dhcp_server, &link->network->dhcp_server_boot_server_address);
if (r < 0)
- return log_link_warning_errno(link, r, "Failed to set next server for DHCPv4 server instance: %m");
+ return log_link_warning_errno(link, r, "Failed to set boot server address for DHCPv4 server instance: %m");
- r = sd_dhcp_server_set_filename(link->dhcp_server, link->network->dhcp_server_filename);
+ r = sd_dhcp_server_set_boot_server_name(link->dhcp_server, link->network->dhcp_server_boot_server_name);
if (r < 0)
- return log_link_warning_errno(link, r, "Failed to set filename for DHCPv4 server instance: %m");
+ return log_link_warning_errno(link, r, "Failed to set boot server name for DHCPv4 server instance: %m");
+
+ r = sd_dhcp_server_set_boot_filename(link->dhcp_server, link->network->dhcp_server_boot_filename);
+ if (r < 0)
+ return log_link_warning_errno(link, r, "Failed to set boot filename for DHCPv4 server instance: %m");
for (sd_dhcp_lease_server_type_t type = 0; type < _SD_DHCP_LEASE_SERVER_TYPE_MAX; type ++) {
@@ -712,7 +716,7 @@ int config_parse_dhcp_server_address(
void *data,
void *userdata) {
- Network *network = userdata;
+ Network *network = ASSERT_PTR(userdata);
union in_addr_union a;
unsigned char prefixlen;
int r;
diff --git a/src/network/networkd-dhcp4.c b/src/network/networkd-dhcp4.c
index 2b985f361a2..420113e1294 100644
--- a/src/network/networkd-dhcp4.c
+++ b/src/network/networkd-dhcp4.c
@@ -1426,7 +1426,7 @@ static int dhcp4_configure(Link *link) {
if (!link->network->dhcp_anonymize) {
if (link->network->dhcp_use_mtu) {
- r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_INTERFACE_MTU);
+ r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_MTU_INTERFACE);
if (r < 0)
return log_link_debug_errno(link, r, "DHCPv4 CLIENT: Failed to set request flag for MTU: %m");
}
@@ -1442,7 +1442,7 @@ static int dhcp4_configure(Link *link) {
}
if (link->network->dhcp_use_domains != DHCP_USE_DOMAINS_NO) {
- r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_DOMAIN_SEARCH_LIST);
+ r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_DOMAIN_SEARCH);
if (r < 0)
return log_link_debug_errno(link, r, "DHCPv4 CLIENT: Failed to set request flag for domain search list: %m");
}
@@ -1460,7 +1460,7 @@ static int dhcp4_configure(Link *link) {
}
if (link->network->dhcp_use_timezone) {
- r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_NEW_TZDB_TIMEZONE);
+ r = sd_dhcp_client_set_request_option(link->dhcp_client, SD_DHCP_OPTION_TZDB_TIMEZONE);
if (r < 0)
return log_link_debug_errno(link, r, "DHCPv4 CLIENT: Failed to set request flag for timezone: %m");
}
diff --git a/src/network/networkd-network-gperf.gperf b/src/network/networkd-network-gperf.gperf
index b639714d970..ceaaa6a0f7c 100644
--- a/src/network/networkd-network-gperf.gperf
+++ b/src/network/networkd-network-gperf.gperf
@@ -222,7 +222,7 @@ DHCPv4.SendHostname, config_parse_bool,
DHCPv4.Hostname, config_parse_hostname, 0, offsetof(Network, dhcp_hostname)
DHCPv4.Label, config_parse_dhcp_label, 0, offsetof(Network, dhcp_label)
DHCPv4.RequestBroadcast, config_parse_tristate, 0, offsetof(Network, dhcp_broadcast)
-DHCPv4.VendorClassIdentifier, config_parse_safe_string, 0, offsetof(Network, dhcp_vendor_class_identifier)
+DHCPv4.VendorClassIdentifier, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(Network, dhcp_vendor_class_identifier)
DHCPv4.MUDURL, config_parse_mud_url, 0, offsetof(Network, dhcp_mudurl)
DHCPv4.MaxAttempts, config_parse_dhcp_max_attempts, 0, 0
DHCPv4.UserClass, config_parse_dhcp_user_or_vendor_class, AF_INET, offsetof(Network, dhcp_user_class)
@@ -305,8 +305,9 @@ DHCPServer.PoolSize, config_parse_uint32,
DHCPServer.SendVendorOption, config_parse_dhcp_send_option, 0, offsetof(Network, dhcp_server_send_vendor_options)
DHCPServer.SendOption, config_parse_dhcp_send_option, 0, offsetof(Network, dhcp_server_send_options)
DHCPServer.BindToInterface, config_parse_bool, 0, offsetof(Network, dhcp_server_bind_to_interface)
-DHCPServer.NextServer, config_parse_in_addr_non_null, AF_INET, offsetof(Network, dhcp_server_next_server)
-DHCPServer.Filename, config_parse_string, 0, offsetof(Network, dhcp_server_filename)
+DHCPServer.BootServerAddress, config_parse_in_addr_non_null, AF_INET, offsetof(Network, dhcp_server_boot_server_address)
+DHCPServer.BootServerName, config_parse_dns_name, 0, offsetof(Network, dhcp_server_boot_server_name)
+DHCPServer.BootFilename, config_parse_string, CONFIG_PARSE_STRING_SAFE_AND_ASCII, offsetof(Network, dhcp_server_boot_filename)
DHCPServerStaticLease.Address, config_parse_dhcp_static_lease_address, 0, 0
DHCPServerStaticLease.MACAddress, config_parse_dhcp_static_lease_hwaddr, 0, 0
Bridge.Cost, config_parse_uint32, 0, offsetof(Network, cost)
@@ -543,7 +544,7 @@ DHCP.SendHostname, config_parse_bool,
DHCP.Hostname, config_parse_hostname, 0, offsetof(Network, dhcp_hostname)
DHCP.RequestBroadcast, config_parse_tristate, 0, offsetof(Network, dhcp_broadcast)
DHCP.CriticalConnection, config_parse_tristate, 0, offsetof(Network, dhcp_critical)
-DHCP.VendorClassIdentifier, config_parse_safe_string, 0, offsetof(Network, dhcp_vendor_class_identifier)
+DHCP.VendorClassIdentifier, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(Network, dhcp_vendor_class_identifier)
DHCP.UserClass, config_parse_dhcp_user_or_vendor_class, AF_INET, offsetof(Network, dhcp_user_class)
DHCP.IAID, config_parse_iaid, AF_INET, 0
DHCP.DUIDType, config_parse_network_duid_type, 0, 0
diff --git a/src/network/networkd-network.c b/src/network/networkd-network.c
index 5dae7b4de11..683b04b5acd 100644
--- a/src/network/networkd-network.c
+++ b/src/network/networkd-network.c
@@ -702,7 +702,8 @@ static Network *network_free(Network *network) {
free(network->dhcp_server_relay_agent_circuit_id);
free(network->dhcp_server_relay_agent_remote_id);
- free(network->dhcp_server_filename);
+ free(network->dhcp_server_boot_server_name);
+ free(network->dhcp_server_boot_filename);
free(network->description);
free(network->dhcp_vendor_class_identifier);
@@ -982,52 +983,6 @@ int config_parse_domains(
}
}
-int config_parse_hostname(
- const char *unit,
- const char *filename,
- unsigned line,
- const char *section,
- unsigned section_line,
- const char *lvalue,
- int ltype,
- const char *rvalue,
- void *data,
- void *userdata) {
-
- char **hostname = data;
- int r;
-
- assert(filename);
- assert(lvalue);
- assert(rvalue);
- assert(data);
-
- if (isempty(rvalue)) {
- *hostname = mfree(*hostname);
- return 0;
- }
-
- if (!hostname_is_valid(rvalue, 0)) {
- log_syntax(unit, LOG_WARNING, filename, line, 0,
- "Hostname is not valid, ignoring assignment: %s", rvalue);
- return 0;
- }
-
- r = dns_name_is_valid(rvalue);
- if (r < 0) {
- log_syntax(unit, LOG_WARNING, filename, line, r,
- "Failed to check validity of hostname '%s', ignoring assignment: %m", rvalue);
- return 0;
- }
- if (r == 0) {
- log_syntax(unit, LOG_WARNING, filename, line, 0,
- "Hostname is not a valid DNS domain name, ignoring assignment: %s", rvalue);
- return 0;
- }
-
- return free_and_strdup_warn(hostname, rvalue);
-}
-
int config_parse_timezone(
const char *unit,
const char *filename,
diff --git a/src/network/networkd-network.h b/src/network/networkd-network.h
index 74d71735fbc..807e0fadc66 100644
--- a/src/network/networkd-network.h
+++ b/src/network/networkd-network.h
@@ -200,8 +200,9 @@ struct Network {
uint32_t dhcp_server_pool_size;
OrderedHashmap *dhcp_server_send_options;
OrderedHashmap *dhcp_server_send_vendor_options;
- struct in_addr dhcp_server_next_server;
- char *dhcp_server_filename;
+ struct in_addr dhcp_server_boot_server_address;
+ char *dhcp_server_boot_server_name;
+ char *dhcp_server_boot_filename;
/* link local addressing support */
AddressFamily link_local;
@@ -374,7 +375,6 @@ CONFIG_PARSER_PROTOTYPE(config_parse_stacked_netdev);
CONFIG_PARSER_PROTOTYPE(config_parse_tunnel);
CONFIG_PARSER_PROTOTYPE(config_parse_domains);
CONFIG_PARSER_PROTOTYPE(config_parse_dns);
-CONFIG_PARSER_PROTOTYPE(config_parse_hostname);
CONFIG_PARSER_PROTOTYPE(config_parse_timezone);
CONFIG_PARSER_PROTOTYPE(config_parse_dnssec_negative_trust_anchors);
CONFIG_PARSER_PROTOTYPE(config_parse_ntp);
diff --git a/src/nspawn/nspawn-gperf.gperf b/src/nspawn/nspawn-gperf.gperf
index 13f51569e86..a93b8c38c93 100644
--- a/src/nspawn/nspawn-gperf.gperf
+++ b/src/nspawn/nspawn-gperf.gperf
@@ -19,64 +19,64 @@ struct ConfigPerfItem;
%struct-type
%includes
%%
-Exec.Boot, config_parse_boot, 0, 0
-Exec.Ephemeral, config_parse_tristate, 0, offsetof(Settings, ephemeral)
-Exec.ProcessTwo, config_parse_pid2, 0, 0
-Exec.Parameters, config_parse_strv, 0, offsetof(Settings, parameters)
-Exec.Environment, config_parse_strv, 0, offsetof(Settings, environment)
-Exec.User, config_parse_safe_string, 0, offsetof(Settings, user)
-Exec.Capability, config_parse_capability, 0, offsetof(Settings, capability)
-Exec.AmbientCapability, config_parse_capability, 0, offsetof(Settings, ambient_capability)
-Exec.DropCapability, config_parse_capability, 0, offsetof(Settings, drop_capability)
-Exec.KillSignal, config_parse_signal, 0, offsetof(Settings, kill_signal)
-Exec.Personality, config_parse_personality, 0, offsetof(Settings, personality)
-Exec.MachineID, config_parse_id128, 0, offsetof(Settings, machine_id)
-Exec.WorkingDirectory, config_parse_path, 0, offsetof(Settings, working_directory)
-Exec.PivotRoot, config_parse_pivot_root, 0, 0
-Exec.PrivateUsers, config_parse_private_users, 0, 0
-Exec.NotifyReady, config_parse_tristate, 0, offsetof(Settings, notify_ready)
-Exec.SystemCallFilter, config_parse_syscall_filter, 0, 0,
-Exec.LimitCPU, config_parse_rlimit, RLIMIT_CPU, offsetof(Settings, rlimit)
-Exec.LimitFSIZE, config_parse_rlimit, RLIMIT_FSIZE, offsetof(Settings, rlimit)
-Exec.LimitDATA, config_parse_rlimit, RLIMIT_DATA, offsetof(Settings, rlimit)
-Exec.LimitSTACK, config_parse_rlimit, RLIMIT_STACK, offsetof(Settings, rlimit)
-Exec.LimitCORE, config_parse_rlimit, RLIMIT_CORE, offsetof(Settings, rlimit)
-Exec.LimitRSS, config_parse_rlimit, RLIMIT_RSS, offsetof(Settings, rlimit)
-Exec.LimitNOFILE, config_parse_rlimit, RLIMIT_NOFILE, offsetof(Settings, rlimit)
-Exec.LimitAS, config_parse_rlimit, RLIMIT_AS, offsetof(Settings, rlimit)
-Exec.LimitNPROC, config_parse_rlimit, RLIMIT_NPROC, offsetof(Settings, rlimit)
-Exec.LimitMEMLOCK, config_parse_rlimit, RLIMIT_MEMLOCK, offsetof(Settings, rlimit)
-Exec.LimitLOCKS, config_parse_rlimit, RLIMIT_LOCKS, offsetof(Settings, rlimit)
-Exec.LimitSIGPENDING, config_parse_rlimit, RLIMIT_SIGPENDING, offsetof(Settings, rlimit)
-Exec.LimitMSGQUEUE, config_parse_rlimit, RLIMIT_MSGQUEUE, offsetof(Settings, rlimit)
-Exec.LimitNICE, config_parse_rlimit, RLIMIT_NICE, offsetof(Settings, rlimit)
-Exec.LimitRTPRIO, config_parse_rlimit, RLIMIT_RTPRIO, offsetof(Settings, rlimit)
-Exec.LimitRTTIME, config_parse_rlimit, RLIMIT_RTTIME, offsetof(Settings, rlimit)
-Exec.Hostname, config_parse_hostname, 0, offsetof(Settings, hostname)
-Exec.NoNewPrivileges, config_parse_tristate, 0, offsetof(Settings, no_new_privileges)
-Exec.OOMScoreAdjust, config_parse_oom_score_adjust, 0, 0
-Exec.CPUAffinity, config_parse_cpu_affinity, 0, 0
-Exec.ResolvConf, config_parse_resolv_conf, 0, offsetof(Settings, resolv_conf)
-Exec.LinkJournal, config_parse_link_journal, 0, 0
-Exec.Timezone, config_parse_timezone, 0, offsetof(Settings, timezone)
-Exec.SuppressSync, config_parse_tristate, 0, offsetof(Settings, suppress_sync)
-Files.ReadOnly, config_parse_tristate, 0, offsetof(Settings, read_only)
-Files.Volatile, config_parse_volatile_mode, 0, offsetof(Settings, volatile_mode)
-Files.Bind, config_parse_bind, 0, 0
-Files.BindReadOnly, config_parse_bind, 1, 0
-Files.TemporaryFileSystem, config_parse_tmpfs, 0, 0
-Files.Inaccessible, config_parse_inaccessible, 0, 0
-Files.Overlay, config_parse_overlay, 0, 0
-Files.OverlayReadOnly, config_parse_overlay, 1, 0
-Files.PrivateUsersChown, config_parse_userns_chown, 0, offsetof(Settings, userns_ownership)
-Files.PrivateUsersOwnership, config_parse_userns_ownership, 0, offsetof(Settings, userns_ownership)
-Files.BindUser, config_parse_bind_user, 0, offsetof(Settings, bind_user)
-Network.Private, config_parse_tristate, 0, offsetof(Settings, private_network)
-Network.Interface, config_parse_strv, 0, offsetof(Settings, network_interfaces)
-Network.MACVLAN, config_parse_strv, 0, offsetof(Settings, network_macvlan)
-Network.IPVLAN, config_parse_strv, 0, offsetof(Settings, network_ipvlan)
-Network.VirtualEthernet, config_parse_tristate, 0, offsetof(Settings, network_veth)
-Network.VirtualEthernetExtra, config_parse_veth_extra, 0, 0
-Network.Bridge, config_parse_ifname, 0, offsetof(Settings, network_bridge)
-Network.Zone, config_parse_network_zone, 0, 0
-Network.Port, config_parse_expose_port, 0, 0
+Exec.Boot, config_parse_boot, 0, 0
+Exec.Ephemeral, config_parse_tristate, 0, offsetof(Settings, ephemeral)
+Exec.ProcessTwo, config_parse_pid2, 0, 0
+Exec.Parameters, config_parse_strv, 0, offsetof(Settings, parameters)
+Exec.Environment, config_parse_strv, 0, offsetof(Settings, environment)
+Exec.User, config_parse_string, CONFIG_PARSE_STRING_SAFE, offsetof(Settings, user)
+Exec.Capability, config_parse_capability, 0, offsetof(Settings, capability)
+Exec.AmbientCapability, config_parse_capability, 0, offsetof(Settings, ambient_capability)
+Exec.DropCapability, config_parse_capability, 0, offsetof(Settings, drop_capability)
+Exec.KillSignal, config_parse_signal, 0, offsetof(Settings, kill_signal)
+Exec.Personality, config_parse_personality, 0, offsetof(Settings, personality)
+Exec.MachineID, config_parse_id128, 0, offsetof(Settings, machine_id)
+Exec.WorkingDirectory, config_parse_path, 0, offsetof(Settings, working_directory)
+Exec.PivotRoot, config_parse_pivot_root, 0, 0
+Exec.PrivateUsers, config_parse_private_users, 0, 0
+Exec.NotifyReady, config_parse_tristate, 0, offsetof(Settings, notify_ready)
+Exec.SystemCallFilter, config_parse_syscall_filter, 0, 0
+Exec.LimitCPU, config_parse_rlimit, RLIMIT_CPU, offsetof(Settings, rlimit)
+Exec.LimitFSIZE, config_parse_rlimit, RLIMIT_FSIZE, offsetof(Settings, rlimit)
+Exec.LimitDATA, config_parse_rlimit, RLIMIT_DATA, offsetof(Settings, rlimit)
+Exec.LimitSTACK, config_parse_rlimit, RLIMIT_STACK, offsetof(Settings, rlimit)
+Exec.LimitCORE, config_parse_rlimit, RLIMIT_CORE, offsetof(Settings, rlimit)
+Exec.LimitRSS, config_parse_rlimit, RLIMIT_RSS, offsetof(Settings, rlimit)
+Exec.LimitNOFILE, config_parse_rlimit, RLIMIT_NOFILE, offsetof(Settings, rlimit)
+Exec.LimitAS, config_parse_rlimit, RLIMIT_AS, offsetof(Settings, rlimit)
+Exec.LimitNPROC, config_parse_rlimit, RLIMIT_NPROC, offsetof(Settings, rlimit)
+Exec.LimitMEMLOCK, config_parse_rlimit, RLIMIT_MEMLOCK, offsetof(Settings, rlimit)
+Exec.LimitLOCKS, config_parse_rlimit, RLIMIT_LOCKS, offsetof(Settings, rlimit)
+Exec.LimitSIGPENDING, config_parse_rlimit, RLIMIT_SIGPENDING, offsetof(Settings, rlimit)
+Exec.LimitMSGQUEUE, config_parse_rlimit, RLIMIT_MSGQUEUE, offsetof(Settings, rlimit)
+Exec.LimitNICE, config_parse_rlimit, RLIMIT_NICE, offsetof(Settings, rlimit)
+Exec.LimitRTPRIO, config_parse_rlimit, RLIMIT_RTPRIO, offsetof(Settings, rlimit)
+Exec.LimitRTTIME, config_parse_rlimit, RLIMIT_RTTIME, offsetof(Settings, rlimit)
+Exec.Hostname, config_parse_hostname, 0, offsetof(Settings, hostname)
+Exec.NoNewPrivileges, config_parse_tristate, 0, offsetof(Settings, no_new_privileges)
+Exec.OOMScoreAdjust, config_parse_oom_score_adjust, 0, 0
+Exec.CPUAffinity, config_parse_cpu_affinity, 0, 0
+Exec.ResolvConf, config_parse_resolv_conf, 0, offsetof(Settings, resolv_conf)
+Exec.LinkJournal, config_parse_link_journal, 0, 0
+Exec.Timezone, config_parse_timezone, 0, offsetof(Settings, timezone)
+Exec.SuppressSync, config_parse_tristate, 0, offsetof(Settings, suppress_sync)
+Files.ReadOnly, config_parse_tristate, 0, offsetof(Settings, read_only)
+Files.Volatile, config_parse_volatile_mode, 0, offsetof(Settings, volatile_mode)
+Files.Bind, config_parse_bind, 0, 0
+Files.BindReadOnly, config_parse_bind, 1, 0
+Files.TemporaryFileSystem, config_parse_tmpfs, 0, 0
+Files.Inaccessible, config_parse_inaccessible, 0, 0
+Files.Overlay, config_parse_overlay, 0, 0
+Files.OverlayReadOnly, config_parse_overlay, 1, 0
+Files.PrivateUsersChown, config_parse_userns_chown, 0, offsetof(Settings, userns_ownership)
+Files.PrivateUsersOwnership, config_parse_userns_ownership, 0, offsetof(Settings, userns_ownership)
+Files.BindUser, config_parse_bind_user, 0, offsetof(Settings, bind_user)
+Network.Private, config_parse_tristate, 0, offsetof(Settings, private_network)
+Network.Interface, config_parse_strv, 0, offsetof(Settings, network_interfaces)
+Network.MACVLAN, config_parse_strv, 0, offsetof(Settings, network_macvlan)
+Network.IPVLAN, config_parse_strv, 0, offsetof(Settings, network_ipvlan)
+Network.VirtualEthernet, config_parse_tristate, 0, offsetof(Settings, network_veth)
+Network.VirtualEthernetExtra, config_parse_veth_extra, 0, 0
+Network.Bridge, config_parse_ifname, 0, offsetof(Settings, network_bridge)
+Network.Zone, config_parse_network_zone, 0, 0
+Network.Port, config_parse_expose_port, 0, 0
diff --git a/src/nspawn/nspawn-settings.c b/src/nspawn/nspawn-settings.c
index 1f58bf3ed48..3a5d72549a1 100644
--- a/src/nspawn/nspawn-settings.c
+++ b/src/nspawn/nspawn-settings.c
@@ -710,31 +710,6 @@ int config_parse_syscall_filter(
}
}
-int config_parse_hostname(
- const char *unit,
- const char *filename,
- unsigned line,
- const char *section,
- unsigned section_line,
- const char *lvalue,
- int ltype,
- const char *rvalue,
- void *data,
- void *userdata) {
-
- char **s = data;
-
- assert(rvalue);
- assert(s);
-
- if (!hostname_is_valid(rvalue, 0)) {
- log_syntax(unit, LOG_WARNING, filename, line, 0, "Invalid hostname, ignoring: %s", rvalue);
- return 0;
- }
-
- return free_and_strdup_warn(s, empty_to_null(rvalue));
-}
-
int config_parse_oom_score_adjust(
const char *unit,
const char *filename,
diff --git a/src/nspawn/nspawn-settings.h b/src/nspawn/nspawn-settings.h
index 59397ca54be..004b663e9e4 100644
--- a/src/nspawn/nspawn-settings.h
+++ b/src/nspawn/nspawn-settings.h
@@ -264,7 +264,6 @@ CONFIG_PARSER_PROTOTYPE(config_parse_boot);
CONFIG_PARSER_PROTOTYPE(config_parse_pid2);
CONFIG_PARSER_PROTOTYPE(config_parse_private_users);
CONFIG_PARSER_PROTOTYPE(config_parse_syscall_filter);
-CONFIG_PARSER_PROTOTYPE(config_parse_hostname);
CONFIG_PARSER_PROTOTYPE(config_parse_oom_score_adjust);
CONFIG_PARSER_PROTOTYPE(config_parse_cpu_affinity);
CONFIG_PARSER_PROTOTYPE(config_parse_resolv_conf);
diff --git a/src/shared/conf-parser.c b/src/shared/conf-parser.c
index 853f60f5173..0ae499814e2 100644
--- a/src/shared/conf-parser.c
+++ b/src/shared/conf-parser.c
@@ -11,11 +11,14 @@
#include "conf-files.h"
#include "conf-parser.h"
#include "def.h"
+#include "dns-domain.h"
+#include "escape.h"
#include "ether-addr-util.h"
#include "extract-word.h"
#include "fd-util.h"
#include "fileio.h"
#include "fs-util.h"
+#include "hostname-util.h"
#include "in-addr-util.h"
#include "log.h"
#include "macro.h"
@@ -873,17 +876,39 @@ int config_parse_string(
void *data,
void *userdata) {
- char **s = data;
+ char **s = ASSERT_PTR(data);
assert(filename);
assert(lvalue);
assert(rvalue);
- assert(data);
+
+ if (isempty(rvalue)) {
+ *s = mfree(*s);
+ return 0;
+ }
+
+ if (FLAGS_SET(ltype, CONFIG_PARSE_STRING_SAFE) && !string_is_safe(rvalue)) {
+ _cleanup_free_ char *escaped = NULL;
+
+ escaped = cescape(rvalue);
+ log_syntax(unit, LOG_WARNING, filename, line, 0,
+ "Specified string contains unsafe characters, ignoring: %s", strna(escaped));
+ return 0;
+ }
+
+ if (FLAGS_SET(ltype, CONFIG_PARSE_STRING_ASCII) && !ascii_is_valid(rvalue)) {
+ _cleanup_free_ char *escaped = NULL;
+
+ escaped = cescape(rvalue);
+ log_syntax(unit, LOG_WARNING, filename, line, 0,
+ "Specified string contains invalid ASCII characters, ignoring: %s", strna(escaped));
+ return 0;
+ }
return free_and_strdup_warn(s, empty_to_null(rvalue));
}
-int config_parse_safe_string(
+int config_parse_dns_name(
const char *unit,
const char *filename,
unsigned line,
@@ -895,19 +920,64 @@ int config_parse_safe_string(
void *data,
void *userdata) {
- char **s = data;
+ char **hostname = ASSERT_PTR(data);
+ int r;
assert(filename);
assert(lvalue);
assert(rvalue);
- assert(data);
- if (!string_is_safe(rvalue)) {
- log_syntax(unit, LOG_WARNING, filename, line, 0, "Specified string contains unsafe characters, ignoring: %s", rvalue);
+ if (isempty(rvalue)) {
+ *hostname = mfree(*hostname);
return 0;
}
- return free_and_strdup_warn(s, empty_to_null(rvalue));
+ r = dns_name_is_valid(rvalue);
+ if (r < 0) {
+ log_syntax(unit, LOG_WARNING, filename, line, r,
+ "Failed to check validity of DNS domain name '%s', ignoring assignment: %m", rvalue);
+ return 0;
+ }
+ if (r == 0) {
+ log_syntax(unit, LOG_WARNING, filename, line, 0,
+ "Specified invalid DNS domain name, ignoring assignment: %s", rvalue);
+ return 0;
+ }
+
+ return free_and_strdup_warn(hostname, rvalue);
+}
+
+int config_parse_hostname(
+ const char *unit,
+ const char *filename,
+ unsigned line,
+ const char *section,
+ unsigned section_line,
+ const char *lvalue,
+ int ltype,
+ const char *rvalue,
+ void *data,
+ void *userdata) {
+
+ char **hostname = ASSERT_PTR(data);
+
+ assert(filename);
+ assert(lvalue);
+ assert(rvalue);
+
+ if (isempty(rvalue)) {
+ *hostname = mfree(*hostname);
+ return 0;
+ }
+
+ if (!hostname_is_valid(rvalue, 0)) {
+ log_syntax(unit, LOG_WARNING, filename, line, 0,
+ "Specified invalid hostname, ignoring assignment: %s", rvalue);
+ return 0;
+ }
+
+ return config_parse_dns_name(unit, filename, line, section, section_line,
+ lvalue, ltype, rvalue, data, userdata);
}
int config_parse_path(
diff --git a/src/shared/conf-parser.h b/src/shared/conf-parser.h
index 7badb4b12b1..94778af4588 100644
--- a/src/shared/conf-parser.h
+++ b/src/shared/conf-parser.h
@@ -168,7 +168,8 @@ CONFIG_PARSER_PROTOTYPE(config_parse_bool);
CONFIG_PARSER_PROTOTYPE(config_parse_id128);
CONFIG_PARSER_PROTOTYPE(config_parse_tristate);
CONFIG_PARSER_PROTOTYPE(config_parse_string);
-CONFIG_PARSER_PROTOTYPE(config_parse_safe_string);
+CONFIG_PARSER_PROTOTYPE(config_parse_dns_name);
+CONFIG_PARSER_PROTOTYPE(config_parse_hostname);
CONFIG_PARSER_PROTOTYPE(config_parse_path);
CONFIG_PARSER_PROTOTYPE(config_parse_strv);
CONFIG_PARSER_PROTOTYPE(config_parse_sec);
@@ -203,6 +204,13 @@ typedef enum Disabled {
DISABLED_EXPERIMENTAL,
} Disabled;
+typedef enum ConfigParseStringFlags {
+ CONFIG_PARSE_STRING_SAFE = 1 << 0,
+ CONFIG_PARSE_STRING_ASCII = 1 << 1,
+
+ CONFIG_PARSE_STRING_SAFE_AND_ASCII = CONFIG_PARSE_STRING_SAFE | CONFIG_PARSE_STRING_ASCII,
+} ConfigParseStringFlags;
+
#define DEFINE_CONFIG_PARSE(function, parser, msg) \
CONFIG_PARSER_PROTOTYPE(function) { \
int *i = data, r; \
diff --git a/src/systemd/sd-dhcp-client.h b/src/systemd/sd-dhcp-client.h
index 78d68addf45..834f80b4210 100644
--- a/src/systemd/sd-dhcp-client.h
+++ b/src/systemd/sd-dhcp-client.h
@@ -44,71 +44,175 @@ enum {
* The client may want to start acquiring link-local addresses. */
};
+/* https://www.iana.org/assignments/bootp-dhcp-parameters/bootp-dhcp-parameters.xhtml#options */
enum {
- SD_DHCP_OPTION_PAD = 0,
- SD_DHCP_OPTION_SUBNET_MASK = 1,
- SD_DHCP_OPTION_TIME_OFFSET = 2,
- SD_DHCP_OPTION_ROUTER = 3,
- SD_DHCP_OPTION_DOMAIN_NAME_SERVER = 6,
- SD_DHCP_OPTION_LPR_SERVER = 9,
- SD_DHCP_OPTION_HOST_NAME = 12,
- SD_DHCP_OPTION_BOOT_FILE_SIZE = 13,
- SD_DHCP_OPTION_DOMAIN_NAME = 15,
- SD_DHCP_OPTION_ROOT_PATH = 17,
- SD_DHCP_OPTION_ENABLE_IP_FORWARDING = 19,
- SD_DHCP_OPTION_ENABLE_IP_FORWARDING_NL = 20,
- SD_DHCP_OPTION_POLICY_FILTER = 21,
- SD_DHCP_OPTION_INTERFACE_MDR = 22,
- SD_DHCP_OPTION_INTERFACE_TTL = 23,
- SD_DHCP_OPTION_INTERFACE_MTU_AGING_TIMEOUT = 24,
- SD_DHCP_OPTION_INTERFACE_MTU = 26,
- SD_DHCP_OPTION_BROADCAST = 28,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_ROUTER_DISCOVER = 31,
- SD_DHCP_OPTION_STATIC_ROUTE = 33,
- SD_DHCP_OPTION_NTP_SERVER = 42,
- SD_DHCP_OPTION_VENDOR_SPECIFIC = 43,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_NETBIOS_NAMESERVER = 44,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_NETBIOS_NODETYPE = 46,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_NETBIOS_SCOPE = 47,
- SD_DHCP_OPTION_REQUESTED_IP_ADDRESS = 50,
- SD_DHCP_OPTION_IP_ADDRESS_LEASE_TIME = 51,
- SD_DHCP_OPTION_OVERLOAD = 52,
- SD_DHCP_OPTION_MESSAGE_TYPE = 53,
- SD_DHCP_OPTION_SERVER_IDENTIFIER = 54,
- SD_DHCP_OPTION_PARAMETER_REQUEST_LIST = 55,
- SD_DHCP_OPTION_ERROR_MESSAGE = 56,
- SD_DHCP_OPTION_MAXIMUM_MESSAGE_SIZE = 57,
- SD_DHCP_OPTION_RENEWAL_T1_TIME = 58,
- SD_DHCP_OPTION_REBINDING_T2_TIME = 59,
- SD_DHCP_OPTION_VENDOR_CLASS_IDENTIFIER = 60,
- SD_DHCP_OPTION_CLIENT_IDENTIFIER = 61,
- SD_DHCP_OPTION_SMTP_SERVER = 69,
- SD_DHCP_OPTION_POP3_SERVER = 70,
- SD_DHCP_OPTION_USER_CLASS = 77,
- SD_DHCP_OPTION_FQDN = 81,
- SD_DHCP_OPTION_RELAY_AGENT_INFORMATION = 82,
- SD_DHCP_OPTION_NEW_POSIX_TIMEZONE = 100,
- SD_DHCP_OPTION_NEW_TZDB_TIMEZONE = 101,
- SD_DHCP_OPTION_DOMAIN_SEARCH_LIST = 119,
- SD_DHCP_OPTION_SIP_SERVER = 120,
- SD_DHCP_OPTION_CLASSLESS_STATIC_ROUTE = 121,
- SD_DHCP_OPTION_MUD_URL = 161,
- SD_DHCP_OPTION_PXELINUX_MAGIC = 208, /* deprecated */
- SD_DHCP_OPTION_CONFIGURATION_FILE = 209,
- SD_DHCP_OPTION_PATH_PREFIX = 210,
- SD_DHCP_OPTION_REBOOT_TIME = 211,
- SD_DHCP_OPTION_6RD = 212,
+ SD_DHCP_OPTION_PAD = 0, /* [RFC2132] */
+ SD_DHCP_OPTION_SUBNET_MASK = 1, /* [RFC2132] */
+ SD_DHCP_OPTION_TIME_OFFSET = 2, /* [RFC2132], deprecated by 100 and 101 */
+ SD_DHCP_OPTION_ROUTER = 3, /* [RFC2132] */
+ SD_DHCP_OPTION_TIME_SERVER = 4, /* [RFC2132] */
+ SD_DHCP_OPTION_NAME_SERVER = 5, /* [RFC2132] */
+ SD_DHCP_OPTION_DOMAIN_NAME_SERVER = 6, /* [RFC2132] */
+ SD_DHCP_OPTION_LOG_SERVER = 7, /* [RFC2132] */
+ SD_DHCP_OPTION_QUOTES_SERVER = 8, /* [RFC2132] */
+ SD_DHCP_OPTION_LPR_SERVER = 9, /* [RFC2132] */
+ SD_DHCP_OPTION_IMPRESS_SERVER = 10, /* [RFC2132] */
+ SD_DHCP_OPTION_RLP_SERVER = 11, /* [RFC2132] */
+ SD_DHCP_OPTION_HOST_NAME = 12, /* [RFC2132] */
+ SD_DHCP_OPTION_BOOT_FILE_SIZE = 13, /* [RFC2132] */
+ SD_DHCP_OPTION_MERIT_DUMP_FILE = 14, /* [RFC2132] */
+ SD_DHCP_OPTION_DOMAIN_NAME = 15, /* [RFC2132] */
+ SD_DHCP_OPTION_SWAP_SERVER = 16, /* [RFC2132] */
+ SD_DHCP_OPTION_ROOT_PATH = 17, /* [RFC2132] */
+ SD_DHCP_OPTION_EXTENSION_FILE = 18, /* [RFC2132] */
+ SD_DHCP_OPTION_FORWARD = 19, /* [RFC2132] */
+ SD_DHCP_OPTION_SOURCE_ROUTE = 20, /* [RFC2132] */
+ SD_DHCP_OPTION_POLICY_FILTER = 21, /* [RFC2132] */
+ SD_DHCP_OPTION_MAX_DATAGRAM_ASSEMBLY = 22, /* [RFC2132] */
+ SD_DHCP_OPTION_DEFAULT_IP_TTL = 23, /* [RFC2132] */
+ SD_DHCP_OPTION_MTU_TIMEOUT = 24, /* [RFC2132] */
+ SD_DHCP_OPTION_MTU_PLATEAU = 25, /* [RFC2132] */
+ SD_DHCP_OPTION_MTU_INTERFACE = 26, /* [RFC2132] */
+ SD_DHCP_OPTION_MTU_SUBNET = 27, /* [RFC2132] */
+ SD_DHCP_OPTION_BROADCAST = 28, /* [RFC2132] */
+ SD_DHCP_OPTION_MASK_DISCOVERY = 29, /* [RFC2132] */
+ SD_DHCP_OPTION_MASK_SUPPLIER = 30, /* [RFC2132] */
+ SD_DHCP_OPTION_ROUTER_DISCOVERY = 31, /* [RFC2132] */
+ SD_DHCP_OPTION_ROUTER_REQUEST = 32, /* [RFC2132] */
+ SD_DHCP_OPTION_STATIC_ROUTE = 33, /* [RFC2132] */
+ SD_DHCP_OPTION_TRAILERS = 34, /* [RFC2132] */
+ SD_DHCP_OPTION_ARP_TIMEOUT = 35, /* [RFC2132] */
+ SD_DHCP_OPTION_ETHERNET = 36, /* [RFC2132] */
+ SD_DHCP_OPTION_DEFAULT_TCP_TTL = 37, /* [RFC2132] */
+ SD_DHCP_OPTION_KEEPALIVE_TIME = 38, /* [RFC2132] */
+ SD_DHCP_OPTION_KEEPALIVE_DATA = 39, /* [RFC2132] */
+ SD_DHCP_OPTION_NIS_DOMAIN = 40, /* [RFC2132] */
+ SD_DHCP_OPTION_NIS_SERVER = 41, /* [RFC2132] */
+ SD_DHCP_OPTION_NTP_SERVER = 42, /* [RFC2132] */
+ SD_DHCP_OPTION_VENDOR_SPECIFIC = 43, /* [RFC2132] */
+ SD_DHCP_OPTION_NETBIOS_NAME_SERVER = 44, /* [RFC2132] */
+ SD_DHCP_OPTION_NETBIOS_DIST_SERVER = 45, /* [RFC2132] */
+ SD_DHCP_OPTION_NETBIOS_NODE_TYPE = 46, /* [RFC2132] */
+ SD_DHCP_OPTION_NETBIOS_SCOPE = 47, /* [RFC2132] */
+ SD_DHCP_OPTION_X_WINDOW_FONT = 48, /* [RFC2132] */
+ SD_DHCP_OPTION_X_WINDOW_MANAGER = 49, /* [RFC2132] */
+ SD_DHCP_OPTION_REQUESTED_IP_ADDRESS = 50, /* [RFC2132] */
+ SD_DHCP_OPTION_IP_ADDRESS_LEASE_TIME = 51, /* [RFC2132] */
+ SD_DHCP_OPTION_OVERLOAD = 52, /* [RFC2132] */
+ SD_DHCP_OPTION_MESSAGE_TYPE = 53, /* [RFC2132] */
+ SD_DHCP_OPTION_SERVER_IDENTIFIER = 54, /* [RFC2132] */
+ SD_DHCP_OPTION_PARAMETER_REQUEST_LIST = 55, /* [RFC2132] */
+ SD_DHCP_OPTION_ERROR_MESSAGE = 56, /* [RFC2132] */
+ SD_DHCP_OPTION_MAXIMUM_MESSAGE_SIZE = 57, /* [RFC2132] */
+ SD_DHCP_OPTION_RENEWAL_TIME = 58, /* [RFC2132] */
+ SD_DHCP_OPTION_REBINDING_TIME = 59, /* [RFC2132] */
+ SD_DHCP_OPTION_VENDOR_CLASS_IDENTIFIER = 60, /* [RFC2132] */
+ SD_DHCP_OPTION_CLIENT_IDENTIFIER = 61, /* [RFC2132] */
+ SD_DHCP_OPTION_NETWARE_IP_DOMAIN = 62, /* [RFC2242] */
+ SD_DHCP_OPTION_NETWARE_IP_OPTION = 63, /* [RFC2242] */
+ SD_DHCP_OPTION_NIS_DOMAIN_NAME = 64, /* [RFC2132] */
+ SD_DHCP_OPTION_NIS_SERVER_ADDR = 65, /* [RFC2132] */
+ SD_DHCP_OPTION_BOOT_SERVER_NAME = 66, /* [RFC2132] */
+ SD_DHCP_OPTION_BOOT_FILENAME = 67, /* [RFC2132] */
+ SD_DHCP_OPTION_HOME_AGENT_ADDRESSES = 68, /* [RFC2132] */
+ SD_DHCP_OPTION_SMTP_SERVER = 69, /* [RFC2132] */
+ SD_DHCP_OPTION_POP3_SERVER = 70, /* [RFC2132] */
+ SD_DHCP_OPTION_NNTP_SERVER = 71, /* [RFC2132] */
+ SD_DHCP_OPTION_WWW_SERVER = 72, /* [RFC2132] */
+ SD_DHCP_OPTION_FINGER_SERVER = 73, /* [RFC2132] */
+ SD_DHCP_OPTION_IRC_SERVER = 74, /* [RFC2132] */
+ SD_DHCP_OPTION_STREETTALK_SERVER = 75, /* [RFC2132] */
+ SD_DHCP_OPTION_STDA_SERVER = 76, /* [RFC2132] */
+ SD_DHCP_OPTION_USER_CLASS = 77, /* [RFC3004] */
+ SD_DHCP_OPTION_DIRECTORY_AGENT = 78, /* [RFC2610] */
+ SD_DHCP_OPTION_SERVICE_SCOPE = 79, /* [RFC2610] */
+ SD_DHCP_OPTION_RAPID_COMMIT = 80, /* [RFC4039] */
+ SD_DHCP_OPTION_FQDN = 81, /* [RFC4702] */
+ SD_DHCP_OPTION_RELAY_AGENT_INFORMATION = 82, /* [RFC3046] */
+ SD_DHCP_OPTION_ISNS = 83, /* [RFC4174] */
+ /* option code 84 is unassigned [RFC3679] */
+ SD_DHCP_OPTION_NDS_SERVER = 85, /* [RFC2241] */
+ SD_DHCP_OPTION_NDS_TREE_NAME = 86, /* [RFC2241] */
+ SD_DHCP_OPTION_NDS_CONTEXT = 87, /* [RFC2241] */
+ SD_DHCP_OPTION_BCMCS_CONTROLLER_DOMAIN_NAM = 88, /* [RFC4280] */
+ SD_DHCP_OPTION_BCMCS_CONTROLLER_ADDRESS = 89, /* [RFC4280] */
+ SD_DHCP_OPTION_AUTHENTICATION = 90, /* [RFC3118] */
+ SD_DHCP_OPTION_CLIENT_LAST_TRANSACTION_TIME = 91, /* [RFC4388] */
+ SD_DHCP_OPTION_ASSOCIATED_IP = 92, /* [RFC4388] */
+ SD_DHCP_OPTION_CLIENT_SYSTEM = 93, /* [RFC4578] */
+ SD_DHCP_OPTION_CLIENT_NDI = 94, /* [RFC4578] */
+ SD_DHCP_OPTION_LDAP = 95, /* [RFC3679] */
+ /* option code 96 is unassigned [RFC3679] */
+ SD_DHCP_OPTION_UUID = 97, /* [RFC4578] */
+ SD_DHCP_OPTION_USER_AUTHENTICATION = 98, /* [RFC2485] */
+ SD_DHCP_OPTION_GEOCONF_CIVIC = 99, /* [RFC4776] */
+ SD_DHCP_OPTION_POSIX_TIMEZONE = 100, /* [RFC4833] */
+ SD_DHCP_OPTION_TZDB_TIMEZONE = 101, /* [RFC4833] */
+ /* option codes 102-107 are unassigned [RFC3679] */
+ SD_DHCP_OPTION_IPV6_ONLY_PREFERRED = 108, /* [RFC8925] */
+ SD_DHCP_OPTION_DHCP4O6_SOURCE_ADDRESS = 109, /* [RFC8539] */
+ /* option codes 110-111 are unassigned [RFC3679] */
+ SD_DHCP_OPTION_NETINFO_ADDRESS = 112, /* [RFC3679] */
+ SD_DHCP_OPTION_NETINFO_TAG = 113, /* [RFC3679] */
+ SD_DHCP_OPTION_DHCP_CAPTIVE_PORTAL = 114, /* [RFC8910] */
+ /* option code 115 is unassigned [RFC3679] */
+ SD_DHCP_OPTION_AUTO_CONFIG = 116, /* [RFC2563] */
+ SD_DHCP_OPTION_NAME_SERVICE_SEARCH = 117, /* [RFC2937] */
+ SD_DHCP_OPTION_SUBNET_SELECTION = 118, /* [RFC3011] */
+ SD_DHCP_OPTION_DOMAIN_SEARCH = 119, /* [RFC3397] */
+ SD_DHCP_OPTION_SIP_SERVER = 120, /* [RFC3361] */
+ SD_DHCP_OPTION_CLASSLESS_STATIC_ROUTE = 121, /* [RFC3442] */
+ SD_DHCP_OPTION_CABLELABS_CLIENT_CONFIGURATION = 122, /* [RFC3495] */
+ SD_DHCP_OPTION_GEOCONF = 123, /* [RFC6225] */
+ SD_DHCP_OPTION_VENDOR_CLASS = 124, /* [RFC3925] */
+ SD_DHCP_OPTION_VENDOR_SPECIFIC_INFORMATION = 125, /* [RFC3925] */
+ /* option codes 126-127 are unassigned [RFC3679] */
+ /* option codes 128-135 are assigned to use by PXE, but they are vendor specific [RFC4578] */
+ SD_DHCP_OPTION_PANA_AGENT = 136, /* [RFC5192] */
+ SD_DHCP_OPTION_LOST_SERVER_FQDN = 137, /* [RFC5223] */
+ SD_DHCP_OPTION_CAPWAP_AC_ADDRESS = 138, /* [RFC5417] */
+ SD_DHCP_OPTION_MOS_ADDRESS = 139, /* [RFC5678] */
+ SD_DHCP_OPTION_MOS_FQDN = 140, /* [RFC5678] */
+ SD_DHCP_OPTION_SIP_SERVICE_DOMAINS = 141, /* [RFC6011] */
+ SD_DHCP_OPTION_ANDSF_ADDRESS = 142, /* [RFC6153] */
+ SD_DHCP_OPTION_SZTP_REDIRECT = 143, /* [RFC8572] */
+ SD_DHCP_OPTION_GEOLOC = 144, /* [RFC6225] */
+ SD_DHCP_OPTION_FORCERENEW_NONCE_CAPABLE = 145, /* [RFC6704] */
+ SD_DHCP_OPTION_RDNSS_SELECTION = 146, /* [RFC6731] */
+ SD_DHCP_OPTION_DOTS_RI = 147, /* [RFC8973] */
+ SD_DHCP_OPTION_DOTS_ADDRESS = 148, /* [RFC8973] */
+ /* option code 149 is unassigned [RFC3942] */
+ SD_DHCP_OPTION_TFTP_SERVER_ADDRESS = 150, /* [RFC5859] */
+ SD_DHCP_OPTION_STATUS_CODE = 151, /* [RFC6926] */
+ SD_DHCP_OPTION_BASE_TIME = 152, /* [RFC6926] */
+ SD_DHCP_OPTION_START_TIME_OF_STATE = 153, /* [RFC6926] */
+ SD_DHCP_OPTION_QUERY_START_TIME = 154, /* [RFC6926] */
+ SD_DHCP_OPTION_QUERY_END_TIME = 155, /* [RFC6926] */
+ SD_DHCP_OPTION_DHCP_STATE = 156, /* [RFC6926] */
+ SD_DHCP_OPTION_DATA_SOURCE = 157, /* [RFC6926] */
+ SD_DHCP_OPTION_PCP_SERVER = 158, /* [RFC7291] */
+ SD_DHCP_OPTION_PORT_PARAMS = 159, /* [RFC7618] */
+ /* option code 160 is unassigned [RFC7710][RFC8910] */
+ SD_DHCP_OPTION_MUD_URL = 161, /* [RFC8520] */
+ /* option codes 162-174 are unassigned [RFC3942] */
+ /* option codes 175-177 are temporary assigned. */
+ /* option codes 178-207 are unassigned [RFC3942] */
+ SD_DHCP_OPTION_PXELINUX_MAGIC = 208, /* [RFC5071] Deprecated */
+ SD_DHCP_OPTION_CONFIGURATION_FILE = 209, /* [RFC5071] */
+ SD_DHCP_OPTION_PATH_PREFIX = 210, /* [RFC5071] */
+ SD_DHCP_OPTION_REBOOT_TIME = 211, /* [RFC5071] */
+ SD_DHCP_OPTION_6RD = 212, /* [RFC5969] */
+ SD_DHCP_OPTION_ACCESS_DOMAIN = 213, /* [RFC5986] */
+ /* option codes 214-219 are unassigned */
+ SD_DHCP_OPTION_SUBNET_ALLOCATION = 220, /* [RFC6656] */
+ SD_DHCP_OPTION_VIRTUAL_SUBNET_SELECTION = 221, /* [RFC6607] */
+ /* option codes 222-223 are unassigned [RFC3942] */
+ /* option codes 224-254 are reserved for private use */
SD_DHCP_OPTION_PRIVATE_BASE = 224,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_PRIVATE_CLASSLESS_STATIC_ROUTE = 249,
- /* Windows 10 option to send when Anonymize=true */
- SD_DHCP_OPTION_PRIVATE_PROXY_AUTODISCOVERY = 252,
+ SD_DHCP_OPTION_PRIVATE_CLASSLESS_STATIC_ROUTE = 249, /* [RFC7844] */
+ SD_DHCP_OPTION_PRIVATE_PROXY_AUTODISCOVERY = 252, /* [RFC7844] */
SD_DHCP_OPTION_PRIVATE_LAST = 254,
- SD_DHCP_OPTION_END = 255,
+ SD_DHCP_OPTION_END = 255, /* [RFC2132] */
};
/* Suboptions for SD_DHCP_OPTION_RELAY_AGENT_INFORMATION option */
diff --git a/src/systemd/sd-dhcp-server.h b/src/systemd/sd-dhcp-server.h
index af7c3b68f3e..371834dd8da 100644
--- a/src/systemd/sd-dhcp-server.h
+++ b/src/systemd/sd-dhcp-server.h
@@ -58,8 +58,9 @@ int sd_dhcp_server_stop(sd_dhcp_server *server);
int sd_dhcp_server_configure_pool(sd_dhcp_server *server, const struct in_addr *address, unsigned char prefixlen, uint32_t offset, uint32_t size);
-int sd_dhcp_server_set_next_server(sd_dhcp_server *server, const struct in_addr *next_server);
-int sd_dhcp_server_set_filename(sd_dhcp_server *server, const char *filename);
+int sd_dhcp_server_set_boot_server_address(sd_dhcp_server *server, const struct in_addr *address);
+int sd_dhcp_server_set_boot_server_name(sd_dhcp_server *server, const char *name);
+int sd_dhcp_server_set_boot_filename(sd_dhcp_server *server, const char *filename);
int sd_dhcp_server_set_bind_to_interface(sd_dhcp_server *server, int enabled);
int sd_dhcp_server_set_timezone(sd_dhcp_server *server, const char *timezone);
int sd_dhcp_server_set_router(sd_dhcp_server *server, const struct in_addr *address);
diff --git a/src/systemd/sd-dhcp6-client.h b/src/systemd/sd-dhcp6-client.h
index 1bb21e0255d..d89b7d1c838 100644
--- a/src/systemd/sd-dhcp6-client.h
+++ b/src/systemd/sd-dhcp6-client.h
@@ -81,8 +81,8 @@ enum {
SD_DHCP6_OPTION_SUBSCRIBER_ID = 38, /* RFC 4580 */
SD_DHCP6_OPTION_CLIENT_FQDN = 39, /* RFC 4704 */
SD_DHCP6_OPTION_PANA_AGENT = 40, /* RFC 5192 */
- SD_DHCP6_OPTION_NEW_POSIX_TIMEZONE = 41, /* RFC 4833 */
- SD_DHCP6_OPTION_NEW_TZDB_TIMEZONE = 42, /* RFC 4833 */
+ SD_DHCP6_OPTION_POSIX_TIMEZONE = 41, /* RFC 4833 */
+ SD_DHCP6_OPTION_TZDB_TIMEZONE = 42, /* RFC 4833 */
SD_DHCP6_OPTION_ERO = 43, /* RFC 4994 */
SD_DHCP6_OPTION_LQ_QUERY = 44, /* RFC 5007 */
SD_DHCP6_OPTION_CLIENT_DATA = 45, /* RFC 5007 */
diff --git a/src/tty-ask-password-agent/tty-ask-password-agent.c b/src/tty-ask-password-agent/tty-ask-password-agent.c
index 72559e11a96..e98b38510eb 100644
--- a/src/tty-ask-password-agent/tty-ask-password-agent.c
+++ b/src/tty-ask-password-agent/tty-ask-password-agent.c
@@ -177,13 +177,13 @@ static int process_one_password_file(const char *filename) {
pid_t pid = 0;
const ConfigTableItem items[] = {
- { "Ask", "Socket", config_parse_safe_string, 0, &socket_name },
- { "Ask", "NotAfter", config_parse_uint64, 0, ¬_after },
- { "Ask", "Message", config_parse_string, 0, &message },
- { "Ask", "PID", config_parse_pid, 0, &pid },
- { "Ask", "AcceptCached", config_parse_bool, 0, &accept_cached },
- { "Ask", "Echo", config_parse_bool, 0, &echo },
- { "Ask", "Silent", config_parse_bool, 0, &silent },
+ { "Ask", "Socket", config_parse_string, CONFIG_PARSE_STRING_SAFE, &socket_name },
+ { "Ask", "NotAfter", config_parse_uint64, 0, ¬_after },
+ { "Ask", "Message", config_parse_string, 0, &message },
+ { "Ask", "PID", config_parse_pid, 0, &pid },
+ { "Ask", "AcceptCached", config_parse_bool, 0, &accept_cached },
+ { "Ask", "Echo", config_parse_bool, 0, &echo },
+ { "Ask", "Silent", config_parse_bool, 0, &silent },
{}
};
diff --git a/test/fuzz/fuzz-network-parser/directives.network b/test/fuzz/fuzz-network-parser/directives.network
index c682ac4ac1a..276f3c93076 100644
--- a/test/fuzz/fuzz-network-parser/directives.network
+++ b/test/fuzz/fuzz-network-parser/directives.network
@@ -409,8 +409,9 @@ RelayAgentCircuitId=
RelayAgentRemoteId=
ServerAddress=
UplinkInterface=
-NextServer=
-Filename=
+BootServerAddress=
+BootServerName=
+BootFilename=
[DHCPServerStaticLease]
MACAddress=
Address=