Accepting request 289785 from home:pluskalm:branches:network

- Cleanup spec-file with spec-cleaner
- Do not generate config.example from README
  * add config.example as source
- Add unit file (nbd-server.service)
- Add sysconfig template (nbd-server.sysconfig)
- Add no-return-nonvoid.patch
- Update requirements
- Update to 3.9

OBS-URL: https://build.opensuse.org/request/show/289785
OBS-URL: https://build.opensuse.org/package/show/network:utilities/nbd?expand=0&rev=27
This commit is contained in:
OBS User mrdocs 2015-03-15 04:37:42 +00:00 committed by Git OBS Bridge
parent b152c83e84
commit 0d56ec87cc
9 changed files with 196 additions and 75 deletions

33
config.example Normal file
View File

@ -0,0 +1,33 @@
[generic]
# The [generic] section is required, even if nothing is specified
# there.
# When either of these options are specified, nbd-server drops
# privileges to the given user and group after opening ports, but
# _before_ opening files.
user = nbd
group = nbd
# Since version 2.9.17, nbd-server will do exports on a name
# basis (the used name is the name of the section in which the
# export is specified). This however required an incompatible
# protocol change. To enable backwards-compatible port-based
# exports, uncomment the following line:
# oldstyle = true
[export1]
exportname = /export/nbd/export1-file
# The following line will be ignored unless the
# "oldstyle = true" line in the generic section above is
# enabled.
port = 12345
authfile = /export/nbd/export1-authfile
timeout = 30
filesize = 10000000
readonly = false
multifile = false
copyonwrite = false
prerun = dd if=/dev/zero of=%s bs=1k count=500
postrun = rm -f %s
[otherexport]
exportname = /export/nbd/experiment
# The other options are all optional, except this one in case
# the oldstyle option is used in [generic]:
# port = 12346

View File

@ -1,8 +1,10 @@
--- nbd-2.9.25/nbd-client.c.orig 2012-01-05 15:40:31.962826124 -0500 Index: nbd-3.9/nbd-client.c
+++ nbd-2.9.25/nbd-client.c 2012-01-05 15:40:53.627555277 -0500 ===================================================================
@@ -70,6 +70,7 @@ --- nbd-3.9.orig/nbd-client.c
len=read(fd, buf, 256); +++ nbd-3.9/nbd-client.c
buf[len-1]='\0'; @@ -79,6 +79,7 @@ int check_conn(char* devname, int do_pri
}
buf[(len < 256) ? len : 255]='\0';
if(do_print) printf("%s\n", buf); if(do_print) printf("%s\n", buf);
+ close(fd); + close(fd);
return 0; return 0;

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:83105718dcab9eee7ea152d6e5f4928095f0d3e21dcf92e43eef183e29a80c19
size 515909

3
nbd-3.9.tar.xz Normal file
View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:af8ba47cf041c61dd2ae5f064fd856bed8affbee426f3d6441beb5764ffc71c3
size 459260

13
nbd-server.service Normal file
View File

@ -0,0 +1,13 @@
[Unit]
Description=Network Block Device server
Documentation=man:nbd-server(1) man:nbd-server(5)
After=syslog.target network.target
[Service]
Type=forking
EnvironmentFile=/etc/sysconfig/nbd-server
ExecStart=/usr/bin/nbd-server $OPTIONS
PIDFile=/run/nbd-server.pid
[Install]
WantedBy=multi-user.target

2
nbd-server.sysconfig Normal file
View File

@ -0,0 +1,2 @@
# Command line options for nbd-server
OPTIONS=""

View File

@ -1,3 +1,38 @@
-------------------------------------------------------------------
Thu Mar 5 12:28:06 UTC 2015 - mpluskal@suse.com
- Cleanup spec-file with spec-cleaner
- Do not generate config.example from README
* add config.example as source
- Add unit file (nbd-server.service)
- Add sysconfig template (nbd-server.sysconfig)
- Add no-return-nonvoid.patch
- Update requirements
- Update to 3.9
* AF_UNIX support
* Fixed test suite on non-GNU getopt() implementations
* New "treefiles" mode, which exports a gazillion of page-sized
files; useful for exporting things which are stored on an
SSHFS or amazon AWS (trough FUSE) or similar, where every
write causes an upload to the backend storage
* New "cowdir" option, allowing to specify where copy-on-write
files are written.
* Minor changes so that nbd-client can now also be compiled for
the Android platform. This required removal of the -swap
command line option, which requires the mlockall() system
call, unavailable on Android.
* Protocol update: a reserved bit is used to avoid sending
the 124 bytes of useless data at the beginning of the
negotiation. The change is implemented so that things will
still work with clients not supporting this option, however.
* gznbd is now built by the same build system, rather than
a separate one. Note however that gznbd is still
unmaintained; it should be considered a "contrib" feature.
* "nbd-server -V" will now output the nbd-server version number.
* Various fixes found through Coverity and the clang static
analyzer, and lots of other minor things too small to
mention here.
------------------------------------------------------------------- -------------------------------------------------------------------
Sun Nov 09 19:27:00 UTC 2014 - Led <ledest@gmail.com> Sun Nov 09 19:27:00 UTC 2014 - Led <ledest@gmail.com>

158
nbd.spec
View File

@ -1,7 +1,7 @@
# #
# spec file for package nbd # spec file for package nbd
# #
# Copyright (c) 2014 SUSE LINUX Products GmbH, Nuernberg, Germany. # Copyright (c) 2015 SUSE LINUX 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
@ -17,22 +17,34 @@
Name: nbd Name: nbd
BuildRequires: doxygen Version: 3.9
BuildRequires: glib2-devel >= 2.26.0
PreReq: %insserv_prereq coreutils
Version: 3.3
Release: 0 Release: 0
Source: http://downloads.sourceforge.net/project/%{name}/%{name}/%{version}/%{name}-%{version}.tar.bz2
Source2: init.nbd-server
Patch2: nbd-2.9.25-close.diff
Patch3: nbd-2.9.25-doxyfile.diff
Summary: Network Block Device Server and Client Utilities Summary: Network Block Device Server and Client Utilities
License: GPL-2.0+ License: GPL-2.0+
Group: Productivity/Networking/Other Group: Productivity/Networking/Other
Url: http://nbd.sourceforge.net/ Url: http://nbd.sourceforge.net/
Prefix: /usr Source0: http://downloads.sourceforge.net/project/%{name}/%{name}/%{version}/%{name}-%{version}.tar.xz
BuildRoot: %{_tmppath}/%{name}-%{version}-build Source1: %{name}-server.service
Source2: init.nbd-server
Source3: config.example
Source4: nbd-server.sysconfig
Patch2: nbd-2.9.25-close.diff
Patch3: nbd-2.9.25-doxyfile.diff
# fix return value
Patch4: no-return-nonvoid.patch
BuildRequires: doxygen
BuildRequires: glib2-devel >= 2.26.0
BuildRequires: xz
Requires(pre): %fillup_prereq
Requires(pre): coreutils
Suggests: nbd-doc Suggests: nbd-doc
BuildRoot: %{_tmppath}/%{name}-%{version}-build
%if 0%{?suse_version} >= 1210
BuildRequires: systemd-rpm-macros
%systemd_requires
%else
Requires(pre): %insserv_prereq
%endif
%description %description
This package contains nbd-server. It is the server backend for the nbd This package contains nbd-server. It is the server backend for the nbd
@ -41,7 +53,7 @@ network block device driver that's in the Linux kernel.
nbd can be used to have a filesystem stored on another machine. It does nbd can be used to have a filesystem stored on another machine. It does
provide a block device, not a file system; so unless you put a provide a block device, not a file system; so unless you put a
clustering filesystem on top of it, you can't access it simultaneously clustering filesystem on top of it, you can't access it simultaneously
from more than one client. Use NFS or a real cluster FS (such as from more than one client. Use NFS or a real cluster FS (such as
ocfs2) if you want to do this. nbd-server can export a file (which may ocfs2) if you want to do this. nbd-server can export a file (which may
contain a filesystem image) or a partition. Swapping over nbd is contain a filesystem image) or a partition. Swapping over nbd is
possible as well, though it's said not to be safe against OOM and possible as well, though it's said not to be safe against OOM and
@ -52,15 +64,6 @@ the connection closes.
The package also contains the nbd-client tools, which you need to The package also contains the nbd-client tools, which you need to
configure the nbd devices on the client side. configure the nbd devices on the client side.
Authors:
--------
Wouter Verhelst <wouter@debian.org>
Anton Altaparmakov <aia21@cam.ac.uk>
Pavel Machek <pavel@ucw.cz>
Paul Clements <Paul.Clements@steeleye.com>
%package doc %package doc
Summary: Network Block Device Server and Client Utilities Summary: Network Block Device Server and Client Utilities
Group: Productivity/Networking/Other Group: Productivity/Networking/Other
@ -73,7 +76,7 @@ device (nbd) utilities.
nbd can be used to have a filesystem stored on another machine. It does nbd can be used to have a filesystem stored on another machine. It does
provide a block device, not a file system; so unless you put a provide a block device, not a file system; so unless you put a
clustering filesystem on top of it, you can't access it simultaneously clustering filesystem on top of it, you can't access it simultaneously
from more than one client. Use NFS or a real cluster FS (such as from more than one client. Use NFS or a real cluster FS (such as
ocfs2) if you want to do this. nbd-server can export a file (which may ocfs2) if you want to do this. nbd-server can export a file (which may
contain a filesystem image) or a partition. Swapping over nbd is contain a filesystem image) or a partition. Swapping over nbd is
possible as well, though it's said not to be safe against OOM and possible as well, though it's said not to be safe against OOM and
@ -81,90 +84,111 @@ should not be used for that case. nbd-server also has a copy-on-write
mode where changes are saved to a separate file and thrown away when mode where changes are saved to a separate file and thrown away when
the connection closes. the connection closes.
Authors:
--------
Wouter Verhelst <wouter@debian.org>
Anton Altaparmakov <aia21@cam.ac.uk>
Pavel Machek <pavel@ucw.cz>
Paul Clements <Paul.Clements@steeleye.com>
%prep %prep
%setup %setup -q
%patch2 -p1 %patch2 -p1
%patch3 -p1 %patch3 -p1
%patch4 -p1
%build %build
export CFLAGS="$RPM_OPT_FLAGS -fstack-protector -fno-strict-aliasing" export CFLAGS="%{optflags} -fstack-protector -fno-strict-aliasing"
./configure --with-gnu-ld --prefix=/usr --mandir=%{_mandir} \ %configure
--infodir=%{_infodir} --libdir=%{_libdir} --libexecdir=%{_libdir} \
--program-prefix="" --sysconfdir=/etc --build=%{_target_cpu}-suse-linux make %{?_smp_mflags}
make
doxygen doc/Doxyfile.in doxygen doc/Doxyfile.in
%install %install
make install DESTDIR=$RPM_BUILD_ROOT man_MANS='nbd-client.8 nbd-server.1 nbd-server.5 nbd-trdump.1' make install DESTDIR=%{buildroot} man_MANS='nbd-client.8 nbd-server.1 nbd-server.5 nbd-trdump.1'
mkdir -p $RPM_BUILD_ROOT/etc/init.d mkdir -p %{buildroot}%{_sysconfdir}/init.d
install %SOURCE2 $RPM_BUILD_ROOT/etc/init.d/nbd-server mkdir -p %{buildroot}%{_prefix}/bin
mkdir -p $RPM_BUILD_ROOT/usr/bin
ln -s ../../etc/init.d/nbd-server $RPM_BUILD_ROOT/usr/bin/rcnbd-server %if 0%{?suse_version} >= 1210
install -D -m 0644 %{SOURCE1} %{buildroot}/%{_unitdir}/%{name}-server.service
ln -s %{_sbindir}/service %{buildroot}%{_sbindir}/rc%{name}-server
%else
install %{SOURCE2} %{buildroot}%{_initddir}/nbd-server
ln -s ../..%{_initddir}/nbd-server %{buildroot}%{_sbindir}/rc%{name}-server
%endif
#echo "#Port file options" > $RPM_BUILD_ROOT/etc/nbd-server.conf #echo "#Port file options" > $RPM_BUILD_ROOT/etc/nbd-server.conf
mkdir -p $RPM_BUILD_ROOT/etc/nbd-server mkdir -p %{buildroot}%{_sysconfdir}/nbd-server
touch $RPM_BUILD_ROOT/etc/nbd-server/config touch %{buildroot}%{_sysconfdir}/nbd-server/config
touch $RPM_BUILD_ROOT/etc/nbd-server/allow touch %{buildroot}%{_sysconfdir}/nbd-server/allow
grep -A16 -B1 '^\[generic\]' README > $RPM_BUILD_ROOT/etc/nbd-server/config.example install -D -m 0644 %{SOURCE3} %{buildroot}%{_sysconfdir}/nbd-server/config.example
install -D -m 0644 %{SOURCE4} %{buildroot}%{_localstatedir}/adm/fillup-templates/sysconfig.%{name}-server
%files %files
%defattr(-,root,root) %defattr(-,root,root)
%attr(0755,root,root) /usr/sbin/nbd-client %attr(0755,root,root) %{_sbindir}/nbd-client
%attr(0755,root,root) /usr/bin/nbd-server %attr(0755,root,root) %{_bindir}/nbd-server
%attr(0755,root,root) /usr/bin/nbd-trdump %attr(0755,root,root) %{_bindir}/nbd-trdump
%attr(0755,root,root) /etc/init.d/nbd-server %{_sbindir}/rcnbd-server
%attr(0755,root,root) /usr/bin/rcnbd-server %if 0%{?suse_version} >= 1210
%{_unitdir}/%{name}-server.service
%else
%{_initddir}/%{name}-server
%endif
%{_mandir}/man1/nbd-server.1.gz %{_mandir}/man1/nbd-server.1.gz
%{_mandir}/man1/nbd-trdump.1.gz %{_mandir}/man1/nbd-trdump.1.gz
%{_mandir}/man5/nbd-server.5.gz %{_mandir}/man5/nbd-server.5.gz
%{_mandir}/man8/nbd-client.8.gz %{_mandir}/man8/nbd-client.8.gz
%doc README %doc README.md
#%%config(noreplace) /etc/nbd-server.conf %dir %{_sysconfdir}/nbd-server
%dir /etc/nbd-server %ghost %config(noreplace) %{_sysconfdir}/nbd-server/config
%ghost %config(noreplace) /etc/nbd-server/config %ghost %config(noreplace) %{_sysconfdir}/nbd-server/allow
%ghost %config(noreplace) /etc/nbd-server/allow %config %{_sysconfdir}/nbd-server/config.example
%config /etc/nbd-server/config.example %{_localstatedir}/adm/fillup-templates/sysconfig.%{name}-server
%files doc %files doc
%defattr(-,root,root) %defattr(-,root,root)
%doc doc/html %doc doc/html
%post %post
%if 0%{?suse_version} >= 1210
%service_add_post %{name}-server.service
%fillup_only -n nbd-server
%else
%{fillup_and_insserv -f nbd-server} %{fillup_and_insserv -f nbd-server}
if test -e /etc/nbd-server.conf; then %endif
if test -e %{_sysconfdir}/nbd-server.conf; then
# Do we have to create a generic section? # Do we have to create a generic section?
unset generic unset generic
if test -e /etc/nbd-server/config; then generic=1; fi if test -e %{_sysconfdir}/nbd-server/config; then generic=1; fi
grep -vE '^(#|[[:blank:]]*$)' /etc/nbd-server.conf | grep -vE '^(#|[[:blank:]]*$)' %{_sysconfdir}/nbd-server.conf |
while read port file opts; do while read port file opts; do
if test -z "$generic"; then if test -z "$generic"; then
echo > /etc/nbd-server/config echo > %{_sysconfdir}/nbd-server/config
echo "[generic]" >> /etc/nbd-server/config echo "[generic]" >> %{_sysconfdir}/nbd-server/config
echo " # No generic options yet" >> /etc/nbd-server/config echo " # No generic options yet" >> %{_sysconfdir}/nbd-server/config
echo >> /etc/nbd-server/config echo >> %{_sysconfdir}/nbd-server/config
generic=1 generic=1
fi fi
FN=${file%/*} FN=${file%/*}
nm="cvt.$port.${FN##*/}.${file##*/}" nm="cvt.$port.${FN##*/}.${file##*/}"
echo " ... convert $port $file $opts -> $nm" echo " ... convert $port $file $opts -> $nm"
/usr/bin/nbd-server $port $file $opts -o "$nm" >> /etc/nbd-server/config %{_bindir}/nbd-server $port $file $opts -o "$nm" >> %{_sysconfdir}/nbd-server/config
done done
mv /etc/nbd-server.conf /etc/nbd-server.conf.converted mv %{_sysconfdir}/nbd-server.conf %{_sysconfdir}/nbd-server.conf.converted
fi fi
%postun %postun
%{insserv_cleanup} %if 0%{?suse_version} >= 1210
%service_del_postun %{name}-server.service
%else
%insserv_cleanup
%restart_on_update nbd-server %restart_on_update nbd-server
%endif
%pre
%if 0%{?suse_version} >= 1210
%service_add_pre %{name}-server.service
%endif
%preun %preun
%if 0%{?suse_version} >= 1210
%service_del_preun %{name}-server.service
%else
%{stop_on_removal nbd-server} %{stop_on_removal nbd-server}
%endif
%changelog %changelog

12
no-return-nonvoid.patch Normal file
View File

@ -0,0 +1,12 @@
Index: nbd-3.9/nbd-server.c
===================================================================
--- nbd-3.9.orig/nbd-server.c
+++ nbd-3.9/nbd-server.c
@@ -1595,6 +1595,7 @@ CLIENT* negotiate(int net, CLIENT *clien
err("Negotiation failed/12: %m");
return NULL;
}
+ return NULL;
}
/** sending macro. */