You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

330 lines
10 KiB

##
## openldap.spec -- OpenPKG RPM Package Specification
## Copyright (c) 2000-2022 OpenPKG Project <http://openpkg.org/>
##
## Permission to use, copy, modify, and distribute this software for
## any purpose with or without fee is hereby granted, provided that
## the above copyright notice and this permission notice appear in all
## copies.
##
## THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
## WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
## MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
## IN NO EVENT SHALL THE AUTHORS AND COPYRIGHT HOLDERS AND THEIR
## CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
## SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
## LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
## USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
## ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
## OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
## OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
## SUCH DAMAGE.
##
# package information
Name: openldap
Summary: Lightweight Directory Access Protocol (LDAP) Toolkit
URL: http://www.openldap.org/
Vendor: OpenLDAP Project
Packager: OpenPKG Project
Distribution: OpenPKG Community
Class: BASE
Group: LDAP
License: BSD-style
Version: 2.4.58
Release: 20210317
# package options
%option with_server yes
%option with_fsl yes
%option with_crypt yes
%option with_overlays yes
%option with_pth yes
%option with_pthreads no
%option with_sasl no
%option with_perl no
%option with_odbc no
# list of sources
Source0: https://www.openldap.org/software/download/OpenLDAP/openldap-release/openldap-%{version}.tgz
Source1: rc.openldap
Source2: fsl.openldap
Source3: openldap.pc
Patch0: openldap.patch
# build information
BuildPreReq: OpenPKG, openpkg >= 20160101, make, gcc
PreReq: OpenPKG, openpkg >= 20160101
BuildPreReq: openssl, db >= 4.5
PreReq: openssl, db >= 4.5
%if "%{with_server}" == "yes" && "%{with_fsl}" == "yes"
BuildPreReq: fsl
PreReq: fsl
%endif
%if "%{with_server}" == "yes" && "%{with_pthreads}" == "yes"
BuildPreReq: db::with_pthreads = yes
PreReq: db::with_pthreads = yes
%endif
%if "%{with_server}" == "yes" && "%{with_pth}" == "yes"
BuildPreReq: pth
PreReq: pth
%endif
%if "%{with_sasl}" == "yes"
BuildPreReq: sasl
PreReq: sasl
%endif
%if "%{with_server}" == "yes" && "%{with_odbc}" == "yes"
BuildPreReq: ODBC
PreReq: ODBC
%endif
%description
OpenLDAP is an open source implementation of the Lightweight
Directory Access Protocol (LDAP). The suite includes libraries
implementing the LDAP protocol plus a stand-alone LDAP server
slapd(8).
%track
prog openldap = {
version = %{version}
url = https://www.openldap.org/software/download/
regex = openldap-(\d+\.\d+\.\d+)\.tgz
}
%prep
%setup -q
%patch -p0
%{l_shtool} subst \
-e 's;-ldb-4\.[1-9];-ldb;g' \
-e 's;-ldb-4-[1-9];-ldb;g' \
-e 's;-ldb-4[1-9];-ldb;g' \
-e 's;-ldb-4;-ldb;g' \
configure
%build
# configuration: standard build flags
export CC="%{l_cc}"
export CFLAGS="%{l_cflags -O}"
export CPPFLAGS="%{l_cppflags}"
export LDFLAGS="%{l_ldflags}"
export LIBS=""
export ARGS=""
ARGS="$ARGS --prefix=%{l_prefix}"
ARGS="$ARGS --mandir=%{l_prefix}/man"
ARGS="$ARGS --infodir=%{l_prefix}/info"
ARGS="$ARGS --libexecdir=%{l_prefix}/libexec/openldap"
ARGS="$ARGS --localstatedir=%{l_prefix}/var/openldap"
ARGS="$ARGS --enable-syslog"
ARGS="$ARGS --with-tls"
ARGS="$ARGS --without-fetch"
ARGS="$ARGS --disable-dynamic"
ARGS="$ARGS --disable-shared"
%if "%{with_server}" == "yes"
ARGS="$ARGS --enable-slapd"
ARGS="$ARGS --disable-modules"
ARGS="$ARGS --enable-local"
ARGS="$ARGS --enable-bdb"
ARGS="$ARGS --enable-hdb"
ARGS="$ARGS --enable-rewrite"
ARGS="$ARGS --enable-ldap"
ARGS="$ARGS --enable-meta"
ARGS="$ARGS --enable-monitor"
ARGS="$ARGS --enable-dnssrv"
ARGS="$ARGS --enable-null"
ARGS="$ARGS --enable-shell"
ARGS="$ARGS --enable-proxycache"
ARGS="$ARGS --disable-mdb"
%else
ARGS="$ARGS --disable-slapd"
ARGS="$ARGS --disable-modules"
%endif
# configuration: force to use OSSP fsl
%if "%{with_server}" == "yes"
LDFLAGS="$LDFLAGS %{l_fsl_ldflags}"
LIBS="$LIBS %{l_fsl_libs}"
%endif
# configuration: force to use GNU pth if enabled
%if "%{with_server}" == "yes"
%if "%{with_pth}" == "yes"
CFLAGS="$CFLAGS `%{l_prefix}/bin/pth-config --cflags`"
CPPFLAGS="$CPPFLAGS -I`%{l_prefix}/bin/pth-config --includedir`"
LDFLAGS="$LDFLAGS `%{l_prefix}/bin/pth-config --ldflags`"
LIBS="`%{l_prefix}/bin/pth-config --libs` $LIBS"
ARGS="$ARGS --with-threads=pth"
%{l_shtool} subst \
-e 's;ac_cv_header_sys_devpoll_h;ac_cv_NOTEXISTING;' \
-e 's;ac_cv_header_sys_epoll_h;ac_cv_NOTEXISTING;' \
configure
%else
%if "%{with_pthreads}" == "yes"
ARGS="$ARGS --with-threads=posix"
%else
ARGS="$ARGS --with-threads=no"
%endif
%endif
%endif
# configuration: optional overlay support
%if "%{with_server}" == "yes" && "%{with_overlays}" == "yes"
ARGS="$ARGS --enable-overlays=yes"
%endif
# configuration: optional SASL support
%if "%{with_sasl}" == "yes"
%{l_shtool} subst \
-e ';ac_cv_lib_sasl2_sasl_client_init;ac_cv_NOTEXISTING;' \
configure
CPPFLAGS="%{l_cppflags sasl} $CPPFLAGS"
ARGS="$ARGS --with-cyrus-sasl --enable-spasswd"
%else
ARGS="$ARGS --without-cyrus-sasl --disable-spasswd"
%endif
# configuration: optional crypt(3) support
%if "%{with_crypt}" == "yes"
ARGS="$ARGS --enable-crypt"
%endif
# configuration: optional Perl support
%if "%{with_server}" == "yes" && "%{with_perl}" == "yes"
ARGS="$ARGS --enable-perl"
%endif
# configuration: optional ODBC-based RDBMS support
%if "%{with_server}" == "yes" && "%{with_odbc}" == "yes"
ARGS="$ARGS --enable-sql"
%endif
# configuration: special platform support
case "%{l_platform -t}" in
*-sunos* ) CFLAGS="$CFLAGS -D_AVL_H"; LIBS="$LIBS -lrt" ;;
esac
# configuration: use hard-links and make sure our Berkeley-DB is picked up first
%{l_shtool} subst \
-e 's;ln -s;ln;g' \
-e 's;-ldb4[1-9];%{l_prefix}/lib/libdb.a;g' \
-e 's;<db\.h>;"db.h";g' \
configure
# configuration
./configure $ARGS
# build toolkit
%{l_make} %{l_mflags} depend
%{l_make} %{l_mflags}
%install
# install toolkit
%{l_make} %{l_mflags} install DESTDIR=$RPM_BUILD_ROOT
# post adjustment: remove extra files
rm -f $RPM_BUILD_ROOT%{l_prefix}/etc/openldap/*.default
rm -f $RPM_BUILD_ROOT%{l_prefix}/etc/openldap/*/*.default
# post adjustment: move files
rm -f $RPM_BUILD_ROOT%{l_prefix}/etc/openldap/DB_CONFIG.example
%if "%{with_server}" == "yes"
mv $RPM_BUILD_ROOT%{l_prefix}/var/openldap/openldap-data/DB_CONFIG.example \
$RPM_BUILD_ROOT%{l_prefix}/var/openldap/openldap-data/DB_CONFIG
%endif
# post adjustment: enable and correct slapd.pid
%if "%{with_server}" == "yes"
%{l_shtool} subst \
-e 's;^\(pidfile\).*$;\1 %{l_prefix}/var/openldap/run/slapd.pid;' \
-e 's;^\(argsfile\).*$;\1 %{l_prefix}/var/openldap/run/slapd.args;' \
$RPM_BUILD_ROOT%{l_prefix}/etc/openldap/slapd.conf
%endif
# post adjustment: remove OSSP fsl dependency from libtool files
%if "%{with_server}" == "yes"
%{l_shtool} subst \
-e 's;-lfsl *;;' \
$RPM_BUILD_ROOT%{l_prefix}/lib/*.la
%endif
# install run-command script
%if "%{with_server}" == "yes"
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/etc/rc.d
%{l_shtool} install -c -m 755 %{l_value -s -a} \
%{SOURCE rc.openldap} $RPM_BUILD_ROOT%{l_prefix}/etc/rc.d/
%endif
# install OSSP fsl configuration
%if "%{with_server}" == "yes"
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/etc/fsl
%{l_shtool} install -c -m 644 %{l_value -s -a} \
%{SOURCE fsl.openldap} \
$RPM_BUILD_ROOT%{l_prefix}/etc/fsl/
%endif
# install pkg-config configuration
%{l_shtool} mkdir -f -p -m 755 \
$RPM_BUILD_ROOT%{l_prefix}/lib/pkgconfig
libs="-lldap -llber"
%if "%{with_sasl}" == "yes"
libs="$libs -lsasl2"
%endif
%{l_shtool} install -c -m 644 %{l_value -s -a} \
-e "s;@version@;%{version};" \
-e "s;@libs@;$libs;" \
%{SOURCE openldap.pc} \
$RPM_BUILD_ROOT%{l_prefix}/lib/pkgconfig/
# optionally remove server-components
%if "%{with_server}" != "yes"
rm -rf $RPM_BUILD_ROOT%{l_prefix}/etc/openldap/schema
rm -f $RPM_BUILD_ROOT%{l_prefix}/etc/openldap/slapd.conf
rm -rf $RPM_BUILD_ROOT%{l_prefix}/sbin
rm -rf $RPM_BUILD_ROOT%{l_prefix}/libexec/openldap
rm -f $RPM_BUILD_ROOT%{l_prefix}/include/slapi-plugin.h
rm -f $RPM_BUILD_ROOT%{l_prefix}/man/man5/slap*
rm -f $RPM_BUILD_ROOT%{l_prefix}/man/man8/slap*
%endif
# determine installation files
%{l_rpmtool} files -v -ofiles -r$RPM_BUILD_ROOT \
%{l_files_std} \
%if "%{with_server}" == "yes"
'%config %{l_prefix}/etc/fsl/fsl.openldap' \
'%config %{l_prefix}/etc/openldap/schema/*.schema' \
'%config %{l_prefix}/etc/openldap/schema/*.ldif' \
%endif
'%config %{l_prefix}/etc/openldap/*.conf'
%files -f files
%clean
%pre
%if "%{with_server}" == "yes"
# before upgrade, save status and stop service
[ $1 -eq 2 ] || exit 0
eval `%{l_rc} openldap status 2>/dev/null | tee %{l_tmpfile}`
%{l_rc} openldap stop 2>/dev/null
exit 0
%endif
%post
# after upgrade, restore status
%if "%{with_server}" == "yes"
[ $1 -eq 2 ] || exit 0
{ eval `cat %{l_tmpfile}`; rm -f %{l_tmpfile}; true; } >/dev/null 2>&1
[ ".$openldap_active" = .yes ] && %{l_rc} openldap start
exit 0
%endif
%preun
# before erase, stop service and remove log files
%if "%{with_server}" == "yes"
[ $1 -eq 0 ] || exit 0
%{l_rc} openldap stop 2>/dev/null
rm -f $RPM_INSTALL_PREFIX/var/openldap/openldap.log* >/dev/null 2>&1 || true
exit 0
%endif