Projects
openEuler:24.03:SP1:Everything
openldap
_service:tar_scm:openldap.spec
Sign Up
Log In
Username
Password
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File _service:tar_scm:openldap.spec of Package openldap
%global systemctl_bin /usr/bin/systemctl Name: openldap Version: 2.6.5 Release: 5 Summary: LDAP support libraries License: OLDAP-2.8 URL: https://www.openldap.org/ Source0: https://www.openldap.org/software/download/OpenLDAP/openldap-release/openldap-%{version}.tgz Source1: slapd.service Source2: slapd.tmpfiles Source3: slapd.ldif Source4: ldap.conf Source10: ltb-project-openldap-ppolicy-check-password-1.1.tar.gz Source50: libexec-functions Source52: libexec-check-config.sh Source53: libexec-upgrade-db.sh Patch0: backport-openldap-manpages.patch Patch1: backport-openldap-reentrant-gethostby.patch Patch2: backport-openldap-smbk5pwd-overlay.patch Patch3: backport-openldap-ai-addrconfig.patch Patch4: backport-openldap-allop-overlay.patch Patch5: backport-openldap-switch-to-lt_dlopenadvise-to-get-RTLD_GLOBAL-set.patch Patch7: backport-check-password-makefile.patch Patch8: backport-check-password.patch Patch9: add-ber_sockbuf_io_udp-to-liber.map.patch BuildRequires: cyrus-sasl-devel openssl-devel krb5-devel unixODBC-devel BuildRequires: glibc-devel libtool libtool-ltdl-devel groff perl-interpreter perl-devel perl-generators perl-ExtUtils-Embed %description OpenLDAP is an open source suite of LDAP (Lightweight Directory Access Protocol) applications and development tools. LDAP is a set of protocols for accessing directory services (usually phone book style information, but other information is possible) over the Internet, similar to the way DNS (Domain Name System) information is propagated over the Internet. The openldap package contains configuration files, libraries, and documentation for OpenLDAP. %package devel Summary: LDAP development libraries and header files Requires: openldap = %{version}-%{release} cyrus-sasl-devel %description devel The openldap-devel package includes the development libraries and header files needed for compiling applications that use LDAP (Lightweight Directory Access Protocol) internals. LDAP is a set of protocols for enabling directory services over the Internet. Install this package only if you plan to develop or will need to compile customized LDAP clients. %package servers Summary: LDAP server License: OLDAP-2.8 Requires: openldap = %{version}-%{release} Requires(pre): shadow-utils %{?systemd_requires} BuildRequires: systemd BuildRequires: cracklib-devel Provides: ldif2ldbm %description servers OpenLDAP is an open-source suite of LDAP (Lightweight Directory Access Protocol) applications and development tools. LDAP is a set of protocols for accessing directory services (usually phone book style information, but other information is possible) over the Internet, similar to the way DNS (Domain Name System) information is propagated over the Internet. This package contains the slapd server and related files. %package clients Summary: LDAP client utilities Requires: openldap = %{version}-%{release} %description clients OpenLDAP is an open-source suite of LDAP (Lightweight Directory Access Protocol) applications and development tools. LDAP is a set of protocols for accessing directory services (usually phone book style information, but other information is possible) over the Internet, similar to the way DNS (Domain Name System) information is propagated over the Internet. The openldap-clients package contains the client programs needed for accessing and modifying OpenLDAP directories. %package_help %prep %setup -q -c -a 0 -a 10 pushd openldap-%{version} AUTOMAKE=%{_bindir}/true autoreconf -fi %patch0 -p1 %patch1 -p1 %patch2 -p1 %patch3 -p1 %patch4 -p1 %patch5 -p1 %patch9 -p1 ln -s ../../../contrib/slapd-modules/smbk5pwd/smbk5pwd.c servers/slapd/overlays mv contrib/slapd-modules/smbk5pwd/README contrib/slapd-modules/smbk5pwd/README.smbk5pwd ln -s ../../../contrib/slapd-modules/allop/allop.c servers/slapd/overlays mv contrib/slapd-modules/allop/README contrib/slapd-modules/allop/README.allop mv contrib/slapd-modules/allop/slapo-allop.5 doc/man/man5/slapo-allop.5 mv servers/slapd/back-perl/README{,.back_perl} for filename in doc/drafts/draft-ietf-ldapext-acl-model-xx.txt; do iconv -f iso-8859-1 -t utf-8 "$filename" > "$filename.utf8" mv "$filename.utf8" "$filename" done popd pushd ltb-project-openldap-ppolicy-check-password-1.1 %patch7 -p1 %patch8 -p1 popd %build %set_build_flags export CFLAGS="${CFLAGS} ${LDFLAGS} -Wl,--as-needed -DLDAP_CONNECTIONLESS -DLDAP_USE_NON_BLOCKING_TLS" pushd openldap-%{version} %configure \ --enable-debug --enable-dynamic --enable-dynacl \ --enable-cleartext --enable-crypt --enable-lmpasswd \ %if 0%{?build_cross} == 1 --disable-spasswd --with-cyrus-sasl=no \ %else --enable-spasswd --with-cyrus-sasl \ %endif --enable-modules --enable-rewrite \ --enable-rlookups --enable-slapi --disable-slp \ --enable-backends=mod \ --enable-mdb=yes --enable-monitor=yes --disable-wt \ --disable-sql --enable-overlays=mod --disable-static \ --without-fetch --with-threads \ --with-pic --with-gnu-ld --libexecdir=%{_libdir} %make_build popd pushd ltb-project-openldap-ppolicy-check-password-1.1 %if "%toolchain" == "clang" make LDAP_INC="-I../openldap-%{version}/include \ -I../openldap-%{version}/servers/slapd \ -I../openldap-%{version}/build-servers/include" CC=clang %else make LDAP_INC="-I../openldap-%{version}/include \ -I../openldap-%{version}/servers/slapd \ -I../openldap-%{version}/build-servers/include" %endif popd %install install -d %{buildroot}%{_libdir}/ pushd openldap-%{version} %make_install STRIP="" popd pushd ltb-project-openldap-ppolicy-check-password-1.1 mv check_password.so check_password.so.1.1 ln -s check_password.so.1.1 %{buildroot}%{_libdir}/openldap/check_password.so install -m 755 check_password.so.1.1 %{buildroot}%{_libdir}/openldap/ install -d -m 755 %{buildroot}%{_sysconfdir}/openldap cat > %{buildroot}%{_sysconfdir}/openldap/check_password.conf <<EOF # OpenLDAP pwdChecker library configuration #useCracklib 1 #minPoints 3 #minUpper 0 #minLower 0 #minDigit 0 #minPunct 0 EOF mv README{,.check_pwd} popd install -d %{buildroot}%{_sysconfdir}/openldap/certs install -d %{buildroot}%{_sharedstatedir} install -d %{buildroot}%{_localstatedir} install -m 0700 -d %{buildroot}%{_sharedstatedir}/ldap install -m 0755 -d %{buildroot}%{_localstatedir}/run/openldap install -d %{buildroot}%{_tmpfilesdir} install -m 0644 %SOURCE2 %{buildroot}%{_tmpfilesdir}/slapd.conf install -m 0644 %SOURCE4 %{buildroot}%{_sysconfdir}/openldap/ldap.conf install -d %{buildroot}%{_libexecdir} install -m 0755 -d %{buildroot}%{_libexecdir}/openldap install -m 0644 %SOURCE50 %{buildroot}%{_libexecdir}/openldap/functions install -m 0755 %SOURCE52 %{buildroot}%{_libexecdir}/openldap/check-config.sh install -m 0755 %SOURCE53 %{buildroot}%{_libexecdir}/openldap/upgrade-db.sh perl -pi -e "s|%{buildroot}||g" %{buildroot}%{_sysconfdir}/openldap/*.conf perl -pi -e "s|%{buildroot}||g" %{buildroot}%{_mandir}/*/*.* rm -f %{buildroot}%{_sysconfdir}/openldap/*.default rm -f %{buildroot}%{_sysconfdir}/openldap/schema/*.default rm -f %{buildroot}%{_sysconfdir}/openldap/slapd.conf rm -f %{buildroot}%{_sysconfdir}/openldap/slapd.ldif install -d %{buildroot}%{_unitdir} install -m 0644 %SOURCE1 %{buildroot}%{_unitdir}/slapd.service mv %{buildroot}%{_libdir}/slapd %{buildroot}%{_sbindir}/ for X in acl add auth cat dn index passwd test schema; do rm -f %{buildroot}%{_sbindir}/slap$X rm -f %{buildroot}%{_libdir}/slap$X done for X in acl add auth cat dn index passwd test schema; do ln -s slapd %{buildroot}%{_sbindir}/slap$X done pushd %{buildroot}%{_libdir} v=%{version} version=$(echo ${v%.[0-9]*}) for lib in liblber libldap libldap_r libslapi; do rm -f ${lib}.so ln -s ${lib}.so.2 ${lib}.so done popd chmod 0755 %{buildroot}%{_libdir}/lib*.so.* chmod 0644 %{buildroot}%{_libdir}/lib*.*a install -d %{buildroot}%{_datadir} install -m 0755 -d %{buildroot}%{_datadir}/openldap-servers install -m 0644 %SOURCE3 %{buildroot}%{_datadir}/openldap-servers/slapd.ldif install -m 0700 -d %{buildroot}%{_sysconfdir}/openldap/slapd.d mv %{buildroot}%{_sysconfdir}/openldap/schema/README README.schema rm -f %{buildroot}%{_libdir}/*.la rm -f %{buildroot}%{_localstatedir}/openldap-data/DB_CONFIG.example ln -fs libldap.so "%{buildroot}%{_libdir}/libldap_r.so" %ldconfig_scriptlets %pre servers getent group ldap &>/dev/null || groupadd -r -g 55 ldap getent passwd ldap &>/dev/null || \ useradd -r -g ldap -u 55 -d %{_sharedstatedir}/ldap -s /sbin/nologin -c "OpenLDAP server" ldap if [ $1 -eq 2 ]; then old_version=$(rpm -q --qf=%%{version} openldap-servers) new_version=%{version} if [ "$old_version" != "$new_version" ]; then touch %{_sharedstatedir}/ldap/rpm_upgrade_openldap &>/dev/null fi fi exit 0 %post servers %systemd_post slapd.service if [[ ! -f %{_sysconfdir}/openldap/slapd.d/cn=config.ldif && \ ! -f %{_sysconfdir}/openldap/slapd.conf ]]; then install -d %{_sysconfdir}/openldap/slapd.d/ &>/dev/null || : /usr/sbin/slapadd -F %{_sysconfdir}/openldap/slapd.d/ -n0 -l %{_datadir}/openldap-servers/slapd.ldif chown -R ldap:ldap %{_sysconfdir}/openldap/slapd.d/ %{systemctl_bin} try-restart slapd.service &>/dev/null fi start_slapd=0 if [ -f %{_sharedstatedir}/ldap/rpm_upgrade_openldap ]; then if %{systemctl_bin} --quiet is-active slapd.service; then %{systemctl_bin} stop slapd.service start_slapd=1 fi %{_libexecdir}/openldap/upgrade-db.sh &>/dev/null rm -f %{_sharedstatedir}/ldap/rpm_upgrade_openldap fi if [ $1 -ge 1 ]; then if [ $start_slapd -eq 1 ]; then %{systemctl_bin} start slapd.service &>/dev/null || : else %{systemctl_bin} condrestart slapd.service &>/dev/null || : fi fi exit 0 %preun servers %systemd_preun slapd.service %postun servers %systemd_postun_with_restart slapd.service %triggerin servers -- libdb if [ $2 -eq 2 ]; then if [ "$(rpm -q --qf="%%{version}\n" libdb | sed 's/\.[0-9]*$//' | sort -u | wc -l)" != "1" ]; then touch %{_sharedstatedir}/ldap/rpm_upgrade_libdb else rm -f %{_sharedstatedir}/ldap/rpm_upgrade_libdb fi fi exit 0 %triggerun servers -- libdb if [ -f %{_sharedstatedir}/ldap/rpm_upgrade_libdb ]; then if %{systemctl_bin} --quiet is-active slapd.service; then %{systemctl_bin} stop slapd.service start=1 else start=0 fi %{_libexecdir}/openldap/upgrade-db.sh &>/dev/null rm -f %{_sharedstatedir}/ldap/rpm_upgrade_libdb [ $start -eq 1 ] && %{systemctl_bin} start slapd.service &>/dev/null fi exit 0 %check pushd openldap-%{version} rm -f tests/scripts/test076-authid-rewrite make check popd %files %defattr(-,root,root) %license openldap-%{version}/COPYRIGHT %license openldap-%{version}/LICENSE %dir %{_sysconfdir}/openldap/certs %config(noreplace) %{_sysconfdir}/openldap/ldap.conf %dir %{_libexecdir}/openldap/ %{_libdir}/lib*.so.* %files servers %defattr(-,root,root) %config(noreplace) %dir %attr(0750,ldap,ldap) %{_sysconfdir}/openldap/slapd.d %config(noreplace) %{_sysconfdir}/openldap/schema %config(noreplace) %{_sysconfdir}/openldap/check_password.conf %{_tmpfilesdir}/slapd.conf %dir %attr(0700,ldap,ldap) %{_sharedstatedir}/ldap %dir %attr(-,ldap,ldap) %{_localstatedir}/run/openldap %{_unitdir}/slapd.service %{_datadir}/openldap-servers/ %{_libdir}/openldap/* %{_libexecdir}/openldap/functions %{_libexecdir}/openldap/check-config.sh %{_libexecdir}/openldap/upgrade-db.sh %{_sbindir}/sl* %ghost %config(noreplace,missingok) %attr(0640,ldap,ldap) %{_sysconfdir}/openldap/slapd.conf %files clients %defattr(-,root,root) %{_bindir}/* %files devel %defattr(-,root,root) %{_libdir}/lib*.so %{_includedir}/* %{_libdir}/pkgconfig/*.pc %files help %defattr(-,root,root) %{_mandir}/man*/* %doc openldap-%{version}/ANNOUNCEMENT %doc openldap-%{version}/CHANGES %doc openldap-%{version}/README %doc openldap-%{version}/doc/guide/admin/*.html %doc openldap-%{version}/doc/guide/admin/*.png %doc openldap-%{version}/servers/slapd/back-perl/SampleLDAP.pm %doc openldap-%{version}/servers/slapd/back-perl/README.back_perl %doc README.schema %doc openldap-%{version}/doc/drafts openldap-%{version}/doc/rfc %doc ltb-project-openldap-ppolicy-check-password-1.1/README.check_pwd %changelog * Fri Jun 14 2024 xinghe <xinghe2@h-partners.com> - 2.6.5-5 - Type:bugfix - ID:NA - SUG:NA - DESC:fix license * Thu Jul 27 2023 zhangchenglin <zhangchenglin@kylinos.cn> - 2.6.5-1 - update to version 2.6.5 * Tue May 30 2023 liyunfei <liyunfei33@huawei.com> - 2.6.3-4 - add clang compile support * Tue Mar 14 2023 zhujunhao <zhujunhao11@huawei.com> - 2.6.3-3 - remove unused file * Tue Feb 28 2023 zhujunhao <zhujunhao11@huawei.com> - 2.6.3-2 - add options for build cross * Wed Feb 8 2023 zhujunhao <zhujunhao11@huawei.com> - 2.6.3-1 - upgrade to 2.6.3 * Mon Nov 7 2022 zhujunhao <zhujunhao11@huawei.com> - 2.6.0-5 - backport patch * Mon Jun 13 2022 Chenyx <chenyixiong3@huawei.com> - 2.6.0-4 - License compliance rectification * Mon May 16 2022 zhujunhao <zhujunhao11@huawei.com> - 2.6.0-3 - Type:bugfix - ID:NA - SUG:restart - DESC:fix cve-2022-29155 * Tue Mar 22 2022 gaihuiying <eaglegai@163.com> - 2.6.0-2 - Type:bugfix - ID:NA - SUG:restart - DESC:delete useless so file * Tue Dec 21 2021 gaihuiying <gaihuiying1@huawei.com> - 2.6.0-1 - Type:requirement - ID:NA - SUG:restart - DESC:update openldap to 2.6.0 * Fri Jul 09 2021 gaihuiying <gaihuiying1@huawei.com> - 2.4.50-8 - fix CVE-2020-25709 CVE-2020-25710 * Sat Feb 27 2021 orange-snn <songnannan2@huawei.com> - 2.4.50-7 - fix CVE-2021-27212 * Thu Feb 25 2021 orange-snn <songnannan2@huawei.com> - 2.4.50-6 - remove libdb-devel in buildrequires and requires. * Thu Feb 18 2021 liulong <liulong20@huawei.com> - 2.4.50-5 - Type:cves - ID:NA - SUG:restart - DESC:fix CVE-2020-36221 CVE-2020-36222 CVE-2020-36223 CVE-2020-36224 CVE-2020-36225 CVE-2020-36226 CVE-2020-36227 CVE-2020-36228 CVE-2020-36229 CVE-2020-36230 * Mon Dec 14 2020 openEuler Buildteam <buildteam@openeuler.org> - 2.4.50-4 - Type:cves - ID:CVE-2020-25692 - SUG:restart - DESC:fix CVE-2020-25692 * Wed Aug 05 2020 lunankun<lunankun@huawei.com> - 2.4.50-3 - Type:cves - ID:CVE-2020-15719 - SUG:restart - DESC:fix CVE-2020-15719 * Thu Jul 23 2020 zhouyihang<zhouyihang3@huawei.com> - 2.4.50-2 - Type:bugfix - ID:NA - SUG:NA - DESC:keep *.la under %{_libdir}/openldap/ * Mon Jun 29 2020 zhangxingliang<zhangxingliang3@huawei.com> - 2.4.50-1 - Type:bugfix - ID:NA - SUG:NA - DESC:update to 2.4.50 * Thu May 14 2020 lijingyu <lijingyu15@huawei.com> - 2.4.46-16 - Type:cves - ID:CVE-2020-12243 - SUG:NA - DESC: fix CVE-2020-12243 * Wed Mar 11 2020 songnannan <songnannan2@huawei.com> - 2.4.46-15 - bugfix about conf file * Fri Feb 21 2020 songnannan<songnannan2@huawei.com> - 2.4.46-14 - Type:bugfix - ID:NA - SUG:NA - DESC:bugfix about make check * Sat Jan 11 2020 zhangrui<zhangrui182@huawei.com> - 2.4.46-13 - Type:cves - ID:CVE-2017-17740 - SUG:NA - DESC: fix CVE-2017-17740 * Mon Dec 30 2019 openEuler Buildteam <buildteam@openeuler.org> - 2.4.46-12 - Type:bugfix - ID: - SUG: - DESC:modify the spec * Sat Dec 21 2019 openEuler Buildteam <buildteam@openeuler.org> - 2.4.46-11 - Type:cves - ID:CVE-2019-13565 - SUG:restart - DESC:fix CVE--2019-13565 * Wed Sep 25 2019 openEuler Buildteam <buildteam@openeuler.org> - 2.4.46-10 - Type:cves - ID:CVE-2019-13057 - SUG:NA - DESC:fix CVE-2019-13057 * Tue Sep 17 2019 openEuler Buildteam <buildteam@openeuler.org> - 2.4.46-9 - Package init
Locations
Projects
Search
Status Monitor
Help
Open Build Service
OBS Manuals
API Documentation
OBS Portal
Reporting a Bug
Contact
Mailing List
Forums
Chat (IRC)
Twitter
Open Build Service (OBS)
is an
openSUSE project
.
浙ICP备2022010568号-2