File webyast-base-ws.spec of Package webyast-base-ws
#
# spec file for package webyast-base-ws
#
# Copyright (c) 2011 SUSE LINUX Products GmbH, Nuernberg, Germany.
#
# 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 http://bugs.opensuse.org/
#
Name: webyast-base-ws
Provides: yast2-webservice = %{version}
Obsoletes: yast2-webservice < %{version}
Provides: webyast-language-ws = 0.1.0
Obsoletes: webyast-language-ws <= 0.1.0
%if 0%{?suse_version} == 0 || %suse_version > 1110
# 11.2 or newer
%if 0%{?suse_version} > 1120
# since 11.3, they are in a separate subpackage
Requires: sysvinit-tools
%else
# Require startproc respecting -p, bnc#559534#c44
Requires: sysvinit > 2.86-215.2
%endif
Requires: yast2-core >= 2.18.10
%else
# 11.1 or SLES11
Requires: yast2-core >= 2.17.30.1
Requires: sysvinit > 2.86-195.3.1
%endif
Requires: rubygem-passenger-nginx
Requires: nginx >= 1.0
Requires: ruby-fcgi, sqlite, syslog-ng
%if 0%{?suse_version} == 0 || %suse_version <= 1130
Requires: ruby-dbus
%else
Requires: rubygem-ruby-dbus
%endif
Requires: rubygem-webyast-rake-tasks, rubygem-http_accept_language
Requires: rubygem-static_record_cache
Requires: yast2-dbus-server
# 634404
Recommends: logrotate
PreReq: PolicyKit, PackageKit, rubygem-rake, rubygem-sqlite3
PreReq: rubygem-rails-2_3 >= 2.3.8
PreReq: rubygem-rpam, rubygem-polkit, rubygem-gettext_rails
PreReq: yast2-runlevel
License: LGPL-2.0
Group: Productivity/Networking/Web/Utilities
Url: http://en.opensuse.org/Portal:WebYaST
AutoReqProv: on
Version: 0.2.25
Release: 0
Summary: WebYaST - base components for rest service
Source: www.tar.bz2
Source1: webyastPermissionsService.rb
Source2: webyast.permissions.conf
Source3: webyast.permissions.service.service
Source4: org.opensuse.yast.permissions.policy
Source5: grantwebyastrights
Source6: yast_user_roles
Source9: yastws
Source10: webyast
Source11: webyast-ws.lr.conf
Source12: nginx.conf
BuildRoot: %{_tmppath}/%{name}-%{version}-build
BuildRequires: pkg-config ruby rubygem-mocha rubygem-static_record_cache
# if we run the tests during build, we need most of Requires here too,
# except for deployment specific stuff
BuildRequires: rubygem-restility rubygem-webyast-rake-tasks
BuildRequires: dbus-1 sqlite yast2-core yast2-dbus-server
%if 0%{?suse_version} == 0 || %suse_version <= 1130
BuildRequires: ruby-dbus
%else
BuildRequires: rubygem-ruby-dbus
%endif
BuildRequires: PackageKit PolicyKit rubygem-sqlite3
BuildRequires: rubygem-rails-2_3 >= 2.3.8
BuildRequires: rubygem-polkit rubygem-rpam
# the testsuite is run during build
BuildRequires: rubygem-mocha rubygem-test-unit
BuildRequires: nginx >= 1.0 rubygem-passenger-nginx
# This is for Hudson (build service) to setup the build env correctly
%if 0
BuildRequires: rubygem-test-unit
BuildRequires: rubygem-rcov >= 0.9.3.2
%endif
# we do not necessarily need any UI in case of WebYaST
Provides: yast2_ui
Provides: yast2_ui_pkg
# rpmlint warns about file duplicates, this should take care but
# doesn't build (?!)
#%if 0%{?suse_version} > 1020
#BuildRequires: fdupes
#%endif
BuildArch: noarch
%package testsuite
Group: Productivity/Networking/Web/Utilities
Requires: webyast-base-ws = %{version}
Summary: Testsuite for webyast-base-ws package
#
%define pkg_home /var/lib/%{webyast_ws_user}
#
%description
WebYaST - Core components for REST based interface to system manipulation.
Authors:
--------
Duncan Mac-Vicar Prett <dmacvicar@suse.de>
Klaus Kaempf <kkaempf@suse.de>
Bjoern Geuken <bgeuken@suse.de>
Stefan Schubert <schubi@suse.de>
%description testsuite
Testsuite for core WebYaST webservice package.
%prep
%setup -q -n www
%build
%check
# run the testsuite
RAILS_ENV=test rake db:migrate
RAILS_ENV=test $RPM_BUILD_ROOT%{webyast_ws_dir}/test/dbus-launch-simple rake test
#---------------------------------------------------------------
%install
#
# Install all web and frontend parts.
#
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/log/
cp -a * $RPM_BUILD_ROOT%{webyast_ws_dir}/
rm -f $RPM_BUILD_ROOT%{webyast_ws_dir}/log/*
rm -f $RPM_BUILD_ROOT%{webyast_ws_dir}/COPYING
touch $RPM_BUILD_ROOT%{webyast_ws_dir}/db/schema.rb
%{__install} -d -m 0755 \
%{buildroot}%{pkg_home}/sockets/ \
%{buildroot}%{pkg_home}/cache/ \
%{buildroot}%{_sbindir} \
%{buildroot}%{_var}/log/%{webyast_ws_user}
#
# init script
#
%{__install} -D -m 0755 %SOURCE9 \
%{buildroot}%{_sysconfdir}/init.d/%{webyast_ws_service}
%{__ln_s} -f %{_sysconfdir}/init.d/%{webyast_ws_service} %{buildroot}%{_sbindir}/rc%{webyast_ws_service}
#
# configure nginx web service
mkdir -p $RPM_BUILD_ROOT/etc/yastws/
install -m 0644 %SOURCE12 $RPM_BUILD_ROOT/etc/yastws/
# create symlinks to nginx config files
ln -s /etc/nginx/fastcgi.conf $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/fastcgi_params $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/koi-utf $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/koi-win $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/mime.types $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/scgi_params $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/uwsgi_params $RPM_BUILD_ROOT/etc/yastws
ln -s /etc/nginx/win-utf $RPM_BUILD_ROOT/etc/yastws
# Policies
mkdir -p $RPM_BUILD_ROOT/usr/share/PolicyKit/policy
install -m 0644 %SOURCE4 $RPM_BUILD_ROOT/usr/share/PolicyKit/policy/
install -m 0644 %SOURCE6 $RPM_BUILD_ROOT/etc/
install -m 0555 %SOURCE5 $RPM_BUILD_ROOT/usr/sbin/
# firewall service definition, bnc#545627
mkdir -p $RPM_BUILD_ROOT/etc/sysconfig/SuSEfirewall2.d/services
install -m 0644 %SOURCE10 $RPM_BUILD_ROOT/etc/sysconfig/SuSEfirewall2.d/services
# logrotate configuration bnc#634404
mkdir $RPM_BUILD_ROOT/etc/logrotate.d
install -m 0644 %SOURCE11 $RPM_BUILD_ROOT/etc/logrotate.d
# create yastwsdirs (config, var and data)
mkdir -p $RPM_BUILD_ROOT/etc/webyast
mkdir -p $RPM_BUILD_ROOT/var/lib/yastws
mkdir -p $RPM_BUILD_ROOT/usr/share/yastws
# create empty tmp directory
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/tmp
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/tmp/cache
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/tmp/pids
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/tmp/sessions
mkdir -p $RPM_BUILD_ROOT%{webyast_ws_dir}/tmp/sockets
# install permissions service
mkdir -p $RPM_BUILD_ROOT/usr/sbin/
install -m 0500 %SOURCE1 $RPM_BUILD_ROOT/usr/sbin/
mkdir -p $RPM_BUILD_ROOT/etc/dbus-1/system.d/
install -m 0644 %SOURCE2 $RPM_BUILD_ROOT/etc/dbus-1/system.d/
mkdir -p $RPM_BUILD_ROOT/usr/share/dbus-1/system-services/
install -m 0444 %SOURCE3 $RPM_BUILD_ROOT/usr/share/dbus-1/system-services/
#create dummy update-script
mkdir -p %buildroot/var/adm/update-scripts
touch %buildroot/var/adm/update-scripts/%name-%version-%release-1
#---------------------------------------------------------------
%clean
rm -rf $RPM_BUILD_ROOT
#---------------------------------------------------------------
%pre
#
# e.g. adding user
#
/usr/sbin/groupadd -r %{webyast_ws_user} &>/dev/null ||:
/usr/sbin/useradd -g %{webyast_ws_user} -s /bin/false -r -c "User for YaST-Webservice" -d %{pkg_home} %{webyast_ws_user} &>/dev/null ||:
# services will not be restarted correctly if
# the package name will changed while the update
# So the service will be restarted by an update-script
# which will be called AFTER the installation
if /bin/rpm -q yast2-webservice > /dev/null ; then
echo "renaming yast2-webservice to webyast-base-ws"
if /sbin/yast runlevel summary service=yastws 2>&1|grep " 3 "|grep yastws >/dev/null ; then
echo "yastws is inserted into the runlevel"
echo "#!/bin/sh" > %name-%version-%release-1
echo "/sbin/yast runlevel add service=yastws" >> %name-%version-%release-1
echo "/usr/sbin/rcyastws restart" >> %name-%version-%release-1
else
if /usr/sbin/rcyastws status > /dev/null ; then
echo "yastws is running"
echo "#!/bin/sh" > %name-%version-%release-1
echo "/usr/sbin/rcyastws restart" >> %name-%version-%release-1
fi
fi
fi
#We are switching from lighttpd to nginx. So lighttpd has to be killed
#at first
if rpm -q --requires %{name}|grep lighttpd > /dev/null ; then
if /usr/sbin/rcyastws status > /dev/null ; then
echo "yastws is running under lighttpd -> switching to nginx"
/usr/sbin/rcyastws stop > /dev/null
echo "#!/bin/sh" > %name-%version-%release-1
echo "/usr/sbin/rcyastws restart" >> %name-%version-%release-1
fi
fi
if [ -f %name-%version-%release-1 ] ; then
install -D -m 755 %name-%version-%release-1 /var/adm/update-scripts
rm %name-%version-%release-1
echo "Please check the service runlevels and restart WebYaST service with \"rcyastws restart\" if the update has not been called with zypper,yast or packagekit"
fi
exit 0
#---------------------------------------------------------------
%post
%fillup_and_insserv %{webyast_ws_service}
#
#granting permissions for yastws
#
if [ `/usr/bin/polkit-auth --user %{webyast_ws_user} | grep -c "org.freedesktop.packagekit.system-update"` -eq 0 ]; then
# FIXME: remove ||: (don't hide errors), has to be correctly implemented for package update...
/usr/bin/polkit-auth --user %{webyast_ws_user} --grant org.freedesktop.packagekit.system-update > /dev/null ||:
fi
if [ `/usr/bin/polkit-auth --user %{webyast_ws_user} | grep -c "org.freedesktop.policykit.read"` -eq 0 ]; then
# FIXME: remove ||: (don't hide errors), has to be correctly implemented for package update...
/usr/bin/polkit-auth --user %{webyast_ws_user} --grant org.freedesktop.policykit.read > /dev/null ||:
fi
if [ `/usr/bin/polkit-auth --user %{webyast_ws_user} | grep -c "org.opensuse.yast.module-manager.import"` -eq 0 ]; then
# FIXME: remove ||: (don't hide errors), has to be correctly implemented for package update...
/usr/bin/polkit-auth --user %{webyast_ws_user} --grant org.opensuse.yast.module-manager.import > /dev/null ||:
fi
#
# granting all permissions for root
#
/usr/sbin/grantwebyastrights --user root --action grant > /dev/null ||:
#
# create database
#
cd %{webyast_ws_dir}
#migrate database
RAILS_ENV=production rake db:migrate
chown -R %{webyast_ws_user}: db
chown -R %{webyast_ws_user}: log
echo "Database is ready"
#
# patching nginx configuration
#
if [ -d /usr/lib64 ]; then
sed -i "s/passenger_root \/usr\/lib/passenger_root \/usr\/lib64/" /etc/yastws/nginx.conf
fi
#
# try-reload D-Bus config (bnc#635826)
#
dbus-send --print-reply --system --dest=org.freedesktop.DBus / org.freedesktop.DBus.ReloadConfig >/dev/null ||:
#---------------------------------------------------------------
%preun
%stop_on_removal %{webyast_ws_service}
#---------------------------------------------------------------
%postun
%restart_on_update %{webyast_ws_service}
%{insserv_cleanup}
#---------------------------------------------------------------
# restart yastws on nginx update (bnc#559534)
%triggerin -- nginx
%restart_on_update %{webyast_ws_service}
#---------------------------------------------------------------
%files
%defattr(-,root,root)
#this /etc/yastws is for ligght conf for yastws
%dir /etc/yastws
%dir %{webyast_ws_dir}
%dir %{_datadir}/PolicyKit
%dir %{_datadir}/PolicyKit/policy
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %dir %{pkg_home}
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %dir %{pkg_home}/sockets
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %dir %{pkg_home}/cache
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %dir %{_var}/log/%{webyast_ws_user}
#logrotate configuration file
%config(noreplace) /etc/logrotate.d/webyast-ws.lr.conf
#this /etc/webyast is for webyast configuration files
%dir /etc/webyast/
%dir %{_datadir}/yastws
%dir %attr(-,%{webyast_ws_user},root) /var/lib/yastws
%dir %{webyast_ws_dir}/db
%{webyast_ws_dir}/app
%{webyast_ws_dir}/db/migrate
%ghost %{webyast_ws_dir}/db/schema.rb
%{webyast_ws_dir}/doc
%{webyast_ws_dir}/lib
%{webyast_ws_dir}/public
%{webyast_ws_dir}/Rakefile
%{webyast_ws_dir}/script
%{webyast_ws_dir}/vendor
%dir %{webyast_ws_dir}/config
%{webyast_ws_dir}/config/boot.rb
%{webyast_ws_dir}/config/database.yml
%{webyast_ws_dir}/config/environments
%{webyast_ws_dir}/config/initializers
%{webyast_ws_dir}/config/routes.rb
#also users can run granting script, as permissions is handled by policyKit right for granting permissions
%attr(555,root,root) /usr/sbin/grantwebyastrights
%attr(755,root,root) %{webyast_ws_dir}/start.sh
%attr(500,root,root) /usr/sbin/webyastPermissionsService.rb
%attr(444,root,root) /usr/share/dbus-1/system-services/webyast.permissions.service.service
%attr(644,root,root) %config /etc/dbus-1/system.d/webyast.permissions.conf
%doc %{webyast_ws_dir}/README
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %{webyast_ws_dir}/log
%attr(-,%{webyast_ws_user},%{webyast_ws_user}) %{webyast_ws_dir}/tmp
#nginx stuff
%config(noreplace) /etc/yastws/nginx.conf
%config /etc/yastws/fastcgi.conf
%config /etc/yastws/fastcgi_params
%config /etc/yastws/koi-utf
%config /etc/yastws/koi-win
%config /etc/yastws/mime.types
%config /etc/yastws/scgi_params
%config /etc/yastws/uwsgi_params
%config /etc/yastws/win-utf
%config /etc/sysconfig/SuSEfirewall2.d/services/webyast
%config /usr/share/PolicyKit/policy/org.opensuse.yast.permissions.policy
%config %{webyast_ws_dir}/config/environment.rb
%config(noreplace) /etc/yast_user_roles
%config %{_sysconfdir}/init.d/%{webyast_ws_service}
%{_sbindir}/rc%{webyast_ws_service}
%doc COPYING
%ghost %attr(755,root,root) /var/adm/update-scripts/%name-%version-%release-1
%files testsuite
%defattr(-,root,root)
%{webyast_ws_dir}/test
#---------------------------------------------------------------
%changelog