X-Git-Url: https://git.pld-linux.org/?a=blobdiff_plain;f=nginx.spec;h=6fed3bbe5850d617e148f31465e505b4b15c9a91;hb=717159c44382c0fb8bd38b838c76139bd63e2c8f;hp=acfde4cd402deaae7ed60757b89cecf2d34476fe;hpb=362f5ab2d0b0188d8fb0e691df12addb75b4b090;p=packages%2Fnginx.git diff --git a/nginx.spec b/nginx.spec index acfde4c..6fed3bb 100644 --- a/nginx.spec +++ b/nginx.spec @@ -1,40 +1,61 @@ # TODO -# - logrotate script -# - more bconds (??) -# - subpackage with error pages +# - /etc/sysconfig/nginx file +# - missing perl build/install requires +# - nginx should have own group (and work with it) or use http group ? +# # Conditional build for nginx: -%bcond_with stub_status # stats module -%bcond_with rtsig -%bcond_with select -%bcond_with poll -%bcond_with ssl # ssl support -%bcond_with imap # imap proxy -%bcond_without http_browser # parse header "User-agent" +%bcond_without light # don't build light version +%bcond_without mail # don't build imap/mail proxy +%bcond_without perl # don't build with perl module +%bcond_without addition # adds module +%bcond_without dav # WebDAV +%bcond_without flv # FLV stream +%bcond_without ipv6 # build without ipv6 support +%bcond_without sub # ngx_http_sub_module +%bcond_without poll # poll +%bcond_without realip # real ip (behind proxy) +%bcond_without rtsig # rtsig +%bcond_without select # select +%bcond_without status # stats module +%bcond_without ssl # ssl support +%bcond_with http_browser # header "User-agent" parser # Summary: High perfomance HTTP and reverse proxy server Summary(pl.UTF-8): Serwer HTTP i odwrotne proxy o wysokiej wydajności Name: nginx -Version: 0.5.31 +Version: 1.2.4 Release: 0.1 License: BSD-like -Group: Networking/Daemons -Source0: http://sysoev.ru/nginx/%{name}-%{version}.tar.gz -# Source0-md5: d84ef8e624b8953faf9cee2b5da535c1 -Source1: %{name}.init -Source2: %{name}-mime.types.sh -Source3: http://www.nginx.eu/favicon.ico -# Source3-md5: 2aaf2115c752cbdbfb8a2f0b3c3189ab -Source4: http://www.nginx.eu/download/proxy.conf -# Source4-md5: f5263ae01c2edb18f46d5d1df2d3a5cd -Source5: http://www.nginx.eu/download/nginx.monitrc -# Source5-md5: 1d3f5eedfd34fe95213f9e0fc19daa88 -Source6: http://www.nginx.eu/download/nginx.conf -# Source6-md5: 1c112d6f03d0f365e4acc98c1d96261a -Patch0: %{name}-config.patch +Group: Networking/Daemons/HTTP +Source0: http://nginx.org/download/%{name}-%{version}.tar.gz +# Source0-md5: a7c9a515f632c8cbb07ab67392208088 +Source1: http://nginx.net/favicon.ico +# Source1-md5: 2aaf2115c752cbdbfb8a2f0b3c3189ab +Source2: proxy.conf +Source3: %{name}.logrotate +Source4: %{name}.mime +Source5: %{name}-light.conf +Source6: %{name}-light.monitrc +Source7: %{name}-light.init +Source8: %{name}-mail.conf +Source9: %{name}-mail.monitrc +Source10: %{name}-mail.init +Source11: %{name}-perl.conf +Source12: %{name}-perl.monitrc +Source13: %{name}-perl.init +Source14: %{name}-standard.conf +Source15: %{name}-standard.monitrc +Source16: %{name}-standard.init +Source17: %{name}-mime.types.sh +Patch0: nginx-no-Werror.patch URL: http://nginx.net/ BuildRequires: mailcap BuildRequires: openssl-devel BuildRequires: pcre-devel +%{?with_perl:BuildRequires: perl-CGI} +%{?with_perl:BuildRequires: perl-devel} +%{?with_perl:BuildRequires: python} +%{?with_perl:BuildRequires: rpm-perlprov} BuildRequires: rpmbuild(macros) >= 1.268 BuildRequires: zlib-devel Requires(post,preun): /sbin/chkconfig @@ -44,69 +65,344 @@ Requires(pre): /bin/id Requires(pre): /usr/bin/getgid Requires(pre): /usr/sbin/groupadd Requires(pre): /usr/sbin/useradd -Requires: rc-scripts +#Requires: nginx-daemon +Requires: openssl +Requires: pcre +Requires: rc-scripts >= 0.2.0 +Requires: zlib +Suggests: nginx-standard +Provides: group(http) +Provides: group(nginx) +Provides: user(nginx) +Provides: webserver +Conflicts: logrotate < 3.8.0 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _sysconfdir /etc/%{name} %define _nginxdir /home/services/%{name} %description -High perfomance HTTP and reverse proxy server. +nginx ("engine x") is a high-performance HTTP server and reverse +proxy, as well as an IMAP/POP3 proxy server. nginx was written by Igor +Sysoev for Rambler.ru, Russia's second-most visited website, where it +has been running in production for over two and a half years. Igor has +released the source code under a BSD-like license. Although still in +beta, nginx is known for its stability, rich feature set, simple +configuration, and low resource consumption. + +Common files for nginx daemon. %description -l pl.UTF-8 -Serwer HTTP i odwrotne proxy o wysokiej wydajności. +nginx ("engine x") jest wysokowydajnym serwerem HTTP, odwrotnym proxy +a także IMAP/POP3 proxy. nginx został napisany przez Igora Sysoeva +na potrzeby serwisu Rambler.ru. Jest to drugi pod względem ilości +odwiedzin serwis w Rosji i działa od ponad dwóch i pół roku. Igor +opublikował źródła na licencji BSD. Mimo, że projekt jest ciągle +w fazie beta, już zasłynął dzięki stabilności, bogactwu dodatków, +prostej konfiguracji oraz małej "zasobożerności". + +Niezbędne pliki dla nginx. + +%package light +Summary: High perfomance HTTP and reverse proxy server +Summary(pl.UTF-8): Serwer HTTP i odwrotne proxy o wysokiej wydajności +Group: Networking/Daemons/HTTP +Requires(post,preun): /sbin/chkconfig +Requires(postun): /usr/sbin/groupdel +Requires(postun): /usr/sbin/userdel +Requires: %{name} = %{version}-%{release} +Requires: openssl +Requires: pcre +Requires: zlib +Provides: group(http) +Provides: group(nginx) +Provides: nginx-daemon +Provides: user(nginx) +Provides: webserver + +%description light +The smallest, but also the fastest nginx edition. No additional +modules, no Perl, no DAV, no FLV, no IMAP, POP3, SMTP proxy. + +%description light -l pl.UTF-8 +Najmniejsza i najszybsza wersja nginx. Bez wsparcia dla Perla, DAV, +FLV oraz IMAP, POP3, SMTP proxy. + +%package perl +Summary: High perfomance HTTP and reverse proxy server +Summary(pl.UTF-8): Serwer HTTP i odwrotne proxy o wysokiej wydajności +Group: Networking/Daemons/HTTP +Requires(post,preun): /sbin/chkconfig +Requires(postun): /usr/sbin/groupdel +Requires(postun): /usr/sbin/userdel +Requires: %{name} = %{version}-%{release} +Requires: openssl +Provides: group(http) +Provides: group(nginx) +Provides: nginx-daemon +Provides: user(nginx) +Provides: webserver + +%description perl +nginx with Perl support. Mail modules not included. + +%description perl -l pl.UTF-8 +nginx z obsługą Perla. Bez wsparcia dla modułów poczty. + +%package mail +Summary: High perfomance IMAP, POP3, SMTP proxy server +Summary(pl.UTF-8): IMAP, POP3, SMTP proxy o wysokiej wydajności +Group: Networking/Daemons/HTTP +Requires(post,preun): /sbin/chkconfig +Requires(postun): /usr/sbin/groupdel +Requires(postun): /usr/sbin/userdel +Requires: %{name} = %{version}-%{release} +Requires: openssl +Requires: pcre +Requires: zlib +Provides: group(http) +Provides: group(nginx) +Provides: nginx-daemon +Provides: user(nginx) +Provides: webserver + +%description mail +nginx with mail support. Only mail modules included. + +%description mail -l pl.UTF-8 +nginx ze wsparciem tylko dla modułów poczty. + +%package standard +Summary: High perfomance HTTP and reverse proxy server +Summary(pl.UTF-8): Serwer HTTP i odwrotne proxy o wysokiej wydajności +Group: Networking/Daemons/HTTP +Requires(post,preun): /sbin/chkconfig +Requires(postun): /usr/sbin/groupdel +Requires(postun): /usr/sbin/userdel +Requires: %{name} = %{version}-%{release} +Requires: openssl +Provides: group(http) +Provides: group(nginx) +Provides: nginx-daemon +Conflicts: logrotate < 3.7-4 + +%description standard +This is standard nginx version, without Perl support and IMAP, POP3, +SMTP proxy. + +%description standard -l pl.UTF-8 +To jest standardowa wersja nginx, bez obsługi Perla oraz proxy dla +IMAP, POP3, SMTP. + +%package -n monit-rc-nginx +Summary: nginx support for monit +Summary(pl.UTF-8): Wsparcie nginx dla monit +Group: Applications/System +URL: http://nginx.eu/ +Requires: %{name} = %{version}-%{release} +Requires: monit + +%description -n monit-rc-nginx +monitrc file for monitoring nginx webserver. + +%description -n monit-rc-nginx -l pl.UTF-8 +Plik monitrc do monitorowania serwera WWW nginx. %prep %setup -q %patch0 -p0 # build mime.types.conf -sh %{SOURCE2} /etc/mime.types +#sh %{SOURCE17} /etc/mime.types %build # NB: not autoconf generated configure +cp -f configure auto/ +# +%if %{with perl} ./configure \ --prefix=%{_prefix} \ - --sbin-path=%{_sbindir}/%{name} \ - --conf-path=%{_sysconfdir}/%{name}.conf \ - --error-log-path=%{_localstatedir}/log/%{name}/error.log \ - --pid-path=%{_localstatedir}/run/%{name}.pid \ + --sbin-path=%{_sbindir}/%{name}-perl \ + --conf-path=%{_sysconfdir}/%{name}-perl.conf \ + --error-log-path=%{_localstatedir}/log/%{name}/%{name}-perl_error.log \ + --http-log-path=%{_localstatedir}/log/%{name}/%{name}-perl_access.log \ + --pid-path=%{_localstatedir}/run/%{name}-perl.pid \ + --lock-path=%{_localstatedir}/lock/subsys/%{name}-perl \ --user=nginx \ --group=nginx \ - %{?with_stub_status:--with-http_stub_status_module} \ + --with-http_perl_module \ + --without-mail_pop3_module \ + --without-mail_imap_module \ + --without-mail_smtp_module \ + %{?with_addition:--with-http_addition_module} \ + %{?with_dav:--with-http_dav_module} \ + %{?with_flv:--with-http_flv_module} \ + %{?with_ipv6:--with-ipv6} \ + %{?with_sub:--with-http_sub_module} \ + %{?with_poll:--with-poll_module} \ + %{?with_realip:--with-http_realip_module} \ %{?with_rtsig:--with-rtsig_module} \ %{?with_select:--with-select_module} \ + %{?with_status:--with-http_stub_status_module} \ + %{?with_ssl:--with-http_ssl_module} \ + %{!?with_http_browser:--without-http_browser_module} \ + --http-client-body-temp-path=%{_localstatedir}/cache/%{name}-perl/client_body_temp \ + --http-proxy-temp-path=%{_localstatedir}/cache/%{name}-perl/proxy_temp \ + --http-fastcgi-temp-path=%{_localstatedir}/cache/%{name}-perl/fastcgi_temp \ + --with-cc="%{__cc}" \ + --with-cc-opt="%{rpmcflags}" \ + --with-ld-opt="%{rpmldflags}" +%{__make} +mv -f objs/nginx contrib/nginx-perl +mv -f objs/src/http/modules/perl/blib/arch/auto/nginx/nginx.bs contrib/nginx.bs +mv -f objs/src/http/modules/perl/blib/arch/auto/nginx/nginx.so contrib/nginx.so +mv -f objs/src/http/modules/perl/nginx.pm contrib/nginx.pm +%endif + +%if %{with mail} +./configure \ + --prefix=%{_prefix} \ + --sbin-path=%{_sbindir}/%{name}-mail \ + --conf-path=%{_sysconfdir}/%{name}-mail.conf \ + --error-log-path=%{_localstatedir}/log/%{name}/%{name}-mail_error.log \ + --http-log-path=%{_localstatedir}/log/%{name}/%{name}-mail_access.log \ + --pid-path=%{_localstatedir}/run/%{name}-mail.pid \ + --lock-path=%{_localstatedir}/lock/subsys/%{name}-mail \ + --user=nginx \ + --group=nginx \ + --with-imap \ + --with-mail \ + --with-mail_ssl_module \ + --without-http \ + %{?with_ipv6:--with-ipv6} \ + %{?with_poll:--with-poll_module} \ + %{?with_rtsig:--with-rtsig_module} \ + %{?with_select:--with-select_module} \ + --http-client-body-temp-path=%{_localstatedir}/cache/%{name}-mail/client_body_temp \ + --http-proxy-temp-path=%{_localstatedir}/cache/%{name}-mail/proxy_temp \ + --http-fastcgi-temp-path=%{_localstatedir}/cache/%{name}-mail/fastcgi_temp \ + --with-cc="%{__cc}" \ + --with-cc-opt="%{rpmcflags}" \ + --with-ld-opt="%{rpmldflags}" \ + %{?debug:--with-debug} +%{__make} +mv -f objs/nginx contrib/nginx-mail +%endif + +%if %{with light} +./configure \ + --prefix=%{_prefix} \ + --sbin-path=%{_sbindir}/%{name}-light \ + --conf-path=%{_sysconfdir}/%{name}-light.conf \ + --error-log-path=%{_localstatedir}/log/%{name}/%{name}-light_error.log \ + --http-log-path=%{_localstatedir}/log/%{name}/%{name}-light_access.log \ + --pid-path=%{_localstatedir}/run/%{name}-light.pid \ + --lock-path=%{_localstatedir}/lock/subsys/%{name}-light \ + --user=nginx \ + --group=nginx \ + %{?with_ipv6:--with-ipv6} \ %{?with_poll:--with-poll_module} \ + %{?with_realip:--with-http_realip_module} \ + %{?with_rtsig:--with-rtsig_module} \ + %{?with_select:--with-select_module} \ + %{?with_status:--with-http_stub_status_module} \ %{?with_ssl:--with-http_ssl_module} \ - %{?with_imap:--with-imap} \ - %{?with_http_browser:--without-http_browser_module} \ - --http-log-path=%{_localstatedir}/log/%{name}/access.log \ - --http-client-body-temp-path=%{_localstatedir}/cache/%{name}/client_body_temp \ - --http-proxy-temp-path=%{_localstatedir}/cache/%{name}/proxy_temp \ - --http-fastcgi-temp-path=%{_localstatedir}/cache/%{name}/fastcgi_temp \ + --without-http_browser_module \ + --without-mail_pop3_module \ + --without-mail_imap_module \ + --without-mail_smtp_module \ + --http-client-body-temp-path=%{_localstatedir}/cache/%{name}-light/client_body_temp \ + --http-proxy-temp-path=%{_localstatedir}/cache/%{name}-light/proxy_temp \ + --http-fastcgi-temp-path=%{_localstatedir}/cache/%{name}-light/fastcgi_temp \ --with-cc="%{__cc}" \ --with-cc-opt="%{rpmcflags}" \ --with-ld-opt="%{rpmldflags}" \ %{?debug:--with-debug} +%{__make} +mv -f objs/nginx contrib/nginx-light +%endif +./configure \ + --prefix=%{_prefix} \ + --sbin-path=%{_sbindir}/%{name}-standard \ + --conf-path=%{_sysconfdir}/%{name}-standard.conf \ + --error-log-path=%{_localstatedir}/log/%{name}/%{name}-standard_error.log \ + --http-log-path=%{_localstatedir}/log/%{name}/%{name}-standard_access.log \ + --pid-path=%{_localstatedir}/run/%{name}-standard.pid \ + --lock-path=%{_localstatedir}/lock/subsys/%{name}-standard \ + --user=nginx \ + --group=nginx \ + %{?with_addition:--with-http_addition_module} \ + %{?with_dav:--with-http_dav_module} \ + %{?with_flv:--with-http_flv_module} \ + %{?with_ipv6:--with-ipv6} \ + %{?with_sub:--with-http_sub_module} \ + %{?with_poll:--with-poll_module} \ + %{?with_realip:--with-http_realip_module} \ + %{?with_rtsig:--with-rtsig_module} \ + %{?with_select:--with-select_module} \ + %{?with_status:--with-http_stub_status_module} \ + %{?with_ssl:--with-http_ssl_module} \ + %{!?with_http_browser:--without-http_browser_module} \ + --http-client-body-temp-path=%{_localstatedir}/cache/%{name}-standard/client_body_temp \ + --http-proxy-temp-path=%{_localstatedir}/cache/%{name}-standard/proxy_temp \ + --http-fastcgi-temp-path=%{_localstatedir}/cache/%{name}-standard/fastcgi_temp \ + --with-cc="%{__cc}" \ + --with-cc-opt="%{rpmcflags}" \ + --with-ld-opt="%{rpmldflags}" \ + %{?debug:--with-debug} %{__make} + %install rm -rf $RPM_BUILD_ROOT install -d $RPM_BUILD_ROOT/etc/rc.d/init.d \ $RPM_BUILD_ROOT%{_nginxdir}/{cgi-bin,html,errors} \ - $RPM_BUILD_ROOT{%{_localstatedir}/log/{%{name},archive/%{name}},%{_localstatedir}/cache/%{name}} \ - $RPM_BUILD_ROOT{%{_sbindir},%{_sysconfdir}} + $RPM_BUILD_ROOT%{_localstatedir}/log/{%{name},archive/%{name}} \ + $RPM_BUILD_ROOT%{_localstatedir}/cache/{%{name}-standard,%{name}-perl,%{name}-mail,%{name}-light} \ + $RPM_BUILD_ROOT%{_localstatedir}/lock/subsys/{%{name}-standard,%{name}-perl,%{name}-mail,%{name}-light} \ + $RPM_BUILD_ROOT{%{_sbindir},%{_sysconfdir}} \ + $RPM_BUILD_ROOT/etc/{logrotate.d,monit} + +install conf/fastcgi_params $RPM_BUILD_ROOT%{_sysconfdir}/fastcgi.params +install conf/koi-utf $RPM_BUILD_ROOT%{_sysconfdir}/koi-utf +install conf/koi-win $RPM_BUILD_ROOT%{_sysconfdir}/koi-win +install conf/win-utf $RPM_BUILD_ROOT%{_sysconfdir}/win-utf +install html/index.html $RPM_BUILD_ROOT%{_nginxdir}/html +install html/50x.html $RPM_BUILD_ROOT%{_nginxdir}/errors +install %{SOURCE1} $RPM_BUILD_ROOT%{_nginxdir}/html/favicon.ico +install %{SOURCE2} $RPM_BUILD_ROOT%{_sysconfdir}/proxy.conf +install %{SOURCE3} $RPM_BUILD_ROOT/etc/logrotate.d/%{name} +install %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/mime.types +install %{SOURCE14} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}-standard.conf +install %{SOURCE15} $RPM_BUILD_ROOT/etc/monit/%{name}-standard.monitrc +install %{SOURCE16} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name}-standard +install objs/%{name} $RPM_BUILD_ROOT%{_sbindir}/%{name}-standard + +%if %{with light} +install %{SOURCE5} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}-light.conf +install %{SOURCE6} $RPM_BUILD_ROOT/etc/monit/%{name}-light.monitrc +install %{SOURCE7} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name}-light +install contrib/nginx-light $RPM_BUILD_ROOT%{_sbindir}/%{name}-light +%endif -install conf/* $RPM_BUILD_ROOT%{_sysconfdir} -install mime.types $RPM_BUILD_ROOT%{_sysconfdir}/mime.types -install %{SOURCE1} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name} -install %{SOURCE3} $RPM_BUILD_ROOT%{_nginxdir}/html/favicon.ico -install %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/proxy.conf -install %{SOURCE5} $RPM_BUILD_ROOT%{_sysconfdir}/nginx.monitrc -install %{SOURCE6} $RPM_BUILD_ROOT%{_sysconfdir}/nginx.conf +%if %{with mail} +install %{SOURCE8} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}-mail.conf +install %{SOURCE9} $RPM_BUILD_ROOT/etc/monit/%{name}-mail.monitrc +install %{SOURCE10} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name}-mail +install contrib/nginx-mail $RPM_BUILD_ROOT%{_sbindir}/%{name}-mail +%endif -install objs/%{name} $RPM_BUILD_ROOT%{_sbindir}/%{name} +%if %{with perl} +install -d $RPM_BUILD_ROOT{%{perl_vendorarch},%{perl_vendorarch}/auto/%{name}} +install %{SOURCE11} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}-perl.conf +install %{SOURCE12} $RPM_BUILD_ROOT/etc/monit/%{name}-perl.monitrc +install %{SOURCE13} $RPM_BUILD_ROOT/etc/rc.d/init.d/%{name}-perl +install contrib/nginx.pm $RPM_BUILD_ROOT%{perl_vendorarch}/%{name}.pm +install contrib/nginx.so $RPM_BUILD_ROOT%{perl_vendorarch}/auto/%{name}/%{name}.so +install contrib/nginx.bs $RPM_BUILD_ROOT%{perl_vendorarch}/auto/%{name}/%{name}.bs +install contrib/nginx-perl $RPM_BUILD_ROOT%{_sbindir}/%{name}-perl +%endif rm -f $RPM_BUILD_ROOT%{_sysconfdir}/*.default rm -rf $RPM_BUILD_ROOT%{_prefix}/html @@ -120,21 +416,80 @@ rm -rf $RPM_BUILD_ROOT %useradd -r -u 213 -d /usr/share/empty -s /bin/false -c "Nginx HTTP User" -g %{name} %{name} %addusertogroup %{name} http -%post +%post standard +for a in access.log error.log; do + if [ ! -f /var/log/%{name}/nginx-standard_$a ]; then + umask 022 + touch /var/log/%{name}/nginx-standard_$a + chown nginx:nginx /var/log/%{name}/nginx-standard_$a + chmod 644 /var/log/%{name}/nginx-standard_$a + fi +done +/sbin/chkconfig --add %{name}-standard +%service %{name}-standard restart +echo 'NOTE: daemon is now using "/etc/nginx/nginx-standard.conf" as config.' + +%post light +for a in access.log error.log; do + if [ ! -f /var/log/%{name}/nginx-light_$a ]; then + umask 022 + touch /var/log/%{name}/nginx-light_$a + chown nginx:nginx /var/log/%{name}/nginx-light_$a + chmod 644 /var/log/%{name}/nginx-light_$a + fi +done +/sbin/chkconfig --add %{name}-light +%service %{name}-light restart +echo 'NOTE: daemon is now using "/etc/nginx/nginx-light.conf" as config' + +%post perl +for a in access.log error.log; do + if [ ! -f /var/log/%{name}/nginx-perl_$a ]; then + umask 022 + touch /var/log/%{name}/nginx-perl_$a + chown nginx:nginx /var/log/%{name}/nginx-perl_$a + chmod 644 /var/log/%{name}/nginx-perl_$a + fi +done +/sbin/chkconfig --add %{name}-perl +%service %{name}-perl restart +echo 'NOTE: daemon is now using "/etc/nginx/nginx-perl.conf" as config' + +%post mail for a in access.log error.log; do - if [ ! -f /var/log/%{name}/$a ]; then - touch /var/log/%{name}/$a - chown nginx:nginx /var/log/%{name}/$a - chmod 644 /var/log/%{name}/$a + if [ ! -f /var/log/%{name}/nginx-mail_$a ]; then + umask 022 + touch /var/log/%{name}/nginx-mail_$a + chown nginx:nginx /var/log/%{name}/nginx-mail_$a + chmod 644 /var/log/%{name}/nginx-mail_$a fi done -/sbin/chkconfig --add %{name} -%service %{name} restart +/sbin/chkconfig --add %{name}-mail +%service %{name}-mail restart +echo 'NOTE: daemon is now using "/etc/nginx/nginx-mail.conf" as config' + +%preun standard +if [ "$1" = "0" ];then + %service %{name}-standard stop + /sbin/chkconfig --del %{name}-standard +fi + +%preun light +if [ "$1" = "0" ]; then + %service %{name}-light stop + /sbin/chkconfig --del %{name}-light +fi -%preun +%preun perl if [ "$1" = "0" ]; then - %service -q %{name} stop - /sbin/chkconfig --del %{name} + %service %{name}-perl stop + /sbin/chkconfig --del %{name}-perl +fi + +%preun mail +if [ "$1" = "0" ]; then + %service %{name}-mail stop + /sbin/chkconfig --del %{name}-mail fi %postun @@ -147,14 +502,72 @@ fi %defattr(644,root,root,755) %doc CHANGES LICENSE README html/index.html conf/nginx.conf %doc %lang(ru) CHANGES.ru -%attr(754,root,root) /etc/rc.d/init.d/%{name} %dir %attr(754,root,root) %{_sysconfdir} -%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}.conf -%attr(640,root,root) %{_sysconfdir}/*[_-]* -%attr(640,root,root) %{_sysconfdir}/proxy.conf -%attr(640,root,root) %{_sysconfdir}/nginx.monitrc +%dir %{_nginxdir} +%dir %{_nginxdir}/cgi-bin +%dir %{_nginxdir}/html +%dir %{_nginxdir}/errors +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/logrotate.d/%{name} +# XXX: duplicates, don't use such glob here +#%attr(640,root,root) %{_sysconfdir}/*[_-]* +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/proxy.conf +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/fastcgi.params %attr(640,root,root) %{_sysconfdir}/mime.types -%attr(755,root,root) %{_sbindir}/%{name} -%attr(770,root,%{name}) /var/cache/%{name} -%attr(750,%{name},logs) /var/log/%{name} -%attr(755,%{name},%{name}) %{_nginxdir}/html/favicon.ico +%attr(640,root,root) %{_sysconfdir}/koi-utf +%attr(640,root,root) %{_sysconfdir}/koi-win +%attr(640,root,root) %{_sysconfdir}/win-utf +%attr(750,nginx,logs) %dir /var/log/archive/%{name} +%attr(750,nginx,logs) /var/log/%{name} +%config(noreplace,missingok) %verify(not md5 mtime size) %{_nginxdir}/html/* +%config(noreplace,missingok) %verify(not md5 mtime size) %{_nginxdir}/errors/* + +%files standard +%defattr(644,root,root,755) +%attr(755,root,root) %{_sbindir}/%{name}-standard +%attr(770,root,%{name}) /var/cache/%{name}-standard +%attr(754,root,root) /etc/rc.d/init.d/%{name}-standard +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}-standard.conf + +%if %{with mail} +%files mail +%defattr(644,root,root,755) +%attr(755,root,root) %{_sbindir}/%{name}-mail +%attr(770,root,%{name}) /var/cache/%{name}-mail +%attr(754,root,root) /etc/rc.d/init.d/%{name}-mail +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}-mail.conf +%endif + +%if %{with light} +%files light +%defattr(644,root,root,755) +%attr(755,root,root) %{_sbindir}/%{name}-light +%attr(770,root,%{name}) /var/cache/%{name}-light +%attr(754,root,root) /etc/rc.d/init.d/%{name}-light +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}-light.conf +%endif + +%if %{with perl} +%files perl +%defattr(644,root,root,755) +%attr(755,root,root) %{_sbindir}/%{name}-perl +%attr(754,root,root) /etc/rc.d/init.d/%{name}-perl +%attr(770,root,%{name}) /var/cache/%{name}-perl +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/%{name}-perl.conf +%dir %{perl_vendorarch}/auto/%{name} +%attr(755,root,root) %{perl_vendorarch}/auto/%{name}/%{name}.so +%{perl_vendorarch}/auto/%{name}/%{name}.bs +%{perl_vendorarch}/%{name}.pm +%endif + +%files -n monit-rc-nginx +%defattr(644,root,root,755) +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/monit/%{name}-standard.monitrc +%if %{with perl} +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/monit/%{name}-perl.monitrc +%endif +%if %{with light} +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/monit/%{name}-light.monitrc +%endif +%if %{with mail} +%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) /etc/monit/%{name}-mail.monitrc +%endif