mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2024-12-22 15:13:50 -06:00
systemd: enforce en_US.UTF-8 locale in systemd units
Python code does detection of the system encoding based on the locale settings. On RHEL 8.4 development images we somehow get LANG=en_US which defaults to iso8859-1 _inside_ the systemd-started service, even though the whole environment defaults to LANG=en_US.UTF-8. When instrumented with ExecStartPre=/usr/bin/locale, the following output can be seen: locale[45481]: LANG=en_US locale[45481]: LC_CTYPE="en_US" locale[45481]: LC_NUMERIC="en_US" locale[45481]: LC_TIME="en_US" locale[45481]: LC_COLLATE="en_US" locale[45481]: LC_MONETARY="en_US" locale[45481]: LC_MESSAGES="en_US" locale[45481]: LC_PAPER="en_US" locale[45481]: LC_NAME="en_US" locale[45481]: LC_ADDRESS="en_US" locale[45481]: LC_TELEPHONE="en_US" locale[45481]: LC_MEASUREMENT="en_US" locale[45481]: LC_IDENTIFICATION="en_US" locale[45481]: LC_ALL= ipactl[45483]: Unexpected error ipactl[45483]: SystemEncodingError: System encoding must be UTF-8, 'iso8859-1' is not supported. Set LC_ALL="C.UTF-8", or LC_ALL="" and LC_CTYPE="C.UTF-8". systemd[1]: ipa.service: Main process exited, code=exited, status=1/FAILURE Set the environment to explicit LC_ALL=C.UTF-8 to please the Python code. FreeIPA server side only cares about actual encoding, not the language itself. We already use LC_ALL=C.UTF-8 in httpd service snippet. Fixes: https://pagure.io/freeipa/issue/8617 Signed-off-by: Alexander Bokovoy <abokovoy@redhat.com> Reviewed-By: Thomas Woerner <twoerner@redhat.com>
This commit is contained in:
parent
07fa32a0a5
commit
38a86e3367
@ -3,6 +3,7 @@ Description=Execute IPA Expiring Password Notification (EPN)
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
ExecStart=@sbindir@/ipa-epn
|
||||
|
||||
[Install]
|
||||
|
@ -2,6 +2,7 @@
|
||||
Description=IPA key daemon
|
||||
|
||||
[Service]
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
EnvironmentFile=@sysconfenvdir@/ipa-dnskeysyncd
|
||||
ExecStart=@libexecdir@/ipa/ipa-dnskeysyncd
|
||||
User=@ODS_USER@
|
||||
|
@ -4,6 +4,7 @@ Wants=ipa-ods-exporter.socket
|
||||
After=ipa-ods-exporter.socket
|
||||
|
||||
[Service]
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
EnvironmentFile=@sysconfenvdir@/ipa-ods-exporter
|
||||
ExecStart=@libexecdir@/ipa/ipa-ods-exporter
|
||||
User=@ODS_USER@
|
||||
|
@ -2,6 +2,7 @@
|
||||
Description=ipa-otpd service
|
||||
|
||||
[Service]
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
EnvironmentFile=@sysconfdir@/ipa/default.conf
|
||||
ExecStart=@libexecdir@/ipa/ipa-otpd $ldap_uri
|
||||
StandardInput=socket
|
||||
|
@ -4,6 +4,7 @@ Wants=gssproxy.service
|
||||
|
||||
[Service]
|
||||
Type=simple
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
ExecStart=@libexecdir@/ipa/ipa-ccache-sweeper
|
||||
PrivateTmp=yes
|
||||
User=ipaapi
|
||||
|
@ -3,6 +3,7 @@ Description=IPA Custodia Service
|
||||
|
||||
[Service]
|
||||
Type=notify
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
ExecStart=@libexecdir@/ipa/ipa-custodia @IPA_SYSCONF_DIR@/custodia/custodia.conf
|
||||
PrivateTmp=yes
|
||||
Restart=on-failure
|
||||
|
@ -6,6 +6,7 @@ After=network.target
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
ExecStart=@sbindir@/ipactl start
|
||||
ExecStop=@sbindir@/ipactl stop
|
||||
RemainAfterExit=yes
|
||||
|
@ -1,5 +1,6 @@
|
||||
# Installed and maintained by ipa update tools, please do not modify
|
||||
|
||||
[Service]
|
||||
Environment=LC_ALL=C.UTF-8
|
||||
Environment=KRB5_KTNAME=$KRB5_KTNAME
|
||||
Environment=KRB5CCNAME=$KRB5CCNAME
|
||||
|
@ -629,6 +629,7 @@ class CAInstance(DogtagInstance):
|
||||
with open(conf, 'w') as f:
|
||||
os.fchmod(f.fileno(), 0o644)
|
||||
f.write('[Service]\n')
|
||||
f.write('Environment=LC_ALL=C.UTF-8\n')
|
||||
f.write('ExecStartPost={}\n'.format(paths.IPA_PKI_WAIT_RUNNING))
|
||||
tasks.systemd_daemon_reload()
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user