0a278ac1df
Adapt suggested changes in %post section. Do not hide output on standard error during generating the keys. OBS-URL: https://build.opensuse.org/package/show/network:ha-clustering:Factory/csync2?expand=0&rev=56
129 lines
3.8 KiB
RPMSpec
129 lines
3.8 KiB
RPMSpec
#
|
|
# spec file for package csync2
|
|
#
|
|
# Copyright (c) 2021 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
Name: csync2
|
|
Version: 2.0+git.1600444747.83b3644
|
|
Release: 0
|
|
Summary: Cluster synchronization tool
|
|
License: GPL-2.0-or-later
|
|
Group: Productivity/Clustering/HA
|
|
URL: http://oss.linbit.com/csync2/
|
|
#Source0: http://oss.linbit.com/csync2/%{name}-%{version}.tar.gz
|
|
Source0: %{name}-%{version}.tar.bz2
|
|
Source1: csync2-README.quickstart
|
|
Source2: csync2-rm-ssl-cert
|
|
BuildRequires: autoconf
|
|
BuildRequires: automake
|
|
BuildRequires: bison
|
|
BuildRequires: flex
|
|
BuildRequires: libgnutls-devel
|
|
BuildRequires: librsync-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: sqlite3-devel
|
|
BuildRequires: systemd-rpm-macros
|
|
Requires: sqlite3
|
|
Requires(post): openssl
|
|
%if 0%{?suse_version} > 1320
|
|
# Conflicts with net-tools in Leap
|
|
Requires(post): hostname
|
|
%endif
|
|
|
|
%description
|
|
Csync2 is a cluster synchronization tool. It can be used to keep files on
|
|
multiple hosts in a cluster in sync. Csync2 can handle complex setups with
|
|
much more than just 2 hosts, handle file deletions and can detect conflicts.
|
|
It is expedient for HA-clusters, HPC-clusters, COWs and server farms.
|
|
|
|
%prep
|
|
%setup -q
|
|
|
|
%build
|
|
autoreconf -fvi
|
|
%configure \
|
|
--enable-sqlite3 \
|
|
--enable-systemd \
|
|
--sysconfdir=%{_sysconfdir}/csync2 \
|
|
--docdir=%{_docdir}/%{name}
|
|
make %{?_smp_mflags}
|
|
|
|
%install
|
|
%make_install
|
|
mkdir -p %{buildroot}%{_localstatedir}/lib/csync2
|
|
install -p -m 644 %{SOURCE1} %{buildroot}%{_docdir}/%{name}/README.quickstart
|
|
install -p -m 755 %{SOURCE2} %{buildroot}%{_sbindir}/csync2-rm-ssl-cert
|
|
mkdir -p %{buildroot}%{_unitdir}
|
|
# We need these empty files to be able to %%ghost them
|
|
touch %{buildroot}%{_sysconfdir}/csync2/csync2_ssl_key.pem
|
|
touch %{buildroot}%{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
|
|
|
%pre
|
|
%service_add_pre csync2.socket
|
|
%service_add_pre csync2@.service
|
|
|
|
%post
|
|
%service_add_post csync2.socket
|
|
%service_add_post csync2@.service
|
|
umask 077
|
|
if [ ! -f %{_sysconfdir}/csync2/csync2_ssl_key.pem ]; then
|
|
%{_bindir}/openssl ecparam -genkey -name secp384r1 -out %{_sysconfdir}/csync2/csync2_ssl_key.pem
|
|
fi
|
|
FQDN=`hostname`
|
|
if [ "x${FQDN}" = "x" ]; then
|
|
FQDN=localhost.localdomain
|
|
fi
|
|
if [ ! -f %{_sysconfdir}/csync2/csync2_ssl_cert.pem ]; then
|
|
cat << EOF | %{_bindir}/openssl req -new -key %{_sysconfdir}/csync2/csync2_ssl_key.pem -x509 -days 3000 -out %{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
|
--
|
|
SomeState
|
|
SomeCity
|
|
SomeOrganization
|
|
SomeOrganization
|
|
SomeName
|
|
name@example.com
|
|
EOF
|
|
fi
|
|
|
|
%preun
|
|
%service_del_preun csync2.socket
|
|
%service_del_preun csync2@.service
|
|
# Cleanup all databases upon last removal
|
|
if [ $1 -eq 0 ]; then
|
|
rm -f %{_localstatedir}/lib/csync2/*
|
|
fi
|
|
|
|
%postun
|
|
%service_del_postun csync2.socket
|
|
%service_del_postun csync2@.service
|
|
|
|
%files
|
|
%{_sbindir}/csync2
|
|
%{_sbindir}/csync2-compare
|
|
%{_unitdir}/csync2.socket
|
|
%{_unitdir}/csync2@.service
|
|
%dir %{_localstatedir}/lib/csync2/
|
|
# Using docdir here ensures correct doc file tagging
|
|
%{_docdir}/%{name}
|
|
%dir %{_sysconfdir}/csync2/
|
|
%config(noreplace) %{_sysconfdir}/csync2/csync2.cfg
|
|
%ghost %config %{_sysconfdir}/csync2/csync2_ssl_key.pem
|
|
%ghost %config %{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
|
%{_sbindir}/csync2-rm-ssl-cert
|
|
%{_mandir}/man1/csync2.1*
|
|
|
|
%changelog
|