aboutsummaryrefslogtreecommitdiffstats
path: root/ftp/curl/Makefile
blob: cf0bfda1225f8391f0ba1b8da6c99c3c5d6e747f (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
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
# Created by: Neil Blakey-Milner <nbm@rucus.ru.ac.za>
# $FreeBSD$

PORTNAME=   curl
PORTVERSION=    7.44.0
CATEGORIES= ftp www
MASTER_SITES=   http://curl.haxx.se/download/ \
        LOCAL/sunpoet

MAINTAINER?=    sunpoet@FreeBSD.org
COMMENT?=   Non-interactive tool to get files from FTP, GOPHER, HTTP(S) servers

LICENSE=    MIT

OPTIONS_DEFINE= CA_BUNDLE COOKIES CURL_DEBUG DEBUG DOCS EXAMPLES HTTP2 IDN IPV6 LDAP LDAPS LIBSSH2 PROXY RTMP TLS_SRP
OPTIONS_RADIO=  RESOLV SSL
OPTIONS_SINGLE= GSSAPI
OPTIONS_RADIO_RESOLV=   CARES THREADED_RESOLVER
OPTIONS_RADIO_SSL=  GNUTLS NSS OPENSSL POLARSSL WOLFSSL
OPTIONS_SINGLE_GSSAPI=  GSSAPI_BASE GSSAPI_HEIMDAL GSSAPI_MIT GSSAPI_NONE
OPTIONS_DEFAULT=    CA_BUNDLE COOKIES IPV6 OPENSSL PROXY RESOLV THREADED_RESOLVER TLS_SRP
CA_BUNDLE_DESC=     Install CA bundle for OpenSSL
CA_BUNDLE_IMPLIES=  OPENSSL
COOKIES_DESC=       Cookies support
CURL_DEBUG_DESC=    cURL debug memory tracking
GSSAPI_BASE_DESC=   GSSAPI support via base system (Kerberos required)
GSSAPI_HEIMDAL_DESC=    GSSAPI support via security/heimdal
GSSAPI_MIT_DESC=    GSSAPI support via security/krb5
GSSAPI_NONE_DESC=   Disable GSSAPI support
LDAPS_IMPLIES=      LDAP
LIBSSH2_DESC=       SCP/SFTP support via libssh2
LIBSSH2_IMPLIES=    OPENSSL
RESOLV_DESC=        DNS resolving options
THREADED_RESOLVER_DESC= Threaded DNS resolver
TLS_SRP_DESC=       TLS-SRP (Secure Remote Password) support

LOCALBASE?= /usr/local
.if defined(WITH_OPENSSL_PORT) || (!defined(WITH_OPENSSL_BASE) && exists(${LOCALBASE}/lib/libcrypto.so))
OPTIONS_DEFAULT+=   GSSAPI_NONE
.else
OPTIONS_DEFAULT+=   GSSAPI_BASE
.endif

CONFIGURE_ARGS+=--disable-werror \
        --enable-imap --enable-pop3 --enable-rtsp --enable-smtp \
        --without-axtls
CONFIGURE_ENV+= LOCALBASE=${LOCALBASE} \
        ac_cv_func_SSLv2_client_method=no
GNU_CONFIGURE=  yes
INSTALL_TARGET= install-strip
USE_PERL5=  build
USES=       libtool pathfix perl5 tar:lzma

.if !defined(BUILDING_HIPHOP)
USE_LDCONFIG=   yes
USES+=      cpe

PORTDOCS=   *
PORTEXAMPLES=   *

CPE_VENDOR= haxx

DOCS=       BINDINGS BUGS CONTRIBUTE DISTRO-DILEMMA FAQ FEATURES HISTORY \
        HTTP-COOKIES HTTP2.md INSTALL INSTALL.devcpp INTERNALS \
        KNOWN_BUGS LICENSE-MIXING MAIL-ETIQUETTE MANUAL \
        RELEASE-PROCEDURE RESOURCES ROADMAP.md SECURITY SSL-PROBLEMS \
        SSLCERTS THANKS TODO TheArtOfHttpScripting VERSIONS \
        curl-config.html curl-config.pdf curl.html curl.pdf index.html \
        mk-ca-bundle.html mk-ca-bundle.pdf
.endif

SLAVEDIRS=  ftp/curl-hiphop

CA_BUNDLE_CONFIGURE_OFF=--without-ca-bundle
CA_BUNDLE_CONFIGURE_ON= --with-ca-bundle=${LOCALBASE}/share/certs/ca-root-nss.crt
CA_BUNDLE_RUN_DEPENDS=  ${LOCALBASE}/share/certs/ca-root-nss.crt:${PORTSDIR}/security/ca_root_nss
CARES_CONFIGURE_OFF=    --disable-ares
CARES_CONFIGURE_ON= --enable-ares=${LOCALBASE}
CARES_LIB_DEPENDS=  libcares.so:${PORTSDIR}/dns/c-ares
COOKIES_CONFIGURE_OFF=  --disable-cookies
COOKIES_CONFIGURE_ON=   --enable-cookies
CURL_DEBUG_CONFIGURE_OFF=   --disable-curldebug
CURL_DEBUG_CONFIGURE_ON=--enable-curldebug
DEBUG_CONFIGURE_OFF=    --disable-debug
DEBUG_CONFIGURE_ON= --enable-debug
GNUTLS_CONFIGURE_OFF=   --without-gnutls
GNUTLS_CONFIGURE_ON=    --with-gnutls=${LOCALBASE}
GNUTLS_LIB_DEPENDS= libgnutls.so:${PORTSDIR}/security/gnutls
GSSAPI_BASE_CONFIGURE_ON=   --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_BASE_CPPFLAGS=   ${GSSAPICPPFLAGS}
GSSAPI_BASE_LDFLAGS=    ${GSSAPILDFLAGS}
GSSAPI_BASE_LIBS=   ${GSSAPILIBS}
GSSAPI_BASE_USES=   gssapi
GSSAPI_HEIMDAL_CONFIGURE_ON=    --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_HEIMDAL_CPPFLAGS=${GSSAPICPPFLAGS}
GSSAPI_HEIMDAL_LDFLAGS= ${GSSAPILDFLAGS}
GSSAPI_HEIMDAL_LIBS=    ${GSSAPILIBS}
GSSAPI_HEIMDAL_USES=    gssapi:heimdal
GSSAPI_MIT_CONFIGURE_ON=    --with-gssapi=${GSSAPIBASEDIR} ${GSSAPI_CONFIGURE_ARGS}
GSSAPI_MIT_CPPFLAGS=    ${GSSAPICPPFLAGS}
GSSAPI_MIT_LDFLAGS= ${GSSAPILDFLAGS}
GSSAPI_MIT_LIBS=    ${GSSAPILIBS}
GSSAPI_MIT_USES=    gssapi:mit
GSSAPI_NONE_CONFIGURE_ON=   --without-gssapi
HTTP2_BUILD_DEPENDS=    nghttp2>=1.0.0:${PORTSDIR}/www/nghttp2
HTTP2_CONFIGURE_OFF=    --without-nghttp2
HTTP2_CONFIGURE_ON= --with-nghttp2=${LOCALBASE}
HTTP2_LIB_DEPENDS=  libnghttp2.so:${PORTSDIR}/www/nghttp2
HTTP2_RUN_DEPENDS=  nghttp2>=1.0.0:${PORTSDIR}/www/nghttp2
HTTP2_USES=     pkgconfig
IDN_CONFIGURE_OFF=  --without-libidn
IDN_CONFIGURE_ON=   --with-libidn=${LOCALBASE}
IDN_LIB_DEPENDS=    libidn.so:${PORTSDIR}/dns/libidn
IPV6_CATEGORIES=    ipv6
IPV6_CONFIGURE_OFF= --disable-ipv6
IPV6_CONFIGURE_ON=  --enable-ipv6
LDAP_CONFIGURE_OFF= --disable-ldap
LDAP_CONFIGURE_ON=  --enable-ldap
LDAP_CPPFLAGS=      -I${LOCALBASE}/include
LDAP_LDFLAGS=       -L${LOCALBASE}/lib
LDAP_USE=       OPENLDAP=yes
LDAPS_CONFIGURE_OFF=    --disable-ldaps
LDAPS_CONFIGURE_ON= --enable-ldaps
LIBSSH2_CONFIGURE_OFF=  --without-libssh2
LIBSSH2_CONFIGURE_ON=   --with-libssh2=${LOCALBASE}
LIBSSH2_LIB_DEPENDS=    libssh2.so:${PORTSDIR}/security/libssh2
NSS_CONFIGURE_OFF=  --without-nss
NSS_CONFIGURE_ON=   --with-nss=yes
NSS_LIB_DEPENDS=    libnss3.so:${PORTSDIR}/security/nss
NSS_USES=       pkgconfig
OPENSSL_CONFIGURE_OFF=  --without-ssl
OPENSSL_CONFIGURE_ON=   --with-ssl=${OPENSSLBASE}
OPENSSL_CPPFLAGS=   -I${OPENSSLINC}
OPENSSL_LDFLAGS=    -L${OPENSSLLIB}
OPENSSL_USE=        OPENSSL=yes
POLARSSL_CONFIGURE_OFF= --without-polarssl
POLARSSL_CONFIGURE_ON=  --with-polarssl=${LOCALBASE}
POLARSSL_LIB_DEPENDS=   libmbedtls.so.9:${PORTSDIR}/security/polarssl13
PROXY_CONFIGURE_OFF=    --disable-proxy
PROXY_CONFIGURE_ON= --enable-proxy
RTMP_CONFIGURE_OFF= --without-librtmp
RTMP_CONFIGURE_ON=  --with-librtmp=${LOCALBASE}
RTMP_LIB_DEPENDS=   librtmp.so:${PORTSDIR}/multimedia/librtmp
THREADED_RESOLVER_CONFIGURE_OFF=--disable-threaded-resolver
THREADED_RESOLVER_CONFIGURE_ON= --enable-threaded-resolver
TLS_SRP_CONFIGURE_OFF=  --disable-tls-srp
TLS_SRP_CONFIGURE_ON=   --enable-tls-srp
WOLFSSL_CONFIGURE_OFF=  --without-cyassl
WOLFSSL_CONFIGURE_ON=   --with-cyassl=${LOCALBASE}
WOLFSSL_LIB_DEPENDS=    libwolfssl.so:${PORTSDIR}/security/wolfssl

.include <bsd.port.options.mk>

.if !${PORT_OPTIONS:MGNUTLS} && !${PORT_OPTIONS:MOPENSSL} && ${PORT_OPTIONS:MTLS_SRP}
IGNORE=     only supports TLS-SRP with either OpenSSL or GnuTLS
.endif

.if ${PORT_OPTIONS:MLDAPS} && !${PORT_OPTIONS:MGNUTLS} && !${PORT_OPTIONS:MNSS} && !${PORT_OPTIONS:MOPENSSL} && !${PORT_OPTIONS:MPOLARSSL} && !${PORT_OPTIONS:MWOLFSSL}
IGNORE=     only supports LDAPS with SSL
.endif

.if ${PORT_OPTIONS:MGSSAPI_BASE} && ${PORT_OPTIONS:MOPENSSL} && (defined(WITH_OPENSSL_PORT) || (!defined(WITH_OPENSSL_BASE) && exists(${LOCALBASE}/lib/libcrypto.so)))
IGNORE=     GSSAPI_BASE is not compatible with OpenSSL from ports. Use other GSSAPI options or OpenSSL from base system
.endif

.if defined(OPENSSL_PORT) && ${OPENSSL_PORT} == "security/libressl"
.if ${PORT_OPTIONS:MGSSAPI_BASE} && ${PORT_OPTIONS:MOPENSSL}
IGNORE=     GSSAPI_BASE is not compatible with LibreSSL. Use other GSSAPI options
.endif
.if ${PORT_OPTIONS:MTLS_SRP}
IGNORE=     unsupported TLS-SRP in LibreSSL
.endif
.endif

post-patch:
    @${REINPLACE_CMD} -e '/^SUBDIRS = / s|$$| docs|; /^DIST_SUBDIRS = / s| docs||; /cd docs &&/d' ${WRKSRC}/Makefile.in
    @${REINPLACE_CMD} -e 's|\(flags_dbg_off=\)".*"|\1""|; s|\(flags_opt_off=\)".*"|\1""|; s|lib/pkgconfig|libdata/pkgconfig|g' ${WRKSRC}/configure
    @${REINPLACE_CMD} -e 's|include <gssapi.h>|include <gssapi/gssapi.h>|' ${WRKSRC}/lib/curl_gssapi.h ${WRKSRC}/lib/urldata.h
    @${REINPLACE_CMD} -e 's|gss_nt_service_name|GSS_C_NT_HOSTBASED_SERVICE|' ${WRKSRC}/lib/curl_sasl_gssapi.c

post-install:
.if !defined(BUILDING_HIPHOP)
    ${LN} -s libcurl.so.4 ${STAGEDIR}${PREFIX}/lib/libcurl.so.7
    ${INSTALL_DATA} ${WRKSRC}/docs/libcurl/libcurl.m4 ${STAGEDIR}${PREFIX}/share/aclocal/
    ${MKDIR} ${STAGEDIR}${DOCSDIR}/ ${STAGEDIR}${DOCSDIR}/libcurl/
    cd ${WRKSRC}/docs/ && ${INSTALL_DATA} ${DOCS} ${STAGEDIR}${DOCSDIR}/
    cd ${WRKSRC}/docs/libcurl/ && ${INSTALL_DATA} ABI *.html *.pdf *.m4 ${STAGEDIR}${DOCSDIR}/libcurl/
    ${MKDIR} ${STAGEDIR}${EXAMPLESDIR}/
    cd ${WRKSRC}/docs/examples/ && ${INSTALL_DATA} README Makefile.example makefile* *.c *.cpp ${STAGEDIR}${EXAMPLESDIR}/
.endif

regression-test test: build
.if !${PORT_OPTIONS:MPROXY}
    @${ECHO_MSG} "******************************************"
    @${ECHO_MSG} "* You have disabled curl proxy support.  *"
    @${ECHO_MSG} "* Some tests SHALL FAIL!                 *"
    @${ECHO_MSG} "* This is being addressed.               *"
    @${ECHO_MSG} "******************************************"
.endif
    cd ${WRKSRC}/ && ${SETENV} ${MAKE_ENV} LC_ALL=C ${MAKE_CMD} test

.include <bsd.port.mk>