forked from pool/csync2
Accepting request 89351 from network:ha-clustering:Factory
Add csync2-rm-ssl-cert script, remove explicit lib requires (without the latter, csync2 doesn't run/install presumably due to lib version mismatch) OBS-URL: https://build.opensuse.org/request/show/89351 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/csync2?expand=0&rev=6
This commit is contained in:
parent
a8d2769fe0
commit
ce7ce5913e
@ -29,6 +29,13 @@ can replace them with your own if you like. The files are :
|
|||||||
/etc/csync2/csync2_ssl_key.pem
|
/etc/csync2/csync2_ssl_key.pem
|
||||||
/etc/csync2/csync2_ssl_cert.pem
|
/etc/csync2/csync2_ssl_cert.pem
|
||||||
|
|
||||||
|
Note that the common name (CN) in each node's SSL certificate must be the
|
||||||
|
same, or the SSL connection will fail. If you ever replace a node, and its
|
||||||
|
SSL key changes, existing nodes will still have a cached copy of the old key,
|
||||||
|
and the connection will fail. To remove the old key from an existing node's
|
||||||
|
cache, run the following command on each existing node:
|
||||||
|
csync2-rm-ssl-cert <replaced-hostname>
|
||||||
|
|
||||||
The csync2 service is disabled by default. To start it on both your hosts :
|
The csync2 service is disabled by default. To start it on both your hosts :
|
||||||
chkconfig csync2 on
|
chkconfig csync2 on
|
||||||
chkconfig --level 345 xinetd on
|
chkconfig --level 345 xinetd on
|
||||||
|
45
csync2-rm-ssl-cert
Normal file
45
csync2-rm-ssl-cert
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
if [ $# -eq 0 -o "$1" = "-h" ]; then
|
||||||
|
cat <<END
|
||||||
|
|
||||||
|
Remove a peer's SSL certificate from csync2's local database. Use this after
|
||||||
|
replacing a peer node (or regenerating its SSL certificate).
|
||||||
|
|
||||||
|
Usage: $0 [-h] <hostname>
|
||||||
|
|
||||||
|
Options:
|
||||||
|
-h Display this usage information
|
||||||
|
|
||||||
|
END
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
DBFILE=/var/lib/csync2/$(hostname).db
|
||||||
|
if [ ! -f "$DBFILE" ]; then
|
||||||
|
echo "Local csync2 database ($DBFILE) not found."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Strip double and single quotes from hostname so they can't interfere with the SQL
|
||||||
|
PEERNAME=$(echo $1 | sed -e "s/['\"]//g")
|
||||||
|
|
||||||
|
certcount()
|
||||||
|
{
|
||||||
|
echo "SELECT COUNT(peername) FROM x509_cert WHERE peername='$1';" | sqlite $DBFILE
|
||||||
|
}
|
||||||
|
|
||||||
|
if [ $(certcount "$PEERNAME") -eq 0 ]; then
|
||||||
|
echo "Certificate for '$PEERNAME' not in local database."
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "DELETE FROM x509_cert WHERE peername='$PEERNAME';" | sqlite $DBFILE
|
||||||
|
|
||||||
|
if [ $(certcount "$PEERNAME") -ne 0 ]; then
|
||||||
|
echo "Error removing certificate for '$PEERNAME' from local database."
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Certificate for '$PEERNAME' removed from local database."
|
||||||
|
|
@ -1,3 +1,18 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Oct 26 09:19:16 UTC 2011 - tserong@suse.com
|
||||||
|
|
||||||
|
- Remove explicit lib dependencies from spec file
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Sep 20 12:41:40 UTC 2011 - tserong@suse.com
|
||||||
|
|
||||||
|
- Add csync2-rm-ssl-cert helper script (bnc#709811)
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Sun Sep 18 00:06:31 UTC 2011 - jengelh@medozas.de
|
||||||
|
|
||||||
|
- Remove redundant tags/sections from specfile
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Tue Jun 8 00:59:40 UTC 2010 - tserong@novell.com
|
Tue Jun 8 00:59:40 UTC 2010 - tserong@novell.com
|
||||||
|
|
||||||
|
21
csync2.spec
21
csync2.spec
@ -1,7 +1,7 @@
|
|||||||
#
|
#
|
||||||
# spec file for package csync2 (Version 1.34)
|
# spec file for package csync2
|
||||||
#
|
#
|
||||||
# Copyright (c) 2010 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
|
||||||
#
|
#
|
||||||
# All modifications and additions to the file contributed by third parties
|
# All modifications and additions to the file contributed by third parties
|
||||||
# remain the property of their copyright owners, unless otherwise agreed
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
@ -20,12 +20,13 @@ Summary: Cluster synchronization tool
|
|||||||
|
|
||||||
Name: csync2
|
Name: csync2
|
||||||
Version: 1.34
|
Version: 1.34
|
||||||
Release: 1
|
Release: 2
|
||||||
Group: Productivity/Clustering/HA
|
Group: Productivity/Clustering/HA
|
||||||
License: GPLv2+ ; LGPLv2.1+
|
License: GPLv2+ ; LGPLv2.1+
|
||||||
Url: http://oss.linbit.com/csync2/
|
Url: http://oss.linbit.com/csync2/
|
||||||
Source0: http://oss.linbit.com/csync2/%{name}-%{version}.tar.gz
|
Source0: http://oss.linbit.com/csync2/%{name}-%{version}.tar.gz
|
||||||
Source1: csync2-README.quickstart
|
Source1: csync2-README.quickstart
|
||||||
|
Source2: csync2-rm-ssl-cert
|
||||||
Patch0: csync2-fix-xinetd.patch
|
Patch0: csync2-fix-xinetd.patch
|
||||||
Patch1: fix-missing-sentinels.diff
|
Patch1: fix-missing-sentinels.diff
|
||||||
%if 0%{?suse_version} > 1120
|
%if 0%{?suse_version} > 1120
|
||||||
@ -34,7 +35,7 @@ BuildRequires: pkg-config
|
|||||||
%endif
|
%endif
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
Requires(post): openssl
|
Requires(post): openssl
|
||||||
Requires: xinetd libgnutls26 libgnutls-extra26 gnutls sqlite2 librsync libtasn1-3
|
Requires: xinetd gnutls sqlite2
|
||||||
BuildRequires: bison flex libgnutls-devel libgnutls-extra-devel librsync libtasn1-devel sqlite2-devel
|
BuildRequires: bison flex libgnutls-devel libgnutls-extra-devel librsync libtasn1-devel sqlite2-devel
|
||||||
|
|
||||||
%description
|
%description
|
||||||
@ -44,12 +45,6 @@ setups with much more than just 2 hosts, handle file deletions and can
|
|||||||
detect conflicts. It is expedient for HA-clusters, HPC-clusters, COWs
|
detect conflicts. It is expedient for HA-clusters, HPC-clusters, COWs
|
||||||
and server farms.
|
and server farms.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Authors:
|
|
||||||
--------
|
|
||||||
Clifford Wolf <clifford@clifford.at>
|
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
%patch0 -p1 -b .fix-xinetd
|
%patch0 -p1 -b .fix-xinetd
|
||||||
@ -64,17 +59,14 @@ install -p -m 644 %{SOURCE1} README.quickstart
|
|||||||
make %{?_smp_mflags}
|
make %{?_smp_mflags}
|
||||||
|
|
||||||
%install
|
%install
|
||||||
rm -rf %{buildroot}
|
|
||||||
make install DESTDIR=%{buildroot}
|
make install DESTDIR=%{buildroot}
|
||||||
mkdir -p %{buildroot}%{_var}/lib/csync2
|
mkdir -p %{buildroot}%{_var}/lib/csync2
|
||||||
install -p -D -m 644 csync2.xinetd %{buildroot}%{_sysconfdir}/xinetd.d/csync2
|
install -p -D -m 644 csync2.xinetd %{buildroot}%{_sysconfdir}/xinetd.d/csync2
|
||||||
|
install -p -m 755 %{SOURCE2} %{buildroot}%{_sbindir}/csync2-rm-ssl-cert
|
||||||
# We need these empty files to be able to %%ghost them
|
# 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_key.pem
|
||||||
touch %{buildroot}%{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
touch %{buildroot}%{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
||||||
|
|
||||||
%clean
|
|
||||||
rm -rf %{buildroot}
|
|
||||||
|
|
||||||
%post
|
%post
|
||||||
umask 077
|
umask 077
|
||||||
if [ ! -f %{_sysconfdir}/csync2/csync2_ssl_key.pem ]; then
|
if [ ! -f %{_sysconfdir}/csync2/csync2_ssl_key.pem ]; then
|
||||||
@ -112,6 +104,7 @@ fi
|
|||||||
%ghost %config %{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
%ghost %config %{_sysconfdir}/csync2/csync2_ssl_cert.pem
|
||||||
%{_sbindir}/csync2
|
%{_sbindir}/csync2
|
||||||
%{_sbindir}/csync2-compare
|
%{_sbindir}/csync2-compare
|
||||||
|
%{_sbindir}/csync2-rm-ssl-cert
|
||||||
%{_mandir}/man1/csync2.1*
|
%{_mandir}/man1/csync2.1*
|
||||||
%dir %{_var}/lib/csync2/
|
%dir %{_var}/lib/csync2/
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user