source: projects/specs/trunk/s/squid/squid-vl.spec @ 3897

Revision 3897, 10.4 KB checked in by miyabi, 13 years ago (diff)

バージョンチェックを調整した

Line 
1%define         base_name       squid
2%define         pkg_epoch       7
3%define         pkg_version     3.1.12
4%define         pkg_release     1%{?_dist_release}
5
6Summary:        The Squid proxy caching server
7Summary(ja):    Squid ウェブプロキシキャッシュ
8Name:           %{base_name}
9Epoch:          %{pkg_epoch}
10Version:        %{pkg_version}
11Release:        %{pkg_release}
12Source0:        %{base_name}-%{version}.tar.bz2
13Source1:        FAQ.sgml
14Source2:        %{base_name}.init
15Source3:        %{base_name}.logrotate
16Source4:        %{base_name}.sysconfig
17Source5:        %{base_name}.pam
18License:        GPLv2+
19Group:          Applications/Services
20URL:            http://www.squid-cache.org
21
22Requires:       bash >= 2.0
23Requires(pre):  shadow-utils
24Requires(post): %{_syssbindir}/chkconfig
25Requires(preun): %{_syssbindir}/chkconfig
26BuildRequires:  openjade linuxdoc-tools
27BuildRequires:  openldap-devel pam-devel openssl-devel krb5-devel
28BuildRequires:  cyrus-sasl-devel
29BuildRoot:      %{_tmppath}/%{base_name}-%{version}-root
30
31Conflicts:      squid30
32Obsoletes:      squid-novm
33
34Vendor:         Project Vine
35Distribution:   Vine Linux
36Packager:       miyabi
37
38%description
39Squid is a high-performance proxy caching server for Web clients,
40supporting FTP, gopher, and HTTP data objects. Unlike traditional
41caching software, Squid handles all requests in a single,
42non-blocking, I/O-driven process. Squid keeps meta data and especially
43hot objects cached in RAM, caches DNS lookups, supports non-blocking
44DNS lookups, and implements negative caching of failed requests.
45
46Squid consists of a main server program squid, a Domain Name System
47lookup program (dnsserver), a program for retrieving FTP data
48(ftpget), and some management and client tools.
49
50%description -l ja
51Squid はウェブクライアントのための高性能のプロキシキャッシュサーバで、
52FTP, gopher, HTTP データオブジェクトに対応しています。これまでの
53キャッシュソフトウェアと違い、 Squid は全ての要求を、単一の
54ブロックしない I/O ドリブンのプロセスで処理します。 Squid はメタデータや
55ホットなオブジェクトを RAM に保持し、 DNS 問い合わせをキャッシュします。
56ブロック無しの DNS 問い合わせをサポートし、失敗した要求のネガティブ
57キャッシングが実装されています。
58
59Squid は、メインのサーバプログラム squid と、 Domain Name System
60問い合わせプログラム (dnsserver) と、 FTP データを取得するプログラム
61(ftpget) と、いくつかの管理用またはクライアントツールから成ります。
62
63%prep
64%setup -q
65
66%build
67export CXXFLAGS="-fPIE %{optflags}" ; export CFLAGS="-fPIE -Os -g -pipe -fsigned-char %{optflags}" ; export LDFLAGS="-pie" ;
68%configure \
69   --libexecdir=%{_libexecdir}/%{base_name} \
70   --sysconfdir=%{_sysconfdir}/%{base_name} \
71   --datadir=%{_datadir}/%{base_name} \
72   --disable-dependency-tracking \
73   --enable-arp-acl \
74   --enable-auth="basic,digest,ntlm,negotiate" \
75   --enable-basic-auth-helpers="LDAP,MSNT,NCSA,PAM,SMB,YP,getpwnam,multi-domain-NTLM,SASL" \
76   --enable-negotiate-auth-helpers="squid_kerb_auth" \
77   --enable-cache-digests \
78   --enable-cachemgr-hostname=localhost \
79   --enable-delay-pools \
80   --enable-digest-auth-helpers="password" \
81   --enable-epoll \
82   --enable-external-acl-helpers="ip_user,ldap_group,unix_group,wbinfo_group" \
83   --enable-icap-client \
84   --enable-ident-lookups \
85   %ifnarch ppc64 ia64 x86_64 s390x
86   --with-large-files \
87   %endif
88   --enable-linux-netfilter \
89   --enable-ntlm-auth-helpers="smb_lm,fakeauth" \
90   --enable-referer-log \
91   --enable-removal-policies="heap,lru" \
92   --enable-snmp \
93   --enable-ssl \
94   --enable-storeio="aufs,diskd,ufs" \
95   --enable-useragent-log \
96   --enable-wccpv2 \
97   --with-aio \
98   --with-default-user="%{base_name}" \
99   --with-logdir=%{_localstatedir}/log/%{base_name} \
100   --with-filedescriptors=16384 \
101   --with-dl \
102   --with-pthreads
103
104export CXXFLAGS="-fPIE" ; export CFLAGS="-fPIE -Os -g -pipe -fsigned-char" ; export LDFLAGS="-pie" ;
105%{__make} \
106    %{?_smp_mflags} \
107    DEFAULT_SWAP_DIR="%{_localstatedir}/cache/%{base_name}"
108
109mkdir faq
110cp %{SOURCE1} faq
111cd faq
112sgml2html FAQ.sgml
113
114%install
115[ "${RPM_BUILD_ROOT}" != "/" ] && %{__rm} -rf ${RPM_BUILD_ROOT}
116
117%{__make} install \
118    DESTDIR="${RPM_BUILD_ROOT}" \
119    DEFAULT_SWAP_DIR="%{_localstatedir}/cache/%{base_name}"
120
121echo "
122#
123# This is %{_sysconfdir}/httpd/conf.d/%{base_name}.conf
124#
125
126ScriptAlias /Squid/cgi-bin/cachemgr.cgi %{_libexecdir}/%{base_name}/cachemgr.cgi
127
128# Only allow access from localhost by default
129<Location /Squid/cgi-bin/cachemgr.cgi>
130 order allow,deny
131 allow from localhost.localdomain
132 # Add additional allowed hosts as needed
133 # allow from .example.com
134</Location>" > ${RPM_BUILD_ROOT}/%{base_name}.httpd.tmp
135
136mkdir -p ${RPM_BUILD_ROOT}%{_initdir}
137mkdir -p ${RPM_BUILD_ROOT}%{_sysconfdir}/logrotate.d
138mkdir -p ${RPM_BUILD_ROOT}%{_sysconfdir}/sysconfig
139mkdir -p ${RPM_BUILD_ROOT}%{_sysconfdir}/pam.d
140mkdir -p ${RPM_BUILD_ROOT}%{_sysconfdir}/httpd/conf.d/
141
142install -m 755 %{SOURCE2} ${RPM_BUILD_ROOT}%{_initdir}/%{base_name}
143install -m 644 %{SOURCE3} ${RPM_BUILD_ROOT}%{_sysconfdir}/logrotate.d/%{base_name}
144install -m 644 %{SOURCE4} ${RPM_BUILD_ROOT}%{_sysconfdir}/sysconfig/%{base_name}
145install -m 644 %{SOURCE5} ${RPM_BUILD_ROOT}%{_sysconfdir}/pam.d/%{base_name}
146install -m 644 ${RPM_BUILD_ROOT}/%{base_name}.httpd.tmp ${RPM_BUILD_ROOT}%{_sysconfdir}/httpd/conf.d/%{base_name}.conf
147mkdir -p ${RPM_BUILD_ROOT}%{_localstatedir}/log/%{base_name}
148mkdir -p ${RPM_BUILD_ROOT}%{_localstatedir}/cache/%{base_name}
149chmod 644 contrib/url-normalizer.pl contrib/rredir.* contrib/user-agents.pl
150iconv -f ISO88591 -t UTF8 ChangeLog -o ChangeLog.tmp
151mv -f ChangeLog.tmp ChangeLog
152
153# remove unpackaged files from the buildroot
154rm -f ${RPM_BUILD_ROOT}/%{base_name}.httpd.tmp
155
156%clean
157[ "${RPM_BUILD_ROOT}" != "/" ] && %{__rm} -rf ${RPM_BUILD_ROOT}
158
159%pre
160if ! getent group %{base_name} >/dev/null 2>&1; then
161  /usr/sbin/groupadd -g 23 %{base_name}
162fi
163
164if ! getent passwd %{base_name} >/dev/null 2>&1 ; then
165  /usr/sbin/useradd -g 23 -u 23 -d %{_localstatedir}/cache/%{base_name} -r -s /sbin/nologin %{base_name} >/dev/null 2>&1 || exit 1
166fi
167
168for i in %{_localstatedir}/log/%{base_name} %{_localstatedir}/cache/%{base_name} ; do
169        if [ -d $i ] ; then
170                for adir in `find $i -maxdepth 0 \! -user %{base_name}`; do
171                        chown -R %{base_name}:%{base_name} $adir
172                done
173        fi
174done
175
176exit 0
177
178%post
179if ! /sbin/chkconfig %{base_name}; then
180  /sbin/chkconfig --add %{base_name}
181fi
182
183if [ "$1" -eq "2" ]; then
184  %{_initdir}/%{base_name} condrestart
185fi
186
187%preun
188if [ "$1" -eq "0" ]; then
189  %{_initdir}/%{base_name} stop
190  rm -f %{_localstatedir}/log/%{base_name}/*
191  /sbin/chkconfig --del %{base_name}
192fi
193
194%triggerin -- samba-common
195/usr/sbin/usermod -a -G wbpriv %{base_name} >/dev/null 2>&1 || \
196    chgrp %{base_name} %{_localstatedir}/cache/samba/winbindd_privileged >/dev/null 2>&1 || :
197
198%files
199%defattr(-,root,root,-)
200
201# Directory
202%dir %{_sysconfdir}/%{base_name}/
203%dir %{_libexecdir}/%{base_name}
204%dir %{_datadir}/%{base_name}
205
206%attr(0750,%{base_name},%{base_name}) %dir %{_localstatedir}/log/%{base_name}
207%attr(0750,%{base_name},%{base_name}) %dir %{_localstatedir}/cache/%{base_name}
208
209# Program Files
210%attr(0755,root,root) %{_sbindir}/%{base_name}
211%attr(0755,root,root) %{_bindir}/squidclient
212
213%attr(0755,root,root) %{_initdir}/%{base_name}
214
215%attr(0755,root,root) %{_libexecdir}/%{base_name}/cachemgr.cgi
216%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/digest_pw_auth
217%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/diskd
218%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/fakeauth_auth
219%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/getpwname_auth
220%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/ip_user_check
221%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/msnt_auth
222%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/ncsa_auth
223%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/negotiate_kerb_auth
224%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/negotiate_kerb_auth_test
225%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/ntlm_smb_lm_auth
226%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/pam_auth
227%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/sasl_auth
228%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/smb_auth
229%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/smb_auth.pl
230%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/smb_auth.sh
231%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/squid_kerb_auth
232%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/squid_kerb_auth_test
233%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/squid_ldap_auth
234%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/squid_ldap_group
235%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/squid_unix_group
236%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/unlinkd
237%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/wbinfo_group.pl
238%attr(4750,root,%{base_name}) %{_libexecdir}/%{base_name}/yp_auth
239
240# Config Files
241%attr(0640,root,%{base_name}) %config(noreplace) %{_sysconfdir}/%{base_name}/%{base_name}.conf
242%attr(0644,root,%{base_name}) %config(noreplace) %{_sysconfdir}/%{base_name}/cachemgr.conf
243%config(noreplace) %{_sysconfdir}/%{base_name}/mime.conf
244%config(noreplace) %{_sysconfdir}/%{base_name}/msntauth.conf
245%config(noreplace) %{_sysconfdir}/%{base_name}/errorpage.css
246
247%attr(0644,root,root) %config(noreplace) %{_sysconfdir}/httpd/conf.d/%{base_name}.conf
248
249%config(noreplace) %{_sysconfdir}/sysconfig/%{base_name}
250%config(noreplace) %{_sysconfdir}/pam.d/%{base_name}
251%config(noreplace) %{_sysconfdir}/logrotate.d/%{base_name}
252
253# Sample Config Files
254%config %{_sysconfdir}/%{base_name}/%{base_name}.conf.default
255%config %{_sysconfdir}/%{base_name}/cachemgr.conf.default
256%config %{_sysconfdir}/%{base_name}/mime.conf.default
257%config %{_sysconfdir}/%{base_name}/msntauth.conf.default
258%config %{_sysconfdir}/%{base_name}/errorpage.css.default
259
260# Data Files
261%{_datadir}/%{base_name}/*
262
263# Document Files
264%doc faq/*\.html README ChangeLog QUICKSTART
265%doc contrib/url-normalizer.pl contrib/rredir.* contrib/user-agents.pl
266%{_mandir}/man8/*
267%{_mandir}/man1/*
268%{_sysconfdir}/%{base_name}/%{base_name}.conf.documented
269
270%changelog
271* Tue May 17 2011 Masahiro INOUE <miyabi.-.inoue@nifty.com> 3.1.12-1
272- initial build for Vine Linux
273- This package is based on Vine Linux - squid-3.0.STABLE25-2
Note: See TracBrowser for help on using the repository browser.