From: Stefan Schantl <stefan.schantl@ipfire.org>
To: development@lists.ipfire.org
Subject: [PATCH] rsync: Update to 3.1.2.
Date: Wed, 11 May 2016 11:32:20 +0200 [thread overview]
Message-ID: <1462959140-30778-1-git-send-email-stefan.schantl@ipfire.org> (raw)
[-- Attachment #1: Type: text/plain, Size: 6526 bytes --]
This is a minor update to the latest stable version of rsync.
* Drop patch which got upstream.
* Link/Use system libpopt and zlib instead of bundled ones.
* Enable testsuite.
* Drop xinetd support and add service files for systemd.
* Ship a sample configuration file.
Fixes #11118.
Signed-off-by: Stefan Schantl <stefan.schantl(a)ipfire.org>
---
rsync/patches/rsync-3.0.7-buf-overflow.patch | 39 -------------------
rsync/rsync.nm | 58 ++++++++++++++++++++++++++--
rsync/rsyncd.conf | 20 ++++++++++
rsync/systemd/rsyncd.service | 9 +++++
rsync/systemd/rsyncd.socket | 10 +++++
rsync/systemd/rsyncd(a).service | 7 ++++
6 files changed, 100 insertions(+), 43 deletions(-)
delete mode 100644 rsync/patches/rsync-3.0.7-buf-overflow.patch
create mode 100644 rsync/rsyncd.conf
create mode 100644 rsync/systemd/rsyncd.service
create mode 100644 rsync/systemd/rsyncd.socket
create mode 100644 rsync/systemd/rsyncd(a).service
diff --git a/rsync/patches/rsync-3.0.7-buf-overflow.patch b/rsync/patches/rsync-3.0.7-buf-overflow.patch
deleted file mode 100644
index 2c6b195..0000000
--- a/rsync/patches/rsync-3.0.7-buf-overflow.patch
+++ /dev/null
@@ -1,39 +0,0 @@
-index 7139b10..fef15aa 100644
---- a/flist.c
-+++ b/flist.c
-@@ -1640,21 +1640,29 @@ static void send_directory(int f, struct file_list *flist, char *fbuf, int len,
- }
-
- p = fbuf + len;
-- if (len != 1 || *fbuf != '/')
-+ if (len == 1 && *fbuf == '/')
-+ remainder = MAXPATHLEN - 1;
-+ else if (len < MAXPATHLEN-1) {
- *p++ = '/';
-- *p = '\0';
-- remainder = MAXPATHLEN - (p - fbuf);
-+ *p = '\0';
-+ remainder = MAXPATHLEN - (len + 1);
-+ } else
-+ remainder = 0;
-
- for (errno = 0, di = readdir(d); di; errno = 0, di = readdir(d)) {
- char *dname = d_name(di);
- if (dname[0] == '.' && (dname[1] == '\0'
- || (dname[1] == '.' && dname[2] == '\0')))
- continue;
-- if (strlcpy(p, dname, remainder) >= remainder) {
-+ unsigned name_len = strlcpy(p, dname, remainder);
-+ if (name_len >= remainder) {
-+ char save = fbuf[len];
-+ fbuf[len] = '\0';
- io_error |= IOERR_GENERAL;
- rprintf(FERROR_XFER,
-- "cannot send long-named file %s\n",
-- full_fname(fbuf));
-+ "filename overflows max-path len by %u: %s/%s\n",
-+ name_len - remainder + 1, fbuf, dname);
-+ fbuf[len] = save;
- continue;
- }
- if (dname[0] == '\0') {
diff --git a/rsync/rsync.nm b/rsync/rsync.nm
index 3af7d69..36e04b2 100644
--- a/rsync/rsync.nm
+++ b/rsync/rsync.nm
@@ -4,7 +4,7 @@
###############################################################################
name = rsync
-version = 3.0.7
+version = 3.1.2
release = 1
groups = Applications/Internet
@@ -31,8 +31,17 @@ build
libacl-devel
libattr-devel
popt-devel
+ zlib-devel
+
+ # Testsuite.
+ %{bindir}/setfacl
end
+ configure_options += \
+ --without-included-popt \
+ --without-included-zlib
+
+
prepare_cmds
# Fix permission issure.
cd %{DIR_APP} && chmod -x support/*
@@ -52,19 +61,60 @@ build
make_build_targets = proto all
+ test
+ # Fix permissions of testsuite helper script.
+ #
+ # Otherwise some tests of the testsuite will fail,
+ # because the script is not allowed to be executed.
+ chmod +x ./support/lsh.sh
+
+ make check
+ end
+
make_install_targets += \
INSTALLCMD="install -p" \
INSTALLMAN="install -p"
install_cmds
- mkdir -pv %{BUILDROOT}/etc/xinetd.d
- install -p -m 644 %{DIR_SOURCE}/rsync.xinetd \
- %{BUILDROOT}/etc/xinetd.d/rsync
+
+ # Install config file.
+ mkdir -pv %{BUILDROOT}%{sysconfdir}
+
+ install -m 0644 %{DIR_SOURCE}/rsyncd.conf \
+ %{BUILDROOT}%{sysconfdir}/
+
+ # Create directory for pidfile.
+ mkdir -pv %{BUILDROOT}/run/rsyncd
end
+
end
packages
package %{name}
+ configfiles
+ %{sysconfdir}/rsyncd.conf
+ end
+
+ script postin
+ systemctl daemon-reload >/dev/null 2>&1 || :
+ end
+
+ script preun
+ systemctl --no-reload disable rsyncd.service >/dev/null 2>&1 || :
+ systemctl --no-reload disable rsyncd.socket >/dev/null 2>&1 || :
+ systemctl stop rsyncd.service >/dev/null 2>&1 || :
+ systemctl stop rsyncd.socket >/dev/null 2>&1 || :
+ systemctl stop rsyncd(a).service >/dev/null 2>&1 || :
+ end
+
+ script postun
+ systemctl daemon-reload >/dev/null 2>&1 || :
+ end
+
+ script postup
+ systemctl daemon-reload >/dev/null 2>&1 || :
+ systemctl try-restart rsyncd.service >/dev/null 2>&1 || :
+ end
end
package %{name}-debuginfo
diff --git a/rsync/rsyncd.conf b/rsync/rsyncd.conf
new file mode 100644
index 0000000..09e768f
--- /dev/null
+++ b/rsync/rsyncd.conf
@@ -0,0 +1,20 @@
+# /etc/rsyncd: configuration file for rsync daemon mode
+
+# See rsyncd.conf man page for more options.
+
+# configuration example:
+
+# uid = nobody
+# gid = nobody
+# use chroot = yes
+# max connections = 4
+# pid file = /run/rsyncd/rsyncd.pid
+# exclude = lost+found/
+# transfer logging = yes
+# timeout = 900
+# ignore nonreadable = yes
+# dont compress = *.gz *.tgz *.zip *.z *.Z *.rpm *.deb *.bz2
+
+# [ftp]
+# path = /home/ftp
+# comment = ftp export area
diff --git a/rsync/systemd/rsyncd.service b/rsync/systemd/rsyncd.service
new file mode 100644
index 0000000..30c3ca0
--- /dev/null
+++ b/rsync/systemd/rsyncd.service
@@ -0,0 +1,9 @@
+[Unit]
+Description=Fast remote file copy program daemon
+ConditionPathExists=/etc/rsyncd.conf
+
+[Service]
+ExecStart=/usr/bin/rsync --daemon --no-detach
+
+[Install]
+WantedBy=multi-user.target
diff --git a/rsync/systemd/rsyncd.socket b/rsync/systemd/rsyncd.socket
new file mode 100644
index 0000000..7306ad0
--- /dev/null
+++ b/rsync/systemd/rsyncd.socket
@@ -0,0 +1,10 @@
+[Unit]
+Description=Rsync Server Socket
+Conflicts=rsyncd.service
+
+[Socket]
+ListenStream=873
+Accept=yes
+
+[Install]
+WantedBy=sockets.target
diff --git a/rsync/systemd/rsyncd(a).service b/rsync/systemd/rsyncd(a).service
new file mode 100644
index 0000000..beef5c9
--- /dev/null
+++ b/rsync/systemd/rsyncd(a).service
@@ -0,0 +1,7 @@
+[Unit]
+Description=Fast remote file copy program daemon
+ConditionPathExists=/etc/rsyncd.conf
+
+[Service]
+ExecStart=/usr/bin/rsync --daemon --no-detach
+StandardInput=socket
--
2.5.5
next reply other threads:[~2016-05-11 9:32 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-05-11 9:32 Stefan Schantl [this message]
2016-05-11 15:11 ` Michael Tremer
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1462959140-30778-1-git-send-email-stefan.schantl@ipfire.org \
--to=stefan.schantl@ipfire.org \
--cc=development@lists.ipfire.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox