Hello community, here is the log from the commit of package boinc-client for openSUSE:Factory checked in at 2017-03-02 19:35:30 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/boinc-client (Old) and /work/SRC/openSUSE:Factory/.boinc-client.new (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Package is "boinc-client" Thu Mar 2 19:35:30 2017 rev:35 rq:460445 version:7.6.33 Changes: -------- --- /work/SRC/openSUSE:Factory/boinc-client/boinc-client.changes 2017-01-10 10:51:39.810177046 +0100 +++ /work/SRC/openSUSE:Factory/.boinc-client.new/boinc-client.changes 2017-03-02 19:35:31.447016443 +0100 @@ -1,0 +2,15 @@ +Sat Feb 25 17:53:03 UTC 2017 - chris@computersalat.de + +- fix for boo#1026965 + * no remote connect, no sysconfig file (--allow_remote_gui_rpc) + * install and fillup sysconfig file + * rework service file +- fix wrong bashism fix by ledest + * grep should NOT match +- do not build boinc-manager on SLES 11/12 + * bcond_with manager +- revert conditionals remove for SLES 11 + * add SysVinit file +- mv boincscr to manager pkg, built with manager + +------------------------------------------------------------------- New: ---- boinc-client.init ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ boinc-client.spec ++++++ --- /var/tmp/diff_new_pack.rnLSgW/_old 2017-03-02 19:35:33.362745342 +0100 +++ /var/tmp/diff_new_pack.rnLSgW/_new 2017-03-02 19:35:33.366744776 +0100 @@ -20,6 +20,14 @@ %define sonum 7 %define boinc_dir %{_localstatedir}/lib/boinc + +# do not build boinc-manager on SLES 11/12 +%if 0%{?is_opensuse} +%bcond_without manager +%else +%bcond_with manager +%endif + Name: boinc-client Version: 7.6.33 Release: 0 @@ -29,13 +37,14 @@ Url: http://boinc.berkeley.edu/ #Git-Clone: git://github.com/BOINC/boinc -Source: https://github.com/BOINC/boinc/archive/client_release/7.6/%version.tar.gz +Source0: https://github.com/BOINC/boinc/archive/client_release/7.6/%{version}.tar.gz Source1: boinc-icons.tar.bz2 Source2: boinc-gui.desktop Source3: README.SUSE Source4: sysconfig.%{name} Source5: boinc-logrotate Source6: boinc-manager +Source10: %{name}.init Source20: %{name}.service Source100: %{name}-rpmlintrc # PATCH-FIX-OPENSUSE boinc-guirpcauth.patch @@ -47,6 +56,8 @@ # PATCH-FIX-OPENSUSE boinc-docbook2x.patch Patch4: boinc-docbook2x.patch Patch5: 0001-Fix-1530-null-pointer-dereference.patch +BuildRoot: %{_tmppath}/%{name}-%{version}-build +# BuildRequires: Mesa-devel BuildRequires: docbook2x BuildRequires: docbook_4 @@ -64,14 +75,11 @@ BuildRequires: pkg-config BuildRequires: pwdutils BuildRequires: sqlite3-devel -BuildRequires: systemd -BuildRequires: update-desktop-files -BuildRequires: wxWidgets-3_0-devel >= 3.0.2 BuildRequires: xorg-x11-libXmu-devel Recommends: boinc-client-lang = %{version} Recommends: logrotate Requires(pre): pwdutils -BuildRoot: %{_tmppath}/%{name}-%{version}-build +# %if 0%{?suse_version} >= 1310 BuildRequires: libXScrnSaver-devel BuildRequires: libXi-devel @@ -80,8 +88,22 @@ %else BuildRequires: xorg-x11-libxcb-devel %endif -%lang_package +# +%if 0%{?suse_version} >= 1210 +BuildRequires: pkgconfig(systemd) +%define has_systemd 1 +%else +Requires(pre): %fillup_prereq +Requires(pre): %insserv_prereq +%endif +# +%if %{with manager} +BuildRequires: update-desktop-files +BuildRequires: wxWidgets-3_0-devel >= 3.0.2 %lang_package -n boinc-manager +%endif +# +%lang_package %description The Berkeley Open Infrastructure for Network Computing (BOINC) is an open- @@ -98,6 +120,7 @@ global warming, discover sources of gravitational waves, and many other types of scientific and mathematical research. +%if %{with manager} %package -n boinc-manager Summary: GUI to control and monitor boinc-client Group: Productivity/Scientific/Astronomy @@ -110,6 +133,7 @@ monitoring. The BOINC Manager has two modes of operation, the "Simple View" in which it only displays the most important information and the "Advanced View" in which all information and all control elements are available. +%endif %package devel Summary: Development files for boinc-client @@ -134,7 +158,9 @@ %package doc Summary: Documentation files for boinc-client Group: Documentation/Other +%if 0%{?suse_version} >= 1120 BuildArch: noarch +%endif %description doc This package contains documentation files for the BOINC client. @@ -165,9 +191,11 @@ touch -r checkin_notes_2010 checkin_notes_2010.utf8 mv checkin_notes_2010.utf8 checkin_notes_2010 +%if %{with manager} # fix permissions and newlines on source files chmod 644 clientgui/{DlgItemProperties.h,AsyncRPC.cpp,DlgItemProperties.cpp} sed -i 's/\r//' clientgui/DlgItemProperties.cpp +%endif ## remove files with questionable licenses # removing NVIDIA owned file that does not clearly allow redistribution or @@ -180,11 +208,16 @@ --enable-shared \ --disable-static \ --enable-dynamic-client-linkage \ + --enable-unicode \ --disable-server \ --disable-fcgi \ - --enable-unicode \ - --with-ssl \ - --with-x +%if ! %{with manager} + --disable-manager \ +%endif +%if %{with manager} + --with-x \ +%endif + --with-ssl # Disable rpaths sed -i 's|^hardcode_libdir_flag_spec=.*|hardcode_libdir_flag_spec=""|g' libtool @@ -199,7 +232,11 @@ %install make DESTDIR=%{buildroot} install %{?_smp_mflags} +%if %{with manager} for i in clientgui locale; do +%else +for i in locale; do +%endif pushd $i make DESTDIR=%{buildroot} install %{?_smp_mflags} popd @@ -213,34 +250,47 @@ rm -f %{buildroot}%{_bindir}/boinc mv -f %{buildroot}%{_bindir}/boinc_client %{buildroot}%{_bindir}/%{name} +%if %{with manager} # Rename boincmgr and wrap it mv %{buildroot}%{_bindir}/boincmgr %{buildroot}%{_bindir}/boinc-gui # Install boinc-manager wrapper script install -Dm0755 %{SOURCE6} %{buildroot}%{_bindir}/boinc-manager +%endif # Use symlink instead of hardlink pushd %{buildroot}%{_bindir} ln -s -f %{name} boinc +%if %{with manager} ln -s -f boinc-manager boincmgr ln -s -f boinc-manager boincmanager +%endif popd +%if %{with manager} # replace @boinc_dir@, @bindir@ sed -i \ -e "s,@boinc_dir@,%{boinc_dir},g" \ -e "s,@bindir@,%{_bindir},g" \ %{buildroot}%{_bindir}/boinc-manager +%endif -# Remove /etc/sysconfig/boinc-client, it is added by %%fillup_and_insserv +# Remove {buildroot}/etc/sysconfig/boinc-client, it is added by %%fillup_and_insserv rm -f %{buildroot}%{_sysconfdir}/sysconfig/%{name} # Install init and create symlink for rcboinc +install -dm0755 %{buildroot}%{_sbindir} +%if 0%{?has_systemd} install -D -m0644 %{SOURCE20} %{buildroot}%{_unitdir}/%{name}.service -mkdir -p %{buildroot}%{_sbindir} -ln -s %{_sbindir}/service %{buildroot}%{_sbindir}/rc%{name} # And remove sysvinit script installed by boinc rm -r %{buildroot}/%{_initddir} +ln -s %{_sbindir}/service %{buildroot}%{_sbindir}/rc%{name} +%else +install -Dm0755 %{SOURCE10} %{buildroot}%{_initddir}/%{name} +/bin/ln -sf %{_sysconfdir}/init.d/%{name} %{buildroot}%{_sbindir}/rc%{name} +%endif +# Install template for sysconfig +install -Dm0644 %{SOURCE4} %{buildroot}%{_localstatedir}/adm/fillup-templates/sysconfig.%{name} # Install logrotate install -Dm0644 %{SOURCE5} %{buildroot}%{_sysconfdir}/logrotate.d/%{name} @@ -248,6 +298,7 @@ # Install bash completion install -Dpm0644 client/scripts/boinc.bash %{buildroot}%{_sysconfdir}/bash_completion.d/boinc +%if %{with manager} # Install desktop-file and icons install -Dm0644 boinc-gui-128.png %{buildroot}%{_datadir}/icons/hicolor/128x128/apps/boinc-gui.png install -Dm0644 boinc-gui-64.png %{buildroot}%{_datadir}/icons/hicolor/64x64/apps/boinc-gui.png @@ -258,12 +309,15 @@ # Install *.desktop File %suse_update_desktop_file -i boinc-gui Utility +%endif # Remove static libraries, libtool archives rm %{buildroot}%{_libdir}/*.{a,la} # Relinking Manpages +%if %{with manager} ln -s -f boincmgr.1.gz %{buildroot}%{_mandir}/man1/boinc-manager.1.gz +%endif ln -s -f boinccmd.1.gz %{buildroot}%{_mandir}/man1/boinccmd.1.gz ln -s -f boinc.1.gz %{buildroot}%{_mandir}/man1/boinc.1.gz @@ -275,7 +329,11 @@ # Prepare $LANG Packages %find_lang BOINC-Client +%if %{with manager} %find_lang BOINC-Manager +%else +find %{buildroot}/%{_datadir}/locale/ -name "BOINC-Manager.mo" -print0 | xargs -0 rm -f -- +%endif %fdupes -s %{buildroot} @@ -285,23 +343,41 @@ # add user %{_sbindir}/useradd -c "BOINC Client" -d "%{_localstatedir}/lib/boinc" \ -g boinc -r -s /sbin/nologin boinc 2>/dev/null || : +# fix replacing old sysconfig file (r21) if [ -f %{_sysconfdir}/sysconfig/%{name} ]; then - if grep "BOINC_BOINC_USR" %{_sysconfdir}/sysconfig/boinc-client | grep -q grep; then + if ! grep -q "BOINC_BOINC_USR" %{_sysconfdir}/sysconfig/boinc-client; then mv -f %{_sysconfdir}/sysconfig/%{name} %{_sysconfdir}/sysconfig/%{name}.save fi fi +%if 0%{?has_systemd} %service_add_pre %{name}.service +%endif %preun +%if 0%{?has_systemd} %service_del_preun %{name}.service +%else +%stop_on_removal %{name} +%endif %post +%if 0%{?has_systemd} +%{fillup_only} %service_add_post %{name}.service +%else +%fillup_and_insserv %{name} +%endif %{_sbindir}/usermod -c "BOINC Client" -s /sbin/nologin boinc 2>/dev/null || : %postun +%if 0%{?has_systemd} %service_del_postun %{name}.service +%else +%restart_on_update %{name} +%insserv_cleanup +%endif +%if %{with manager} %post -n boinc-manager %{_bindir}/touch --no-create %{_datadir}/icons/hicolor || : if [ -x %{_bindir}/gtk-update-icon-cache ]; then @@ -313,6 +389,7 @@ if [ -x %{_bindir}/gtk-update-icon-cache ]; then %{_bindir}/gtk-update-icon-cache --quiet %{_datadir}/icons/hicolor || : fi +%endif %post -n libboinc%{sonum} -p /sbin/ldconfig @@ -330,12 +407,16 @@ %{_bindir}/boinc %{_bindir}/%{name} %{_bindir}/boinccmd -%{_bindir}/boincscr %{_bindir}/switcher %{_mandir}/man1/boinccmd.1.gz %{_mandir}/man1/boinc.1.gz +%if 0%{?has_systemd} %{_unitdir}/%{name}.service +%else +%{_initddir}/%{name} +%endif %{_sbindir}/rc%{name} +%{_localstatedir}/adm/fillup-templates/sysconfig.%{name} %defattr(-,boinc,boinc,-) %{_localstatedir}/lib/boinc/ @@ -344,22 +425,25 @@ %doc checkin_* %doc doc/*.txt doc/bolt doc/logo doc/*.php doc/*.png doc/*.html +%files -n %{name}-lang -f BOINC-Client.lang +%defattr(-,root,root) + +%if %{with manager} %files -n boinc-manager %defattr(-,root,root,-) %{_bindir}/boinc-gui %{_bindir}/boinc-manager %{_bindir}/boincmgr %{_bindir}/boincmanager +%{_bindir}/boincscr %{_datadir}/applications/boinc-gui.desktop %{_datadir}/icons/hicolor/*/apps/* %{_mandir}/man1/boincmgr.1.gz %{_mandir}/man1/boinc-manager.1.gz -%files -n %{name}-lang -f BOINC-Client.lang -%defattr(-,root,root) - %files -n boinc-manager-lang -f BOINC-Manager.lang %defattr(-,root,root) +%endif %files -n libboinc%{sonum} %defattr(-,root,root,-) ++++++ boinc-client.init ++++++ #!/bin/sh # # Copyright (c) 2012 Scorpio IT, Deidesheim, Germany # All rights reserved # # Author: Christian Wittmer <rpm@scorpio-it.net> # # /etc/init.d/boinc-client # and its symbolic link # /(usr/)sbin/rcboinc-client # ### BEGIN INIT INFO # Provides: boinc-client # Required-Start: $syslog $network $remote_fs # Should-Start: $time # Required-Stop: $syslog $network $remote_fs # Should-Stop: $time # Default-Start: 3 5 # Default-Stop: 0 1 2 6 # Short-Description: BOINC daemon providing boinc-client # Description: Start BOINC client # For more information about BOINC (the Berkeley Open Infrastructure # for Network Computing) see http://boinc.berkeley.edu ### END INIT INFO # # Note on runlevels: # 0 - halt/poweroff 6 - reboot # 1 - single user 2 - multiuser without network exported # 3 - multiuser w/ network (text mode) 5 - multiuser w/ network and X11 (xdm) # # Note on script names: # http://www.linuxbase.org/spec/refspecs/LSB_1.3.0/gLSB/gLSB/scrptnames.html # A registry has been set up to manage the init script namespace. # http://www.lanana.org/ # Please use the names already registered or register one or use a # vendor prefix. # Check for missing binaries (stale symlinks should not happen) # Note: Special treatment of stop for LSB conformance BOINC_BIN=/usr/bin/boinc-client test -x $BOINC_BIN || { echo "$BOINC_BIN not installed"; if [ "$1" = "stop" ]; then exit 0; else exit 5; fi; } # Check for existence of needed config file and read it BOINC_CONFIG=/etc/sysconfig/boinc-client test -r $BOINC_CONFIG || { echo "$BOINC_CONFIG not existing"; if [ "$1" = "stop" ]; then exit 0; else exit 6; fi; } # Read config . $BOINC_CONFIG # some other VARS BOINC_SVC="BOINC Client" BOINCCMD_BIN="/usr/bin/boinccmd" BOINC_LOG="/var/log/boinc-client.log" BOINC_ERRLOG="/var/log/boinc-client.err.log" BOINC_PIDFILE="/var/run/boinc-client.pid" BOINC_LOCKFILE="/var/run/boinc-client.lock" BOINC_USR=${BOINC_BOINC_USR:="boinc"} BOINC_GRP=${BOINC_BOINC_GRP:="boinc"} BOINC_DIR=${BOINC_BOINC_DIR:="/var/lib/boinc"} BOINC_OPTS=${BOINC_BOINC_OPTS:=""} # Source LSB init functions # providing start_daemon, killproc, pidofproc, # log_success_msg, log_failure_msg and log_warning_msg. # This is currently not used by UnitedLinux based distributions and # not needed for init scripts for UnitedLinux only. If it is used, # the functions from rc.status should not be sourced or used. #. /lib/lsb/init-functions # Shell functions sourced from /etc/rc.status: # rc_check check and set local and overall rc status # rc_status check and set local and overall rc status # rc_status -v be verbose in local rc status and clear it afterwards # rc_status -v -r ditto and clear both the local and overall rc status # rc_status -s display "skipped" and exit with status 3 # rc_status -u display "unused" and exit with status 3 # rc_failed set local and overall rc status to failed # rc_failed <num> set local and overall rc status to <num> # rc_reset clear both the local and overall rc status # rc_exit exit appropriate to overall rc status # rc_active checks whether a service is activated by symlinks . /etc/rc.status # Reset status of this service rc_reset # Return values acc. to LSB for all commands but status: # 0 - success # 1 - generic or unspecified error # 2 - invalid or excess argument(s) # 3 - unimplemented feature (e.g. "reload") # 4 - user had insufficient privileges # 5 - program is not installed # 6 - program is not configured # 7 - program is not running # 8--199 - reserved (8--99 LSB, 100--149 distrib, 150--199 appl) # # Note that starting an already running service, stopping # or restarting a not-running service as well as the restart # with force-reload (in case signaling is not supported) are # considered a success. case "$1" in start) echo -n "Starting ${BOINC_SVC} " ## Start daemon with startproc(8). If this fails ## the return value is set appropriately by startproc. /sbin/startproc -u $BOINC_USR -g $BOINC_GRP -l $BOINC_LOG -s $BOINC_BIN --dir $BOINC_DIR $BOINC_OPTS # Remember status and be verbose rc_status -v ;; stop) echo -n "Shutting down ${BOINC_SVC} " ## Stop daemon with killproc(8) and if this fails ## killproc sets the return value according to LSB. /sbin/killproc $BOINC_BIN # Remember status and be verbose rc_status -v ;; try-restart|condrestart) ## Do a restart only if the service was active before. ## Note: try-restart is now part of LSB (as of 1.9). ## RH has a similar command named condrestart. if test "$1" = "condrestart"; then echo "${attn} Use try-restart ${done}(LSB)${attn} rather than condrestart ${warn}(RH)${norm}" fi $0 status if test $? = 0; then $0 restart else rc_reset # Not running is not a failure. fi # Remember status and be quiet rc_status ;; restart) ## Stop the service and regardless of whether it was ## running or not, start it again. $0 stop $0 start # Remember status and be quiet rc_status ;; force-reload) ## Signal the daemon to reload its config. Most daemons ## do this on signal 1 (SIGHUP). ## If it does not support it, restart the service if it ## is running. echo -n "Reload service ${BOINC_SVC} " ## if it supports it: #/sbin/killproc -HUP $BOINC_BIN #touch /var/run/$BOINC_PIDFILE # Remember status and be verbose #rc_status -v ## Otherwise: $0 try-restart # Remember status and be quiet rc_status ;; reload) ## Like force-reload, but if daemon does not support ## signaling, do nothing (!) # If it supports signaling: echo -n "Reload service ${BOINC_SVC} " #/sbin/killproc -HUP $BOINC_BIN #touch /var/run/FOO.pid # Remember status and be verbose #rc_status -v ## Otherwise if it does not support reload: rc_failed 3 # Remember status and be verbose rc_status -v ;; status) echo -n "Checking for service ${BOINC_SVC} " ## Check status with checkproc(8), if process is running ## checkproc will return with exit status 0. # Return value is slightly different for the status command: # 0 - service up and running # 1 - service dead, but /var/run/ pid file exists # 2 - service dead, but /var/lock/ lock file exists # 3 - service not running (unused) # 4 - service status unknown :-( # 5--199 reserved (5--99 LSB, 100--149 distro, 150--199 appl.) # NOTE: checkproc returns LSB compliant status values. /sbin/checkproc $BOINC_BIN # NOTE: rc_status knows that we called this init script with # "status" option and adapts its messages accordingly. rc_status -v ;; *) echo "Usage: $0 {start|stop|status|try-restart|restart|force-reload|reload}" exit 1 ;; esac rc_exit ++++++ boinc-client.service ++++++ --- /var/tmp/diff_new_pack.rnLSgW/_old 2017-03-02 19:35:33.450732891 +0100 +++ /var/tmp/diff_new_pack.rnLSgW/_new 2017-03-02 19:35:33.450732891 +0100 @@ -3,17 +3,19 @@ After=network.target [Service] +EnvironmentFile=-/etc/sysconfig/boinc-client Nice=10 User=boinc CPUSchedulingPolicy=batch Slice=background.slice PermissionsStartOnly=yes -ExecStartPre=/bin/sleep 1 -ExecStartPre=/usr/bin/touch /var/log/boinc.log /var/log/boincerr.log -ExecStartPre=/usr/bin/chown boinc:boinc /var/log/boinc.log /var/log/boincerr.log -ExecStart=/usr/bin/boinc --dir /var/lib/boinc +### boinc logs (with --redirectio) to stdoutdae.txt and stderrdae.txt +#ExecStartPre=/bin/sleep 1 +#ExecStartPre=/usr/bin/touch /var/log/boinc-client.log /var/log/boinc-client.err.log +#ExecStartPre=/usr/bin/chown $BOINC_BOINC_USR:$BOINC_BOINC_GRP /var/log/boinc-client.log /var/log/boinc-client.err.log +ExecStart=/usr/bin/boinc --dir $BOINC_BOINC_DIR $BOINC_BOINC_OPTS ExecReload=/usr/bin/boinccmd --read_cc_config -ExecStopPost=/bin/rm -f /var/lib/boinc/lockfile +ExecStopPost=/bin/rm -f $BOINC_BOINC_DIR/lockfile [Install] WantedBy=multi-user.target ++++++ sysconfig.boinc-client ++++++ --- /var/tmp/diff_new_pack.rnLSgW/_old 2017-03-02 19:35:33.510724401 +0100 +++ /var/tmp/diff_new_pack.rnLSgW/_new 2017-03-02 19:35:33.510724401 +0100 @@ -1,4 +1,3 @@ - ## Path: Productivity/Clustering/Computing ## Description: define BOINC user ## Type: string @@ -25,9 +24,9 @@ ## Default: "/var/lib/boinc" ## Config: BOINC ## -## An empty setting will point to /var/lib/boinc +## An empty setting will point to /var/lib/boinc (SysVinit) ## -BOINC_BOINC_DIR="" +BOINC_BOINC_DIR="/var/lib/boinc" ## Path: Productivity/Clustering/Computing ## Description: define BOINC options @@ -38,15 +37,30 @@ ## --allow_remote_gui_rpc ## allow boinc manager connections from remote machines ## -## --daemon -## turn off all logging +## --check_all_logins +## for idle detection, check remote logins too +## run only when no logins from anywhere are active +## +## --gui_rpc_port <port> +## port for GUI RPCs ## -## --redirectio -## redirect logging to the files stderrdae.txt and stdoutdae.txt -## in BOINCDIR rather than LOGFILE and ERRORLOG +## --gui_rpc_unix_domain +## use Unix domain for GUI RPCs ## -## --check_all_logins -## run only when no logins from anywhere are active +## --no_gpus +## don't check for GPUs +## +## --redirectio +## redirect stdout and stderr to log files +## +## --no_gui_rpc +## don't allow GUI RPC, don't make socket +## +## --run_cpu_benchmarks +## run the CPU benchmarks +## +## --skip_cpu_benchmarks +## don't run CPU benchmarks ## # BOINC_BOINC_OPTS=""