aboutsummaryrefslogtreecommitdiffstats
path: root/www/squid27/Makefile
blob: fc405c6b3f46bce5b4421c36aac2f318ad449d15 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
# New ports collection makefile for:    squid24
# Date created:     Tue Mar 27 14:56:08 CEST 2001
# Whom:         Adrian Chadd <adrian@FreeBSD.org>
#
# $FreeBSD$
#

PORTNAME=   squid
PORTVERSION=    2.5
PORTREVISION=   4
CATEGORIES= www
MASTER_SITES=   \
    ftp://ftp.squid-cache.org/pub/%SUBDIR%/ \
    ftp://www.unimelb.edu.au/pub/cwis/servers/unix/squid/%SUBDIR%/ \
    ftp://sunsite.auc.dk/pub/infosystems/squid/%SUBDIR%/ \
    ftp://ftp.net.lut.ac.uk/squid/%SUBDIR%/ \
    ${MASTER_SITE_RINGSERVER:S,%SUBDIR%,net/www/squid/&,}
MASTER_SITE_SUBDIR= squid-2/STABLE
DISTNAME=   squid-2.5.STABLE3
EXTRACT_SUFX=   .tar.bz2
DIST_SUBDIR=    squid2.5

PATCH_SITES=    http://www.squid-cache.org/Versions/v2/2.5/bugs/
PATCHFILES= squid-2.5.STABLE3-deny_info.patch \
        squid-2.5.STABLE3-cache_dir_doc.patch \
        squid-2.5.STABLE3-devnull.patch \
        squid-2.5.STABLE3-log_quote.patch \
        squid-2.5.STABLE3-rfc_reference.patch \
        squid-2.5.STABLE3-external_acl_ident.patch \
        squid-2.5.STABLE3-gcc-3_3.patch \
        squid-2.5.STABLE3-carpfactor.patch \
        squid-2.5.STABLE3-neighbor_type_domain.patch \
        squid-2.5.STABLE3-header_access_peer.patch \
        squid-2.5.STABLE3-memwarnsbrk.patch \
        squid-2.5.STABLE3-hostscomments.patch \
        squid-2.5.STABLE3-store_check_cachable_stats.patch \
        squid-2.5.STABLE3-cachePeerPingsSentsnmp.patch \
        squid-2.5.STABLE3-minimum_retry_timeout.patch \
        squid-2.5.STABLE3-tcp_reset_leak.patch \
        squid-2.5.STABLE3-hostheader.patch \
        squid-2.5.STABLE3-reply_body_max_size.patch \
        squid-2.5.STABLE3-ie_refresh.patch \
        squid-2.5.STABLE3-http_reply_access-denied.patch \
        squid-2.5.STABLE3-SENT_PASV.patch \
        squid-2.5.STABLE3-peer_digest_not_found_assertion.patch \
        squid-2.5.STABLE3-round_robin_max_size.patch
PATCH_DIST_STRIP=   -p1

MAINTAINER= adrian@freebsd.org
COMMENT=    The successful WWW proxy cache and accelerator

GNU_CONFIGURE=  yes
USE_BZIP2=  yes
USE_PERL5=  yes
USE_REINPLACE=  yes
# Follow the apache port's lead...
CONFIGURE_ARGS= --bindir=${PREFIX}/sbin  --sysconfdir=${PREFIX}/etc/squid \
        --datadir=${PREFIX}/etc/squid \
        --localstatedir=${PREFIX}/squid \
        --enable-storeio="ufs diskd null" \
        --enable-removal-policies="lru heap" \
        --enable-auth=basic --enable-basic-auth-helpers="NCSA PAM YP" \
        --enable-external-acl-helpers="ip_user unix_group" \
        --enable-underscores

MAKEFILE=   Makefile
MAN8=   pam_auth.8 squid_unix_group.8 squid.8

