diff --git a/Makefile.am b/Makefile.am index 93c7ce08815..f15c2ed914a 100644 --- a/Makefile.am +++ b/Makefile.am @@ -179,6 +179,7 @@ sssdlibexec_PROGRAMS = \ ldap_child \ proxy_child \ sss_signal \ + setdomainname \ $(NULL) if BUILD_SUDO sssdlibexec_PROGRAMS += sssd_sudo @@ -220,6 +221,7 @@ if BUILD_PAC_RESPONDER endif if HAVE_SYSTEMD_UNIT sssdlibexec_PROGRAMS += sssd_check_socket_activated_responders +sssdlibexec_SCRIPTS = src/sysv/systemd/set-nis-domainname endif if HAVE_CHECK @@ -1916,6 +1918,8 @@ sss_signal_LDADD = \ libsss_debug.la \ $(NULL) +setdomainname_SOURCES = src/tools/setdomainname.c $(NULL) + sss_override_SOURCES = \ src/tools/sss_override.c \ src/tools/common/sss_colondb.c \ @@ -5406,6 +5410,14 @@ src/sysv/systemd/sssd-kcm.service: src/sysv/systemd/sssd-kcm.service.in Makefile $(replace_script) endif +EXTRA_DIST += \ + src/sysv/systemd/set-nis-domainname.in \ + $(NULL) + +src/sysv/systemd/set-nis-domainname: src/sysv/systemd/set-nis-domainname.in Makefile + @$(MKDIR_P) src/sysv/systemd/ + $(replace_script) + EXTRA_DIST += \ src/tools/wrappers/sss_debuglevel.in \ $(NULL) @@ -5695,6 +5707,7 @@ endif rm -f $(builddir)/src/sysv/systemd/sssd-sudo.service rm -f $(builddir)/src/sysv/systemd/sssd-kcm.socket rm -f $(builddir)/src/sysv/systemd/sssd-kcm.service + rm -f $(builddir)/src/sysv/systemd/set-nis-domainname rm -f $(builddir)/src/tools/wrappers/sss_debuglevel rm -Rf $(builddir)/src/examples rm -Rf $(builddir)/contrib diff --git a/contrib/sssd.spec.in b/contrib/sssd.spec.in index 4fbacb959d6..d32aa4a08bf 100644 --- a/contrib/sssd.spec.in +++ b/contrib/sssd.spec.in @@ -845,6 +845,8 @@ install -D -p -m 0644 %{SOURCE1} %{buildroot}%{_sysusersdir}/sssd.conf %{_bindir}/sss_ssh_knownhostsproxy %{_sbindir}/sss_cache %{_libexecdir}/%{servicename}/sss_signal +%{_libexecdir}/%{servicename}/setdomainname +%{_libexecdir}/%{servicename}/set-nis-domainname %attr(775,%{sssd_user},%{sssd_user}) %dir %{sssdstatedir} %dir %{_localstatedir}/cache/krb5rcache diff --git a/src/sysv/systemd/set-nis-domainname.in b/src/sysv/systemd/set-nis-domainname.in new file mode 100644 index 00000000000..7adeb81b1e0 --- /dev/null +++ b/src/sysv/systemd/set-nis-domainname.in @@ -0,0 +1,9 @@ +#!/usr/bin/bash + +source /etc/sysconfig/network + +if [ -n "${NISDOMAIN}" ] && [ -x @libexecdir@/sssd/setdomainname ]; then + @libexecdir@/sssd/setdomainname ${NISDOMAIN} +fi + +exit 0 diff --git a/src/sysv/systemd/sssd.service.in b/src/sysv/systemd/sssd.service.in index 37e0a63f87e..d18039c8a2f 100644 --- a/src/sysv/systemd/sssd.service.in +++ b/src/sysv/systemd/sssd.service.in @@ -10,6 +10,7 @@ StartLimitBurst=5 [Service] Environment=DEBUG_LOGGER=--logger=files EnvironmentFile=-@environment_file@ +ExecStartPre=+-@libexecdir@/sssd/set-nis-domainname ExecStartPre=+-/bin/chown -f @SSSD_USER@:@SSSD_USER@ @sssdconfdir@ ExecStartPre=+-/bin/chown -f @SSSD_USER@:@SSSD_USER@ @sssdconfdir@/sssd.conf ExecStartPre=+-/bin/chown -f -R @SSSD_USER@:@SSSD_USER@ @sssdconfdir@/conf.d diff --git a/src/tools/setdomainname.c b/src/tools/setdomainname.c new file mode 100644 index 00000000000..bff1f629ae9 --- /dev/null +++ b/src/tools/setdomainname.c @@ -0,0 +1,38 @@ +/* + Copyright (C) 2024 Red Hat + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . +*/ + +#include +#include +#include +#include + + +int main(int argc, const char *argv[]) +{ + if (argc != 2) { + return EINVAL; + } + + if ((argv[1] == NULL) || (argv[1][0] == 0)) { + return EINVAL; + } + + errno = 0; + setdomainname(argv[1], strlen(argv[1])); + + return errno; +}