# Some other configure options..
#  - Compile and use the malloc package from Doug Lea
#CONFIGURE_ARGS+= --enable-dlmalloc
#  - Compile and use the supplied GNUregex routines instead of BSD regex.
#CONFIGURE_ARGS+= --enable-gnuregex
#  - Enable simple malloc debugging
#CONFIGURE_ARGS+= --enable-xmalloc-debug
#  - Detailed trace of memory allocations
#CONFIGURE_ARGS+= --enable-xmalloc-debug-count
#  - Show malloc statistics in cachemgr status pages
#CONFIGURE_ARGS+= --enable-xmalloc-statistics
#  - Enable CARP support
#CONFIGURE_ARGS+= --enable-carp
#  - Enable ICMP pinging for heirarchy stats and selection
#CONFIGURE_ARGS+= --enable-icmp
#  - Enable delay pools to limit bandwidth usage
#CONFIGURE_ARGS+= --enable-delay-pools
#  - Enable generic memory use tracing
#CONFIGURE_ARGS+= --enable-mem-gen-trace
#  - Enable logging of the User-Agent header
#CONFIGURE_ARGS+= --enable-useragent-log
#  - Disable Web Cache Coordination Protocol
#CONFIGURE_ARGS+= --disable-wccp
#  - Kill parent (eg: RunCache) on shutdown (use with great care!!)
#CONFIGURE_ARGS+= --enable-kill-parent-hack
#  - Turn on SNMP server support
#CONFIGURE_ARGS+= --enable-snmp
#  - Turn on SSL server support for reverse proxies
#CONFIGURE_ARGS+= --enable-ssl
#  - Optimize time updates to one per second rather than calling gettimeofday()
#CONFIGURE_ARGS+= --enable-time-hack
#  - Set an explicit hostname in cachemgr.cgi
#CONFIGURE_ARGS+= --enable-cachemgr-hostname=some.hostname
#  - Enable ACL based on ethernet address (eg: for machines with dynamic DHCP
#    assigned IP addresses)
#CONFIGURE_ARGS+= --enable-arp-acl
#  - Enable HTCP protocol
#CONFIGURE_ARGS+= --enable-htcp
#  - Enable Forw/Via database
#CONFIGURE_ARGS+= --enable-forw-via-db
#  - Use Cache Digests - see http://squid.nlanr.net/Squid/FAQ/FAQ-16.html
#CONFIGURE_ARGS+= --enable-cache-digests
#  - Select language for Error pages (see errors dir)
#CONFIGURE_ARGS+= --enable-err-language=lang
#  (--enable-poll is not needed, it's detected correctly on 3.0)
#  - Strict HTTP compliance
#CONFIGURE_ARGS+= --disable-http-violations
#  - Enable Transparent Proxy support for IP-Filter systems (incl 3.0)
#CONFIGURE_ARGS+= --enable-ipf-transparent
# (--enable-leakfinder is a developer support tool only)
#  - Compile out code that does optional Ident (RFC931) lookups
#CONFIGURE_ARGS+= --disable-ident-lookups
#  - Disable squid's internal async DNS lookup code.
#CONFIGURE_ARGS+= --disable-internal-dns
#  - Use truncate() rather than unlink()
#CONFIGURE_ARGS+= --enable-truncate
#  - accept the illegal '_' character in hostnames.
#CONFIGURE_ARGS+= --enable-underscores
#  - Enable control of different heap replacement algorithms at runtime.
#CONFIGURE_ARGS+= --enable-removal-policies

post-patch:
    @${REINPLACE_CMD} -e 's|-lpthread|${PTHREAD_LIBS}|g' ${WRKSRC}/configure
    @${REINPLACE_CMD} -e 's|/etc|${PREFIX}/etc|g' ${WRKSRC}/doc/squid.8

post-install:
#   I don't think many people use the pinger nowadays, and if you
#   do you'll want squid in its own group so as to restrict access
#   to it.
#   cd ${WRKSRC}/src; make install-pinger
.for sbin_file in client squid
    if [ -f ${PREFIX}/sbin/${sbin_file} ] ; then \
        ${STRIP_CMD} ${PREFIX}/sbin/${sbin_file} ; \
    fi
.endfor
.for libexec_file in cachemgr.cgi dnsserver pinger unlinkd
    if [ -f ${PREFIX}/libexec/${libexec_file} ] ; then \
        ${STRIP_CMD} ${PREFIX}/libexec/${libexec_file} ; \
    fi
.endfor
    @if [ ! -d ${PREFIX}/squid/logs ]; then         \
        ${MKDIR} ${PREFIX}/squid/logs;          \
        ${CHOWN} nobody:nogroup ${PREFIX}/squid/logs;   \
    fi
    @if [ ! -d ${PREFIX}/squid/cache ]; then        \
        ${MKDIR} ${PREFIX}/squid/cache;         \
        ${CHOWN} nobody:nogroup ${PREFIX}/squid/cache;  \
    fi
    @if [ ! -f ${PREFIX}/etc/rc.d/squid.sh ]; then \
        ${ECHO} "Installing ${PREFIX}/etc/rc.d/squid.sh startup file."; \
        ${INSTALL_SCRIPT} -m 751 ${FILESDIR}/squid.sh ${PREFIX}/etc/rc.d/squid.sh; \
    fi

.include <bsd.port.mk>