Compare commits
345 Commits
curl-7_28_
...
curl-7_29_
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
bf633a584d | ||
|
|
0f1deac71e | ||
|
|
f206d6c055 | ||
|
|
add37cc49f | ||
|
|
85625c5e28 | ||
|
|
453e821ad7 | ||
|
|
e0c491026f | ||
|
|
12f4ea50f7 | ||
|
|
ae6b5f1772 | ||
|
|
5f8f20f5e6 | ||
|
|
33a182e6c2 | ||
|
|
68de6a0b3e | ||
|
|
25d13822ae | ||
|
|
25f351424b | ||
|
|
cb3e6dfa35 | ||
|
|
1d22407863 | ||
|
|
bb7c2ee37c | ||
|
|
278ab75e9f | ||
|
|
0d1b754376 | ||
|
|
4cd027f17e | ||
|
|
bd1f170a5a | ||
|
|
03577a355e | ||
|
|
022e67294e | ||
|
|
7fd5f680ea | ||
|
|
9ca812f386 | ||
|
|
a94a68a3c1 | ||
|
|
f850abf439 | ||
|
|
e1cd753e4d | ||
|
|
4c26ba9cea | ||
|
|
c0c334b42a | ||
|
|
b4270a9af1 | ||
|
|
6b6bdc83bd | ||
|
|
56b7c87c74 | ||
|
|
32e8467a66 | ||
|
|
e243d80dea | ||
|
|
a33075b8d3 | ||
|
|
ddd40a43aa | ||
|
|
38131d415b | ||
|
|
c7b6e43ef8 | ||
|
|
3d7b7b6b84 | ||
|
|
163a1dca5f | ||
|
|
23a47ef01b | ||
|
|
38ec16d671 | ||
|
|
d411402a65 | ||
|
|
826e1b81fa | ||
|
|
11dde6ac72 | ||
|
|
0494da830b | ||
|
|
5243b18f3d | ||
|
|
0e5e720c19 | ||
|
|
3dbf11d0a1 | ||
|
|
499e30c4bb | ||
|
|
73fae58132 | ||
|
|
44cf225f7a | ||
|
|
d9c3505e83 | ||
|
|
593f242803 | ||
|
|
a76ea8b79a | ||
|
|
c0e8e94ca2 | ||
|
|
eb2e62c0af | ||
|
|
2bfb8b6080 | ||
|
|
fda0f14f73 | ||
|
|
f8ba1273af | ||
|
|
8b275718e2 | ||
|
|
379d63ecc7 | ||
|
|
b1826d81fb | ||
|
|
6a55f25f67 | ||
|
|
f2f897172f | ||
|
|
aa9e72d358 | ||
|
|
c527759701 | ||
|
|
5c28a64e57 | ||
|
|
8c6c42a67f | ||
|
|
045c734e16 | ||
|
|
de991037e4 | ||
|
|
56d4de468c | ||
|
|
2698520aef | ||
|
|
fa176376c8 | ||
|
|
efe4656656 | ||
|
|
0ed4a0923c | ||
|
|
a3e65b1a50 | ||
|
|
1347b3085c | ||
|
|
9d1effad05 | ||
|
|
e5ea45ec2e | ||
|
|
63605d281f | ||
|
|
f4cc54cb47 | ||
|
|
34ae007d4d | ||
|
|
d90b9aee64 | ||
|
|
ece8681a60 | ||
|
|
7b5be79908 | ||
|
|
446afec71a | ||
|
|
e2bfae239f | ||
|
|
ccb34cb46d | ||
|
|
0e1855d9d3 | ||
|
|
c43127414d | ||
|
|
9fd88abb70 | ||
|
|
4ed6b07d8d | ||
|
|
533c31b785 | ||
|
|
7ab3ae0bf0 | ||
|
|
4b401b2d99 | ||
|
|
d7f2c3af5f | ||
|
|
bc682cbd3e | ||
|
|
26613d7817 | ||
|
|
18e7c14f30 | ||
|
|
16abdd4f39 | ||
|
|
99229b74eb | ||
|
|
600cbaca6f | ||
|
|
b36f1d26f8 | ||
|
|
d17f536688 | ||
|
|
b35a176c66 | ||
|
|
a7db42e4f0 | ||
|
|
308cce8231 | ||
|
|
a6848250d2 | ||
|
|
a9ca5e61e5 | ||
|
|
06558695d5 | ||
|
|
dd73c924ac | ||
|
|
5a053ffe80 | ||
|
|
e2bcd2ab9e | ||
|
|
fea3a3d569 | ||
|
|
75fa3542d0 | ||
|
|
4ffb8a6398 | ||
|
|
7a6d8b1b1a | ||
|
|
905d0be509 | ||
|
|
fd3efca164 | ||
|
|
825677ad09 | ||
|
|
561b551deb | ||
|
|
6a4f5e5268 | ||
|
|
f6e33cf669 | ||
|
|
4e6265ea5a | ||
|
|
494b8664da | ||
|
|
d6bebd56f7 | ||
|
|
70dcde78d0 | ||
|
|
89a3086231 | ||
|
|
cfb6f03224 | ||
|
|
11f55a9672 | ||
|
|
5475ac279d | ||
|
|
a77d18efaf | ||
|
|
dd561c3834 | ||
|
|
db20517796 | ||
|
|
4a5aa6682d | ||
|
|
e0ba958e28 | ||
|
|
8f80f412fb | ||
|
|
cc4ac82bb6 | ||
|
|
1795e24176 | ||
|
|
b708a522a1 | ||
|
|
65e8ba8e1d | ||
|
|
0b3180b4f5 | ||
|
|
8f13e3ddb9 | ||
|
|
7d83dfff9c | ||
|
|
dbf93a8973 | ||
|
|
5b6e7927c6 | ||
|
|
13606bbfde | ||
|
|
8f0171bdd4 | ||
|
|
c087374c64 | ||
|
|
dfe4769157 | ||
|
|
404a95b588 | ||
|
|
bc5298e25c | ||
|
|
d86503ea82 | ||
|
|
bd8ae68006 | ||
|
|
c02449ca53 | ||
|
|
1576548428 | ||
|
|
36837c10b2 | ||
|
|
f947de4bb5 | ||
|
|
2424b7ab1b | ||
|
|
c43af566fa | ||
|
|
488245f99c | ||
|
|
27f90c0962 | ||
|
|
ffa62e5bab | ||
|
|
2255ac52f7 | ||
|
|
b3204e6d60 | ||
|
|
f6f6f278e2 | ||
|
|
167717b806 | ||
|
|
8177bc262f | ||
|
|
ffd8e127e7 | ||
|
|
f871de0064 | ||
|
|
ec691ca34b | ||
|
|
709b3506cd | ||
|
|
2ee2693a47 | ||
|
|
431ead1c9a | ||
|
|
e3ed2b82e6 | ||
|
|
311151beab | ||
|
|
ae2a2c9931 | ||
|
|
eb5aa12c8b | ||
|
|
77b5c0b2cf | ||
|
|
b44da5a82a | ||
|
|
219fe7b29c | ||
|
|
d49531dd3a | ||
|
|
4a23b19a13 | ||
|
|
a662f86f6f | ||
|
|
d335aa2cdc | ||
|
|
0aabfd9963 | ||
|
|
14b77db1b9 | ||
|
|
e125eea5a6 | ||
|
|
1649e680f6 | ||
|
|
2897ce7dc2 | ||
|
|
5ed03ebe52 | ||
|
|
3456bbc4cc | ||
|
|
7a09907146 | ||
|
|
a1fc9b80c8 | ||
|
|
dfe382c6ae | ||
|
|
b3d91a147f | ||
|
|
c59c5e8ea2 | ||
|
|
0969045b6e | ||
|
|
c30c557e4d | ||
|
|
d738adc1fb | ||
|
|
c691037517 | ||
|
|
eafccdb315 | ||
|
|
b7a1eccce8 | ||
|
|
c91a6cd78f | ||
|
|
7d49d774fd | ||
|
|
9ab5f9dd8d | ||
|
|
b8dde1cf19 | ||
|
|
57fa576a35 | ||
|
|
f6af9d9886 | ||
|
|
87e8691e7c | ||
|
|
bbb4bbc0f1 | ||
|
|
0e8e340cba | ||
|
|
a0b207164c | ||
|
|
f254c59dc7 | ||
|
|
568befb6aa | ||
|
|
f4b60e7f14 | ||
|
|
85b77209ae | ||
|
|
e880680fb6 | ||
|
|
aee540b831 | ||
|
|
4710d3d969 | ||
|
|
d758234ade | ||
|
|
c07a6f3ff3 | ||
|
|
d021f2e8a0 | ||
|
|
ca5f4e2135 | ||
|
|
3c6ea7ca82 | ||
|
|
8b15c84ea9 | ||
|
|
60edbf65b6 | ||
|
|
fe2b2a3b9d | ||
|
|
7332a7cafb | ||
|
|
23f8dca6fb | ||
|
|
b908376bef | ||
|
|
8b02afd9a9 | ||
|
|
3202cc6162 | ||
|
|
068f7ae264 | ||
|
|
68d2830ee9 | ||
|
|
2ecdd48683 | ||
|
|
6bd6b3a8a1 | ||
|
|
91b57cd6e5 | ||
|
|
d27a46f09b | ||
|
|
4abf4fbaac | ||
|
|
16a8281f71 | ||
|
|
534d2ca1d7 | ||
|
|
79954a1b07 | ||
|
|
b33074d893 | ||
|
|
0683adbf50 | ||
|
|
68e2c9a85f | ||
|
|
616a0099d1 | ||
|
|
665adcd4b7 | ||
|
|
91dc73ef44 | ||
|
|
14dc679ce0 | ||
|
|
ef6f040355 | ||
|
|
c1dd687af6 | ||
|
|
f435d6699d | ||
|
|
ba33665d1f | ||
|
|
67f053b672 | ||
|
|
cfb67752fe | ||
|
|
ba476bb6d8 | ||
|
|
7762192ecf | ||
|
|
b9fdb721f2 | ||
|
|
c830115c48 | ||
|
|
52af6e69f0 | ||
|
|
32be348af2 | ||
|
|
7e87499213 | ||
|
|
7719333f55 | ||
|
|
276452ca10 | ||
|
|
1b10dd7aae | ||
|
|
7aebb3cc42 | ||
|
|
6f444b2761 | ||
|
|
81d96c4421 | ||
|
|
10296ac665 | ||
|
|
ab0fa55780 | ||
|
|
409f2a041f | ||
|
|
dd75cba3ef | ||
|
|
ee588fe088 | ||
|
|
db4215f14a | ||
|
|
32afaaef93 | ||
|
|
0ac827848d | ||
|
|
c277bd6ce7 | ||
|
|
6d8443a245 | ||
|
|
53c83ee3ed | ||
|
|
fa1ae0abcd | ||
|
|
38ed72cd37 | ||
|
|
1099f3a071 | ||
|
|
6a4bdb027b | ||
|
|
7c0cbcf2f6 | ||
|
|
076e1fa348 | ||
|
|
cd5261ea6d | ||
|
|
4b994e14fb | ||
|
|
e62ee60c7a | ||
|
|
e237402c47 | ||
|
|
1c23d2b392 | ||
|
|
7ecd874bce | ||
|
|
49c37e6c1c | ||
|
|
dca8ae5f02 | ||
|
|
cf75a64651 | ||
|
|
0af1a9d270 | ||
|
|
1394cad30f | ||
|
|
18c0e9bd71 | ||
|
|
c70c1a22d2 | ||
|
|
5a4f6413d1 | ||
|
|
6d1b493f3d | ||
|
|
7840c4c70c | ||
|
|
9096f4f451 | ||
|
|
487538e87a | ||
|
|
e1fa945e7e | ||
|
|
cda6d891ab | ||
|
|
473003fbdf | ||
|
|
3f20303702 | ||
|
|
a1be8e7f9b | ||
|
|
8d97bed806 | ||
|
|
13ce9031cc | ||
|
|
95326a40ff | ||
|
|
8e329bb759 | ||
|
|
da82f59b69 | ||
|
|
ab1f80200a | ||
|
|
41eec4efa2 | ||
|
|
2045d83dd3 | ||
|
|
0da6c113ce | ||
|
|
fa6d78829f | ||
|
|
550e403f00 | ||
|
|
f99430d89e | ||
|
|
09a491378a | ||
|
|
9019a0a86c | ||
|
|
b2954e66e8 | ||
|
|
7c0f201075 | ||
|
|
0ecb57056f | ||
|
|
3be96564a8 | ||
|
|
0cb5650386 | ||
|
|
8f61e5cea7 | ||
|
|
34ff881ece | ||
|
|
af121ccad8 | ||
|
|
c81eb7e226 | ||
|
|
74fe1b95fb | ||
|
|
d1c769877a | ||
|
|
94891ff296 | ||
|
|
12a40e17a9 | ||
|
|
8ffc971138 | ||
|
|
f1d2e18508 | ||
|
|
1a02e84589 | ||
|
|
c79c0909d9 | ||
|
|
3fc5779b91 | ||
|
|
ff32546d81 | ||
|
|
99b036c9b2 |
@@ -132,22 +132,6 @@ mark_as_advanced(DISABLED_THREADSAFE)
|
|||||||
option(ENABLE_IPV6 "Define if you want to enable IPv6 support" OFF)
|
option(ENABLE_IPV6 "Define if you want to enable IPv6 support" OFF)
|
||||||
mark_as_advanced(ENABLE_IPV6)
|
mark_as_advanced(ENABLE_IPV6)
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
# Windows standard libraries are located in C:/Program Files/Microsoft SDKs/[...]
|
|
||||||
# They are already included in the default MSVC LIBPATH => no find_library is needed!
|
|
||||||
list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES wsock32.lib ws2_32.lib) # bufferoverflowu.lib
|
|
||||||
if(CURL_DISABLE_LDAP)
|
|
||||||
# Remove wldap32.lib from space-separated list
|
|
||||||
string(REPLACE " " ";" _LIST ${CMAKE_C_STANDARD_LIBRARIES})
|
|
||||||
list(REMOVE_ITEM _LIST "wldap32.lib")
|
|
||||||
to_list_spaces(_LIST CMAKE_C_STANDARD_LIBRARIES)
|
|
||||||
else()
|
|
||||||
# Append wldap32.lib
|
|
||||||
list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES wldap32.lib)
|
|
||||||
endif()
|
|
||||||
set(CMAKE_C_STANDARD_LIBRARIES "${CMAKE_C_STANDARD_LIBRARIES}" CACHE STRING "" FORCE)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
|
|
||||||
# We need ansi c-flags, especially on HP
|
# We need ansi c-flags, especially on HP
|
||||||
set(CMAKE_C_FLAGS "${CMAKE_ANSI_CFLAGS} ${CMAKE_C_FLAGS}")
|
set(CMAKE_C_FLAGS "${CMAKE_ANSI_CFLAGS} ${CMAKE_C_FLAGS}")
|
||||||
@@ -249,26 +233,28 @@ if(CURL_ZLIB) # AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE
|
|||||||
set(HAVE_ZLIB_H ON)
|
set(HAVE_ZLIB_H ON)
|
||||||
set(HAVE_ZLIB ON)
|
set(HAVE_ZLIB ON)
|
||||||
set(HAVE_LIBZ ON)
|
set(HAVE_LIBZ ON)
|
||||||
|
list(APPEND CURL_LIBS ${ZLIB_LIBRARIES})
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON)
|
option(CMAKE_USE_OPENSSL "Use OpenSSL code. Experimental" ON)
|
||||||
mark_as_advanced(CMAKE_USE_OPENSSL)
|
mark_as_advanced(CMAKE_USE_OPENSSL)
|
||||||
if(CMAKE_USE_OPENSSL)
|
if(CMAKE_USE_OPENSSL)
|
||||||
if(WIN32)
|
|
||||||
|
set(USE_SSLEAY OFF)
|
||||||
|
set(USE_OPENSSL OFF)
|
||||||
|
set(HAVE_LIBCRYPTO OFF)
|
||||||
|
set(HAVE_LIBSSL OFF)
|
||||||
|
|
||||||
find_package(OpenSSL)
|
find_package(OpenSSL)
|
||||||
if(OPENSSL_FOUND)
|
if(OPENSSL_FOUND)
|
||||||
set(USE_SSLEAY TRUE)
|
|
||||||
set(USE_OPENSSL TRUE)
|
|
||||||
list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES})
|
list(APPEND CURL_LIBS ${OPENSSL_LIBRARIES})
|
||||||
else()
|
list(APPEND CMAKE_REQUIRED_INCLUDES ${OPENSSL_INCLUDE_DIR})
|
||||||
set(CMAKE_USE_OPENSSL FALSE)
|
set(USE_SSLEAY ON)
|
||||||
message(STATUS "OpenSSL NOT Found, disabling CMAKE_USE_OPENSSL")
|
set(USE_OPENSSL ON)
|
||||||
endif()
|
set(HAVE_LIBCRYPTO ON)
|
||||||
else(WIN32)
|
set(HAVE_LIBSSL ON)
|
||||||
check_library_exists_concat("crypto" CRYPTO_lock HAVE_LIBCRYPTO)
|
endif(OPENSSL_FOUND)
|
||||||
check_library_exists_concat("ssl" SSL_connect HAVE_LIBSSL)
|
|
||||||
endif(WIN32)
|
|
||||||
endif(CMAKE_USE_OPENSSL)
|
endif(CMAKE_USE_OPENSSL)
|
||||||
|
|
||||||
# If we have features.h, then do the _BSD_SOURCE magic
|
# If we have features.h, then do the _BSD_SOURCE magic
|
||||||
@@ -334,6 +320,7 @@ check_include_file_concat("net/if.h" HAVE_NET_IF_H)
|
|||||||
check_include_file_concat("netdb.h" HAVE_NETDB_H)
|
check_include_file_concat("netdb.h" HAVE_NETDB_H)
|
||||||
check_include_file_concat("netinet/in.h" HAVE_NETINET_IN_H)
|
check_include_file_concat("netinet/in.h" HAVE_NETINET_IN_H)
|
||||||
check_include_file_concat("netinet/tcp.h" HAVE_NETINET_TCP_H)
|
check_include_file_concat("netinet/tcp.h" HAVE_NETINET_TCP_H)
|
||||||
|
if(CMAKE_USE_OPENSSL AND OPENSSL_FOUND)
|
||||||
check_include_file_concat("openssl/crypto.h" HAVE_OPENSSL_CRYPTO_H)
|
check_include_file_concat("openssl/crypto.h" HAVE_OPENSSL_CRYPTO_H)
|
||||||
check_include_file_concat("openssl/engine.h" HAVE_OPENSSL_ENGINE_H)
|
check_include_file_concat("openssl/engine.h" HAVE_OPENSSL_ENGINE_H)
|
||||||
check_include_file_concat("openssl/err.h" HAVE_OPENSSL_ERR_H)
|
check_include_file_concat("openssl/err.h" HAVE_OPENSSL_ERR_H)
|
||||||
@@ -342,6 +329,8 @@ check_include_file_concat("openssl/pkcs12.h" HAVE_OPENSSL_PKCS12_H)
|
|||||||
check_include_file_concat("openssl/rsa.h" HAVE_OPENSSL_RSA_H)
|
check_include_file_concat("openssl/rsa.h" HAVE_OPENSSL_RSA_H)
|
||||||
check_include_file_concat("openssl/ssl.h" HAVE_OPENSSL_SSL_H)
|
check_include_file_concat("openssl/ssl.h" HAVE_OPENSSL_SSL_H)
|
||||||
check_include_file_concat("openssl/x509.h" HAVE_OPENSSL_X509_H)
|
check_include_file_concat("openssl/x509.h" HAVE_OPENSSL_X509_H)
|
||||||
|
check_include_file_concat("openssl/rand.h" HAVE_OPENSSL_RAND_H)
|
||||||
|
endif(CMAKE_USE_OPENSSL AND OPENSSL_FOUND)
|
||||||
check_include_file_concat("pem.h" HAVE_PEM_H)
|
check_include_file_concat("pem.h" HAVE_PEM_H)
|
||||||
check_include_file_concat("poll.h" HAVE_POLL_H)
|
check_include_file_concat("poll.h" HAVE_POLL_H)
|
||||||
check_include_file_concat("pwd.h" HAVE_PWD_H)
|
check_include_file_concat("pwd.h" HAVE_PWD_H)
|
||||||
@@ -377,10 +366,6 @@ check_include_file_concat("sockio.h" HAVE_SOCKIO_H)
|
|||||||
check_include_file_concat("sys/utsname.h" HAVE_SYS_UTSNAME_H)
|
check_include_file_concat("sys/utsname.h" HAVE_SYS_UTSNAME_H)
|
||||||
check_include_file_concat("idna.h" HAVE_IDNA_H)
|
check_include_file_concat("idna.h" HAVE_IDNA_H)
|
||||||
|
|
||||||
if(CMAKE_USE_OPENSSL)
|
|
||||||
check_include_file_concat("openssl/rand.h" HAVE_OPENSSL_RAND_H)
|
|
||||||
endif(CMAKE_USE_OPENSSL)
|
|
||||||
|
|
||||||
if(NOT HAVE_LDAP_H)
|
if(NOT HAVE_LDAP_H)
|
||||||
message(STATUS "LDAP_H not found CURL_DISABLE_LDAP set ON")
|
message(STATUS "LDAP_H not found CURL_DISABLE_LDAP set ON")
|
||||||
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
||||||
@@ -816,9 +801,6 @@ endif(MSVC)
|
|||||||
function(SETUP_CURL_DEPENDENCIES TARGET_NAME)
|
function(SETUP_CURL_DEPENDENCIES TARGET_NAME)
|
||||||
if(CURL_ZLIB AND ZLIB_FOUND)
|
if(CURL_ZLIB AND ZLIB_FOUND)
|
||||||
include_directories(${ZLIB_INCLUDE_DIR})
|
include_directories(${ZLIB_INCLUDE_DIR})
|
||||||
endif()
|
|
||||||
if(CURL_ZLIB AND ZLIB_FOUND)
|
|
||||||
target_link_libraries(${TARGET_NAME} ${ZLIB_LIBRARIES})
|
|
||||||
#ADD_DEFINITIONS( -DHAVE_ZLIB_H -DHAVE_ZLIB -DHAVE_LIBZ )
|
#ADD_DEFINITIONS( -DHAVE_ZLIB_H -DHAVE_ZLIB -DHAVE_LIBZ )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@@ -826,9 +808,10 @@ function(SETUP_CURL_DEPENDENCIES TARGET_NAME)
|
|||||||
include_directories(${OPENSSL_INCLUDE_DIR})
|
include_directories(${OPENSSL_INCLUDE_DIR})
|
||||||
endif()
|
endif()
|
||||||
if(CMAKE_USE_OPENSSL AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
|
if(CMAKE_USE_OPENSSL AND CURL_CONFIG_HAS_BEEN_RUN_BEFORE)
|
||||||
target_link_libraries(${TARGET_NAME} ${OPENSSL_LIBRARIES})
|
|
||||||
#ADD_DEFINITIONS( -DUSE_SSLEAY )
|
#ADD_DEFINITIONS( -DUSE_SSLEAY )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
target_link_libraries(${TARGET_NAME} ${CURL_LIBS})
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
# Ugly (but functional) way to include "Makefile.inc" by transforming it (= regenerate it).
|
# Ugly (but functional) way to include "Makefile.inc" by transforming it (= regenerate it).
|
||||||
@@ -869,3 +852,13 @@ install(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}/include/curl"
|
|||||||
DESTINATION include
|
DESTINATION include
|
||||||
FILES_MATCHING PATTERN "*.h"
|
FILES_MATCHING PATTERN "*.h"
|
||||||
PATTERN "curlbuild.h" EXCLUDE)
|
PATTERN "curlbuild.h" EXCLUDE)
|
||||||
|
|
||||||
|
|
||||||
|
# Workaround for MSVS10 to avoid the Dialog Hell
|
||||||
|
# FIXME: This could be removed with future version of CMake.
|
||||||
|
if(MSVC_VERSION EQUAL 1600)
|
||||||
|
set(CURL_SLN_FILENAME "${CMAKE_CURRENT_BINARY_DIR}/CURL.sln")
|
||||||
|
if(EXISTS "${CURL_SLN_FILENAME}")
|
||||||
|
file(APPEND "${CURL_SLN_FILENAME}" "\n# This should be regenerated!\n")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|||||||
2
COPYING
2
COPYING
@@ -1,6 +1,6 @@
|
|||||||
COPYRIGHT AND PERMISSION NOTICE
|
COPYRIGHT AND PERMISSION NOTICE
|
||||||
|
|
||||||
Copyright (c) 1996 - 2012, Daniel Stenberg, <daniel@haxx.se>.
|
Copyright (c) 1996 - 2013, Daniel Stenberg, <daniel@haxx.se>.
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
|
|||||||
6
GIT-INFO
6
GIT-INFO
@@ -48,9 +48,9 @@ installed:
|
|||||||
o nroff + perl
|
o nroff + perl
|
||||||
|
|
||||||
If you don't have nroff and perl and you for some reason don't want to
|
If you don't have nroff and perl and you for some reason don't want to
|
||||||
install them, you can rename the source file src/hugehelp.c.cvs to
|
install them, you can rename the source file src/tool_hugehelp.c.cvs to
|
||||||
src/hugehelp.c and avoid having to generate this file. This will give you
|
src/tool_hugehelp.c and avoid having to generate this file. This will
|
||||||
a stubbed version of the file that doesn't contain actual content.
|
give you a stubbed version of the file that doesn't contain actual content.
|
||||||
|
|
||||||
MAC OS X
|
MAC OS X
|
||||||
|
|
||||||
|
|||||||
@@ -81,6 +81,9 @@ test-full:
|
|||||||
test-torture:
|
test-torture:
|
||||||
@(cd tests; $(MAKE) all torture-test)
|
@(cd tests; $(MAKE) all torture-test)
|
||||||
|
|
||||||
|
test-am:
|
||||||
|
@(cd tests; $(MAKE) all am-test)
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
examples:
|
examples:
|
||||||
|
|||||||
151
RELEASE-NOTES
151
RELEASE-NOTES
@@ -1,62 +1,66 @@
|
|||||||
Curl and libcurl 7.28.0
|
Curl and libcurl 7.29.0
|
||||||
|
|
||||||
Public curl releases: 129
|
Public curl releases: 131
|
||||||
Command line options: 152
|
Command line options: 152
|
||||||
curl_easy_setopt() options: 199
|
curl_easy_setopt() options: 199
|
||||||
Public functions in libcurl: 58
|
Public functions in libcurl: 58
|
||||||
Known libcurl bindings: 39
|
Known libcurl bindings: 39
|
||||||
Contributors: 953
|
Contributors: 993
|
||||||
|
|
||||||
|
This release includes the following securify fix:
|
||||||
|
|
||||||
|
o POP3/IMAP/SMTP SASL buffer overflow vulnerability [17]
|
||||||
|
|
||||||
This release includes the following changes:
|
This release includes the following changes:
|
||||||
|
|
||||||
o SSH: added agent based authentication
|
o test: offer "automake" output and check for perl better
|
||||||
o ftp: active conn, allow application to set sockopt after accept() call
|
o always-multi: always use non-blocking internals [1]
|
||||||
with CURLSOCKTYPE_ACCEPT
|
o imap: Added support for sasl digest-md5 authentication
|
||||||
o multi: add curl_multi_wait() [12]
|
o imap: Added support for sasl cram-md5 authentication
|
||||||
o metalink: Added support for Microsoft Windows CryptoAPI
|
o imap: Added support for sasl ntlm authentication
|
||||||
o md5: Added support for Microsoft Windows CryptoAPI
|
o imap: Added support for sasl login authentication
|
||||||
o parse_proxy: treat "socks://x" as a socks4 proxy [17]
|
o imap: Added support for sasl plain text authentication
|
||||||
o socks: Added support for IPv6 connections through SOCKSv5 proxy
|
o imap: Added support for login disabled server capability
|
||||||
|
o mk-ca-bundle: add -f, support passing to stdout and more [5]
|
||||||
|
o writeout: -w now supports remote_ip/port and local_ip/port
|
||||||
|
|
||||||
This release includes the following bugfixes:
|
This release includes the following bugfixes:
|
||||||
|
|
||||||
o WSAPoll disabled on Windows builds due to its bugs [8]
|
o nss: prevent NSS from crashing on client auth hook failure
|
||||||
o segfault on request retries [1]
|
o darwinssl: Fixed inability to disable peer verification on Snow Leopard
|
||||||
o curl-config: parentheses fix [2]
|
and Lion
|
||||||
o VC build: add define for openssl [3]
|
o curl_multi_remove_handle: fix memory leak triggered with CURLOPT_RESOLVE
|
||||||
o globbing: fix segfault when >9 globs were used [4]
|
o SCP: relative path didn't work as documented [7]
|
||||||
o fixed a few clang-analyzer warnings
|
o setup_once.h: HP-UX <sys/socket.h> issue workaround
|
||||||
o metalink: change code order to build with gnutls-nettle [5]
|
o configure: fix cross pkg-config detection
|
||||||
o gtls: fix build failure by including nettle-specific headers [5]
|
o runtests: Do not add undefined values to @INC
|
||||||
o change preferred HTTP auth on a handle previously used for another auth [9]
|
o build: fix compilation with CURL_DISABLE_CRYPTO_AUTH flag
|
||||||
o file: use fdopen() to avoid race condition [6]
|
o multi: fix re-sending request on early connection close
|
||||||
o Added DWANT_IDN_PROTOTYPES define for MSVC too [7]
|
o HTTP: remove stray CRLF in chunk-encoded content-free request bodies
|
||||||
o verbose: fixed (nil) output of hostnames in re-used connections [10]
|
o build: fix AIX compilation and usage of events/revents
|
||||||
o metalink: Un-broke the build when building --with-darwinssl
|
o VC Makefiles: add missing hostcheck
|
||||||
o curl man page cleanup
|
o nss: clear session cache if a client certificate from file is used
|
||||||
o Avoid leak of local device string when reusing connection
|
o nss: fix error messages for CURLE_SSL_{CACERT,CRL}_BADFILE
|
||||||
o Curl_socket_check: fix return code for timeout [11]
|
o fix HTTP CONNECT tunnel establishment upon delayed response [2]
|
||||||
o nss: do not print misleading NSS error codes
|
o --libcurl: fix for non-zero default options
|
||||||
o configure: remove the --enable/disable-nonblocking options
|
o FTP: reject illegal port numbers in EPSV 229 responses
|
||||||
o darwinssl: add TLS 1.1 and 1.2 support, replace deprecated functions
|
o build: use per-target '_CPPFLAGS' for those currently using default
|
||||||
o NTLM: re-use existing connection better
|
o configure: fix automake 1.13 compatibility [6]
|
||||||
o schannel crash on multi and easy handle cleanup
|
o curl: ignore SIGPIPE [4]
|
||||||
o SOCKS: truly disable it if CURL_DISABLE_PROXY is defined [13]
|
o pop3: Added support for non-blocking SSL upgrade
|
||||||
o mk-ca-bundle: detect start of trust section better [14]
|
o pop3: Fixed default authentication detection
|
||||||
o gnutls: do not fail on non-fatal handshake errors [15]
|
o imap: Fixed usernames and passwords that contain escape characters
|
||||||
o SMTP: only send SIZE if supported [16]
|
o packages/DOS/common.dj: remove COFF debug info generation [3]
|
||||||
o ftpserver: respond with a 250 to SMTP EHLO
|
o imap/pop3/smtp: Fixed failure detection during TLS upgrade [8]
|
||||||
o ssh: do not crash if MD5 fingerprint is not provided by libssh2
|
o pop3: Fixed no known authentication mechanism when fallback is required [9]
|
||||||
o winbuild: Added support for building with SPNEGO enabled
|
o formadd: reject trying to read a directory where a file is expected [10]
|
||||||
o metalink: Fixed validation of binary files containing EOF
|
o formpost: support quotes, commas and semicolon in file names [11]
|
||||||
o setup.h: fixed for MS VC10 build [18]
|
o docs: update the comments about loading CA certs with NSS [12]
|
||||||
o cmake: use standard findxxx modules for cmake v2.8+
|
o docs: fix typos in man pages [13]
|
||||||
o HTTP_ONLY: disable more protocols [19]
|
o darwinssl: Fix bug where packets were sometimes transmitted twice [14]
|
||||||
o Curl_reconnect_request: clear pointer on failure [20]
|
o winbuild: include version info for .dll .exe [15]
|
||||||
o https.c example: remember to call curl_global_init()
|
o schannel: Removed extended error connection setup flag [16]
|
||||||
o metalink: Filter resource URLs by type
|
o VMS: fix and generate the VMS build config
|
||||||
o multi interface: CURLOPT_LOW_SPEED_* fix during rate limitation [21]
|
|
||||||
o curl_schannel: Removed buffer limit and optimized buffer strategy
|
|
||||||
|
|
||||||
This release includes the following known bugs:
|
This release includes the following known bugs:
|
||||||
|
|
||||||
@@ -65,35 +69,32 @@ This release includes the following known bugs:
|
|||||||
This release would not have looked like this without help, code, reports and
|
This release would not have looked like this without help, code, reports and
|
||||||
advice from friends like these:
|
advice from friends like these:
|
||||||
|
|
||||||
Guenter Knauf, Joe Mason, Kamil Dudka, Steve Holme, Anthony G. Basile,
|
Nick Zitzmann, Colin Watson, Fabian Keil, Kamil Dudka, Lijo Antony,
|
||||||
Edward Sheldrake, Jan Koen Annot, Maxime Larocque, Mike Crowe, Anthony Bryan,
|
Linus Nielsen Feltzing, Marc Hoersken, Stanislav Ivochkin, Steve Holme,
|
||||||
Nick Zitzmann, Gisle Vanem, Armel Asselin, Dan Fandrich, Dave Reisner,
|
Yang Tse, Balaji Parasuram, Dan Fandrich, Bob Relyea, Gisle Vanem,
|
||||||
Gokhan Sengun, Sara Golemon, Olivier Berger, Marc Hoersken, David Blaikie,
|
Yves Arrouye, Kai Engert, Lluís Batlle i Rossell, Jirí Hruka,
|
||||||
Alessandro Ghedini, František Kučera, Marcel Raad, Scott Bailey, Ho-chi Chen,
|
John E. Malmberg, Tor Arntsen, Matt Arsenault, Sergei Nikulov,
|
||||||
Tomas Mlcoch, Jie He, Tatsuhiro Tsujikawa, Sergei Nikulov, Mark Tully
|
Guenter Knauf, Craig Davison, Ulrich Doehner, Jiri Jaburek, Bruno de Carvalho,
|
||||||
|
Eldar Zaitov
|
||||||
|
|
||||||
Thanks! (and sorry if I forgot to mention someone)
|
Thanks! (and sorry if I forgot to mention someone)
|
||||||
|
|
||||||
References to bug reports and discussions on issues:
|
References to bug reports and discussions on issues:
|
||||||
|
|
||||||
[1] = http://curl.haxx.se/bug/view.cgi?id=3544688
|
[1] = http://daniel.haxx.se/blog/2013/01/17/internally-were-all-multi-now/
|
||||||
[2] = http://curl.haxx.se/bug/view.cgi?id=3551460
|
[2] = http://curl.haxx.se/mail/lib-2013-01/0191.html
|
||||||
[3] = http://curl.haxx.se/bug/view.cgi?id=3552997
|
[3] = http://curl.haxx.se/mail/lib-2013-01/0130.html
|
||||||
[4] = http://curl.haxx.se/bug/view.cgi?id=3546353
|
[4] = http://curl.haxx.se/bug/view.cgi?id=1180
|
||||||
[5] = http://curl.haxx.se/bug/view.cgi?id=3554668
|
[5] = http://curl.haxx.se/mail/lib-2013-01/0045.html
|
||||||
[6] = https://bugzilla.redhat.com/844385
|
[6] = http://curl.haxx.se/mail/lib-2012-12/0246.html
|
||||||
[7] = http://curl.haxx.se/mail/lib-2012-07/0271.html
|
[7] = http://curl.haxx.se/bug/view.cgi?id=1173
|
||||||
[8] = http://curl.haxx.se/mail/lib-2012-07/0310.html
|
[8] = http://curl.haxx.se/mail/lib-2013-01/0250.html
|
||||||
[9] = http://curl.haxx.se/bug/view.cgi?id=3545398
|
[9] = http://curl.haxx.se/mail/lib-2013-02/0004.html
|
||||||
[10] = http://curl.haxx.se/mail/lib-2012-07/0111.html
|
[10] = http://curl.haxx.se/mail/archive-2013-01/0017.html
|
||||||
[11] = http://curl.haxx.se/mail/lib-2012-07/0122.html
|
[11] = http://curl.haxx.se/bug/view.cgi?id=1171
|
||||||
[12] = http://daniel.haxx.se/blog/2012/09/03/introducing-curl_multi_wait/
|
[12] = https://bugzilla.redhat.com/696783
|
||||||
[13] = http://curl.haxx.se/bug/view.cgi?id=3561305
|
[13] = https://bugzilla.redhat.com/896544
|
||||||
[14] = http://curl.haxx.se/mail/lib-2012-09/0019.html
|
[14] = http://curl.haxx.se/mail/lib-2013-01/0295.html
|
||||||
[15] = http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=685402
|
[15] = http://curl.haxx.se/bug/view.cgi?id=1186
|
||||||
[16] = http://curl.haxx.se/bug/view.cgi?id=3564114
|
[16] = http://curl.haxx.se/bug/view.cgi?id=1187
|
||||||
[17] = http://curl.haxx.se/bug/view.cgi?id=3566860
|
[17] = http://curl.haxx.se/docs/adv_20130206.html
|
||||||
[18] = http://curl.haxx.se/bug/view.cgi?id=3568327
|
|
||||||
[19] = http://curl.haxx.se/mail/lib-2012-09/0127.html
|
|
||||||
[20] = http://curl.haxx.se/mail/lib-2012-09/0188.html
|
|
||||||
[21] = http://curl.haxx.se/mail/lib-2012-09/0081.html
|
|
||||||
|
|||||||
59
acinclude.m4
59
acinclude.m4
@@ -130,7 +130,7 @@ int main (void)
|
|||||||
]])
|
]])
|
||||||
],[
|
],[
|
||||||
tst_lib_xnet_required="yes"
|
tst_lib_xnet_required="yes"
|
||||||
LIBS="$LIBS -lxnet"
|
LIBS="-lxnet $LIBS"
|
||||||
])
|
])
|
||||||
AC_MSG_RESULT([$tst_lib_xnet_required])
|
AC_MSG_RESULT([$tst_lib_xnet_required])
|
||||||
])
|
])
|
||||||
@@ -150,6 +150,7 @@ AC_DEFUN([CURL_CHECK_AIX_ALL_SOURCE], [
|
|||||||
#endif])
|
#endif])
|
||||||
AC_BEFORE([$0], [AC_SYS_LARGEFILE])dnl
|
AC_BEFORE([$0], [AC_SYS_LARGEFILE])dnl
|
||||||
AC_BEFORE([$0], [CURL_CONFIGURE_REENTRANT])dnl
|
AC_BEFORE([$0], [CURL_CONFIGURE_REENTRANT])dnl
|
||||||
|
AC_BEFORE([$0], [CURL_CONFIGURE_PULL_SYS_POLL])dnl
|
||||||
AC_MSG_CHECKING([if OS is AIX (to define _ALL_SOURCE)])
|
AC_MSG_CHECKING([if OS is AIX (to define _ALL_SOURCE)])
|
||||||
AC_EGREP_CPP([yes_this_is_aix],[
|
AC_EGREP_CPP([yes_this_is_aix],[
|
||||||
#ifdef _AIX
|
#ifdef _AIX
|
||||||
@@ -2153,7 +2154,6 @@ AC_DEFUN([CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC], [
|
|||||||
else
|
else
|
||||||
LIBS="$curl_cv_gclk_LIBS $curl_cv_save_LIBS"
|
LIBS="$curl_cv_gclk_LIBS $curl_cv_save_LIBS"
|
||||||
fi
|
fi
|
||||||
CURL_LIBS="$CURL_LIBS $curl_cv_gclk_LIBS"
|
|
||||||
AC_MSG_RESULT([$curl_cv_gclk_LIBS])
|
AC_MSG_RESULT([$curl_cv_gclk_LIBS])
|
||||||
ac_cv_func_clock_gettime="yes"
|
ac_cv_func_clock_gettime="yes"
|
||||||
;;
|
;;
|
||||||
@@ -2310,6 +2310,8 @@ AC_DEFUN([CURL_CONFIGURE_CURL_SOCKLEN_T], [
|
|||||||
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
AC_REQUIRE([CURL_INCLUDES_SYS_SOCKET])dnl
|
||||||
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
AC_REQUIRE([CURL_PREPROCESS_CALLCONV])dnl
|
||||||
#
|
#
|
||||||
|
AC_BEFORE([$0], [CURL_CONFIGURE_PULL_SYS_POLL])dnl
|
||||||
|
#
|
||||||
AC_MSG_CHECKING([for curl_socklen_t data type])
|
AC_MSG_CHECKING([for curl_socklen_t data type])
|
||||||
curl_typeof_curl_socklen_t="unknown"
|
curl_typeof_curl_socklen_t="unknown"
|
||||||
for arg1 in int SOCKET; do
|
for arg1 in int SOCKET; do
|
||||||
@@ -2418,6 +2420,45 @@ AC_DEFUN([CURL_CONFIGURE_CURL_SOCKLEN_T], [
|
|||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
dnl CURL_CONFIGURE_PULL_SYS_POLL
|
||||||
|
dnl -------------------------------------------------
|
||||||
|
dnl Find out if system header file sys/poll.h must be included by the
|
||||||
|
dnl external interface, making appropriate definitions for template file
|
||||||
|
dnl include/curl/curlbuild.h.in to properly configure and use the library.
|
||||||
|
dnl
|
||||||
|
dnl The need for the sys/poll.h inclusion arises mainly to properly
|
||||||
|
dnl interface AIX systems which define macros 'events' and 'revents'.
|
||||||
|
|
||||||
|
AC_DEFUN([CURL_CONFIGURE_PULL_SYS_POLL], [
|
||||||
|
AC_REQUIRE([CURL_INCLUDES_POLL])dnl
|
||||||
|
#
|
||||||
|
tst_poll_events_macro_defined="unknown"
|
||||||
|
#
|
||||||
|
AC_COMPILE_IFELSE([
|
||||||
|
AC_LANG_PROGRAM([[
|
||||||
|
$curl_includes_poll
|
||||||
|
]],[[
|
||||||
|
#if defined(events) || defined(revents)
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
force compilation error
|
||||||
|
#endif
|
||||||
|
]])
|
||||||
|
],[
|
||||||
|
tst_poll_events_macro_defined="yes"
|
||||||
|
],[
|
||||||
|
tst_poll_events_macro_defined="no"
|
||||||
|
])
|
||||||
|
#
|
||||||
|
if test "$tst_poll_events_macro_defined" = "yes"; then
|
||||||
|
if test "x$ac_cv_header_sys_poll_h" = "xyes"; then
|
||||||
|
CURL_DEFINE_UNQUOTED([CURL_PULL_SYS_POLL_H])
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
])
|
||||||
|
|
||||||
|
|
||||||
dnl CURL_CHECK_FUNC_SELECT
|
dnl CURL_CHECK_FUNC_SELECT
|
||||||
dnl -------------------------------------------------
|
dnl -------------------------------------------------
|
||||||
dnl Test if the socket select() function is available,
|
dnl Test if the socket select() function is available,
|
||||||
@@ -3215,8 +3256,8 @@ AC_DEFUN([CURL_EXPORT_PCDIR], [
|
|||||||
|
|
||||||
dnl CURL_CHECK_PKGCONFIG ($module, [$pcdir])
|
dnl CURL_CHECK_PKGCONFIG ($module, [$pcdir])
|
||||||
dnl ------------------------
|
dnl ------------------------
|
||||||
dnl search for the pkg-config tool (if not cross-compiling). Set the PKGCONFIG
|
dnl search for the pkg-config tool. Set the PKGCONFIG variable to hold the
|
||||||
dnl variable to hold the path to it, or 'no' if not found/present.
|
dnl path to it, or 'no' if not found/present.
|
||||||
dnl
|
dnl
|
||||||
dnl If pkg-config is present, check that it has info about the $module or
|
dnl If pkg-config is present, check that it has info about the $module or
|
||||||
dnl return "no" anyway!
|
dnl return "no" anyway!
|
||||||
@@ -3228,15 +3269,7 @@ AC_DEFUN([CURL_CHECK_PKGCONFIG], [
|
|||||||
|
|
||||||
PKGCONFIG="no"
|
PKGCONFIG="no"
|
||||||
|
|
||||||
if test x$cross_compiling = xyes; then
|
AC_PATH_TOOL( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin)
|
||||||
dnl see if there's a pkg-specific for this host setup
|
|
||||||
AC_PATH_PROG( PKGCONFIG, ${host}-pkg-config, no,
|
|
||||||
$PATH:/usr/bin:/usr/local/bin)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test x$PKGCONFIG = xno; then
|
|
||||||
AC_PATH_PROG( PKGCONFIG, pkg-config, no, $PATH:/usr/bin:/usr/local/bin)
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test x$PKGCONFIG != xno; then
|
if test x$PKGCONFIG != xno; then
|
||||||
AC_MSG_CHECKING([for $1 options with pkg-config])
|
AC_MSG_CHECKING([for $1 options with pkg-config])
|
||||||
|
|||||||
@@ -12,9 +12,9 @@ ECHO ERROR: This file shall only be used with a curl git tree checkout.
|
|||||||
goto end_all
|
goto end_all
|
||||||
:start_doing
|
:start_doing
|
||||||
|
|
||||||
REM create hugehelp.c
|
REM create tool_hugehelp.c
|
||||||
if not exist src\hugehelp.c.cvs goto end_hugehelp_c
|
if not exist src\tool_hugehelp.c.cvs goto end_hugehelp_c
|
||||||
copy /Y src\hugehelp.c.cvs src\hugehelp.c
|
copy /Y src\tool_hugehelp.c.cvs src\tool_hugehelp.c
|
||||||
:end_hugehelp_c
|
:end_hugehelp_c
|
||||||
|
|
||||||
REM create Makefile
|
REM create Makefile
|
||||||
|
|||||||
345
configure.ac
345
configure.ac
@@ -5,7 +5,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -27,15 +27,16 @@ dnl We don't know the version number "statically" so we use a dash here
|
|||||||
AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/])
|
AC_INIT([curl], [-], [a suitable curl mailing list: http://curl.haxx.se/mail/])
|
||||||
|
|
||||||
XC_OVR_ZZ50
|
XC_OVR_ZZ50
|
||||||
|
XC_OVR_ZZ60
|
||||||
CURL_OVERRIDE_AUTOCONF
|
CURL_OVERRIDE_AUTOCONF
|
||||||
|
|
||||||
dnl configure script copyright
|
dnl configure script copyright
|
||||||
AC_COPYRIGHT([Copyright (c) 1998 - 2012 Daniel Stenberg, <daniel@haxx.se>
|
AC_COPYRIGHT([Copyright (c) 1998 - 2013 Daniel Stenberg, <daniel@haxx.se>
|
||||||
This configure script may be copied, distributed and modified under the
|
This configure script may be copied, distributed and modified under the
|
||||||
terms of the curl license; see COPYING for more details])
|
terms of the curl license; see COPYING for more details])
|
||||||
|
|
||||||
AC_CONFIG_SRCDIR([lib/urldata.h])
|
AC_CONFIG_SRCDIR([lib/urldata.h])
|
||||||
AM_CONFIG_HEADER(lib/curl_config.h include/curl/curlbuild.h)
|
AC_CONFIG_HEADERS(lib/curl_config.h include/curl/curlbuild.h)
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
AM_MAINTAINER_MODE
|
AM_MAINTAINER_MODE
|
||||||
|
|
||||||
@@ -47,7 +48,7 @@ CURL_CHECK_OPTION_CURLDEBUG
|
|||||||
CURL_CHECK_OPTION_SYMBOL_HIDING
|
CURL_CHECK_OPTION_SYMBOL_HIDING
|
||||||
CURL_CHECK_OPTION_ARES
|
CURL_CHECK_OPTION_ARES
|
||||||
|
|
||||||
CURL_CHECK_PATH_SEPARATOR_REQUIRED
|
XC_CHECK_PATH_SEPARATOR
|
||||||
|
|
||||||
#
|
#
|
||||||
# save the configure arguments
|
# save the configure arguments
|
||||||
@@ -124,6 +125,7 @@ fi
|
|||||||
|
|
||||||
dnl figure out the libcurl version
|
dnl figure out the libcurl version
|
||||||
CURLVERSION=`$SED -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curlver.h`
|
CURLVERSION=`$SED -ne 's/^#define LIBCURL_VERSION "\(.*\)"/\1/p' ${srcdir}/include/curl/curlver.h`
|
||||||
|
XC_CHECK_PROG_CC
|
||||||
AM_INIT_AUTOMAKE
|
AM_INIT_AUTOMAKE
|
||||||
AC_MSG_CHECKING([curl version])
|
AC_MSG_CHECKING([curl version])
|
||||||
AC_MSG_RESULT($CURLVERSION)
|
AC_MSG_RESULT($CURLVERSION)
|
||||||
@@ -145,7 +147,7 @@ AC_SUBST(PKGADD_VENDOR)
|
|||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl initialize all the info variables
|
dnl initialize all the info variables
|
||||||
curl_ssl_msg="no (--with-{ssl,gnutls,nss,polarssl,cyassl,axtls,winssl} )"
|
curl_ssl_msg="no (--with-{ssl,gnutls,nss,polarssl,cyassl,axtls,winssl,darwinssl} )"
|
||||||
curl_ssh_msg="no (--with-libssh2)"
|
curl_ssh_msg="no (--with-libssh2)"
|
||||||
curl_zlib_msg="no (--with-zlib)"
|
curl_zlib_msg="no (--with-zlib)"
|
||||||
curl_krb4_msg="no (--with-krb4*)"
|
curl_krb4_msg="no (--with-krb4*)"
|
||||||
@@ -168,9 +170,10 @@ curl_verbose_msg="enabled (--disable-verbose)"
|
|||||||
init_ssl_msg=${curl_ssl_msg}
|
init_ssl_msg=${curl_ssl_msg}
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl Save anything in $LIBS for later
|
dnl Save some initial values the user might have provided
|
||||||
dnl
|
dnl
|
||||||
ALL_LIBS=$LIBS
|
INITIAL_LDFLAGS=$LDFLAGS
|
||||||
|
INITIAL_LIBS=$LIBS
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl Detect the canonical host and target build environment
|
dnl Detect the canonical host and target build environment
|
||||||
@@ -181,7 +184,6 @@ dnl Get system canonical name
|
|||||||
AC_DEFINE_UNQUOTED(OS, "${host}", [cpu-machine-OS])
|
AC_DEFINE_UNQUOTED(OS, "${host}", [cpu-machine-OS])
|
||||||
|
|
||||||
dnl Checks for programs.
|
dnl Checks for programs.
|
||||||
CURL_CHECK_PROG_CC
|
|
||||||
|
|
||||||
dnl Our curl_off_t internal and external configure settings
|
dnl Our curl_off_t internal and external configure settings
|
||||||
CURL_CONFIGURE_CURL_OFF_T
|
CURL_CONFIGURE_CURL_OFF_T
|
||||||
@@ -273,6 +275,7 @@ else
|
|||||||
REQUIRE_LIB_DEPS=yes
|
REQUIRE_LIB_DEPS=yes
|
||||||
fi
|
fi
|
||||||
AC_SUBST(REQUIRE_LIB_DEPS)
|
AC_SUBST(REQUIRE_LIB_DEPS)
|
||||||
|
AM_CONDITIONAL(USE_EXPLICIT_LIB_DEPS, test x$REQUIRE_LIB_DEPS = xyes)
|
||||||
|
|
||||||
dnl The install stuff has already been taken care of by the automake stuff
|
dnl The install stuff has already been taken care of by the automake stuff
|
||||||
dnl AC_PROG_INSTALL
|
dnl AC_PROG_INSTALL
|
||||||
@@ -305,6 +308,7 @@ fi
|
|||||||
|
|
||||||
CURL_CHECK_COMPILER_HALT_ON_ERROR
|
CURL_CHECK_COMPILER_HALT_ON_ERROR
|
||||||
CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE
|
CURL_CHECK_COMPILER_ARRAY_SIZE_NEGATIVE
|
||||||
|
CURL_CHECK_COMPILER_PROTOTYPE_MISMATCH
|
||||||
CURL_CHECK_COMPILER_SYMBOL_HIDING
|
CURL_CHECK_COMPILER_SYMBOL_HIDING
|
||||||
|
|
||||||
CURL_CHECK_NO_UNDEFINED
|
CURL_CHECK_NO_UNDEFINED
|
||||||
@@ -681,6 +685,20 @@ dnl **********************************************************************
|
|||||||
dnl Checks for libraries.
|
dnl Checks for libraries.
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([whether to use libgcc])
|
||||||
|
AC_ARG_ENABLE(libgcc,
|
||||||
|
AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]),
|
||||||
|
[ case "$enableval" in
|
||||||
|
yes)
|
||||||
|
LIBS="-lgcc $LIBS"
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
;;
|
||||||
|
*) AC_MSG_RESULT(no)
|
||||||
|
;;
|
||||||
|
esac ],
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
)
|
||||||
|
|
||||||
CURL_CHECK_LIB_XNET
|
CURL_CHECK_LIB_XNET
|
||||||
|
|
||||||
dnl gethostbyname without lib or in the nsl lib?
|
dnl gethostbyname without lib or in the nsl lib?
|
||||||
@@ -689,7 +707,7 @@ AC_CHECK_FUNC(gethostbyname,
|
|||||||
],
|
],
|
||||||
[ AC_CHECK_LIB(nsl, gethostbyname,
|
[ AC_CHECK_LIB(nsl, gethostbyname,
|
||||||
[HAVE_GETHOSTBYNAME="1"
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
LIBS="$LIBS -lnsl"
|
LIBS="-lnsl $LIBS"
|
||||||
])
|
])
|
||||||
])
|
])
|
||||||
|
|
||||||
@@ -698,7 +716,7 @@ then
|
|||||||
dnl gethostbyname in the socket lib?
|
dnl gethostbyname in the socket lib?
|
||||||
AC_CHECK_LIB(socket, gethostbyname,
|
AC_CHECK_LIB(socket, gethostbyname,
|
||||||
[HAVE_GETHOSTBYNAME="1"
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
LIBS="$LIBS -lsocket"
|
LIBS="-lsocket $LIBS"
|
||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -709,7 +727,7 @@ then
|
|||||||
[HAVE_GETHOSTBYNAME="1"
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
CPPFLAGS="-I/dev/env/WATT_ROOT/inc"
|
CPPFLAGS="-I/dev/env/WATT_ROOT/inc"
|
||||||
LDFLAGS="-L/dev/env/WATT_ROOT/lib"
|
LDFLAGS="-L/dev/env/WATT_ROOT/lib"
|
||||||
LIBS="$LIBS -lwatt"
|
LIBS="-lwatt $LIBS"
|
||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -828,7 +846,7 @@ then
|
|||||||
dnl gethostbyname in the network lib - for Haiku OS
|
dnl gethostbyname in the network lib - for Haiku OS
|
||||||
AC_CHECK_LIB(network, gethostbyname,
|
AC_CHECK_LIB(network, gethostbyname,
|
||||||
[HAVE_GETHOSTBYNAME="1"
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
LIBS="$LIBS -lnetwork"
|
LIBS="-lnetwork $LIBS"
|
||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -837,7 +855,7 @@ then
|
|||||||
dnl gethostbyname in the net lib - for BeOS
|
dnl gethostbyname in the net lib - for BeOS
|
||||||
AC_CHECK_LIB(net, gethostbyname,
|
AC_CHECK_LIB(net, gethostbyname,
|
||||||
[HAVE_GETHOSTBYNAME="1"
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
LIBS="$LIBS -lnet"
|
LIBS="-lnet $LIBS"
|
||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -869,26 +887,109 @@ CURL_CHECK_LIBS_CLOCK_GETTIME_MONOTONIC
|
|||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl The preceding library checks are all potentially useful for test
|
dnl The preceding library checks are all potentially useful for test
|
||||||
dnl servers (for providing networking support). Save the list of required
|
dnl servers and libtest cases which require networking and clock_gettime
|
||||||
dnl libraries at this point for use while linking those test servers.
|
dnl support. Save the list of required libraries at this point for use
|
||||||
|
dnl while linking those test servers and programs.
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
TEST_SERVER_LIBS=$LIBS
|
CURL_NETWORK_AND_TIME_LIBS=$LIBS
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
AC_MSG_CHECKING([whether to use libgcc])
|
dnl Check for the presence of ZLIB libraries and headers
|
||||||
AC_ARG_ENABLE(libgcc,
|
dnl **********************************************************************
|
||||||
AC_HELP_STRING([--enable-libgcc],[use libgcc when linking]),
|
|
||||||
[ case "$enableval" in
|
dnl Check for & handle argument to --with-zlib.
|
||||||
yes)
|
|
||||||
ALL_LIBS="$ALL_LIBS -lgcc"
|
clean_CPPFLAGS=$CPPFLAGS
|
||||||
AC_MSG_RESULT(yes)
|
clean_LDFLAGS=$LDFLAGS
|
||||||
;;
|
clean_LIBS=$LIBS
|
||||||
*) AC_MSG_RESULT(no)
|
ZLIB_LIBS=""
|
||||||
;;
|
AC_ARG_WITH(zlib,
|
||||||
esac ],
|
AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH])
|
||||||
AC_MSG_RESULT(no)
|
AC_HELP_STRING([--without-zlib],[disable use of zlib]),
|
||||||
|
[OPT_ZLIB="$withval"])
|
||||||
|
|
||||||
|
if test "$OPT_ZLIB" = "no" ; then
|
||||||
|
AC_MSG_WARN([zlib disabled])
|
||||||
|
else
|
||||||
|
if test "$OPT_ZLIB" = "yes" ; then
|
||||||
|
OPT_ZLIB=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -z "$OPT_ZLIB" ; then
|
||||||
|
dnl check for the lib first without setting any new path, since many
|
||||||
|
dnl people have it in the default path
|
||||||
|
|
||||||
|
AC_CHECK_LIB(z, inflateEnd,
|
||||||
|
dnl libz found, set the variable
|
||||||
|
[HAVE_LIBZ="1"
|
||||||
|
LIBS="-lz $LIBS"],
|
||||||
|
dnl if no lib found, try /usr/local
|
||||||
|
[OPT_ZLIB="/usr/local"])
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
dnl Add a nonempty path to the compiler flags
|
||||||
|
if test -n "$OPT_ZLIB"; then
|
||||||
|
CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include"
|
||||||
|
LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff"
|
||||||
|
fi
|
||||||
|
|
||||||
|
AC_CHECK_HEADER(zlib.h,
|
||||||
|
[
|
||||||
|
dnl zlib.h was found
|
||||||
|
HAVE_ZLIB_H="1"
|
||||||
|
dnl if the lib wasn't found already, try again with the new paths
|
||||||
|
if test "$HAVE_LIBZ" != "1"; then
|
||||||
|
AC_CHECK_LIB(z, gzread,
|
||||||
|
[
|
||||||
|
dnl the lib was found!
|
||||||
|
HAVE_LIBZ="1"
|
||||||
|
LIBS="-lz $LIBS"
|
||||||
|
],
|
||||||
|
[ CPPFLAGS=$clean_CPPFLAGS
|
||||||
|
LDFLAGS=$clean_LDFLAGS])
|
||||||
|
fi
|
||||||
|
],
|
||||||
|
[
|
||||||
|
dnl zlib.h was not found, restore the flags
|
||||||
|
CPPFLAGS=$clean_CPPFLAGS
|
||||||
|
LDFLAGS=$clean_LDFLAGS]
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" != "1"
|
||||||
|
then
|
||||||
|
AC_MSG_WARN([configure found only the libz lib, not the header file!])
|
||||||
|
HAVE_LIBZ=""
|
||||||
|
CPPFLAGS=$clean_CPPFLAGS
|
||||||
|
LDFLAGS=$clean_LDFLAGS
|
||||||
|
LIBS=$clean_LIBS
|
||||||
|
elif test "$HAVE_LIBZ" != "1" && test "$HAVE_ZLIB_H" = "1"
|
||||||
|
then
|
||||||
|
AC_MSG_WARN([configure found only the libz header file, not the lib!])
|
||||||
|
CPPFLAGS=$clean_CPPFLAGS
|
||||||
|
LDFLAGS=$clean_LDFLAGS
|
||||||
|
LIBS=$clean_LIBS
|
||||||
|
elif test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" = "1"
|
||||||
|
then
|
||||||
|
dnl both header and lib were found!
|
||||||
|
AC_SUBST(HAVE_LIBZ)
|
||||||
|
AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file])
|
||||||
|
AC_DEFINE(HAVE_LIBZ, 1, [if zlib is available])
|
||||||
|
|
||||||
|
ZLIB_LIBS="-lz"
|
||||||
|
LIBS="-lz $clean_LIBS"
|
||||||
|
|
||||||
|
dnl replace 'HAVE_LIBZ' in the automake makefile.ams
|
||||||
|
AMFIXLIB="1"
|
||||||
|
AC_MSG_NOTICE([found both libz and libz.h header])
|
||||||
|
curl_zlib_msg="enabled"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
dnl set variable for use in automakefile(s)
|
||||||
|
AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1)
|
||||||
|
AC_SUBST(ZLIB_LIBS)
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for LDAP
|
dnl Check for LDAP
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -1313,29 +1414,29 @@ if test x"$want_gss" = xyes; then
|
|||||||
if test -n "$gnu_gss"; then
|
if test -n "$gnu_gss"; then
|
||||||
curl_gss_msg="enabled (GNU GSS)"
|
curl_gss_msg="enabled (GNU GSS)"
|
||||||
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
||||||
LIBS="$LIBS -lgss"
|
LIBS="-lgss $LIBS"
|
||||||
elif test -z "$GSSAPI_LIB_DIR"; then
|
elif test -z "$GSSAPI_LIB_DIR"; then
|
||||||
case $host in
|
case $host in
|
||||||
*-*-darwin*)
|
*-*-darwin*)
|
||||||
LIBS="$LIBS -lgssapi_krb5 -lresolv"
|
LIBS="-lgssapi_krb5 -lresolv $LIBS"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
if test -f "$GSSAPI_ROOT/bin/krb5-config"; then
|
if test -f "$GSSAPI_ROOT/bin/krb5-config"; then
|
||||||
dnl krb5-config doesn't have --libs-only-L or similar, put everything
|
dnl krb5-config doesn't have --libs-only-L or similar, put everything
|
||||||
dnl into LIBS
|
dnl into LIBS
|
||||||
gss_libs=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi`
|
gss_libs=`$GSSAPI_ROOT/bin/krb5-config --libs gssapi`
|
||||||
LIBS="$LIBS $gss_libs"
|
LIBS="$gss_libs $LIBS"
|
||||||
elif test "$GSSAPI_ROOT" != "yes"; then
|
elif test "$GSSAPI_ROOT" != "yes"; then
|
||||||
LDFLAGS="$LDFLAGS -L$GSSAPI_ROOT/lib$libsuff"
|
LDFLAGS="$LDFLAGS -L$GSSAPI_ROOT/lib$libsuff"
|
||||||
LIBS="$LIBS -lgssapi"
|
LIBS="-lgssapi $LIBS"
|
||||||
else
|
else
|
||||||
LIBS="$LIBS -lgssapi"
|
LIBS="-lgssapi $LIBS"
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
else
|
else
|
||||||
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
LDFLAGS="$LDFLAGS $GSSAPI_LIB_DIR"
|
||||||
LIBS="$LIBS -lgssapi"
|
LIBS="-lgssapi $LIBS"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
CPPFLAGS="$save_CPPFLAGS"
|
CPPFLAGS="$save_CPPFLAGS"
|
||||||
@@ -1482,7 +1583,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then
|
|||||||
dnl the argument to --with-ssl we don't know what
|
dnl the argument to --with-ssl we don't know what
|
||||||
dnl additional libs may be necessary. Hope that we
|
dnl additional libs may be necessary. Hope that we
|
||||||
dnl don't need any.
|
dnl don't need any.
|
||||||
LIBS="$LIBS $SSL_LIBS"
|
LIBS="$SSL_LIBS $LIBS"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -1534,7 +1635,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then
|
|||||||
dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff
|
dnl we didn't find the SSL lib, try the RSAglue/rsaref stuff
|
||||||
AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use);
|
AC_MSG_CHECKING(for ssl with RSAglue/rsaref libs in use);
|
||||||
OLIBS=$LIBS
|
OLIBS=$LIBS
|
||||||
LIBS="$LIBS -lRSAglue -lrsaref"
|
LIBS="-lRSAglue -lrsaref $LIBS"
|
||||||
AC_CHECK_LIB(ssl, SSL_connect)
|
AC_CHECK_LIB(ssl, SSL_connect)
|
||||||
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
if test "$ac_cv_lib_ssl_SSL_connect" != yes; then
|
||||||
dnl still no SSL_connect
|
dnl still no SSL_connect
|
||||||
@@ -1649,92 +1750,6 @@ if test "$curl_ssl_msg" = "$init_ssl_msg" && test X"$OPT_SSL" != Xno; then
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dnl **********************************************************************
|
|
||||||
dnl Check for the presence of ZLIB libraries and headers
|
|
||||||
dnl **********************************************************************
|
|
||||||
|
|
||||||
dnl Check for & handle argument to --with-zlib.
|
|
||||||
|
|
||||||
_cppflags=$CPPFLAGS
|
|
||||||
_ldflags=$LDFLAGS
|
|
||||||
AC_ARG_WITH(zlib,
|
|
||||||
AC_HELP_STRING([--with-zlib=PATH],[search for zlib in PATH])
|
|
||||||
AC_HELP_STRING([--without-zlib],[disable use of zlib]),
|
|
||||||
[OPT_ZLIB="$withval"])
|
|
||||||
|
|
||||||
if test "$OPT_ZLIB" = "no" ; then
|
|
||||||
AC_MSG_WARN([zlib disabled])
|
|
||||||
else
|
|
||||||
if test "$OPT_ZLIB" = "yes" ; then
|
|
||||||
OPT_ZLIB=""
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test -z "$OPT_ZLIB" ; then
|
|
||||||
dnl check for the lib first without setting any new path, since many
|
|
||||||
dnl people have it in the default path
|
|
||||||
|
|
||||||
AC_CHECK_LIB(z, inflateEnd,
|
|
||||||
dnl libz found, set the variable
|
|
||||||
[HAVE_LIBZ="1"],
|
|
||||||
dnl if no lib found, try /usr/local
|
|
||||||
[OPT_ZLIB="/usr/local"])
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl Add a nonempty path to the compiler flags
|
|
||||||
if test -n "$OPT_ZLIB"; then
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$OPT_ZLIB/include"
|
|
||||||
LDFLAGS="$LDFLAGS -L$OPT_ZLIB/lib$libsuff"
|
|
||||||
fi
|
|
||||||
|
|
||||||
AC_CHECK_HEADER(zlib.h,
|
|
||||||
[
|
|
||||||
dnl zlib.h was found
|
|
||||||
HAVE_ZLIB_H="1"
|
|
||||||
dnl if the lib wasn't found already, try again with the new paths
|
|
||||||
if test "$HAVE_LIBZ" != "1"; then
|
|
||||||
AC_CHECK_LIB(z, gzread,
|
|
||||||
[
|
|
||||||
dnl the lib was found!
|
|
||||||
HAVE_LIBZ="1"
|
|
||||||
],
|
|
||||||
[ CPPFLAGS=$_cppflags
|
|
||||||
LDFLAGS=$_ldflags])
|
|
||||||
fi
|
|
||||||
],
|
|
||||||
[
|
|
||||||
dnl zlib.h was not found, restore the flags
|
|
||||||
CPPFLAGS=$_cppflags
|
|
||||||
LDFLAGS=$_ldflags]
|
|
||||||
)
|
|
||||||
|
|
||||||
if test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" != "1"
|
|
||||||
then
|
|
||||||
AC_MSG_WARN([configure found only the libz lib, not the header file!])
|
|
||||||
HAVE_LIBZ=""
|
|
||||||
elif test "$HAVE_LIBZ" != "1" && test "$HAVE_ZLIB_H" = "1"
|
|
||||||
then
|
|
||||||
AC_MSG_WARN([configure found only the libz header file, not the lib!])
|
|
||||||
elif test "$HAVE_LIBZ" = "1" && test "$HAVE_ZLIB_H" = "1"
|
|
||||||
then
|
|
||||||
dnl both header and lib were found!
|
|
||||||
AC_SUBST(HAVE_LIBZ)
|
|
||||||
AC_DEFINE(HAVE_ZLIB_H, 1, [if you have the zlib.h header file])
|
|
||||||
AC_DEFINE(HAVE_LIBZ, 1, [if zlib is available])
|
|
||||||
|
|
||||||
CURL_LIBS="$CURL_LIBS -lz"
|
|
||||||
LIBS="$LIBS -lz"
|
|
||||||
|
|
||||||
dnl replace 'HAVE_LIBZ' in the automake makefile.ams
|
|
||||||
AMFIXLIB="1"
|
|
||||||
AC_MSG_NOTICE([found both libz and libz.h header])
|
|
||||||
curl_zlib_msg="enabled"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl set variable for use in automakefile(s)
|
|
||||||
AM_CONDITIONAL(HAVE_LIBZ, test x"$AMFIXLIB" = x1)
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the random seed preferences
|
dnl Check for the random seed preferences
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -1799,6 +1814,11 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
if test X"$OPT_GNUTLS" != Xno; then
|
if test X"$OPT_GNUTLS" != Xno; then
|
||||||
|
|
||||||
addld=""
|
addld=""
|
||||||
|
addlib=""
|
||||||
|
gtlslib=""
|
||||||
|
version=""
|
||||||
|
addcflags=""
|
||||||
|
|
||||||
if test "x$OPT_GNUTLS" = "xyes"; then
|
if test "x$OPT_GNUTLS" = "xyes"; then
|
||||||
dnl this is with no partiular path given
|
dnl this is with no partiular path given
|
||||||
CURL_CHECK_PKGCONFIG(gnutls)
|
CURL_CHECK_PKGCONFIG(gnutls)
|
||||||
@@ -1849,9 +1869,9 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
|
|
||||||
CLEANLIBS="$LIBS"
|
CLEANLIBS="$LIBS"
|
||||||
CLEANCPPFLAGS="$CPPFLAGS"
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
CLEADLDFLAGS="$LDFLAGS"
|
CLEANLDFLAGS="$LDFLAGS"
|
||||||
|
|
||||||
LIBS="$LIBS $addlib"
|
LIBS="$addlib $LIBS"
|
||||||
LDFLAGS="$LDFLAGS $addld"
|
LDFLAGS="$LDFLAGS $addld"
|
||||||
if test "$addcflags" != "-I/usr/include"; then
|
if test "$addcflags" != "-I/usr/include"; then
|
||||||
CPPFLAGS="$CPPFLAGS $addcflags"
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
||||||
@@ -1916,9 +1936,9 @@ if test "$GNUTLS_ENABLED" = "1"; then
|
|||||||
if test "$USE_GNUTLS_NETTLE" = "1"; then
|
if test "$USE_GNUTLS_NETTLE" = "1"; then
|
||||||
AC_DEFINE(USE_GNUTLS_NETTLE, 1, [if GnuTLS uses nettle as crypto backend])
|
AC_DEFINE(USE_GNUTLS_NETTLE, 1, [if GnuTLS uses nettle as crypto backend])
|
||||||
AC_SUBST(USE_GNUTLS_NETTLE, [1])
|
AC_SUBST(USE_GNUTLS_NETTLE, [1])
|
||||||
LIBS="$LIBS -lnettle"
|
LIBS="-lnettle $LIBS"
|
||||||
else
|
else
|
||||||
LIBS="$LIBS -lgcrypt"
|
LIBS="-lgcrypt $LIBS"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -1969,6 +1989,11 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
addld=""
|
||||||
|
addlib=""
|
||||||
|
addcflags=""
|
||||||
|
polarssllib=""
|
||||||
|
|
||||||
if test "x$USE_POLARSSL" != "xyes"; then
|
if test "x$USE_POLARSSL" != "xyes"; then
|
||||||
dnl add the path and test again
|
dnl add the path and test again
|
||||||
addld=-L$OPT_POLARSSL/lib$libsuff
|
addld=-L$OPT_POLARSSL/lib$libsuff
|
||||||
@@ -1997,8 +2022,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
if test "x$USE_POLARSSL" = "xyes"; then
|
if test "x$USE_POLARSSL" = "xyes"; then
|
||||||
AC_MSG_NOTICE([detected PolarSSL])
|
AC_MSG_NOTICE([detected PolarSSL])
|
||||||
|
|
||||||
CURL_LIBS="$CURL_LIBS -lpolarssl"
|
LIBS="-lpolarssl $LIBS"
|
||||||
LIBS="$LIBS -lpolarssl"
|
|
||||||
|
|
||||||
if test -n "$polarssllib"; then
|
if test -n "$polarssllib"; then
|
||||||
dnl when shared libs were found in a path that the run-time
|
dnl when shared libs were found in a path that the run-time
|
||||||
@@ -2053,6 +2077,11 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
addld=""
|
||||||
|
addlib=""
|
||||||
|
addcflags=""
|
||||||
|
cyassllib=""
|
||||||
|
|
||||||
if test "x$USE_CYASSL" != "xyes"; then
|
if test "x$USE_CYASSL" != "xyes"; then
|
||||||
dnl add the path and test again
|
dnl add the path and test again
|
||||||
addld=-L$OPT_CYASSL/lib$libsuff
|
addld=-L$OPT_CYASSL/lib$libsuff
|
||||||
@@ -2081,8 +2110,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
if test "x$USE_CYASSL" = "xyes"; then
|
if test "x$USE_CYASSL" = "xyes"; then
|
||||||
AC_MSG_NOTICE([detected CyaSSL])
|
AC_MSG_NOTICE([detected CyaSSL])
|
||||||
|
|
||||||
CURL_LIBS="$CURL_LIBS -lcyassl -lm"
|
LIBS="-lcyassl -lm $LIBS"
|
||||||
LIBS="$LIBS -lcyassl -lm"
|
|
||||||
|
|
||||||
if test -n "$cyassllib"; then
|
if test -n "$cyassllib"; then
|
||||||
dnl when shared libs were found in a path that the run-time
|
dnl when shared libs were found in a path that the run-time
|
||||||
@@ -2117,6 +2145,13 @@ AC_HELP_STRING([--without-nss], [disable NSS detection]),
|
|||||||
if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
||||||
|
|
||||||
if test X"$OPT_NSS" != Xno; then
|
if test X"$OPT_NSS" != Xno; then
|
||||||
|
|
||||||
|
addld=""
|
||||||
|
addlib=""
|
||||||
|
addcflags=""
|
||||||
|
nssprefix=""
|
||||||
|
version=""
|
||||||
|
|
||||||
if test "x$OPT_NSS" = "xyes"; then
|
if test "x$OPT_NSS" = "xyes"; then
|
||||||
|
|
||||||
CURL_CHECK_PKGCONFIG(nss)
|
CURL_CHECK_PKGCONFIG(nss)
|
||||||
@@ -2154,7 +2189,7 @@ if test "$curl_ssl_msg" = "$init_ssl_msg"; then
|
|||||||
CLEANLIBS="$LIBS"
|
CLEANLIBS="$LIBS"
|
||||||
CLEANCPPFLAGS="$CPPFLAGS"
|
CLEANCPPFLAGS="$CPPFLAGS"
|
||||||
|
|
||||||
LIBS="$LIBS $addlib"
|
LIBS="$addlib $LIBS"
|
||||||
if test "$addcflags" != "-I/usr/include"; then
|
if test "$addcflags" != "-I/usr/include"; then
|
||||||
CPPFLAGS="$CPPFLAGS $addcflags"
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
||||||
fi
|
fi
|
||||||
@@ -2284,11 +2319,12 @@ AC_HELP_STRING([--without-libmetalink], [disable libmetalink detection]),
|
|||||||
|
|
||||||
if test X"$OPT_LIBMETALINK" != Xno; then
|
if test X"$OPT_LIBMETALINK" != Xno; then
|
||||||
|
|
||||||
addlib=""
|
|
||||||
addld=""
|
addld=""
|
||||||
|
addlib=""
|
||||||
addcflags=""
|
addcflags=""
|
||||||
version=""
|
version=""
|
||||||
libmetalinklib=""
|
libmetalinklib=""
|
||||||
|
|
||||||
PKGTEST="no"
|
PKGTEST="no"
|
||||||
if test "x$OPT_LIBMETALINK" = "xyes"; then
|
if test "x$OPT_LIBMETALINK" = "xyes"; then
|
||||||
dnl this is with no partiular path given
|
dnl this is with no partiular path given
|
||||||
@@ -2348,10 +2384,10 @@ if test X"$OPT_LIBMETALINK" != Xno; then
|
|||||||
AC_DEFINE(USE_METALINK, 1, [Define to enable metalink support])
|
AC_DEFINE(USE_METALINK, 1, [Define to enable metalink support])
|
||||||
LIBMETALINK_LIBS=$addlib
|
LIBMETALINK_LIBS=$addlib
|
||||||
LIBMETALINK_LDFLAGS=$addld
|
LIBMETALINK_LDFLAGS=$addld
|
||||||
LIBMETALINK_CFLAGS=$addcflags
|
LIBMETALINK_CPPFLAGS=$addcflags
|
||||||
AC_SUBST([LIBMETALINK_LIBS])
|
AC_SUBST([LIBMETALINK_LIBS])
|
||||||
AC_SUBST([LIBMETALINK_LDFLAGS])
|
AC_SUBST([LIBMETALINK_LDFLAGS])
|
||||||
AC_SUBST([LIBMETALINK_CFLAGS])
|
AC_SUBST([LIBMETALINK_CPPFLAGS])
|
||||||
curl_mtlnk_msg="enabled"
|
curl_mtlnk_msg="enabled"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -2408,7 +2444,7 @@ if test X"$OPT_LIBSSH2" != Xno; then
|
|||||||
|
|
||||||
LDFLAGS="$LDFLAGS $LD_SSH2"
|
LDFLAGS="$LDFLAGS $LD_SSH2"
|
||||||
CPPFLAGS="$CPPFLAGS $CPP_SSH2"
|
CPPFLAGS="$CPPFLAGS $CPP_SSH2"
|
||||||
LIBS="$LIBS $LIB_SSH2"
|
LIBS="$LIB_SSH2 $LIBS"
|
||||||
|
|
||||||
AC_CHECK_LIB(ssh2, libssh2_channel_open_ex)
|
AC_CHECK_LIB(ssh2, libssh2_channel_open_ex)
|
||||||
|
|
||||||
@@ -2504,7 +2540,7 @@ if test X"$OPT_LIBRTMP" != Xno; then
|
|||||||
|
|
||||||
LDFLAGS="$LDFLAGS $LD_RTMP"
|
LDFLAGS="$LDFLAGS $LD_RTMP"
|
||||||
CPPFLAGS="$CPPFLAGS $CPP_RTMP"
|
CPPFLAGS="$CPPFLAGS $CPP_RTMP"
|
||||||
LIBS="$LIBS $LIB_RTMP"
|
LIBS="$LIB_RTMP $LIBS"
|
||||||
|
|
||||||
AC_CHECK_LIB(rtmp, RTMP_Init,
|
AC_CHECK_LIB(rtmp, RTMP_Init,
|
||||||
[
|
[
|
||||||
@@ -2948,6 +2984,8 @@ AC_CHECK_TYPE([bool],[
|
|||||||
|
|
||||||
CURL_CONFIGURE_CURL_SOCKLEN_T
|
CURL_CONFIGURE_CURL_SOCKLEN_T
|
||||||
|
|
||||||
|
CURL_CONFIGURE_PULL_SYS_POLL
|
||||||
|
|
||||||
TYPE_IN_ADDR_T
|
TYPE_IN_ADDR_T
|
||||||
|
|
||||||
TYPE_SOCKADDR_STORAGE
|
TYPE_SOCKADDR_STORAGE
|
||||||
@@ -3310,33 +3348,21 @@ AC_HELP_STRING([--disable-soname-bump],[Disable enforced SONAME bump]),
|
|||||||
)
|
)
|
||||||
AM_CONDITIONAL(SONAME_BUMP, test x$soname_bump = xyes)
|
AM_CONDITIONAL(SONAME_BUMP, test x$soname_bump = xyes)
|
||||||
|
|
||||||
|
|
||||||
dnl ************************************************************
|
|
||||||
if test ! -z "$winsock_LIB"; then
|
|
||||||
|
|
||||||
dnl If ws2_32 is wanted, make sure it is the _last_ lib in LIBS (makes
|
|
||||||
dnl things work when built with c-ares). But we can't just move it last
|
|
||||||
dnl since then other stuff (SSL) won't build. So we simply append it to the
|
|
||||||
dnl end.
|
|
||||||
|
|
||||||
LIBS="$LIBS $winsock_LIB"
|
|
||||||
TEST_SERVER_LIBS="$TEST_SERVER_LIBS $winsock_LIB"
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl
|
dnl
|
||||||
dnl All the library dependencies put into $LIB apply to libcurl only.
|
dnl All the library dependencies put into $LIB apply to libcurl only.
|
||||||
dnl Those in $CURL_LIBS apply to the curl command-line client only.
|
|
||||||
dnl Those in $TEST_SERVER_LIBS apply to test servers only.
|
|
||||||
dnl Those in $ALL_LIBS apply to all targets, including test targets.
|
|
||||||
dnl
|
dnl
|
||||||
LIBCURL_LIBS=$LIBS
|
LIBCURL_LIBS=$LIBS
|
||||||
|
|
||||||
AC_SUBST(LIBCURL_LIBS)
|
AC_SUBST(LIBCURL_LIBS)
|
||||||
AC_SUBST(CURL_LIBS)
|
|
||||||
AC_SUBST(TEST_SERVER_LIBS)
|
|
||||||
AC_SUBST(CURL_NETWORK_LIBS)
|
AC_SUBST(CURL_NETWORK_LIBS)
|
||||||
LIBS=$ALL_LIBS dnl LIBS is a magic variable that's used for every link
|
AC_SUBST(CURL_NETWORK_AND_TIME_LIBS)
|
||||||
|
|
||||||
|
dnl BLANK_AT_MAKETIME may be used in our Makefile.am files to blank
|
||||||
|
dnl LIBS variable used in generated makefile at makefile processing
|
||||||
|
dnl time. Doing this functionally prevents LIBS from being used for
|
||||||
|
dnl all link targets in given makefile.
|
||||||
|
BLANK_AT_MAKETIME=
|
||||||
|
AC_SUBST(BLANK_AT_MAKETIME)
|
||||||
|
|
||||||
AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes)
|
AM_CONDITIONAL(CROSSCOMPILING, test x$cross_compiling = xyes)
|
||||||
|
|
||||||
@@ -3469,14 +3495,15 @@ squeeze DEFS
|
|||||||
squeeze LDFLAGS
|
squeeze LDFLAGS
|
||||||
squeeze LIBS
|
squeeze LIBS
|
||||||
|
|
||||||
squeeze CURL_LIBS
|
|
||||||
squeeze LIBCURL_LIBS
|
squeeze LIBCURL_LIBS
|
||||||
squeeze TEST_SERVER_LIBS
|
|
||||||
squeeze CURL_NETWORK_LIBS
|
squeeze CURL_NETWORK_LIBS
|
||||||
|
squeeze CURL_NETWORK_AND_TIME_LIBS
|
||||||
|
|
||||||
squeeze SUPPORT_FEATURES
|
squeeze SUPPORT_FEATURES
|
||||||
squeeze SUPPORT_PROTOCOLS
|
squeeze SUPPORT_PROTOCOLS
|
||||||
|
|
||||||
|
XC_CHECK_BUILD_FLAGS
|
||||||
|
|
||||||
if test "x$want_curldebug_assumed" = "xyes" &&
|
if test "x$want_curldebug_assumed" = "xyes" &&
|
||||||
test "x$want_curldebug" = "xyes" && test "x$USE_ARES" = "x1"; then
|
test "x$want_curldebug" = "xyes" && test "x$USE_ARES" = "x1"; then
|
||||||
ac_configure_args="$ac_configure_args --enable-curldebug"
|
ac_configure_args="$ac_configure_args --enable-curldebug"
|
||||||
@@ -3492,6 +3519,8 @@ AC_CONFIG_FILES([Makefile \
|
|||||||
lib/Makefile \
|
lib/Makefile \
|
||||||
lib/libcurl.vers \
|
lib/libcurl.vers \
|
||||||
tests/Makefile \
|
tests/Makefile \
|
||||||
|
tests/certs/Makefile \
|
||||||
|
tests/certs/scripts/Makefile \
|
||||||
tests/data/Makefile \
|
tests/data/Makefile \
|
||||||
tests/server/Makefile \
|
tests/server/Makefile \
|
||||||
tests/libtest/Makefile \
|
tests/libtest/Makefile \
|
||||||
|
|||||||
@@ -148,14 +148,14 @@ while test $# -gt 0; do
|
|||||||
CURLLIBDIR=""
|
CURLLIBDIR=""
|
||||||
fi
|
fi
|
||||||
if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then
|
if test "X@REQUIRE_LIB_DEPS@" = "Xyes"; then
|
||||||
echo ${CURLLIBDIR}-lcurl @LIBCURL_LIBS@ @LIBS@
|
echo ${CURLLIBDIR}-lcurl @LIBCURL_LIBS@
|
||||||
else
|
else
|
||||||
echo ${CURLLIBDIR}-lcurl @LIBS@
|
echo ${CURLLIBDIR}-lcurl
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--static-libs)
|
--static-libs)
|
||||||
echo @libdir@/libcurl.@libext@ @LDFLAGS@ @LIBCURL_LIBS@ @LIBS@
|
echo @libdir@/libcurl.@libext@ @LDFLAGS@ @LIBCURL_LIBS@
|
||||||
;;
|
;;
|
||||||
|
|
||||||
--configure)
|
--configure)
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ BUGS
|
|||||||
1.1 There are still bugs
|
1.1 There are still bugs
|
||||||
|
|
||||||
Curl and libcurl have grown substantially since the beginning. At the time
|
Curl and libcurl have grown substantially since the beginning. At the time
|
||||||
of writing (September 2011), there are about 66000 lines of source code, and
|
of writing (January 2013), there are about 83,000 lines of source code, and
|
||||||
by the time you read this it has probably grown even more.
|
by the time you read this it has probably grown even more.
|
||||||
|
|
||||||
Of course there are lots of bugs left. And lots of misfeatures.
|
Of course there are lots of bugs left. And lots of misfeatures.
|
||||||
@@ -35,9 +35,11 @@ BUGS
|
|||||||
have a go at a solution. You can optionally also post your bug/problem at
|
have a go at a solution. You can optionally also post your bug/problem at
|
||||||
curl's bug tracking system over at
|
curl's bug tracking system over at
|
||||||
|
|
||||||
http://sourceforge.net/bugs/?group_id=976
|
https://sourceforge.net/p/curl/bugs/
|
||||||
|
|
||||||
(but please read the sections below first before doing that)
|
Please read the rest of this document below first before doing that! Also,
|
||||||
|
you need to login to your sourceforge account before being able to submit a
|
||||||
|
bug report (necessary evil done to avoid spam).
|
||||||
|
|
||||||
If you feel you need to ask around first, find a suitable mailing list and
|
If you feel you need to ask around first, find a suitable mailing list and
|
||||||
post there. The lists are available on http://curl.haxx.se/mail/
|
post there. The lists are available on http://curl.haxx.se/mail/
|
||||||
|
|||||||
64
docs/FAQ
64
docs/FAQ
@@ -52,6 +52,7 @@ FAQ
|
|||||||
3.19 How do I get HTTP from a host using a specific IP address?
|
3.19 How do I get HTTP from a host using a specific IP address?
|
||||||
3.20 How to SFTP from my user's home directory?
|
3.20 How to SFTP from my user's home directory?
|
||||||
3.21 Protocol xxx not supported or disabled in libcurl
|
3.21 Protocol xxx not supported or disabled in libcurl
|
||||||
|
3.22 curl -X gives me HTTP problems
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
4.1 Problems connecting to SSL servers.
|
4.1 Problems connecting to SSL servers.
|
||||||
@@ -97,6 +98,7 @@ FAQ
|
|||||||
5.14 Using C++ non-static functions for callbacks?
|
5.14 Using C++ non-static functions for callbacks?
|
||||||
5.15 How do I get an FTP directory listing?
|
5.15 How do I get an FTP directory listing?
|
||||||
5.16 I want a different time-out!
|
5.16 I want a different time-out!
|
||||||
|
5.17 Can I write a server with libcurl?
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
6.1 I have a GPL program, can I use the libcurl library?
|
6.1 I have a GPL program, can I use the libcurl library?
|
||||||
@@ -417,10 +419,15 @@ FAQ
|
|||||||
|
|
||||||
2.2 Does curl work/build with other SSL libraries?
|
2.2 Does curl work/build with other SSL libraries?
|
||||||
|
|
||||||
Curl has been written to use OpenSSL, GnuTLS, yassl, NSS, PolarSSL, axTLS or
|
Curl has been written to use a generic SSL function layer internally, and
|
||||||
qssl, although there should not be many problems using a different
|
that SSL functionality can then be provided by one out of many different SSL
|
||||||
library. If anyone does "port" curl to use a different SSL library, we are
|
backends.
|
||||||
of course very interested in getting the patch!
|
|
||||||
|
curl can be built to use one of the following SSL alternatives: OpenSSL,
|
||||||
|
GnuTLS, yassl, NSS, PolarSSL, axTLS, Secure Transport (native iOS/OS X),
|
||||||
|
schannel (native Windows) or qssl (native IBM i). They all have their pros
|
||||||
|
and cons, and we try to maintain a comparison of them here:
|
||||||
|
http://curl.haxx.se/docs/ssl-compared.html
|
||||||
|
|
||||||
2.3 Where can I find a copy of LIBEAY32.DLL?
|
2.3 Where can I find a copy of LIBEAY32.DLL?
|
||||||
|
|
||||||
@@ -481,9 +488,10 @@ FAQ
|
|||||||
You can tell curl to perform optional commands both before and/or after a
|
You can tell curl to perform optional commands both before and/or after a
|
||||||
file transfer. Study the -Q/--quote option.
|
file transfer. Study the -Q/--quote option.
|
||||||
|
|
||||||
Since curl is used for file transfers, you don't use curl to just perform
|
Since curl is used for file transfers, you don't normally use curl to
|
||||||
FTP commands without transferring anything. Therefore you must always specify
|
perform FTP commands without transferring anything. Therefore you must
|
||||||
a URL to transfer to/from even when doing custom FTP commands.
|
always specify a URL to transfer to/from even when doing custom FTP
|
||||||
|
commands, or use -I which implies the "no body" option sent to libcurl.
|
||||||
|
|
||||||
3.5 How can I disable the Accept: */* header?
|
3.5 How can I disable the Accept: */* header?
|
||||||
|
|
||||||
@@ -730,6 +738,33 @@ FAQ
|
|||||||
part as in "htpt://example.com" or as in the less evident case if you prefix
|
part as in "htpt://example.com" or as in the less evident case if you prefix
|
||||||
the protocol part with a space as in " http://example.com/".
|
the protocol part with a space as in " http://example.com/".
|
||||||
|
|
||||||
|
3.22 curl -X gives me HTTP problems
|
||||||
|
|
||||||
|
In normal circumstances, -X should hardly ever be used.
|
||||||
|
|
||||||
|
By default you use curl without explicitly saying which request method to
|
||||||
|
use when the URL identifies a HTTP transfer. If you just pass in a URL like
|
||||||
|
"curl http://example.com" it will use GET. If you use -d or -F curl will use
|
||||||
|
POST, -I will cause a HEAD and -T will make it a PUT.
|
||||||
|
|
||||||
|
If for whatever reason you're not happy with these default choices that curl
|
||||||
|
does for you, you can override those request methods by specifying -X
|
||||||
|
[WHATEVER]. This way you can for example send a DELETE by doing "curl -X
|
||||||
|
DELETE [URL]".
|
||||||
|
|
||||||
|
It is thus pointless to do "curl -XGET [URL]" as GET would be used
|
||||||
|
anyway. In the same vein it is pointless to do "curl -X POST -d data
|
||||||
|
[URL]"... But you can make a fun and somewhat rare request that sends a
|
||||||
|
request-body in a GET request with something like "curl -X GET -d data
|
||||||
|
[URL]"
|
||||||
|
|
||||||
|
Note that -X doesn't change curl's behavior. It only modifies the actual
|
||||||
|
string sent in the request.
|
||||||
|
|
||||||
|
Accordingly, by using -XPOST on a command line that for example would follow
|
||||||
|
a 303 redirect, you will effectively prevent curl from behaving
|
||||||
|
correctly. Be aware.
|
||||||
|
|
||||||
|
|
||||||
4. Running Problems
|
4. Running Problems
|
||||||
|
|
||||||
@@ -878,8 +913,8 @@ FAQ
|
|||||||
|
|
||||||
4.9 Curl can't authenticate to the server that requires NTLM?
|
4.9 Curl can't authenticate to the server that requires NTLM?
|
||||||
|
|
||||||
NTLM support requires OpenSSL, GnuTLS, NSS or Microsoft Windows libraries at
|
NTLM support requires OpenSSL, GnuTLS, NSS, Secure Transport, or Microsoft
|
||||||
build-time to provide this functionality.
|
Windows libraries at build-time to provide this functionality.
|
||||||
|
|
||||||
NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You
|
NTLM is a Microsoft proprietary protocol. Proprietary formats are evil. You
|
||||||
should not use such ones.
|
should not use such ones.
|
||||||
@@ -1252,7 +1287,7 @@ FAQ
|
|||||||
|
|
||||||
If you're using the multi interface, you can also stop a transfer by
|
If you're using the multi interface, you can also stop a transfer by
|
||||||
removing the particular easy handle from the multi stack at any moment you
|
removing the particular easy handle from the multi stack at any moment you
|
||||||
think the transfer is done.
|
think the transfer is done or when you wish to abort the transfer.
|
||||||
|
|
||||||
5.14 Using C++ non-static functions for callbacks?
|
5.14 Using C++ non-static functions for callbacks?
|
||||||
|
|
||||||
@@ -1310,6 +1345,15 @@ FAQ
|
|||||||
use that to figure out exactly when the right condition is met when the
|
use that to figure out exactly when the right condition is met when the
|
||||||
transfer should get stopped.
|
transfer should get stopped.
|
||||||
|
|
||||||
|
5.17 Can I write a server with libcurl?
|
||||||
|
|
||||||
|
No. libcurl offers no functions or building blocks to build any kind of
|
||||||
|
internet protocol server. libcurl is only a client-side library. For server
|
||||||
|
libraries, you need to continue your search elsewhere but there exist many
|
||||||
|
good open source ones out there for most protocols you could possibly want a
|
||||||
|
server for. And there are really good stand-alone ones that have been tested
|
||||||
|
and proven for many years. There's no need for you to reinvent them!
|
||||||
|
|
||||||
|
|
||||||
6. License Issues
|
6. License Issues
|
||||||
|
|
||||||
|
|||||||
@@ -122,10 +122,52 @@ FILE
|
|||||||
- "uploads"
|
- "uploads"
|
||||||
- resume
|
- resume
|
||||||
|
|
||||||
|
SMTP
|
||||||
|
- authentication: Plain, Login, CRAM-MD5, Digest-MD5 and NTLM (*9)
|
||||||
|
- send mail
|
||||||
|
- mail from support
|
||||||
|
- mail size support
|
||||||
|
- mail auth support for trusted server-to-server relaying
|
||||||
|
- multiple recipients
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
|
SMTPS (*1)
|
||||||
|
- implicit smtps:// support
|
||||||
|
- explicit "STARTTLS" usage to "upgrade" plain smtp:// connections to use SSL
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
|
POP3
|
||||||
|
- authentication: Clear Text, APOP and SASL
|
||||||
|
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5 and
|
||||||
|
NTLM (*9)
|
||||||
|
- list e-mails
|
||||||
|
- retrieve e-mails
|
||||||
|
- enhanced command support for: CAPA, DELE, TOP, STAT, UIDL and NOOP
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
|
POP3S (*1)
|
||||||
|
- implicit pop3s:// support
|
||||||
|
- explicit "STLS" usage to "upgrade" plain pop3:// connections to use SSL
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
|
IMAP
|
||||||
|
- authentication: Clear Text and SASL
|
||||||
|
- select mailbox
|
||||||
|
- basic fetch e-mail support
|
||||||
|
- SASL based authentication: Plain, Login, CRAM-MD5, Digest-MD5 and
|
||||||
|
NTLM (*9)
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
|
IMAPS (*1)
|
||||||
|
- implicit imaps:// support
|
||||||
|
- explicit "STARTTLS" usage to "upgrade" plain imap:// connections to use SSL
|
||||||
|
- via http-proxy
|
||||||
|
|
||||||
FOOTNOTES
|
FOOTNOTES
|
||||||
=========
|
=========
|
||||||
|
|
||||||
*1 = requires OpenSSL, GnuTLS, NSS, yassl, axTLS, PolarSSL or schannel
|
*1 = requires OpenSSL, GnuTLS, NSS, yassl, axTLS, PolarSSL, schannel (native
|
||||||
|
Windows), Secure Transport (native iOS/OS X) or qssl (native IBM i)
|
||||||
*2 = requires OpenLDAP
|
*2 = requires OpenLDAP
|
||||||
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
|
*3 = requires a GSSAPI-compliant library, such as Heimdal or similar.
|
||||||
*4 = requires FBopenssl
|
*4 = requires FBopenssl
|
||||||
@@ -133,4 +175,4 @@ FOOTNOTES
|
|||||||
*6 = requires c-ares
|
*6 = requires c-ares
|
||||||
*7 = requires OpenSSL or NSS, as GnuTLS only supports SSLv3 and TLSv1
|
*7 = requires OpenSSL or NSS, as GnuTLS only supports SSLv3 and TLSv1
|
||||||
*8 = requires libssh2
|
*8 = requires libssh2
|
||||||
*9 = requires OpenSSL, GnuTLS, NSS or yassl
|
*9 = requires OpenSSL, GnuTLS, NSS, yassl or SSPI (native Windows)
|
||||||
|
|||||||
58
docs/INSTALL
58
docs/INSTALL
@@ -135,21 +135,18 @@ UNIX
|
|||||||
default. But if you want to alter it, you can select how to deal with
|
default. But if you want to alter it, you can select how to deal with
|
||||||
each individual library.
|
each individual library.
|
||||||
|
|
||||||
To build with GnuTLS support instead of OpenSSL for SSL/TLS, note that
|
To build with GnuTLS for SSL/TLS, use both --without-ssl and
|
||||||
you need to use both --without-ssl and --with-gnutls.
|
--with-gnutls.
|
||||||
|
|
||||||
To build with yassl support instead of OpenSSL or GnuTLS, you must build
|
To build with Cyassl for SSL/TLS, use both --without-ssl and
|
||||||
yassl with its OpenSSL emulation enabled and point to that directory root
|
--with-cyassl.
|
||||||
with configure --with-ssl.
|
|
||||||
|
|
||||||
To build with NSS support instead of OpenSSL for SSL/TLS, note that
|
To build with NSS for SSL/TLS, use both --without-ssl and --with-nss.
|
||||||
you need to use both --without-ssl and --with-nss.
|
|
||||||
|
|
||||||
To build with PolarSSL support instead of OpenSSL for SSL/TLS, note that
|
To build with PolarSSL for SSL/TLS, use both --without-ssl and
|
||||||
you need to use both --without-ssl and --with-polarssl.
|
--with-polarssl.
|
||||||
|
|
||||||
To build with axTLS support instead of OpenSSL for TLS, note that you
|
To build with axTLS for SSL/TLS, use both --without-ssl and --with-axtls.
|
||||||
need to use both --without-ssl and --with-axtls.
|
|
||||||
|
|
||||||
To get GSSAPI support, build with --with-gssapi and have the MIT or
|
To get GSSAPI support, build with --with-gssapi and have the MIT or
|
||||||
Heimdal Kerberos 5 packages installed.
|
Heimdal Kerberos 5 packages installed.
|
||||||
@@ -225,7 +222,7 @@ Win32
|
|||||||
|
|
||||||
set ZLIB_PATH=c:\zlib-1.2.7
|
set ZLIB_PATH=c:\zlib-1.2.7
|
||||||
set OPENSSL_PATH=c:\openssl-0.9.8x
|
set OPENSSL_PATH=c:\openssl-0.9.8x
|
||||||
set LIBSSH2_PATH=c:\libssh2-1.4.2
|
set LIBSSH2_PATH=c:\libssh2-1.4.3
|
||||||
|
|
||||||
ATTENTION: if you want to build with libssh2 support you have to use latest
|
ATTENTION: if you want to build with libssh2 support you have to use latest
|
||||||
version 0.17 - previous versions will NOT work with 7.17.0 and later!
|
version 0.17 - previous versions will NOT work with 7.17.0 and later!
|
||||||
@@ -467,7 +464,7 @@ Win32
|
|||||||
possibilities:
|
possibilities:
|
||||||
|
|
||||||
- Modify lib/config-win32.h
|
- Modify lib/config-win32.h
|
||||||
- Modify lib/setup.h
|
- Modify lib/curl_setup.h
|
||||||
- Modify lib/Makefile.vc6
|
- Modify lib/Makefile.vc6
|
||||||
- Add defines to Project/Settings/C/C++/General/Preprocessor Definitions
|
- Add defines to Project/Settings/C/C++/General/Preprocessor Definitions
|
||||||
in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project.
|
in the vc6libcurl.dsw/vc6libcurl.dsp Visual C++ 6 IDE project.
|
||||||
@@ -509,6 +506,38 @@ Win32
|
|||||||
dynamic import symbols.
|
dynamic import symbols.
|
||||||
|
|
||||||
|
|
||||||
|
Apple iOS and Mac OS X
|
||||||
|
======================
|
||||||
|
On recent Apple operating systems, curl can be built to use Apple's
|
||||||
|
SSL/TLS implementation, Secure Transport, instead of OpenSSL. To build with
|
||||||
|
Secure Transport for SSL/TLS, use the configure option --with-darwinssl. (It
|
||||||
|
is not necessary to use the option --without-ssl.) This feature requires iOS
|
||||||
|
5.0 or later, or OS X 10.5 ("Leopard") or later.
|
||||||
|
|
||||||
|
When Secure Transport is in use, the curl options --cacert and --capath and
|
||||||
|
their libcurl equivalents, will be ignored, because Secure Transport uses
|
||||||
|
the certificates stored in the Keychain to evaluate whether or not to trust
|
||||||
|
the server. This, of course, includes the root certificates that ship with
|
||||||
|
the OS. The --cert and --engine options, and their libcurl equivalents, are
|
||||||
|
currently unimplemented in curl with Secure Transport.
|
||||||
|
|
||||||
|
For OS X users: In OS X 10.8 ("Mountain Lion"), Apple made a major
|
||||||
|
overhaul to the Secure Transport API that, among other things, added
|
||||||
|
support for the newer TLS 1.1 and 1.2 protocols. To get curl to support
|
||||||
|
TLS 1.1 and 1.2, you must build curl on Mountain Lion or later, or by
|
||||||
|
using the equivalent SDK. If you set the MACOSX_DEPLOYMENT_TARGET
|
||||||
|
environmental variable to an earlier version of OS X prior to building curl,
|
||||||
|
then curl will use the new Secure Transport API on Mountain Lion and later,
|
||||||
|
and fall back on the older API when the same curl binary is executed on
|
||||||
|
older cats. For example, running these commands in curl's directory in the
|
||||||
|
shell will build the code such that it will run on cats as old as OS X 10.6
|
||||||
|
("Snow Leopard") (using bash):
|
||||||
|
|
||||||
|
export MACOSX_DEPLOYMENT_TARGET="10.6"
|
||||||
|
./configure --with-darwinssl
|
||||||
|
make
|
||||||
|
|
||||||
|
|
||||||
IBM OS/2
|
IBM OS/2
|
||||||
========
|
========
|
||||||
Building under OS/2 is not much different from building under unix.
|
Building under OS/2 is not much different from building under unix.
|
||||||
@@ -1018,7 +1047,7 @@ PORTS
|
|||||||
- AVR32 Linux
|
- AVR32 Linux
|
||||||
- ARM Android 1.5, 2.1
|
- ARM Android 1.5, 2.1
|
||||||
- ARM INTEGRITY
|
- ARM INTEGRITY
|
||||||
- ARM iPhone OS
|
- ARM iOS
|
||||||
- Cell Linux
|
- Cell Linux
|
||||||
- Cell Cell OS
|
- Cell Cell OS
|
||||||
- HP-PA HP-UX 9.X 10.X 11.X
|
- HP-PA HP-UX 9.X 10.X 11.X
|
||||||
@@ -1056,6 +1085,7 @@ PORTS
|
|||||||
- i386 HURD
|
- i386 HURD
|
||||||
- i386 Haiku OS
|
- i386 Haiku OS
|
||||||
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6
|
- i386 Linux 1.3, 2.0, 2.2, 2.3, 2.4, 2.6
|
||||||
|
- i386 Mac OS X
|
||||||
- i386 MINIX 3.1
|
- i386 MINIX 3.1
|
||||||
- i386 NetBSD
|
- i386 NetBSD
|
||||||
- i386 Novell NetWare
|
- i386 Novell NetWare
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ Current flaws in the curl CMake build
|
|||||||
Missing features in the cmake build:
|
Missing features in the cmake build:
|
||||||
|
|
||||||
- Builds libcurl without large file support
|
- Builds libcurl without large file support
|
||||||
- It doesn't build src/hugehelp.c which creates the --manual output
|
- It doesn't build src/tool_hugehelp.c which creates the --manual output
|
||||||
- Can't select which SSL library to build with, only OpenSSL
|
- Can't select which SSL library to build with, only OpenSSL
|
||||||
- Doesn't build with SCP and SFTP support (libssh2)
|
- Doesn't build with SCP and SFTP support (libssh2)
|
||||||
- Doesn't allow different resolver backends (no c-ares build support)
|
- Doesn't allow different resolver backends (no c-ares build support)
|
||||||
|
|||||||
@@ -47,9 +47,6 @@ Portability
|
|||||||
axTLS 1.2.7
|
axTLS 1.2.7
|
||||||
Heimdal ?
|
Heimdal ?
|
||||||
|
|
||||||
* = only partly functional, but that's due to bugs in the third party lib, not
|
|
||||||
because of libcurl code
|
|
||||||
|
|
||||||
On systems where configure runs, we aim at working on them all - if they have
|
On systems where configure runs, we aim at working on them all - if they have
|
||||||
a suitable C compiler. On systems that don't run configure, we strive to keep
|
a suitable C compiler. On systems that don't run configure, we strive to keep
|
||||||
curl running fine on:
|
curl running fine on:
|
||||||
@@ -413,10 +410,10 @@ Client
|
|||||||
|
|
||||||
main() resides in src/main.c together with most of the client code.
|
main() resides in src/main.c together with most of the client code.
|
||||||
|
|
||||||
src/hugehelp.c is automatically generated by the mkhelp.pl perl script to
|
src/tool_hugehelp.c is automatically generated by the mkhelp.pl perl script
|
||||||
display the complete "manual" and the src/urlglob.c file holds the functions
|
to display the complete "manual" and the src/urlglob.c file holds the
|
||||||
used for the URL-"globbing" support. Globbing in the sense that the {} and []
|
functions used for the URL-"globbing" support. Globbing in the sense that
|
||||||
expansion stuff is there.
|
the {} and [] expansion stuff is there.
|
||||||
|
|
||||||
The client mostly messes around to setup its 'config' struct properly, then
|
The client mostly messes around to setup its 'config' struct properly, then
|
||||||
it calls the curl_easy_*() functions of the library and when it gets back
|
it calls the curl_easy_*() functions of the library and when it gets back
|
||||||
|
|||||||
28
docs/THANKS
28
docs/THANKS
@@ -12,6 +12,7 @@ Adam Piggott
|
|||||||
Adam Tkac
|
Adam Tkac
|
||||||
Adrian Schuur
|
Adrian Schuur
|
||||||
Adriano Meirelles
|
Adriano Meirelles
|
||||||
|
Ajit Dhumale
|
||||||
Akos Pasztory
|
Akos Pasztory
|
||||||
Alan Pinstein
|
Alan Pinstein
|
||||||
Albert Chin
|
Albert Chin
|
||||||
@@ -24,6 +25,7 @@ Alessandro Ghedini
|
|||||||
Alessandro Vesely
|
Alessandro Vesely
|
||||||
Alex Bligh
|
Alex Bligh
|
||||||
Alex Fishman
|
Alex Fishman
|
||||||
|
Alex Gruz
|
||||||
Alex Neblett
|
Alex Neblett
|
||||||
Alex Suykov
|
Alex Suykov
|
||||||
Alex Vinnik
|
Alex Vinnik
|
||||||
@@ -75,6 +77,7 @@ Anthony G. Basile
|
|||||||
Antoine Calando
|
Antoine Calando
|
||||||
Anton Bychkov
|
Anton Bychkov
|
||||||
Anton Kalmykov
|
Anton Kalmykov
|
||||||
|
Anton Malov
|
||||||
Anton Yabchinskiy
|
Anton Yabchinskiy
|
||||||
Arkadiusz Miskiewicz
|
Arkadiusz Miskiewicz
|
||||||
Armel Asselin
|
Armel Asselin
|
||||||
@@ -175,6 +178,7 @@ Craig Davison
|
|||||||
Craig Markwardt
|
Craig Markwardt
|
||||||
Cris Bailiff
|
Cris Bailiff
|
||||||
Cristian Rodriguez
|
Cristian Rodriguez
|
||||||
|
Cristian Rodríguez
|
||||||
Curt Bogmine
|
Curt Bogmine
|
||||||
Cyrill Osterwalder
|
Cyrill Osterwalder
|
||||||
Dag Ekengren
|
Dag Ekengren
|
||||||
@@ -207,6 +211,7 @@ Dave Reisner
|
|||||||
Dave Vasilevsky
|
Dave Vasilevsky
|
||||||
David Bau
|
David Bau
|
||||||
David Binderman
|
David Binderman
|
||||||
|
David Blaikie
|
||||||
David Byron
|
David Byron
|
||||||
David Cohen
|
David Cohen
|
||||||
David Eriksson
|
David Eriksson
|
||||||
@@ -263,6 +268,7 @@ Early Ehlinger
|
|||||||
Ebenezer Ikonne
|
Ebenezer Ikonne
|
||||||
Edin Kadribasic
|
Edin Kadribasic
|
||||||
Eduard Bloch
|
Eduard Bloch
|
||||||
|
Edward Sheldrake
|
||||||
Eelco Dolstra
|
Eelco Dolstra
|
||||||
Eetu Ojanen
|
Eetu Ojanen
|
||||||
Ellis Pritchard
|
Ellis Pritchard
|
||||||
@@ -302,11 +308,13 @@ Frank McGeough
|
|||||||
Frank Meier
|
Frank Meier
|
||||||
Frank Ticheler
|
Frank Ticheler
|
||||||
Frank Van Uffelen
|
Frank Van Uffelen
|
||||||
|
František Kučera
|
||||||
Fred Machado
|
Fred Machado
|
||||||
Fred New
|
Fred New
|
||||||
Fred Noz
|
Fred Noz
|
||||||
Frederic Lepied
|
Frederic Lepied
|
||||||
Gabriel Kuri
|
Gabriel Kuri
|
||||||
|
Gabriel Sjoberg
|
||||||
Garrett Holmstrom
|
Garrett Holmstrom
|
||||||
Gary Maxwell
|
Gary Maxwell
|
||||||
Gautam Kachroo
|
Gautam Kachroo
|
||||||
@@ -341,6 +349,7 @@ Greg Zavertnik
|
|||||||
Grigory Entin
|
Grigory Entin
|
||||||
Guenole Bescon
|
Guenole Bescon
|
||||||
Guenter Knauf
|
Guenter Knauf
|
||||||
|
Guido Berhoerster
|
||||||
Guillaume Arluison
|
Guillaume Arluison
|
||||||
Gustaf Hui
|
Gustaf Hui
|
||||||
Gwenole Beauchesne
|
Gwenole Beauchesne
|
||||||
@@ -360,6 +369,7 @@ Henrik Storner
|
|||||||
Henry Ludemann
|
Henry Ludemann
|
||||||
Herve Amblard
|
Herve Amblard
|
||||||
Hidemoto Nakada
|
Hidemoto Nakada
|
||||||
|
Ho-chi Chen
|
||||||
Hoi-Ho Chan
|
Hoi-Ho Chan
|
||||||
Hongli Lai
|
Hongli Lai
|
||||||
Howard Chu
|
Howard Chu
|
||||||
@@ -397,6 +407,7 @@ Jamie Lokier
|
|||||||
Jamie Newton
|
Jamie Newton
|
||||||
Jamie Wilkinson
|
Jamie Wilkinson
|
||||||
Jan Ehrhardt
|
Jan Ehrhardt
|
||||||
|
Jan Koen Annot
|
||||||
Jan Kunder
|
Jan Kunder
|
||||||
Jan Schaumann
|
Jan Schaumann
|
||||||
Jan Van Boghout
|
Jan Van Boghout
|
||||||
@@ -415,6 +426,7 @@ Jean-Francois Bertrand
|
|||||||
Jean-Louis Lemaire
|
Jean-Louis Lemaire
|
||||||
Jean-Marc Ranger
|
Jean-Marc Ranger
|
||||||
Jean-Philippe Barrette-LaPierre
|
Jean-Philippe Barrette-LaPierre
|
||||||
|
Jeff Connelly
|
||||||
Jeff Johnson
|
Jeff Johnson
|
||||||
Jeff Lawson
|
Jeff Lawson
|
||||||
Jeff Phillips
|
Jeff Phillips
|
||||||
@@ -428,6 +440,7 @@ Jerry Wu
|
|||||||
Jes Badwal
|
Jes Badwal
|
||||||
Jesper Jensen
|
Jesper Jensen
|
||||||
Jesse Noller
|
Jesse Noller
|
||||||
|
Jie He
|
||||||
Jim Drash
|
Jim Drash
|
||||||
Jim Freeman
|
Jim Freeman
|
||||||
Jim Hollinger
|
Jim Hollinger
|
||||||
@@ -435,6 +448,7 @@ Jim Meyering
|
|||||||
Jocelyn Jaubert
|
Jocelyn Jaubert
|
||||||
Joe Halpin
|
Joe Halpin
|
||||||
Joe Malicki
|
Joe Malicki
|
||||||
|
Joe Mason
|
||||||
Joel Chen
|
Joel Chen
|
||||||
Jofell Gallardo
|
Jofell Gallardo
|
||||||
Johan Anderson
|
Johan Anderson
|
||||||
@@ -453,6 +467,7 @@ John Lightsey
|
|||||||
John Marino
|
John Marino
|
||||||
John McGowan
|
John McGowan
|
||||||
John P. McCaskey
|
John P. McCaskey
|
||||||
|
John Suprock
|
||||||
John Wilkinson
|
John Wilkinson
|
||||||
John-Mark Bell
|
John-Mark Bell
|
||||||
Johnny Luong
|
Johnny Luong
|
||||||
@@ -525,6 +540,7 @@ Kyle Sallee
|
|||||||
Lachlan O'Dea
|
Lachlan O'Dea
|
||||||
Larry Campbell
|
Larry Campbell
|
||||||
Larry Fahnoe
|
Larry Fahnoe
|
||||||
|
Lars Buitinck
|
||||||
Lars Gustafsson
|
Lars Gustafsson
|
||||||
Lars J. Aas
|
Lars J. Aas
|
||||||
Lars Nilsson
|
Lars Nilsson
|
||||||
@@ -579,6 +595,8 @@ Mark Incley
|
|||||||
Mark Karpeles
|
Mark Karpeles
|
||||||
Mark Lentczner
|
Mark Lentczner
|
||||||
Mark Salisbury
|
Mark Salisbury
|
||||||
|
Mark Snelling
|
||||||
|
Mark Tully
|
||||||
Markus Duft
|
Markus Duft
|
||||||
Markus Koetter
|
Markus Koetter
|
||||||
Markus Moeller
|
Markus Moeller
|
||||||
@@ -612,6 +630,7 @@ Max Katsev
|
|||||||
Maxim Ivanov
|
Maxim Ivanov
|
||||||
Maxim Perenesenko
|
Maxim Perenesenko
|
||||||
Maxim Prohorov
|
Maxim Prohorov
|
||||||
|
Maxime Larocque
|
||||||
Mehmet Bozkurt
|
Mehmet Bozkurt
|
||||||
Mekonikum
|
Mekonikum
|
||||||
Mettgut Jamalla
|
Mettgut Jamalla
|
||||||
@@ -630,6 +649,7 @@ Michael Stillwell
|
|||||||
Michael Wallner
|
Michael Wallner
|
||||||
Michal Bonino
|
Michal Bonino
|
||||||
Michal Gorny
|
Michal Gorny
|
||||||
|
Michal Kowalczyk
|
||||||
Michal Marek
|
Michal Marek
|
||||||
Michele Bini
|
Michele Bini
|
||||||
Mihai Ionescu
|
Mihai Ionescu
|
||||||
@@ -680,8 +700,11 @@ Ofer
|
|||||||
Olaf Flebbe
|
Olaf Flebbe
|
||||||
Olaf Stueben
|
Olaf Stueben
|
||||||
Olaf Stüben
|
Olaf Stüben
|
||||||
|
Olivier Berger
|
||||||
Oren Tirosh
|
Oren Tirosh
|
||||||
Ori Avtalion
|
Ori Avtalion
|
||||||
|
Oscar Koeroo
|
||||||
|
Oscar Norlander
|
||||||
P R Schaffner
|
P R Schaffner
|
||||||
Paolo Piacentini
|
Paolo Piacentini
|
||||||
Pascal Terjan
|
Pascal Terjan
|
||||||
@@ -823,13 +846,17 @@ Sander Gates
|
|||||||
Sandor Feldi
|
Sandor Feldi
|
||||||
Santhana Todatry
|
Santhana Todatry
|
||||||
Saqib Ali
|
Saqib Ali
|
||||||
|
Sara Golemon
|
||||||
Saul good
|
Saul good
|
||||||
|
Scott Bailey
|
||||||
Scott Barrett
|
Scott Barrett
|
||||||
Scott Cantor
|
Scott Cantor
|
||||||
Scott Davis
|
Scott Davis
|
||||||
Scott McCreary
|
Scott McCreary
|
||||||
|
Sebastian Rasmussen
|
||||||
Sebastien Willemijns
|
Sebastien Willemijns
|
||||||
Senthil Raja Velu
|
Senthil Raja Velu
|
||||||
|
Sergei Nikulov
|
||||||
Sergio Ballestrero
|
Sergio Ballestrero
|
||||||
Seshubabu Pasam
|
Seshubabu Pasam
|
||||||
Sh Diao
|
Sh Diao
|
||||||
@@ -913,6 +940,7 @@ Tom Mueller
|
|||||||
Tom Regner
|
Tom Regner
|
||||||
Tom Wright
|
Tom Wright
|
||||||
Tom Zerucha
|
Tom Zerucha
|
||||||
|
Tomas Mlcoch
|
||||||
Tomas Pospisek
|
Tomas Pospisek
|
||||||
Tomas Szepe
|
Tomas Szepe
|
||||||
Tomasz Lacki
|
Tomasz Lacki
|
||||||
|
|||||||
177
docs/TODO
177
docs/TODO
@@ -21,8 +21,7 @@
|
|||||||
|
|
||||||
2. libcurl - multi interface
|
2. libcurl - multi interface
|
||||||
2.1 More non-blocking
|
2.1 More non-blocking
|
||||||
2.2 Remove easy interface internally
|
2.2 Fix HTTP Pipelining for PUT
|
||||||
2.4 Fix HTTP Pipelining for PUT
|
|
||||||
|
|
||||||
3. Documentation
|
3. Documentation
|
||||||
3.1 More and better
|
3.1 More and better
|
||||||
@@ -69,55 +68,52 @@
|
|||||||
10. POP3
|
10. POP3
|
||||||
10.1 auth= in URLs
|
10.1 auth= in URLs
|
||||||
|
|
||||||
11. IMAP
|
11. LDAP
|
||||||
11.1 SASL based authentication mechanisms
|
11.1 SASL based authentication mechanisms
|
||||||
|
|
||||||
12. LDAP
|
12. Other protocols
|
||||||
12.1 SASL based authentication mechanisms
|
|
||||||
|
|
||||||
13. Other protocols
|
13. New protocols
|
||||||
|
13.1 RSYNC
|
||||||
|
|
||||||
14. New protocols
|
14. SASL
|
||||||
14.1 RSYNC
|
14.1 Other authentication mechanisms
|
||||||
|
|
||||||
15. SASL
|
15. Client
|
||||||
15.1 Other authentication mechanisms
|
15.1 sync
|
||||||
|
15.2 glob posts
|
||||||
|
15.3 prevent file overwriting
|
||||||
|
15.4 simultaneous parallel transfers
|
||||||
|
15.5 provide formpost headers
|
||||||
|
15.6 url-specific options
|
||||||
|
15.7 warning when setting an option
|
||||||
|
15.8 IPv6 addresses with globbing
|
||||||
|
|
||||||
16. Client
|
16. Build
|
||||||
16.1 sync
|
16.1 roffit
|
||||||
16.2 glob posts
|
|
||||||
16.3 prevent file overwriting
|
|
||||||
16.4 simultaneous parallel transfers
|
|
||||||
16.5 provide formpost headers
|
|
||||||
16.6 url-specific options
|
|
||||||
16.7 warning when setting an option
|
|
||||||
16.8 IPv6 addresses with globbing
|
|
||||||
|
|
||||||
17. Build
|
17. Test suite
|
||||||
17.1 roffit
|
17.1 SSL tunnel
|
||||||
|
17.2 nicer lacking perl message
|
||||||
|
17.3 more protocols supported
|
||||||
|
17.4 more platforms supported
|
||||||
|
|
||||||
18. Test suite
|
18. Next SONAME bump
|
||||||
18.1 SSL tunnel
|
18.1 http-style HEAD output for ftp
|
||||||
18.2 nicer lacking perl message
|
18.2 combine error codes
|
||||||
18.3 more protocols supported
|
18.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
||||||
18.4 more platforms supported
|
|
||||||
|
|
||||||
19. Next SONAME bump
|
19. Next major release
|
||||||
19.1 http-style HEAD output for ftp
|
19.1 cleanup return codes
|
||||||
19.2 combine error codes
|
19.2 remove obsolete defines
|
||||||
19.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
19.3 size_t
|
||||||
|
19.4 remove several functions
|
||||||
20. Next major release
|
19.5 remove CURLOPT_FAILONERROR
|
||||||
20.1 cleanup return codes
|
19.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
||||||
20.2 remove obsolete defines
|
19.7 remove progress meter from libcurl
|
||||||
20.3 size_t
|
19.8 remove 'curl_httppost' from public
|
||||||
20.4 remove several functions
|
19.9 have form functions use CURL handle argument
|
||||||
20.5 remove CURLOPT_FAILONERROR
|
19.10 Add CURLOPT_MAIL_CLIENT option
|
||||||
20.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
|
||||||
20.7 remove progress meter from libcurl
|
|
||||||
20.8 remove 'curl_httppost' from public
|
|
||||||
20.9 have form functions use CURL handle argument
|
|
||||||
20.10 Add CURLOPT_MAIL_CLIENT option
|
|
||||||
|
|
||||||
==============================================================================
|
==============================================================================
|
||||||
|
|
||||||
@@ -194,16 +190,7 @@
|
|||||||
- The "DONE" operation (post transfer protocol-specific actions) for the
|
- The "DONE" operation (post transfer protocol-specific actions) for the
|
||||||
protocols SFTP, SMTP, FTP. Fixing Curl_done() for this is a worthy task.
|
protocols SFTP, SMTP, FTP. Fixing Curl_done() for this is a worthy task.
|
||||||
|
|
||||||
2.2 Remove easy interface internally
|
2.2 Fix HTTP Pipelining for PUT
|
||||||
|
|
||||||
Make curl_easy_perform() a wrapper-function that simply creates a multi
|
|
||||||
handle, adds the easy handle to it, runs curl_multi_perform() until the
|
|
||||||
transfer is done, then detach the easy handle, destroy the multi handle and
|
|
||||||
return the easy handle's return code. This will thus make everything
|
|
||||||
internally use and assume the multi interface. The select()-loop should use
|
|
||||||
curl_multi_socket().
|
|
||||||
|
|
||||||
2.4 Fix HTTP Pipelining for PUT
|
|
||||||
|
|
||||||
HTTP Pipelining can be a way to greatly enhance performance for multiple
|
HTTP Pipelining can be a way to greatly enhance performance for multiple
|
||||||
serial requests and currently libcurl only supports that for HEAD and GET
|
serial requests and currently libcurl only supports that for HEAD and GET
|
||||||
@@ -402,42 +389,34 @@ to provide the data to send.
|
|||||||
Being able to specify the preferred authentication mechanism in the URL as
|
Being able to specify the preferred authentication mechanism in the URL as
|
||||||
per RFC2384.
|
per RFC2384.
|
||||||
|
|
||||||
11. IMAP
|
11. LDAP
|
||||||
|
|
||||||
11.1 SASL based authentication mechanisms
|
11.1 SASL based authentication mechanisms
|
||||||
|
|
||||||
Curl currently sends usernames and passwords as clear text whilst SASL based
|
|
||||||
authentication mechanisms can be more secure. As such, support should be
|
|
||||||
added to support these authentication mechanisms.
|
|
||||||
|
|
||||||
12. LDAP
|
|
||||||
|
|
||||||
12.1 SASL based authentication mechansims
|
|
||||||
|
|
||||||
Currently the LDAP module only supports ldap_simple_bind_s() in order to bind
|
Currently the LDAP module only supports ldap_simple_bind_s() in order to bind
|
||||||
to an LDAP server. However, this function sends username and password details
|
to an LDAP server. However, this function sends username and password details
|
||||||
using the simple authentication mechanism (as clear text). However, it should
|
using the simple authentication mechanism (as clear text). However, it should
|
||||||
be possible to use ldap_bind_s() instead specifing the security context
|
be possible to use ldap_bind_s() instead specifing the security context
|
||||||
information ourselves.
|
information ourselves.
|
||||||
|
|
||||||
13. Other protocols
|
12. Other protocols
|
||||||
|
|
||||||
14. New protocols
|
13. New protocols
|
||||||
|
|
||||||
14.1 RSYNC
|
13.1 RSYNC
|
||||||
|
|
||||||
There's no RFC for the protocol or an URI/URL format. An implementation
|
There's no RFC for the protocol or an URI/URL format. An implementation
|
||||||
should most probably use an existing rsync library, such as librsync.
|
should most probably use an existing rsync library, such as librsync.
|
||||||
|
|
||||||
15. SASL
|
14. SASL
|
||||||
|
|
||||||
15.1 Other authentication mechanisms
|
14.1 Other authentication mechanisms
|
||||||
|
|
||||||
Add support for gssapi to SMTP and POP3.
|
Add support for gssapi to SMTP, POP3 and IMAP.
|
||||||
|
|
||||||
16. Client
|
15. Client
|
||||||
|
|
||||||
16.1 sync
|
15.1 sync
|
||||||
|
|
||||||
"curl --sync http://example.com/feed[1-100].rss" or
|
"curl --sync http://example.com/feed[1-100].rss" or
|
||||||
"curl --sync http://example.net/{index,calendar,history}.html"
|
"curl --sync http://example.net/{index,calendar,history}.html"
|
||||||
@@ -446,12 +425,12 @@ to provide the data to send.
|
|||||||
remote file is newer than the local file. A Last-Modified HTTP date header
|
remote file is newer than the local file. A Last-Modified HTTP date header
|
||||||
should also be used to set the mod date on the downloaded file.
|
should also be used to set the mod date on the downloaded file.
|
||||||
|
|
||||||
16.2 glob posts
|
15.2 glob posts
|
||||||
|
|
||||||
Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'.
|
Globbing support for -d and -F, as in 'curl -d "name=foo[0-9]" URL'.
|
||||||
This is easily scripted though.
|
This is easily scripted though.
|
||||||
|
|
||||||
16.3 prevent file overwriting
|
15.3 prevent file overwriting
|
||||||
|
|
||||||
Add an option that prevents cURL from overwriting existing local files. When
|
Add an option that prevents cURL from overwriting existing local files. When
|
||||||
used, and there already is an existing file with the target file name
|
used, and there already is an existing file with the target file name
|
||||||
@@ -459,14 +438,14 @@ to provide the data to send.
|
|||||||
existing). So that index.html becomes first index.html.1 and then
|
existing). So that index.html becomes first index.html.1 and then
|
||||||
index.html.2 etc.
|
index.html.2 etc.
|
||||||
|
|
||||||
16.4 simultaneous parallel transfers
|
15.4 simultaneous parallel transfers
|
||||||
|
|
||||||
The client could be told to use maximum N simultaneous parallel transfers and
|
The client could be told to use maximum N simultaneous parallel transfers and
|
||||||
then just make sure that happens. It should of course not make more than one
|
then just make sure that happens. It should of course not make more than one
|
||||||
connection to the same remote host. This would require the client to use the
|
connection to the same remote host. This would require the client to use the
|
||||||
multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595
|
multi interface. http://curl.haxx.se/bug/feature.cgi?id=1558595
|
||||||
|
|
||||||
16.5 provide formpost headers
|
15.5 provide formpost headers
|
||||||
|
|
||||||
Extending the capabilities of the multipart formposting. How about leaving
|
Extending the capabilities of the multipart formposting. How about leaving
|
||||||
the ';type=foo' syntax as it is and adding an extra tag (headers) which
|
the ';type=foo' syntax as it is and adding an extra tag (headers) which
|
||||||
@@ -480,7 +459,7 @@ to provide the data to send.
|
|||||||
which should overwrite the program reasonable defaults (plain/text,
|
which should overwrite the program reasonable defaults (plain/text,
|
||||||
8bit...)
|
8bit...)
|
||||||
|
|
||||||
16.6 url-specific options
|
15.6 url-specific options
|
||||||
|
|
||||||
Provide a way to make options bound to a specific URL among several on the
|
Provide a way to make options bound to a specific URL among several on the
|
||||||
command line. Possibly by letting ':' separate options between URLs,
|
command line. Possibly by letting ':' separate options between URLs,
|
||||||
@@ -494,57 +473,57 @@ to provide the data to send.
|
|||||||
|
|
||||||
The example would do a POST-GET-POST combination on a single command line.
|
The example would do a POST-GET-POST combination on a single command line.
|
||||||
|
|
||||||
16.7 warning when setting an option
|
15.7 warning when setting an option
|
||||||
|
|
||||||
Display a warning when libcurl returns an error when setting an option.
|
Display a warning when libcurl returns an error when setting an option.
|
||||||
This can be useful to tell when support for a particular feature hasn't been
|
This can be useful to tell when support for a particular feature hasn't been
|
||||||
compiled into the library.
|
compiled into the library.
|
||||||
|
|
||||||
16.8 IPv6 addresses with globbing
|
15.8 IPv6 addresses with globbing
|
||||||
|
|
||||||
Currently the command line client needs to get url globbing disabled (with
|
Currently the command line client needs to get url globbing disabled (with
|
||||||
-g) for it to support IPv6 numerical addresses. This is a rather silly flaw
|
-g) for it to support IPv6 numerical addresses. This is a rather silly flaw
|
||||||
that should be corrected. It probably involves a smarter detection of the
|
that should be corrected. It probably involves a smarter detection of the
|
||||||
'[' and ']' letters.
|
'[' and ']' letters.
|
||||||
|
|
||||||
17. Build
|
16. Build
|
||||||
|
|
||||||
17.1 roffit
|
16.1 roffit
|
||||||
|
|
||||||
Consider extending 'roffit' to produce decent ASCII output, and use that
|
Consider extending 'roffit' to produce decent ASCII output, and use that
|
||||||
instead of (g)nroff when building src/hugehelp.c
|
instead of (g)nroff when building src/tool_hugehelp.c
|
||||||
|
|
||||||
18. Test suite
|
17. Test suite
|
||||||
|
|
||||||
18.1 SSL tunnel
|
17.1 SSL tunnel
|
||||||
|
|
||||||
Make our own version of stunnel for simple port forwarding to enable HTTPS
|
Make our own version of stunnel for simple port forwarding to enable HTTPS
|
||||||
and FTP-SSL tests without the stunnel dependency, and it could allow us to
|
and FTP-SSL tests without the stunnel dependency, and it could allow us to
|
||||||
provide test tools built with either OpenSSL or GnuTLS
|
provide test tools built with either OpenSSL or GnuTLS
|
||||||
|
|
||||||
18.2 nicer lacking perl message
|
17.2 nicer lacking perl message
|
||||||
|
|
||||||
If perl wasn't found by the configure script, don't attempt to run the tests
|
If perl wasn't found by the configure script, don't attempt to run the tests
|
||||||
but explain something nice why it doesn't.
|
but explain something nice why it doesn't.
|
||||||
|
|
||||||
18.3 more protocols supported
|
17.3 more protocols supported
|
||||||
|
|
||||||
Extend the test suite to include more protocols. The telnet could just do ftp
|
Extend the test suite to include more protocols. The telnet could just do ftp
|
||||||
or http operations (for which we have test servers).
|
or http operations (for which we have test servers).
|
||||||
|
|
||||||
18.4 more platforms supported
|
17.4 more platforms supported
|
||||||
|
|
||||||
Make the test suite work on more platforms. OpenBSD and Mac OS. Remove
|
Make the test suite work on more platforms. OpenBSD and Mac OS. Remove
|
||||||
fork()s and it should become even more portable.
|
fork()s and it should become even more portable.
|
||||||
|
|
||||||
19. Next SONAME bump
|
18. Next SONAME bump
|
||||||
|
|
||||||
19.1 http-style HEAD output for ftp
|
18.1 http-style HEAD output for ftp
|
||||||
|
|
||||||
#undef CURL_FTP_HTTPSTYLE_HEAD in lib/ftp.c to remove the HTTP-style headers
|
#undef CURL_FTP_HTTPSTYLE_HEAD in lib/ftp.c to remove the HTTP-style headers
|
||||||
from being output in NOBODY requests over ftp
|
from being output in NOBODY requests over ftp
|
||||||
|
|
||||||
19.2 combine error codes
|
18.2 combine error codes
|
||||||
|
|
||||||
Combine some of the error codes to remove duplicates. The original
|
Combine some of the error codes to remove duplicates. The original
|
||||||
numbering should not be changed, and the old identifiers would be
|
numbering should not be changed, and the old identifiers would be
|
||||||
@@ -569,29 +548,29 @@ to provide the data to send.
|
|||||||
|
|
||||||
CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED
|
CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED
|
||||||
|
|
||||||
19.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
18.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
||||||
|
|
||||||
The current prototype only provides 'purpose' that tells what the
|
The current prototype only provides 'purpose' that tells what the
|
||||||
connection/socket is for, but not any protocol or similar. It makes it hard
|
connection/socket is for, but not any protocol or similar. It makes it hard
|
||||||
for applications to differentiate on TCP vs UDP and even HTTP vs FTP and
|
for applications to differentiate on TCP vs UDP and even HTTP vs FTP and
|
||||||
similar.
|
similar.
|
||||||
|
|
||||||
20. Next major release
|
10. Next major release
|
||||||
|
|
||||||
20.1 cleanup return codes
|
19.1 cleanup return codes
|
||||||
|
|
||||||
curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a
|
curl_easy_cleanup() returns void, but curl_multi_cleanup() returns a
|
||||||
CURLMcode. These should be changed to be the same.
|
CURLMcode. These should be changed to be the same.
|
||||||
|
|
||||||
20.2 remove obsolete defines
|
19.2 remove obsolete defines
|
||||||
|
|
||||||
remove obsolete defines from curl/curl.h
|
remove obsolete defines from curl/curl.h
|
||||||
|
|
||||||
20.3 size_t
|
19.3 size_t
|
||||||
|
|
||||||
make several functions use size_t instead of int in their APIs
|
make several functions use size_t instead of int in their APIs
|
||||||
|
|
||||||
20.4 remove several functions
|
19.4 remove several functions
|
||||||
|
|
||||||
remove the following functions from the public API:
|
remove the following functions from the public API:
|
||||||
|
|
||||||
@@ -612,18 +591,18 @@ to provide the data to send.
|
|||||||
|
|
||||||
curl_multi_socket_all
|
curl_multi_socket_all
|
||||||
|
|
||||||
20.5 remove CURLOPT_FAILONERROR
|
19.5 remove CURLOPT_FAILONERROR
|
||||||
|
|
||||||
Remove support for CURLOPT_FAILONERROR, it has gotten too kludgy and weird
|
Remove support for CURLOPT_FAILONERROR, it has gotten too kludgy and weird
|
||||||
internally. Let the app judge success or not for itself.
|
internally. Let the app judge success or not for itself.
|
||||||
|
|
||||||
20.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
19.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
||||||
|
|
||||||
Remove support for a global DNS cache. Anything global is silly, and we
|
Remove support for a global DNS cache. Anything global is silly, and we
|
||||||
already offer the share interface for the same functionality but done
|
already offer the share interface for the same functionality but done
|
||||||
"right".
|
"right".
|
||||||
|
|
||||||
20.7 remove progress meter from libcurl
|
19.7 remove progress meter from libcurl
|
||||||
|
|
||||||
The internally provided progress meter output doesn't belong in the library.
|
The internally provided progress meter output doesn't belong in the library.
|
||||||
Basically no application wants it (apart from curl) but instead applications
|
Basically no application wants it (apart from curl) but instead applications
|
||||||
@@ -633,7 +612,7 @@ to provide the data to send.
|
|||||||
variable types passed to it instead of doubles so that big files work
|
variable types passed to it instead of doubles so that big files work
|
||||||
correctly.
|
correctly.
|
||||||
|
|
||||||
20.8 remove 'curl_httppost' from public
|
19.8 remove 'curl_httppost' from public
|
||||||
|
|
||||||
curl_formadd() was made to fill in a public struct, but the fact that the
|
curl_formadd() was made to fill in a public struct, but the fact that the
|
||||||
struct is public is never really used by application for their own advantage
|
struct is public is never really used by application for their own advantage
|
||||||
@@ -642,7 +621,7 @@ to provide the data to send.
|
|||||||
Changing them to return a private handle will benefit the implementation and
|
Changing them to return a private handle will benefit the implementation and
|
||||||
allow us much greater freedoms while still maintining a solid API and ABI.
|
allow us much greater freedoms while still maintining a solid API and ABI.
|
||||||
|
|
||||||
20.9 have form functions use CURL handle argument
|
19.9 have form functions use CURL handle argument
|
||||||
|
|
||||||
curl_formadd() and curl_formget() both currently have no CURL handle
|
curl_formadd() and curl_formget() both currently have no CURL handle
|
||||||
argument, but both can use a callback that is set in the easy handle, and
|
argument, but both can use a callback that is set in the easy handle, and
|
||||||
@@ -650,7 +629,7 @@ to provide the data to send.
|
|||||||
curl_easy_perform() (or similar) called - which is hard to grasp and a design
|
curl_easy_perform() (or similar) called - which is hard to grasp and a design
|
||||||
mistake.
|
mistake.
|
||||||
|
|
||||||
20.10 Add CURLOPT_MAIL_CLIENT option
|
19.10 Add CURLOPT_MAIL_CLIENT option
|
||||||
|
|
||||||
Rather than use the URL to specify the mail client string to present in the
|
Rather than use the URL to specify the mail client string to present in the
|
||||||
HELO and EHLO commands, libcurl should support a new CURLOPT specifically for
|
HELO and EHLO commands, libcurl should support a new CURLOPT specifically for
|
||||||
|
|||||||
40
docs/curl.1
40
docs/curl.1
@@ -423,11 +423,8 @@ The windows version of curl will automatically look for a CA certs file named
|
|||||||
\'curl-ca-bundle.crt\', either in the same directory as curl.exe, or in the
|
\'curl-ca-bundle.crt\', either in the same directory as curl.exe, or in the
|
||||||
Current Working Directory, or in any folder along your PATH.
|
Current Working Directory, or in any folder along your PATH.
|
||||||
|
|
||||||
If curl is built against the NSS SSL library then this option tells
|
If curl is built against the NSS SSL library, the NSS PEM PKCS#11 module
|
||||||
curl the nickname of the CA certificate to use within the NSS database
|
(libnsspem.so) needs to be available for this option to work properly.
|
||||||
defined by the environment variable SSL_DIR (or by default /etc/pki/nssdb).
|
|
||||||
If the NSS PEM PKCS#11 module (libnsspem.so) is available then PEM files
|
|
||||||
may be loaded.
|
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is used several times, the last one will be used.
|
||||||
.IP "--capath <CA certificate directory>"
|
.IP "--capath <CA certificate directory>"
|
||||||
@@ -484,6 +481,17 @@ filename=, like this:
|
|||||||
|
|
||||||
\fBcurl\fP -F "file=@localfile;filename=nameinpost" url.com
|
\fBcurl\fP -F "file=@localfile;filename=nameinpost" url.com
|
||||||
|
|
||||||
|
If filename/path contains ',' or ';', it must be quoted by double-quotes like:
|
||||||
|
|
||||||
|
\fBcurl\fP -F "file=@\\"localfile\\";filename=\\"nameinpost\\"" url.com
|
||||||
|
|
||||||
|
or
|
||||||
|
|
||||||
|
\fBcurl\fP -F 'file=@"localfile";filename="nameinpost"' url.com
|
||||||
|
|
||||||
|
Note that if a filename/path is quoted by double-quotes, any double-quote
|
||||||
|
or backslash within the filename must be escaped by backslash.
|
||||||
|
|
||||||
See further examples and details in the MANUAL.
|
See further examples and details in the MANUAL.
|
||||||
|
|
||||||
This option can be used multiple times.
|
This option can be used multiple times.
|
||||||
@@ -1524,6 +1532,13 @@ same info.
|
|||||||
The numerical code that was found in the last response (from a proxy) to a
|
The numerical code that was found in the last response (from a proxy) to a
|
||||||
curl CONNECT request. (Added in 7.12.4)
|
curl CONNECT request. (Added in 7.12.4)
|
||||||
.TP
|
.TP
|
||||||
|
.B local_ip
|
||||||
|
The IP address of the local end of the most recently done connection - can be
|
||||||
|
either IPv4 or IPv6 (Added in 7.29.0)
|
||||||
|
.TP
|
||||||
|
.B local_port
|
||||||
|
The local port number of the most recently done connection (Added in 7.29.0)
|
||||||
|
.TP
|
||||||
.B num_connects
|
.B num_connects
|
||||||
Number of new connects made in the recent transfer. (Added in 7.12.3)
|
Number of new connects made in the recent transfer. (Added in 7.12.3)
|
||||||
.TP
|
.TP
|
||||||
@@ -1534,6 +1549,13 @@ Number of redirects that were followed in the request. (Added in 7.12.3)
|
|||||||
When an HTTP request was made without -L to follow redirects, this variable
|
When an HTTP request was made without -L to follow redirects, this variable
|
||||||
will show the actual URL a redirect \fIwould\fP take you to. (Added in 7.18.2)
|
will show the actual URL a redirect \fIwould\fP take you to. (Added in 7.18.2)
|
||||||
.TP
|
.TP
|
||||||
|
.B remote_ip
|
||||||
|
The remote IP address of the most recently done connection - can be either
|
||||||
|
IPv4 or IPv6 (Added in 7.29.0)
|
||||||
|
.TP
|
||||||
|
.B remote_port
|
||||||
|
The remote port number of the most recently done connection (Added in 7.29.0)
|
||||||
|
.TP
|
||||||
.B size_download
|
.B size_download
|
||||||
The total amount of bytes that were downloaded.
|
The total amount of bytes that were downloaded.
|
||||||
.TP
|
.TP
|
||||||
@@ -1631,6 +1653,14 @@ details and explanations. Common additional HTTP requests include PUT and
|
|||||||
DELETE, but related technologies like WebDAV offers PROPFIND, COPY, MOVE and
|
DELETE, but related technologies like WebDAV offers PROPFIND, COPY, MOVE and
|
||||||
more.
|
more.
|
||||||
|
|
||||||
|
Normally you don't need this option. All sorts of GET, HEAD, POST and PUT
|
||||||
|
requests are rather invoked by using dedicated command line options.
|
||||||
|
|
||||||
|
This option only changes the actual word used in the HTTP request, it does not
|
||||||
|
alter the way curl behaves. So for example if you want to make a proper HEAD
|
||||||
|
request, using -X HEAD will not suffice. You need to use the \fI-I, --head\fP
|
||||||
|
option.
|
||||||
|
|
||||||
(FTP)
|
(FTP)
|
||||||
Specifies a custom FTP command to use instead of LIST when doing file lists
|
Specifies a custom FTP command to use instead of LIST when doing file lists
|
||||||
with FTP.
|
with FTP.
|
||||||
|
|||||||
@@ -31,24 +31,32 @@ EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \
|
|||||||
# might possibly already be installed in the system.
|
# might possibly already be installed in the system.
|
||||||
#
|
#
|
||||||
# $(top_builddir)/include/curl for generated curlbuild.h included from curl.h
|
# $(top_builddir)/include/curl for generated curlbuild.h included from curl.h
|
||||||
# $(top_builddir)/include for generated curlbuild.h included from lib/setup.h
|
# $(top_builddir)/include for generated curlbuild.h inc. from lib/curl_setup.h
|
||||||
# $(top_srcdir)/include is for libcurl's external include files
|
# $(top_srcdir)/include is for libcurl's external include files
|
||||||
|
|
||||||
INCLUDES = -I$(top_builddir)/include/curl \
|
AM_CPPFLAGS = -I$(top_builddir)/include/curl \
|
||||||
-I$(top_builddir)/include \
|
-I$(top_builddir)/include \
|
||||||
-I$(top_srcdir)/include
|
-I$(top_srcdir)/include
|
||||||
|
|
||||||
LIBDIR = $(top_builddir)/lib
|
LIBDIR = $(top_builddir)/lib
|
||||||
|
|
||||||
AM_CPPFLAGS = -DCURL_NO_OLDIES
|
# Avoid libcurl obsolete stuff
|
||||||
|
AM_CPPFLAGS += -DCURL_NO_OLDIES
|
||||||
|
|
||||||
# Mostly for Windows build targets, when using static libcurl
|
# Mostly for Windows build targets, when using static libcurl
|
||||||
if USE_CPPFLAG_CURL_STATICLIB
|
if USE_CPPFLAG_CURL_STATICLIB
|
||||||
AM_CPPFLAGS += -DCURL_STATICLIB
|
AM_CPPFLAGS += -DCURL_STATICLIB
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Prevent LIBS from being used for all link targets
|
||||||
|
LIBS = $(BLANK_AT_MAKETIME)
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
|
if USE_EXPLICIT_LIB_DEPS
|
||||||
|
LDADD = $(LIBDIR)/libcurl.la @LIBCURL_LIBS@
|
||||||
|
else
|
||||||
LDADD = $(LIBDIR)/libcurl.la
|
LDADD = $(LIBDIR)/libcurl.la
|
||||||
|
endif
|
||||||
|
|
||||||
# Makefile.inc provides the check_PROGRAMS and COMPLICATED_EXAMPLES defines
|
# Makefile.inc provides the check_PROGRAMS and COMPLICATED_EXAMPLES defines
|
||||||
include Makefile.inc
|
include Makefile.inc
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ check_PROGRAMS = 10-at-a-time anyauthput cookie_interface debug fileupload \
|
|||||||
|
|
||||||
# These examples require external dependencies that may not be commonly
|
# These examples require external dependencies that may not be commonly
|
||||||
# available on POSIX systems, so don't bother attempting to compile them here.
|
# available on POSIX systems, so don't bother attempting to compile them here.
|
||||||
COMPLICATED_EXAMPLES = curlgtk.c curlx.c htmltitle.cc cacertinmem.c \
|
COMPLICATED_EXAMPLES = curlgtk.c curlx.c htmltitle.cpp cacertinmem.c \
|
||||||
ftpuploadresume.c ghiper.c hiperfifo.c htmltidy.c multithread.c \
|
ftpuploadresume.c ghiper.c hiperfifo.c htmltidy.c multithread.c \
|
||||||
opensslthreadlock.c sampleconv.c synctime.c threaded-ssl.c evhiperfifo.c \
|
opensslthreadlock.c sampleconv.c synctime.c threaded-ssl.c evhiperfifo.c \
|
||||||
smooth-gtk-thread.c version-check.pl
|
smooth-gtk-thread.c version-check.pl href_extractor.c asiohiper.cpp
|
||||||
|
|||||||
@@ -42,7 +42,7 @@ OPENSSL_PATH = ../../../openssl-0.9.8x
|
|||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../../libssh2-1.4.2
|
LIBSSH2_PATH = ../../../libssh2-1.4.3
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your librtmp package.
|
# Edit the path below to point to the base of your librtmp package.
|
||||||
ifndef LIBRTMP_PATH
|
ifndef LIBRTMP_PATH
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ endif
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../../libssh2-1.4.2
|
LIBSSH2_PATH = ../../../libssh2-1.4.3
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your axTLS package.
|
# Edit the path below to point to the base of your axTLS package.
|
||||||
|
|||||||
@@ -27,7 +27,9 @@
|
|||||||
# ifdef __VMS
|
# ifdef __VMS
|
||||||
typedef int intptr_t;
|
typedef int intptr_t;
|
||||||
# endif
|
# endif
|
||||||
|
# if !defined(_AIX) && !defined(__sgi) && !defined(__osf__)
|
||||||
# include <stdint.h>
|
# include <stdint.h>
|
||||||
|
# endif
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@@ -51,6 +53,12 @@
|
|||||||
#define TRUE 1
|
#define TRUE 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(_AIX) || defined(__sgi) || defined(__osf__)
|
||||||
|
#ifndef intptr_t
|
||||||
|
#define intptr_t long
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This example shows a HTTP PUT operation with authentiction using "any"
|
* This example shows a HTTP PUT operation with authentiction using "any"
|
||||||
* type. It PUTs a file given as a command line argument to the URL also given
|
* type. It PUTs a file given as a command line argument to the URL also given
|
||||||
|
|||||||
454
docs/examples/asiohiper.cpp
Normal file
454
docs/examples/asiohiper.cpp
Normal file
@@ -0,0 +1,454 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* file: asiohiper.cpp
|
||||||
|
* Example program to demonstrate the use of multi socket interface
|
||||||
|
* with boost::asio
|
||||||
|
*
|
||||||
|
* This program is in c++ and uses boost::asio instead of libevent/libev.
|
||||||
|
* Requires boost::asio, boost::bind and boost::system
|
||||||
|
*
|
||||||
|
* This is an adaptation of libcurl's "hiperfifo.c" and "evhiperfifo.c"
|
||||||
|
* sample programs. This example implements a subset of the functionality from
|
||||||
|
* hiperfifo.c, for full functionality refer hiperfifo.c or evhiperfifo.c
|
||||||
|
*
|
||||||
|
* Written by Lijo Antony based on hiperfifo.c by Jeff Pohlmeyer
|
||||||
|
*
|
||||||
|
* When running, the program creates an easy handle for a URL and
|
||||||
|
* uses the curl_multi API to fetch it.
|
||||||
|
*
|
||||||
|
* Note:
|
||||||
|
* For the sake of simplicity, URL is hard coded to "www.google.com"
|
||||||
|
*
|
||||||
|
* This is purely a demo app, all retrieved data is simply discarded by the write
|
||||||
|
* callback.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <boost/asio.hpp>
|
||||||
|
#include <boost/bind.hpp>
|
||||||
|
|
||||||
|
#define MSG_OUT stdout /* Send info to stdout, change to stderr if you want */
|
||||||
|
|
||||||
|
/* boost::asio related objects
|
||||||
|
* using global variables for simplicity
|
||||||
|
*/
|
||||||
|
boost::asio::io_service io_service;
|
||||||
|
boost::asio::deadline_timer timer(io_service);
|
||||||
|
std::map<curl_socket_t, boost::asio::ip::tcp::socket *> socket_map;
|
||||||
|
|
||||||
|
/* Global information, common to all connections */
|
||||||
|
typedef struct _GlobalInfo
|
||||||
|
{
|
||||||
|
CURLM *multi;
|
||||||
|
int still_running;
|
||||||
|
} GlobalInfo;
|
||||||
|
|
||||||
|
/* Information associated with a specific easy handle */
|
||||||
|
typedef struct _ConnInfo
|
||||||
|
{
|
||||||
|
CURL *easy;
|
||||||
|
char *url;
|
||||||
|
GlobalInfo *global;
|
||||||
|
char error[CURL_ERROR_SIZE];
|
||||||
|
} ConnInfo;
|
||||||
|
|
||||||
|
static void timer_cb(const boost::system::error_code & error, GlobalInfo *g);
|
||||||
|
|
||||||
|
/* Update the event timer after curl_multi library calls */
|
||||||
|
static int multi_timer_cb(CURLM *multi, long timeout_ms, GlobalInfo *g)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nmulti_timer_cb: timeout_ms %ld", timeout_ms);
|
||||||
|
|
||||||
|
/* cancel running timer */
|
||||||
|
timer.cancel();
|
||||||
|
|
||||||
|
if ( timeout_ms > 0 )
|
||||||
|
{
|
||||||
|
/* update timer */
|
||||||
|
timer.expires_from_now(boost::posix_time::millisec(timeout_ms));
|
||||||
|
timer.async_wait(boost::bind(&timer_cb, _1, g));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* call timeout function immediately */
|
||||||
|
boost::system::error_code error; /*success*/
|
||||||
|
timer_cb(error, g);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Die if we get a bad CURLMcode somewhere */
|
||||||
|
static void mcode_or_die(const char *where, CURLMcode code)
|
||||||
|
{
|
||||||
|
if ( CURLM_OK != code )
|
||||||
|
{
|
||||||
|
const char *s;
|
||||||
|
switch ( code )
|
||||||
|
{
|
||||||
|
case CURLM_CALL_MULTI_PERFORM: s="CURLM_CALL_MULTI_PERFORM"; break;
|
||||||
|
case CURLM_BAD_HANDLE: s="CURLM_BAD_HANDLE"; break;
|
||||||
|
case CURLM_BAD_EASY_HANDLE: s="CURLM_BAD_EASY_HANDLE"; break;
|
||||||
|
case CURLM_OUT_OF_MEMORY: s="CURLM_OUT_OF_MEMORY"; break;
|
||||||
|
case CURLM_INTERNAL_ERROR: s="CURLM_INTERNAL_ERROR"; break;
|
||||||
|
case CURLM_UNKNOWN_OPTION: s="CURLM_UNKNOWN_OPTION"; break;
|
||||||
|
case CURLM_LAST: s="CURLM_LAST"; break;
|
||||||
|
default: s="CURLM_unknown";
|
||||||
|
break;
|
||||||
|
case CURLM_BAD_SOCKET: s="CURLM_BAD_SOCKET";
|
||||||
|
fprintf(MSG_OUT, "\nERROR: %s returns %s", where, s);
|
||||||
|
/* ignore this error */
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
fprintf(MSG_OUT, "\nERROR: %s returns %s", where, s);
|
||||||
|
exit(code);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check for completed transfers, and remove their easy handles */
|
||||||
|
static void check_multi_info(GlobalInfo *g)
|
||||||
|
{
|
||||||
|
char *eff_url;
|
||||||
|
CURLMsg *msg;
|
||||||
|
int msgs_left;
|
||||||
|
ConnInfo *conn;
|
||||||
|
CURL *easy;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
fprintf(MSG_OUT, "\nREMAINING: %d", g->still_running);
|
||||||
|
|
||||||
|
while ((msg = curl_multi_info_read(g->multi, &msgs_left)))
|
||||||
|
{
|
||||||
|
if (msg->msg == CURLMSG_DONE)
|
||||||
|
{
|
||||||
|
easy = msg->easy_handle;
|
||||||
|
res = msg->data.result;
|
||||||
|
curl_easy_getinfo(easy, CURLINFO_PRIVATE, &conn);
|
||||||
|
curl_easy_getinfo(easy, CURLINFO_EFFECTIVE_URL, &eff_url);
|
||||||
|
fprintf(MSG_OUT, "\nDONE: %s => (%d) %s", eff_url, res, conn->error);
|
||||||
|
curl_multi_remove_handle(g->multi, easy);
|
||||||
|
free(conn->url);
|
||||||
|
curl_easy_cleanup(easy);
|
||||||
|
free(conn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Called by asio when there is an action on a socket */
|
||||||
|
static void event_cb(GlobalInfo * g, boost::asio::ip::tcp::socket * tcp_socket, int action)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nevent_cb: action=%d", action);
|
||||||
|
|
||||||
|
CURLMcode rc;
|
||||||
|
rc = curl_multi_socket_action(g->multi, tcp_socket->native_handle(), action, &g->still_running);
|
||||||
|
|
||||||
|
mcode_or_die("event_cb: curl_multi_socket_action", rc);
|
||||||
|
check_multi_info(g);
|
||||||
|
|
||||||
|
if ( g->still_running <= 0 )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nlast transfer done, kill timeout");
|
||||||
|
timer.cancel();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Called by asio when our timeout expires */
|
||||||
|
static void timer_cb(const boost::system::error_code & error, GlobalInfo *g)
|
||||||
|
{
|
||||||
|
if ( !error)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\ntimer_cb: ");
|
||||||
|
|
||||||
|
CURLMcode rc;
|
||||||
|
rc = curl_multi_socket_action(g->multi, CURL_SOCKET_TIMEOUT, 0, &g->still_running);
|
||||||
|
|
||||||
|
mcode_or_die("timer_cb: curl_multi_socket_action", rc);
|
||||||
|
check_multi_info(g);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Clean up any data */
|
||||||
|
static void remsock(int *f, GlobalInfo *g)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nremsock: ");
|
||||||
|
|
||||||
|
if ( f )
|
||||||
|
{
|
||||||
|
free(f);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void setsock(int *fdp, curl_socket_t s, CURL*e, int act, GlobalInfo*g)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nsetsock: socket=%d, act=%d, fdp=%p", s, act, fdp);
|
||||||
|
|
||||||
|
std::map<curl_socket_t, boost::asio::ip::tcp::socket *>::iterator it = socket_map.find(s);
|
||||||
|
|
||||||
|
if ( it == socket_map.end() )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nsocket %d is a c-ares socket, ignoring", s);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
boost::asio::ip::tcp::socket * tcp_socket = it->second;
|
||||||
|
|
||||||
|
*fdp = act;
|
||||||
|
|
||||||
|
if ( act == CURL_POLL_IN )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nwatching for socket to become readable");
|
||||||
|
|
||||||
|
tcp_socket->async_read_some(boost::asio::null_buffers(),
|
||||||
|
boost::bind(&event_cb, g,
|
||||||
|
tcp_socket,
|
||||||
|
act));
|
||||||
|
}
|
||||||
|
else if ( act == CURL_POLL_OUT )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nwatching for socket to become writable");
|
||||||
|
|
||||||
|
tcp_socket->async_write_some(boost::asio::null_buffers(),
|
||||||
|
boost::bind(&event_cb, g,
|
||||||
|
tcp_socket,
|
||||||
|
act));
|
||||||
|
}
|
||||||
|
else if ( act == CURL_POLL_INOUT )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nwatching for socket to become readable & writable");
|
||||||
|
|
||||||
|
tcp_socket->async_read_some(boost::asio::null_buffers(),
|
||||||
|
boost::bind(&event_cb, g,
|
||||||
|
tcp_socket,
|
||||||
|
act));
|
||||||
|
|
||||||
|
tcp_socket->async_write_some(boost::asio::null_buffers(),
|
||||||
|
boost::bind(&event_cb, g,
|
||||||
|
tcp_socket,
|
||||||
|
act));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void addsock(curl_socket_t s, CURL *easy, int action, GlobalInfo *g)
|
||||||
|
{
|
||||||
|
int *fdp = (int *)calloc(sizeof(int), 1); /* fdp is used to store current action */
|
||||||
|
|
||||||
|
setsock(fdp, s, easy, action, g);
|
||||||
|
curl_multi_assign(g->multi, s, fdp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* CURLMOPT_SOCKETFUNCTION */
|
||||||
|
static int sock_cb(CURL *e, curl_socket_t s, int what, void *cbp, void *sockp)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nsock_cb: socket=%d, what=%d, sockp=%p", s, what, sockp);
|
||||||
|
|
||||||
|
GlobalInfo *g = (GlobalInfo*) cbp;
|
||||||
|
int *actionp = (int*) sockp;
|
||||||
|
const char *whatstr[]={ "none", "IN", "OUT", "INOUT", "REMOVE"};
|
||||||
|
|
||||||
|
fprintf(MSG_OUT,
|
||||||
|
"\nsocket callback: s=%d e=%p what=%s ", s, e, whatstr[what]);
|
||||||
|
|
||||||
|
if ( what == CURL_POLL_REMOVE )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\n");
|
||||||
|
remsock(actionp, g);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if ( !actionp )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nAdding data: %s", whatstr[what]);
|
||||||
|
addsock(s, e, what, g);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT,
|
||||||
|
"\nChanging action from %s to %s",
|
||||||
|
whatstr[*actionp], whatstr[what]);
|
||||||
|
setsock(actionp, s, e, what, g);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* CURLOPT_WRITEFUNCTION */
|
||||||
|
static size_t write_cb(void *ptr, size_t size, size_t nmemb, void *data)
|
||||||
|
{
|
||||||
|
|
||||||
|
size_t written = size * nmemb;
|
||||||
|
char* pBuffer = (char*)malloc(written + 1);
|
||||||
|
|
||||||
|
strncpy(pBuffer, (const char *)ptr, written);
|
||||||
|
pBuffer [written] = '\0';
|
||||||
|
|
||||||
|
fprintf(MSG_OUT, "%s", pBuffer);
|
||||||
|
|
||||||
|
free(pBuffer);
|
||||||
|
|
||||||
|
return written;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* CURLOPT_PROGRESSFUNCTION */
|
||||||
|
static int prog_cb (void *p, double dltotal, double dlnow, double ult,
|
||||||
|
double uln)
|
||||||
|
{
|
||||||
|
ConnInfo *conn = (ConnInfo *)p;
|
||||||
|
(void)ult;
|
||||||
|
(void)uln;
|
||||||
|
|
||||||
|
fprintf(MSG_OUT, "\nProgress: %s (%g/%g)", conn->url, dlnow, dltotal);
|
||||||
|
fprintf(MSG_OUT, "\nProgress: %s (%g)", conn->url, ult);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* CURLOPT_OPENSOCKETFUNCTION */
|
||||||
|
static curl_socket_t opensocket(void *clientp,
|
||||||
|
curlsocktype purpose,
|
||||||
|
struct curl_sockaddr *address)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nopensocket :");
|
||||||
|
|
||||||
|
curl_socket_t sockfd = CURL_SOCKET_BAD;
|
||||||
|
|
||||||
|
/* restrict to ipv4 */
|
||||||
|
if (purpose == CURLSOCKTYPE_IPCXN && address->family == AF_INET)
|
||||||
|
{
|
||||||
|
/* create a tcp socket object */
|
||||||
|
boost::asio::ip::tcp::socket *tcp_socket = new boost::asio::ip::tcp::socket(io_service);
|
||||||
|
|
||||||
|
/* open it and get the native handle*/
|
||||||
|
boost::system::error_code ec;
|
||||||
|
tcp_socket->open(boost::asio::ip::tcp::v4(), ec);
|
||||||
|
|
||||||
|
if (ec)
|
||||||
|
{
|
||||||
|
//An error occurred
|
||||||
|
std::cout << std::endl << "Couldn't open socket [" << ec << "][" << ec.message() << "]";
|
||||||
|
fprintf(MSG_OUT, "\nERROR: Returning CURL_SOCKET_BAD to signal error");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sockfd = tcp_socket->native_handle();
|
||||||
|
fprintf(MSG_OUT, "\nOpened socket %d", sockfd);
|
||||||
|
|
||||||
|
/* save it for monitoring */
|
||||||
|
socket_map.insert(std::pair<curl_socket_t, boost::asio::ip::tcp::socket *>(sockfd, tcp_socket));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return sockfd;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* CURLOPT_CLOSESOCKETFUNCTION */
|
||||||
|
static int closesocket(void *clientp, curl_socket_t item)
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\nclosesocket : %d", item);
|
||||||
|
|
||||||
|
std::map<curl_socket_t, boost::asio::ip::tcp::socket *>::iterator it = socket_map.find(item);
|
||||||
|
|
||||||
|
if ( it != socket_map.end() )
|
||||||
|
{
|
||||||
|
delete it->second;
|
||||||
|
socket_map.erase(it);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Create a new easy handle, and add it to the global curl_multi */
|
||||||
|
static void new_conn(char *url, GlobalInfo *g )
|
||||||
|
{
|
||||||
|
ConnInfo *conn;
|
||||||
|
CURLMcode rc;
|
||||||
|
|
||||||
|
conn = (ConnInfo *)calloc(1, sizeof(ConnInfo));
|
||||||
|
memset(conn, 0, sizeof(ConnInfo));
|
||||||
|
conn->error[0]='\0';
|
||||||
|
|
||||||
|
conn->easy = curl_easy_init();
|
||||||
|
|
||||||
|
if ( !conn->easy )
|
||||||
|
{
|
||||||
|
fprintf(MSG_OUT, "\ncurl_easy_init() failed, exiting!");
|
||||||
|
exit(2);
|
||||||
|
}
|
||||||
|
conn->global = g;
|
||||||
|
conn->url = strdup(url);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, &conn);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 1L);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_NOPROGRESS, 1L);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_PROGRESSFUNCTION, prog_cb);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_PROGRESSDATA, conn);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_LOW_SPEED_TIME, 3L);
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_LOW_SPEED_LIMIT, 10L);
|
||||||
|
|
||||||
|
/* call this function to get a socket */
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_OPENSOCKETFUNCTION, opensocket);
|
||||||
|
|
||||||
|
/* call this function to close a socket */
|
||||||
|
curl_easy_setopt(conn->easy, CURLOPT_CLOSESOCKETFUNCTION, closesocket);
|
||||||
|
|
||||||
|
fprintf(MSG_OUT,
|
||||||
|
"\nAdding easy %p to multi %p (%s)", conn->easy, g->multi, url);
|
||||||
|
rc = curl_multi_add_handle(g->multi, conn->easy);
|
||||||
|
mcode_or_die("new_conn: curl_multi_add_handle", rc);
|
||||||
|
|
||||||
|
/* note that the add_handle() will set a time-out to trigger very soon so
|
||||||
|
that the necessary socket_action() call will be called by this app */
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
GlobalInfo g;
|
||||||
|
CURLMcode rc;
|
||||||
|
(void)argc;
|
||||||
|
(void)argv;
|
||||||
|
|
||||||
|
memset(&g, 0, sizeof(GlobalInfo));
|
||||||
|
g.multi = curl_multi_init();
|
||||||
|
|
||||||
|
curl_multi_setopt(g.multi, CURLMOPT_SOCKETFUNCTION, sock_cb);
|
||||||
|
curl_multi_setopt(g.multi, CURLMOPT_SOCKETDATA, &g);
|
||||||
|
curl_multi_setopt(g.multi, CURLMOPT_TIMERFUNCTION, multi_timer_cb);
|
||||||
|
curl_multi_setopt(g.multi, CURLMOPT_TIMERDATA, &g);
|
||||||
|
|
||||||
|
new_conn((char *)"www.google.com", &g); /* add a URL */
|
||||||
|
|
||||||
|
/* enter io_service run loop */
|
||||||
|
io_service.run();
|
||||||
|
|
||||||
|
curl_multi_cleanup(g.multi);
|
||||||
|
|
||||||
|
fprintf(MSG_OUT, "\ndone.\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
@@ -52,18 +52,24 @@ int main(void)
|
|||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
if(!res) {
|
if(!res) {
|
||||||
struct curl_certinfo *ci = NULL;
|
union {
|
||||||
|
struct curl_slist *to_info;
|
||||||
|
struct curl_certinfo *to_certinfo;
|
||||||
|
} ptr;
|
||||||
|
|
||||||
res = curl_easy_getinfo(curl, CURLINFO_CERTINFO, &ci);
|
ptr.to_info = NULL;
|
||||||
|
|
||||||
if(!res && ci) {
|
res = curl_easy_getinfo(curl, CURLINFO_CERTINFO, &ptr.to_info);
|
||||||
|
|
||||||
|
if(!res && ptr.to_info) {
|
||||||
int i;
|
int i;
|
||||||
printf("%d certs!\n", ci->num_of_certs);
|
|
||||||
|
|
||||||
for(i=0; i<ci->num_of_certs; i++) {
|
printf("%d certs!\n", ptr.to_certinfo->num_of_certs);
|
||||||
|
|
||||||
|
for(i = 0; i < ptr.to_certinfo->num_of_certs; i++) {
|
||||||
struct curl_slist *slist;
|
struct curl_slist *slist;
|
||||||
|
|
||||||
for(slist = ci->certinfo[i]; slist; slist = slist->next)
|
for(slist = ptr.to_certinfo->certinfo[i]; slist; slist = slist->next)
|
||||||
printf("%s\n", slist->data);
|
printf("%s\n", slist->data);
|
||||||
|
|
||||||
}
|
}
|
||||||
@@ -71,7 +77,6 @@ int main(void)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
curl_easy_cleanup(curl);
|
curl_easy_cleanup(curl);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -89,7 +89,7 @@ main(void)
|
|||||||
#endif
|
#endif
|
||||||
/* Netscape format cookie */
|
/* Netscape format cookie */
|
||||||
snprintf(nline, sizeof(nline), "%s\t%s\t%s\t%s\t%lu\t%s\t%s",
|
snprintf(nline, sizeof(nline), "%s\t%s\t%s\t%s\t%lu\t%s\t%s",
|
||||||
".google.com", "TRUE", "/", "FALSE", time(NULL) + 31337, "PREF", "hello google, i like you very much!");
|
".google.com", "TRUE", "/", "FALSE", (unsigned long)time(NULL) + 31337UL, "PREF", "hello google, i like you very much!");
|
||||||
res = curl_easy_setopt(curl, CURLOPT_COOKIELIST, nline);
|
res = curl_easy_setopt(curl, CURLOPT_COOKIELIST, nline);
|
||||||
if (res != CURLE_OK) {
|
if (res != CURLE_OK) {
|
||||||
fprintf(stderr, "Curl curl_easy_setopt failed: %s\n", curl_easy_strerror(res));
|
fprintf(stderr, "Curl curl_easy_setopt failed: %s\n", curl_easy_strerror(res));
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -130,6 +130,9 @@ int main(void)
|
|||||||
/* the DEBUGFUNCTION has no effect until we enable VERBOSE */
|
/* the DEBUGFUNCTION has no effect until we enable VERBOSE */
|
||||||
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(curl, CURLOPT_VERBOSE, 1L);
|
||||||
|
|
||||||
|
/* example.com is redirected, so we tell libcurl to follow redirection */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
/* Check for errors */
|
/* Check for errors */
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -336,7 +336,7 @@ static void new_conn(char *url, GlobalInfo *g )
|
|||||||
conn->url = strdup(url);
|
conn->url = strdup(url);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url);
|
curl_easy_setopt(conn->easy, CURLOPT_URL, conn->url);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb);
|
curl_easy_setopt(conn->easy, CURLOPT_WRITEFUNCTION, write_cb);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, &conn);
|
curl_easy_setopt(conn->easy, CURLOPT_WRITEDATA, conn);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 1L);
|
curl_easy_setopt(conn->easy, CURLOPT_VERBOSE, 1L);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error);
|
curl_easy_setopt(conn->easy, CURLOPT_ERRORBUFFER, conn->error);
|
||||||
curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn);
|
curl_easy_setopt(conn->easy, CURLOPT_PRIVATE, conn);
|
||||||
|
|||||||
@@ -47,6 +47,10 @@
|
|||||||
#define IPADDR "127.0.0.1"
|
#define IPADDR "127.0.0.1"
|
||||||
#define PORTNUM 80
|
#define PORTNUM 80
|
||||||
|
|
||||||
|
#ifndef INADDR_NONE
|
||||||
|
#define INADDR_NONE 0xffffffff
|
||||||
|
#endif
|
||||||
|
|
||||||
static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
int written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
int written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -43,8 +43,8 @@ int main(void)
|
|||||||
char ftpurl[] = "ftp://ftp.example.com/gnu/binutils/binutils-2.19.1.tar.bz2";
|
char ftpurl[] = "ftp://ftp.example.com/gnu/binutils/binutils-2.19.1.tar.bz2";
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
const time_t filetime;
|
long filetime = -1;
|
||||||
const double filesize;
|
double filesize = 0.0;
|
||||||
const char *filename = strrchr(ftpurl, '/') + 1;
|
const char *filename = strrchr(ftpurl, '/') + 1;
|
||||||
|
|
||||||
curl_global_init(CURL_GLOBAL_DEFAULT);
|
curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
@@ -67,10 +67,12 @@ int main(void)
|
|||||||
if(CURLE_OK == res) {
|
if(CURLE_OK == res) {
|
||||||
/* http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */
|
/* http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html */
|
||||||
res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime);
|
res = curl_easy_getinfo(curl, CURLINFO_FILETIME, &filetime);
|
||||||
if((CURLE_OK == res) && filetime)
|
if((CURLE_OK == res) && (filetime >= 0)) {
|
||||||
printf("filetime %s: %s", filename, ctime(&filetime));
|
time_t file_time = (time_t)filetime;
|
||||||
|
printf("filetime %s: %s", filename, ctime(&file_time));
|
||||||
|
}
|
||||||
res = curl_easy_getinfo(curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD, &filesize);
|
res = curl_easy_getinfo(curl, CURLINFO_CONTENT_LENGTH_DOWNLOAD, &filesize);
|
||||||
if((CURLE_OK == res) && (filesize>0))
|
if((CURLE_OK == res) && (filesize>0.0))
|
||||||
printf("filesize %s: %0.0f bytes\n", filename, filesize);
|
printf("filesize %s: %0.0f bytes\n", filename, filesize);
|
||||||
} else {
|
} else {
|
||||||
/* we failed */
|
/* we failed */
|
||||||
|
|||||||
86
docs/examples/href_extractor.c
Normal file
86
docs/examples/href_extractor.c
Normal file
@@ -0,0 +1,86 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This example uses the "Streaming HTML parser" to extract the href pieces in
|
||||||
|
* a streaming manner from a downloaded HTML. Kindly donated by Michał
|
||||||
|
* Kowalczyk.
|
||||||
|
*
|
||||||
|
* The parser is found at
|
||||||
|
* http://code.google.com/p/htmlstreamparser/
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
#include <htmlstreamparser.h>
|
||||||
|
|
||||||
|
|
||||||
|
static size_t write_callback(void *buffer, size_t size, size_t nmemb,
|
||||||
|
void *hsp)
|
||||||
|
{
|
||||||
|
size_t realsize = size * nmemb, p;
|
||||||
|
for (p = 0; p < realsize; p++) {
|
||||||
|
html_parser_char_parse(hsp, ((char *)buffer)[p]);
|
||||||
|
if (html_parser_cmp_tag(hsp, "a", 1))
|
||||||
|
if (html_parser_cmp_attr(hsp, "href", 4))
|
||||||
|
if (html_parser_is_in(hsp, HTML_VALUE_ENDED)) {
|
||||||
|
html_parser_val(hsp)[html_parser_val_length(hsp)] = '\0';
|
||||||
|
printf("%s\n", html_parser_val(hsp));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return realsize;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
char tag[1], attr[4], val[128];
|
||||||
|
CURL *curl;
|
||||||
|
HTMLSTREAMPARSER *hsp;
|
||||||
|
|
||||||
|
if (argc != 2) {
|
||||||
|
printf("Usage: %s URL\n", argv[0]);
|
||||||
|
return EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
|
||||||
|
hsp = html_parser_init();
|
||||||
|
|
||||||
|
html_parser_set_tag_to_lower(hsp, 1);
|
||||||
|
html_parser_set_attr_to_lower(hsp, 1);
|
||||||
|
html_parser_set_tag_buffer(hsp, tag, sizeof(tag));
|
||||||
|
html_parser_set_attr_buffer(hsp, attr, sizeof(attr));
|
||||||
|
html_parser_set_val_buffer(hsp, val, sizeof(val)-1);
|
||||||
|
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, argv[1]);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, write_callback);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_WRITEDATA, hsp);
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1);
|
||||||
|
|
||||||
|
curl_easy_perform(curl);
|
||||||
|
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
html_parser_cleanup(hsp);
|
||||||
|
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -53,6 +53,9 @@ int main(void)
|
|||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
curl_easy_cleanup(curl);
|
curl_easy_cleanup(curl);
|
||||||
|
|
||||||
|
/* free the custom headers */
|
||||||
|
curl_slist_free_all(chunk);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -58,7 +58,7 @@ int main(void)
|
|||||||
struct WriteThis pooh;
|
struct WriteThis pooh;
|
||||||
|
|
||||||
pooh.readptr = data;
|
pooh.readptr = data;
|
||||||
pooh.sizeleft = strlen(data);
|
pooh.sizeleft = (long)strlen(data);
|
||||||
|
|
||||||
/* In windows, this will init the winsock stuff */
|
/* In windows, this will init the winsock stuff */
|
||||||
res = curl_global_init(CURL_GLOBAL_DEFAULT);
|
res = curl_global_init(CURL_GLOBAL_DEFAULT);
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ static int progress(void *p,
|
|||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res=0;
|
CURLcode res = CURLE_OK;
|
||||||
struct myprogress prog;
|
struct myprogress prog;
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
@@ -74,7 +74,7 @@ int main(void)
|
|||||||
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L);
|
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L);
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
if(res)
|
if(res != CURLE_OK)
|
||||||
fprintf(stderr, "%s\n", curl_easy_strerror(res));
|
fprintf(stderr, "%s\n", curl_easy_strerror(res));
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
|||||||
@@ -178,7 +178,7 @@ int main(int argc, char * const argv[])
|
|||||||
#endif
|
#endif
|
||||||
const char *range = "0.000-";
|
const char *range = "0.000-";
|
||||||
int rc = EXIT_SUCCESS;
|
int rc = EXIT_SUCCESS;
|
||||||
char *basename = NULL;
|
char *base_name = NULL;
|
||||||
|
|
||||||
printf("\nRTSP request %s\n", VERSION_STR);
|
printf("\nRTSP request %s\n", VERSION_STR);
|
||||||
printf(" Project web site: http://code.google.com/p/rtsprequest/\n");
|
printf(" Project web site: http://code.google.com/p/rtsprequest/\n");
|
||||||
@@ -186,20 +186,20 @@ int main(int argc, char * const argv[])
|
|||||||
|
|
||||||
/* check command line */
|
/* check command line */
|
||||||
if ((argc != 2) && (argc != 3)) {
|
if ((argc != 2) && (argc != 3)) {
|
||||||
basename = strrchr(argv[0], '/');
|
base_name = strrchr(argv[0], '/');
|
||||||
if (basename == NULL) {
|
if (base_name == NULL) {
|
||||||
basename = strrchr(argv[0], '\\');
|
base_name = strrchr(argv[0], '\\');
|
||||||
}
|
}
|
||||||
if (basename == NULL) {
|
if (base_name == NULL) {
|
||||||
basename = argv[0];
|
base_name = argv[0];
|
||||||
} else {
|
} else {
|
||||||
basename++;
|
base_name++;
|
||||||
}
|
}
|
||||||
printf("Usage: %s url [transport]\n", basename);
|
printf("Usage: %s url [transport]\n", base_name);
|
||||||
printf(" url of video server\n");
|
printf(" url of video server\n");
|
||||||
printf(" transport (optional) specifier for media stream protocol\n");
|
printf(" transport (optional) specifier for media stream protocol\n");
|
||||||
printf(" default transport: %s\n", transport);
|
printf(" default transport: %s\n", transport);
|
||||||
printf("Example: %s rtsp://192.168.0.2/media/video1\n\n", basename);
|
printf("Example: %s rtsp://192.168.0.2/media/video1\n\n", base_name);
|
||||||
rc = EXIT_FAILURE;
|
rc = EXIT_FAILURE;
|
||||||
} else {
|
} else {
|
||||||
const char *url = argv[1];
|
const char *url = argv[1];
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -30,6 +30,8 @@ int main(void)
|
|||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com");
|
||||||
|
/* example.com is redirected, so we tell libcurl to follow redirection */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_FOLLOWLOCATION, 1L);
|
||||||
|
|
||||||
/* Perform the request, res will get the return code */
|
/* Perform the request, res will get the return code */
|
||||||
res = curl_easy_perform(curl);
|
res = curl_easy_perform(curl);
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -43,6 +43,7 @@
|
|||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
|
int i;
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
FILE *headerfile;
|
FILE *headerfile;
|
||||||
@@ -76,7 +77,7 @@ int main(void)
|
|||||||
curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://your.favourite.ssl.site");
|
curl_easy_setopt(curl, CURLOPT_URL, "HTTPS://your.favourite.ssl.site");
|
||||||
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
curl_easy_setopt(curl, CURLOPT_WRITEHEADER, headerfile);
|
||||||
|
|
||||||
while(1) /* do some ugly short cut... */
|
for(i = 0; i < 1; i++) /* single-iteration loop, just to break out from */
|
||||||
{
|
{
|
||||||
if (pEngine) /* use crypto engine */
|
if (pEngine) /* use crypto engine */
|
||||||
{
|
{
|
||||||
@@ -125,7 +126,7 @@ int main(void)
|
|||||||
fprintf(stderr, "curl_easy_perform() failed: %s\n",
|
fprintf(stderr, "curl_easy_perform() failed: %s\n",
|
||||||
curl_easy_strerror(res));
|
curl_easy_strerror(res));
|
||||||
|
|
||||||
break; /* we are done... */
|
/* we are done... */
|
||||||
}
|
}
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
curl_easy_cleanup(curl);
|
curl_easy_cleanup(curl);
|
||||||
|
|||||||
@@ -162,7 +162,7 @@ method(s) available for your proxy authentication. (Added in 7.10.8)
|
|||||||
.IP CURLINFO_OS_ERRNO
|
.IP CURLINFO_OS_ERRNO
|
||||||
Pass a pointer to a long to receive the errno variable from a connect failure.
|
Pass a pointer to a long to receive the errno variable from a connect failure.
|
||||||
Note that the value is only set on failure, it is not reset upon a
|
Note that the value is only set on failure, it is not reset upon a
|
||||||
successfull operation. (Added in 7.12.2)
|
successful operation. (Added in 7.12.2)
|
||||||
.IP CURLINFO_NUM_CONNECTS
|
.IP CURLINFO_NUM_CONNECTS
|
||||||
Pass a pointer to a long to receive how many new connections libcurl had to
|
Pass a pointer to a long to receive how many new connections libcurl had to
|
||||||
create to achieve the previous transfer (only the successful connects are
|
create to achieve the previous transfer (only the successful connects are
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
.\" * | (__| |_| | _ <| |___
|
.\" * | (__| |_| | _ <| |___
|
||||||
.\" * \___|\___/|_| \_\_____|
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.\" *
|
.\" *
|
||||||
.\" * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al.
|
.\" * Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.\" *
|
.\" *
|
||||||
.\" * This software is licensed as described in the file COPYING, which
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.\" * you should have received as part of this distribution. The terms
|
.\" * you should have received as part of this distribution. The terms
|
||||||
@@ -59,8 +59,13 @@ On success, returns \fBCURLE_OK\fP, stores the received data into
|
|||||||
|
|
||||||
On failure, returns the appropriate error code.
|
On failure, returns the appropriate error code.
|
||||||
|
|
||||||
If there is no data to read, the function returns \fBCURLE_AGAIN\fP. Use
|
If there is no data to read, the function returns \fBCURLE_AGAIN\fP. Use your
|
||||||
your operating system facilities to wait until the data is ready, and retry.
|
operating system facilities to wait until the data is ready, and retry.
|
||||||
|
|
||||||
|
Reading exactly 0 bytes would indicate a closed connection.
|
||||||
|
|
||||||
|
If there's no socket available to use from the previous transfer, this function
|
||||||
|
returns CURLE_UNSUPPORTED_PROTOCOL.
|
||||||
.SH EXAMPLE
|
.SH EXAMPLE
|
||||||
See \fBsendrecv.c\fP in \fBdocs/examples\fP directory for usage example.
|
See \fBsendrecv.c\fP in \fBdocs/examples\fP directory for usage example.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
.\" * | (__| |_| | _ <| |___
|
.\" * | (__| |_| | _ <| |___
|
||||||
.\" * \___|\___/|_| \_\_____|
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.\" *
|
.\" *
|
||||||
.\" * Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
.\" * Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.\" *
|
.\" *
|
||||||
.\" * This software is licensed as described in the file COPYING, which
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.\" * you should have received as part of this distribution. The terms
|
.\" * you should have received as part of this distribution. The terms
|
||||||
@@ -57,6 +57,9 @@ sent into \fB*n\fP. Note that this may very well be less than the amount you
|
|||||||
wanted to send.
|
wanted to send.
|
||||||
|
|
||||||
On failure, returns the appropriate error code.
|
On failure, returns the appropriate error code.
|
||||||
|
|
||||||
|
If there's no socket available to use from the previous transfer, this function
|
||||||
|
returns CURLE_UNSUPPORTED_PROTOCOL.
|
||||||
.SH EXAMPLE
|
.SH EXAMPLE
|
||||||
See \fBsendrecv.c\fP in \fBdocs/examples\fP directory for usage example.
|
See \fBsendrecv.c\fP in \fBdocs/examples\fP directory for usage example.
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
|
|||||||
@@ -2093,11 +2093,12 @@ Resolve to IPv6 addresses.
|
|||||||
.IP CURLOPT_CONNECT_ONLY
|
.IP CURLOPT_CONNECT_ONLY
|
||||||
Pass a long. If the parameter equals 1, it tells the library to perform all
|
Pass a long. If the parameter equals 1, it tells the library to perform all
|
||||||
the required proxy authentication and connection setup, but no data transfer.
|
the required proxy authentication and connection setup, but no data transfer.
|
||||||
This option is useful only on HTTP URLs.
|
This option is implemented for HTTP, SMTP and POP3.
|
||||||
|
|
||||||
This option is useful with the \fICURLINFO_LASTSOCKET\fP option to
|
The option can be used to simply test a connection to a server, but is more
|
||||||
\fIcurl_easy_getinfo(3)\fP. The library can set up the connection and then the
|
useful when used with the \fICURLINFO_LASTSOCKET\fP option to
|
||||||
application can obtain the most recently used socket for special data
|
\fIcurl_easy_getinfo(3)\fP as the library can set up the connection and then
|
||||||
|
the application can obtain the most recently used socket for special data
|
||||||
transfers. (Added in 7.15.2)
|
transfers. (Added in 7.15.2)
|
||||||
.IP CURLOPT_USE_SSL
|
.IP CURLOPT_USE_SSL
|
||||||
Pass a long using one of the values from below, to make libcurl use your
|
Pass a long using one of the values from below, to make libcurl use your
|
||||||
@@ -2259,8 +2260,8 @@ even indicate an accessible file.
|
|||||||
This option is by default set to the system path where libcurl's cacert bundle
|
This option is by default set to the system path where libcurl's cacert bundle
|
||||||
is assumed to be stored, as established at build time.
|
is assumed to be stored, as established at build time.
|
||||||
|
|
||||||
When built against NSS, this is the directory that the NSS certificate
|
If curl is built against the NSS SSL library, the NSS PEM PKCS#11 module
|
||||||
database resides in.
|
(libnsspem.so) needs to be available for this option to work properly.
|
||||||
.IP CURLOPT_ISSUERCERT
|
.IP CURLOPT_ISSUERCERT
|
||||||
Pass a char * to a zero terminated string naming a file holding a CA
|
Pass a char * to a zero terminated string naming a file holding a CA
|
||||||
certificate in PEM format. If the option is set, an additional check against
|
certificate in PEM format. If the option is set, an additional check against
|
||||||
@@ -2323,8 +2324,9 @@ Curl considers the server the intended one when the Common Name field or a
|
|||||||
Subject Alternate Name field in the certificate matches the host name in the
|
Subject Alternate Name field in the certificate matches the host name in the
|
||||||
URL to which you told Curl to connect.
|
URL to which you told Curl to connect.
|
||||||
|
|
||||||
When the value is 1, the certificate must contain a Common Name field, but it
|
When the value is 1, libcurl will return a failure. It was previously (in
|
||||||
doesn't matter what name it says. (This is not ordinarily a useful setting).
|
7.28.0 and earlier) a debug option of some sorts, but it is no longer
|
||||||
|
supported due to frequently leading to programmer mistakes.
|
||||||
|
|
||||||
When the value is 0, the connection succeeds regardless of the names in the
|
When the value is 0, the connection succeeds regardless of the names in the
|
||||||
certificate.
|
certificate.
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ To replace strdup()
|
|||||||
.IP "void *calloc_callback(size_t nmemb, size_t size);"
|
.IP "void *calloc_callback(size_t nmemb, size_t size);"
|
||||||
To replace calloc()
|
To replace calloc()
|
||||||
.SH "CAUTION"
|
.SH "CAUTION"
|
||||||
Manipulating these gives considerable powers to the application to severly
|
Manipulating these gives considerable powers to the application to severely
|
||||||
screw things up for libcurl. Take care!
|
screw things up for libcurl. Take care!
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl_global_init "(3), "
|
.BR curl_global_init "(3), "
|
||||||
|
|||||||
@@ -1,51 +1,70 @@
|
|||||||
.Dd April 27, 2012
|
.\" **************************************************************************
|
||||||
.Dt MK-CA-BUNDLE 1
|
.\" * _ _ ____ _
|
||||||
.Os
|
.\" * Project ___| | | | _ \| |
|
||||||
.Sh NAME
|
.\" * / __| | | | |_) | |
|
||||||
.Nm mk-ca-bundle
|
.\" * | (__| |_| | _ <| |___
|
||||||
.Nd create a new ca-bundle.crt from mozilla's certdata.txt
|
.\" * \___|\___/|_| \_\_____|
|
||||||
.Sh SYNOPSIS
|
.\" *
|
||||||
.Nm
|
.\" * Copyright (C) 2008 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
.Op Fl bilnqtuv
|
.\" *
|
||||||
.Or outputfile
|
.\" * This software is licensed as described in the file COPYING, which
|
||||||
.Sh DESCRIPTION
|
.\" * you should have received as part of this distribution. The terms
|
||||||
The
|
.\" * are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
.Nm
|
.\" *
|
||||||
tool downloads the certdata.txt file from Mozilla's source tree, then
|
.\" * You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
parses certdata.txt and extracts CA Root Certificates into PEM format.
|
.\" * copies of the Software, and permit persons to whom the Software is
|
||||||
These are then processed with the OpenSSL commandline tool to produce the
|
.\" * furnished to do so, under the terms of the COPYING file.
|
||||||
final ca-bundle.crt file.
|
.\" *
|
||||||
.Sh OPTIONS
|
.\" * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
The following options are supported by
|
.\" * KIND, either express or implied.
|
||||||
.Nm :
|
.\" *
|
||||||
.Bl -tag -width _h
|
.\" **************************************************************************
|
||||||
.It Fl b
|
.\"
|
||||||
backup an existing version of ca-bundle.crt
|
.TH mk-ca-bundle 1 "5 Jan 2013" "version 1.17" "mk-ca-bundle manual"
|
||||||
.It Fl i
|
.SH NAME
|
||||||
|
mk-ca-bundle \- convert mozilla's certdata.txt to PEM format
|
||||||
|
.SH SYNOPSIS
|
||||||
|
mk-ca-bundle [bilnqtuv]
|
||||||
|
.I [outputfile]
|
||||||
|
.SH DESCRIPTION
|
||||||
|
The mk-ca-bundle tool downloads the certdata.txt file from Mozilla's source
|
||||||
|
tree over HTTP, then parses certdata.txt and extracts CA Root Certificates
|
||||||
|
into PEM format. These are then processed with the OpenSSL commandline tool
|
||||||
|
to produce the final ca-bundle file.
|
||||||
|
|
||||||
|
The default \fIoutputfile\fP name is \fBca-bundle.crt\fP. By setting it to '-'
|
||||||
|
(a single dash) you will get the output sent to STDOUT instead of a file.
|
||||||
|
|
||||||
|
The PEM format this scripts uses for output makes the result readily available
|
||||||
|
for use by just about all OpenSSL or GnuTLS powered applications, such as
|
||||||
|
curl, wget and more.
|
||||||
|
.SH OPTIONS
|
||||||
|
The following options are supported:
|
||||||
|
.IP -b
|
||||||
|
backup an existing version of \fIoutputfilename\fP
|
||||||
|
.IP -f
|
||||||
|
force rebuild even if certdata.txt is current (Added in version 1.17)
|
||||||
|
.IP -i
|
||||||
print version info about used modules
|
print version info about used modules
|
||||||
.It Fl l
|
.IP -l
|
||||||
print license info about certdata.txt
|
print license info about certdata.txt
|
||||||
.It Fl n
|
.IP -n
|
||||||
no download of certdata.txt (to use existing)
|
no download of certdata.txt (to use existing)
|
||||||
.It Fl q
|
.IP -q
|
||||||
be really quiet (no progress output at all)
|
be really quiet (no progress output at all)
|
||||||
.It Fl t
|
.IP -t
|
||||||
include plain text listing of certificates
|
include plain text listing of certificates
|
||||||
.It Fl u
|
.IP -u
|
||||||
unlink (remove) certdata.txt after processing
|
unlink (remove) certdata.txt after processing
|
||||||
.It Fl v
|
.IP -v
|
||||||
be verbose and print out processed CAs
|
be verbose and print out processed CAs
|
||||||
.El
|
.SH EXIT STATUS
|
||||||
.Sh EXIT STATUS
|
Returns 0 on success. Returns 1 if it fails to download data.
|
||||||
.Ex -std
|
.SH SEE ALSO
|
||||||
.Sh SEE ALSO
|
.BR curl (1)
|
||||||
.Xr curl 1
|
.SH HISTORY
|
||||||
.Sh HISTORY
|
\fBmk-ca-bundle\fP is a command line tool that is shipped as part of every
|
||||||
.Nm
|
curl and libcurl release (see http://curl.haxx.se/). It was originally based
|
||||||
was based on the parse-certs script written by
|
on the parse-certs script written by Roland Krikava and was later much
|
||||||
.An Roland Krikava
|
improved by Guenter Knauf. This manual page was written by Jan Schaumann
|
||||||
and hacked by
|
\&<jschauma@netmeister.org>.
|
||||||
.An Guenter Knauf .
|
|
||||||
This manual page was written by
|
|
||||||
.An Jan Schaumann
|
|
||||||
.Aq jschauma@netmeister.org .
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -151,6 +151,13 @@
|
|||||||
# include <sys/socket.h>
|
# include <sys/socket.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Configure process defines this to 1 when it finds out that system */
|
||||||
|
/* header file sys/poll.h must be included by the external interface. */
|
||||||
|
#undef CURL_PULL_SYS_POLL_H
|
||||||
|
#ifdef CURL_PULL_SYS_POLL_H
|
||||||
|
# include <sys/poll.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
/* The size of `long', as computed by sizeof. */
|
/* The size of `long', as computed by sizeof. */
|
||||||
#undef CURL_SIZEOF_LONG
|
#undef CURL_SIZEOF_LONG
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -190,7 +190,7 @@ typedef char
|
|||||||
* CURL_ISOCPP and CURL_OFF_T_C definitions are done here in order to allow
|
* CURL_ISOCPP and CURL_OFF_T_C definitions are done here in order to allow
|
||||||
* these to be visible and exported by the external libcurl interface API,
|
* these to be visible and exported by the external libcurl interface API,
|
||||||
* while also making them visible to the library internals, simply including
|
* while also making them visible to the library internals, simply including
|
||||||
* setup.h, without actually needing to include curl.h internally.
|
* curl_setup.h, without actually needing to include curl.h internally.
|
||||||
* If some day this section would grow big enough, all this should be moved
|
* If some day this section would grow big enough, all this should be moved
|
||||||
* to its own header file.
|
* to its own header file.
|
||||||
*/
|
*/
|
||||||
@@ -248,6 +248,7 @@ typedef char
|
|||||||
#undef CURL_PULL_WS2TCPIP_H
|
#undef CURL_PULL_WS2TCPIP_H
|
||||||
#undef CURL_PULL_SYS_TYPES_H
|
#undef CURL_PULL_SYS_TYPES_H
|
||||||
#undef CURL_PULL_SYS_SOCKET_H
|
#undef CURL_PULL_SYS_SOCKET_H
|
||||||
|
#undef CURL_PULL_SYS_POLL_H
|
||||||
#undef CURL_PULL_STDINT_H
|
#undef CURL_PULL_STDINT_H
|
||||||
#undef CURL_PULL_INTTYPES_H
|
#undef CURL_PULL_INTTYPES_H
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -26,17 +26,17 @@
|
|||||||
a script at release-time. This was made its own header file in 7.11.2 */
|
a script at release-time. This was made its own header file in 7.11.2 */
|
||||||
|
|
||||||
/* This is the global package copyright */
|
/* This is the global package copyright */
|
||||||
#define LIBCURL_COPYRIGHT "1996 - 2012 Daniel Stenberg, <daniel@haxx.se>."
|
#define LIBCURL_COPYRIGHT "1996 - 2013 Daniel Stenberg, <daniel@haxx.se>."
|
||||||
|
|
||||||
/* This is the version number of the libcurl package from which this header
|
/* This is the version number of the libcurl package from which this header
|
||||||
file origins: */
|
file origins: */
|
||||||
#define LIBCURL_VERSION "7.28.0-DEV"
|
#define LIBCURL_VERSION "7.28.2-DEV"
|
||||||
|
|
||||||
/* The numeric version number is also available "in parts" by using these
|
/* The numeric version number is also available "in parts" by using these
|
||||||
defines: */
|
defines: */
|
||||||
#define LIBCURL_VERSION_MAJOR 7
|
#define LIBCURL_VERSION_MAJOR 7
|
||||||
#define LIBCURL_VERSION_MINOR 28
|
#define LIBCURL_VERSION_MINOR 28
|
||||||
#define LIBCURL_VERSION_PATCH 0
|
#define LIBCURL_VERSION_PATCH 2
|
||||||
|
|
||||||
/* This is the numeric version of the libcurl version number, meant for easier
|
/* This is the numeric version of the libcurl version number, meant for easier
|
||||||
parsing and comparions by programs. The LIBCURL_VERSION_NUM define will
|
parsing and comparions by programs. The LIBCURL_VERSION_NUM define will
|
||||||
@@ -53,7 +53,7 @@
|
|||||||
and it is always a greater number in a more recent release. It makes
|
and it is always a greater number in a more recent release. It makes
|
||||||
comparisons with greater than and less than work.
|
comparisons with greater than and less than work.
|
||||||
*/
|
*/
|
||||||
#define LIBCURL_VERSION_NUM 0x071c00
|
#define LIBCURL_VERSION_NUM 0x071c02
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is the date and time when the full source package was created. The
|
* This is the date and time when the full source package was created. The
|
||||||
|
|||||||
@@ -89,7 +89,7 @@ ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.7
|
|||||||
!ifdef %libssh2_root
|
!ifdef %libssh2_root
|
||||||
LIBSSH2_ROOT = $(%libssh2_root)
|
LIBSSH2_ROOT = $(%libssh2_root)
|
||||||
!else
|
!else
|
||||||
LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.4.2
|
LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.4.3
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifdef %librtmp_root
|
!ifdef %librtmp_root
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
# | (__| |_| | _ <| |___
|
# | (__| |_| | _ <| |___
|
||||||
# \___|\___/|_| \_\_____|
|
# \___|\___/|_| \_\_____|
|
||||||
#
|
#
|
||||||
# Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
# Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
#
|
#
|
||||||
# This software is licensed as described in the file COPYING, which
|
# This software is licensed as described in the file COPYING, which
|
||||||
# you should have received as part of this distribution. The terms
|
# you should have received as part of this distribution. The terms
|
||||||
@@ -33,12 +33,12 @@ CMAKE_DIST = CMakeLists.txt curl_config.h.cmake
|
|||||||
EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 $(DSP) \
|
EXTRA_DIST = Makefile.b32 Makefile.m32 Makefile.vc6 $(DSP) \
|
||||||
vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h \
|
vc6libcurl.dsw config-win32.h config-win32ce.h config-riscos.h \
|
||||||
config-mac.h curl_config.h.in makefile.dj config-dos.h libcurl.plist \
|
config-mac.h curl_config.h.in makefile.dj config-dos.h libcurl.plist \
|
||||||
libcurl.rc config-amigaos.h makefile.amiga \
|
libcurl.rc config-amigaos.h makefile.amiga Makefile.netware nwlib.c \
|
||||||
Makefile.netware nwlib.c nwos.c msvcproj.head msvcproj.foot \
|
nwos.c msvcproj.head msvcproj.foot config-win32ce.h config-os400.h \
|
||||||
config-win32ce.h config-os400.h setup-os400.h config-symbian.h \
|
setup-os400.h config-symbian.h Makefile.Watcom config-tpf.h $(DOCS) \
|
||||||
Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl \
|
$(VCPROJ) mk-ca-bundle.pl mk-ca-bundle.vbs firefox-db2pem.sh \
|
||||||
mk-ca-bundle.vbs firefox-db2pem.sh $(CMAKE_DIST) config-vxworks.h \
|
$(CMAKE_DIST) config-vxworks.h Makefile.vxworks checksrc.pl \
|
||||||
Makefile.vxworks config-vms.h checksrc.pl
|
objnames-test08.sh objnames-test10.sh objnames.inc
|
||||||
|
|
||||||
CLEANFILES = $(DSP) $(VCPROJ)
|
CLEANFILES = $(DSP) $(VCPROJ)
|
||||||
|
|
||||||
@@ -56,15 +56,15 @@ CFLAG_CURL_SYMBOL_HIDING = @CFLAG_CURL_SYMBOL_HIDING@
|
|||||||
# might possibly already be installed in the system.
|
# might possibly already be installed in the system.
|
||||||
#
|
#
|
||||||
# $(top_builddir)/include/curl for generated curlbuild.h included from curl.h
|
# $(top_builddir)/include/curl for generated curlbuild.h included from curl.h
|
||||||
# $(top_builddir)/include for generated curlbuild.h included from lib/setup.h
|
# $(top_builddir)/include for generated curlbuild.h inc. from lib/curl_setup.h
|
||||||
# $(top_srcdir)/include is for libcurl's external include files
|
# $(top_srcdir)/include is for libcurl's external include files
|
||||||
# $(top_builddir)/lib is for libcurl's generated lib/curl_config.h file
|
# $(top_builddir)/lib is for libcurl's generated lib/curl_config.h file
|
||||||
# $(top_srcdir)/lib is for libcurl's lib/setup.h and other "private" files
|
# $(top_srcdir)/lib for libcurl's lib/curl_setup.h and other "private" files
|
||||||
# $(top_builddir)/ares is for in-tree c-ares's generated ares_build.h file
|
# $(top_builddir)/ares is for in-tree c-ares's generated ares_build.h file
|
||||||
# $(top_srcdir)/ares is for in-tree c-ares's external include files
|
# $(top_srcdir)/ares is for in-tree c-ares's external include files
|
||||||
|
|
||||||
if USE_EMBEDDED_ARES
|
if USE_EMBEDDED_ARES
|
||||||
INCLUDES = -I$(top_builddir)/include/curl \
|
AM_CPPFLAGS = -I$(top_builddir)/include/curl \
|
||||||
-I$(top_builddir)/include \
|
-I$(top_builddir)/include \
|
||||||
-I$(top_srcdir)/include \
|
-I$(top_srcdir)/include \
|
||||||
-I$(top_builddir)/lib \
|
-I$(top_builddir)/lib \
|
||||||
@@ -72,15 +72,13 @@ INCLUDES = -I$(top_builddir)/include/curl \
|
|||||||
-I$(top_builddir)/ares \
|
-I$(top_builddir)/ares \
|
||||||
-I$(top_srcdir)/ares
|
-I$(top_srcdir)/ares
|
||||||
else
|
else
|
||||||
INCLUDES = -I$(top_builddir)/include/curl \
|
AM_CPPFLAGS = -I$(top_builddir)/include/curl \
|
||||||
-I$(top_builddir)/include \
|
-I$(top_builddir)/include \
|
||||||
-I$(top_srcdir)/include \
|
-I$(top_srcdir)/include \
|
||||||
-I$(top_builddir)/lib \
|
-I$(top_builddir)/lib \
|
||||||
-I$(top_srcdir)/lib
|
-I$(top_srcdir)/lib
|
||||||
endif
|
endif
|
||||||
|
|
||||||
AM_CPPFLAGS =
|
|
||||||
|
|
||||||
# Mostly for Windows build targets, when building libcurl library
|
# Mostly for Windows build targets, when building libcurl library
|
||||||
if USE_CPPFLAG_BUILDING_LIBCURL
|
if USE_CPPFLAG_BUILDING_LIBCURL
|
||||||
AM_CPPFLAGS += -DBUILDING_LIBCURL
|
AM_CPPFLAGS += -DBUILDING_LIBCURL
|
||||||
@@ -101,9 +99,9 @@ if SONAME_BUMP
|
|||||||
#
|
#
|
||||||
# This conditional soname bump SHOULD be removed at next "proper" bump.
|
# This conditional soname bump SHOULD be removed at next "proper" bump.
|
||||||
#
|
#
|
||||||
VERSIONINFO=-version-info 7:0:2
|
VERSIONINFO=-version-info 8:0:3
|
||||||
else
|
else
|
||||||
VERSIONINFO=-version-info 6:0:2
|
VERSIONINFO=-version-info 7:0:3
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
# This flag accepts an argument of the form current[:revision[:age]]. So,
|
||||||
@@ -134,6 +132,9 @@ if VERSIONED_SYMBOLS
|
|||||||
VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers
|
VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Prevent LIBS from being used for all link targets
|
||||||
|
LIBS = $(BLANK_AT_MAKETIME)
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS)
|
libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS)
|
||||||
|
|
||||||
if DOING_CURL_SYMBOL_HIDING
|
if DOING_CURL_SYMBOL_HIDING
|
||||||
|
|||||||
@@ -24,7 +24,8 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c \
|
|||||||
idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c non-ascii.c \
|
idn_win32.c http_negotiate_sspi.c cyassl.c http_proxy.c non-ascii.c \
|
||||||
asyn-ares.c asyn-thread.c curl_gssapi.c curl_ntlm.c curl_ntlm_wb.c \
|
asyn-ares.c asyn-thread.c curl_gssapi.c curl_ntlm.c curl_ntlm_wb.c \
|
||||||
curl_ntlm_core.c curl_ntlm_msgs.c curl_sasl.c curl_schannel.c \
|
curl_ntlm_core.c curl_ntlm_msgs.c curl_sasl.c curl_schannel.c \
|
||||||
curl_multibyte.c curl_darwinssl.c
|
curl_multibyte.c curl_darwinssl.c hostcheck.c \
|
||||||
|
bundles.c conncache.c
|
||||||
|
|
||||||
HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
||||||
progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h \
|
progress.h formdata.h cookie.h http.h sendf.h ftp.h url.h dict.h \
|
||||||
@@ -33,12 +34,14 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
|||||||
curl_fnmatch.h wildcard.h fileinfo.h ftplistparser.h strtok.h \
|
curl_fnmatch.h wildcard.h fileinfo.h ftplistparser.h strtok.h \
|
||||||
connect.h llist.h hash.h content_encoding.h share.h curl_md4.h \
|
connect.h llist.h hash.h content_encoding.h share.h curl_md4.h \
|
||||||
curl_md5.h http_digest.h http_negotiate.h inet_pton.h amigaos.h \
|
curl_md5.h http_digest.h http_negotiate.h inet_pton.h amigaos.h \
|
||||||
strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h setup.h \
|
strtoofft.h strerror.h inet_ntop.h curlx.h curl_memory.h curl_setup.h \
|
||||||
transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h \
|
transfer.h select.h easyif.h multiif.h parsedate.h sslgen.h gtls.h \
|
||||||
tftp.h sockaddr.h splay.h strdup.h setup_once.h socks.h ssh.h nssg.h \
|
tftp.h sockaddr.h splay.h strdup.h socks.h ssh.h nssg.h \
|
||||||
curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h \
|
curl_base64.h rawstr.h curl_addrinfo.h curl_sspi.h slist.h nonblock.h \
|
||||||
curl_memrchr.h imap.h pop3.h smtp.h pingpong.h rtsp.h curl_threads.h \
|
curl_memrchr.h imap.h pop3.h smtp.h pingpong.h rtsp.h curl_threads.h \
|
||||||
warnless.h curl_hmac.h polarssl.h curl_rtmp.h curl_gethostname.h \
|
warnless.h curl_hmac.h polarssl.h curl_rtmp.h curl_gethostname.h \
|
||||||
gopher.h axtls.h cyassl.h http_proxy.h non-ascii.h asyn.h curl_ntlm.h \
|
gopher.h axtls.h cyassl.h http_proxy.h non-ascii.h asyn.h curl_ntlm.h \
|
||||||
curl_gssapi.h curl_ntlm_wb.h curl_ntlm_core.h curl_ntlm_msgs.h \
|
curl_gssapi.h curl_ntlm_wb.h curl_ntlm_core.h curl_ntlm_msgs.h \
|
||||||
curl_sasl.h curl_schannel.h curl_multibyte.h curl_darwinssl.h
|
curl_sasl.h curl_schannel.h curl_multibyte.h curl_darwinssl.h \
|
||||||
|
hostcheck.h bundles.h conncache.h curl_setup_once.h multihandle.h \
|
||||||
|
setup-vms.h
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ OPENSSL_PATH = ../../openssl-0.9.8x
|
|||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.4.2
|
LIBSSH2_PATH = ../../libssh2-1.4.3
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your librtmp package.
|
# Edit the path below to point to the base of your librtmp package.
|
||||||
ifndef LIBRTMP_PATH
|
ifndef LIBRTMP_PATH
|
||||||
@@ -273,8 +273,9 @@ $(libcurl_a_LIBRARY): $(libcurl_a_OBJECTS) $(libcurl_a_DEPENDENCIES)
|
|||||||
|
|
||||||
$(libcurl_dll_LIBRARY): $(libcurl_a_OBJECTS) $(RESOURCE) $(libcurl_dll_DEPENDENCIES)
|
$(libcurl_dll_LIBRARY): $(libcurl_a_OBJECTS) $(RESOURCE) $(libcurl_dll_DEPENDENCIES)
|
||||||
@$(call DEL, $@)
|
@$(call DEL, $@)
|
||||||
$(CC) $(LDFLAGS) -shared -Wl,--out-implib,$(libcurl_dll_a_LIBRARY) \
|
$(CC) $(LDFLAGS) -shared -o $@ \
|
||||||
-o $@ $(libcurl_a_OBJECTS) $(RESOURCE) $(DLL_LIBS)
|
-Wl,--output-def,$(@:.dll=.def),--out-implib,$(libcurl_dll_a_LIBRARY) \
|
||||||
|
$(libcurl_a_OBJECTS) $(RESOURCE) $(DLL_LIBS)
|
||||||
|
|
||||||
%.o: %.c $(PROOT)/include/curl/curlbuild.h
|
%.o: %.c $(PROOT)/include/curl/curlbuild.h
|
||||||
$(CC) $(INCLUDES) $(CFLAGS) -c $<
|
$(CC) $(INCLUDES) $(CFLAGS) -c $<
|
||||||
@@ -289,7 +290,7 @@ endif
|
|||||||
@$(call DEL, $(libcurl_a_OBJECTS) $(RESOURCE))
|
@$(call DEL, $(libcurl_a_OBJECTS) $(RESOURCE))
|
||||||
|
|
||||||
distclean vclean: clean
|
distclean vclean: clean
|
||||||
@$(call DEL, $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_a_LIBRARY))
|
@$(call DEL, $(libcurl_a_LIBRARY) $(libcurl_dll_LIBRARY) $(libcurl_dll_LIBRARY:.dll=.def) $(libcurl_dll_a_LIBRARY))
|
||||||
|
|
||||||
$(PROOT)/include/curl/curlbuild.h:
|
$(PROOT)/include/curl/curlbuild.h:
|
||||||
@echo Creating $@
|
@echo Creating $@
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ endif
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your LibSSH2 package.
|
# Edit the path below to point to the base of your LibSSH2 package.
|
||||||
ifndef LIBSSH2_PATH
|
ifndef LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.4.2
|
LIBSSH2_PATH = ../../libssh2-1.4.3
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your axTLS package.
|
# Edit the path below to point to the base of your axTLS package.
|
||||||
|
|||||||
@@ -69,7 +69,7 @@ OPENSSL_PATH = ../../openssl-0.9.8x
|
|||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF LIBSSH2_PATH
|
!IFNDEF LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.4.2
|
LIBSSH2_PATH = ../../libssh2-1.4.3
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF ZLIB_PATH
|
!IFNDEF ZLIB_PATH
|
||||||
@@ -497,6 +497,8 @@ X_OBJS= \
|
|||||||
$(DIROBJ)\asyn-ares.obj \
|
$(DIROBJ)\asyn-ares.obj \
|
||||||
$(DIROBJ)\asyn-thread.obj \
|
$(DIROBJ)\asyn-thread.obj \
|
||||||
$(DIROBJ)\base64.obj \
|
$(DIROBJ)\base64.obj \
|
||||||
|
$(DIROBJ)\bundles.obj \
|
||||||
|
$(DIROBJ)\conncache.obj \
|
||||||
$(DIROBJ)\connect.obj \
|
$(DIROBJ)\connect.obj \
|
||||||
$(DIROBJ)\content_encoding.obj \
|
$(DIROBJ)\content_encoding.obj \
|
||||||
$(DIROBJ)\cookie.obj \
|
$(DIROBJ)\cookie.obj \
|
||||||
@@ -531,6 +533,7 @@ X_OBJS= \
|
|||||||
$(DIROBJ)\hash.obj \
|
$(DIROBJ)\hash.obj \
|
||||||
$(DIROBJ)\hmac.obj \
|
$(DIROBJ)\hmac.obj \
|
||||||
$(DIROBJ)\hostasyn.obj \
|
$(DIROBJ)\hostasyn.obj \
|
||||||
|
$(DIROBJ)\hostcheck.obj \
|
||||||
$(DIROBJ)\hostip.obj \
|
$(DIROBJ)\hostip.obj \
|
||||||
$(DIROBJ)\hostip4.obj \
|
$(DIROBJ)\hostip4.obj \
|
||||||
$(DIROBJ)\hostip6.obj \
|
$(DIROBJ)\hostip6.obj \
|
||||||
|
|||||||
@@ -32,4 +32,4 @@
|
|||||||
hostip6.c - ipv6-specific functions
|
hostip6.c - ipv6-specific functions
|
||||||
|
|
||||||
The hostip.h is the single united header file for all this. It defines the
|
The hostip.h is the single united header file for all this. It defines the
|
||||||
CURLRES_* defines based on the config*.h and setup.h defines.
|
CURLRES_* defines based on the config*.h and curl_setup.h defines.
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(__AMIGA__) && !defined(__ixemul__)
|
#if defined(__AMIGA__) && !defined(__ixemul__)
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(__AMIGA__) && !defined(__ixemul__)
|
#if defined(__AMIGA__) && !defined(__ixemul__)
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,14 +20,11 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_LIMITS_H
|
#ifdef HAVE_LIMITS_H
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETINET_IN_H
|
#ifdef HAVE_NETINET_IN_H
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -37,9 +34,6 @@
|
|||||||
#ifdef HAVE_ARPA_INET_H
|
#ifdef HAVE_ARPA_INET_H
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h> /* for the close() proto */
|
|
||||||
#endif
|
|
||||||
#ifdef __VMS
|
#ifdef __VMS
|
||||||
#include <in.h>
|
#include <in.h>
|
||||||
#include <inet.h>
|
#include <inet.h>
|
||||||
@@ -83,6 +77,8 @@
|
|||||||
# define CARES_STATICLIB
|
# define CARES_STATICLIB
|
||||||
# endif
|
# endif
|
||||||
# include <ares.h>
|
# include <ares.h>
|
||||||
|
# include <ares_version.h> /* really old c-ares didn't include this by
|
||||||
|
itself */
|
||||||
|
|
||||||
#if ARES_VERSION >= 0x010500
|
#if ARES_VERSION >= 0x010500
|
||||||
/* c-ares 1.5.0 or later, the callback proto is modified */
|
/* c-ares 1.5.0 or later, the callback proto is modified */
|
||||||
@@ -211,12 +207,12 @@ static void destroy_async_data (struct Curl_async *async)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Curl_resolver_fdset() is called when someone from the outside world (using
|
* Curl_resolver_getsock() is called when someone from the outside world
|
||||||
* curl_multi_fdset()) wants to get our fd_set setup and we're talking with
|
* (using curl_multi_fdset()) wants to get our fd_set setup and we're talking
|
||||||
* ares. The caller must make sure that this function is only called when we
|
* with ares. The caller must make sure that this function is only called when
|
||||||
* have a working ares channel.
|
* we have a working ares channel.
|
||||||
*
|
*
|
||||||
* Returns: CURLE_OK always!
|
* Returns: sockets-in-use-bitmap
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int Curl_resolver_getsock(struct connectdata *conn,
|
int Curl_resolver_getsock(struct connectdata *conn,
|
||||||
|
|||||||
@@ -20,11 +20,8 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETINET_IN_H
|
#ifdef HAVE_NETINET_IN_H
|
||||||
#include <netinet/in.h>
|
#include <netinet/in.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -34,9 +31,6 @@
|
|||||||
#ifdef HAVE_ARPA_INET_H
|
#ifdef HAVE_ARPA_INET_H
|
||||||
#include <arpa/inet.h>
|
#include <arpa/inet.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h> /* for the close() proto */
|
|
||||||
#endif
|
|
||||||
#ifdef __VMS
|
#ifdef __VMS
|
||||||
#include <in.h>
|
#include <in.h>
|
||||||
#include <inet.h>
|
#include <inet.h>
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
#include "curl_addrinfo.h"
|
#include "curl_addrinfo.h"
|
||||||
|
|
||||||
struct addrinfo;
|
struct addrinfo;
|
||||||
|
|||||||
72
lib/axtls.c
72
lib/axtls.c
@@ -26,16 +26,12 @@
|
|||||||
* but sslgen.c should ever call or use these functions.
|
* but sslgen.c should ever call or use these functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_AXTLS
|
#ifdef USE_AXTLS
|
||||||
#include <axTLS/ssl.h>
|
#include <axTLS/ssl.h>
|
||||||
#include "axtls.h"
|
#include "axtls.h"
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
#include "inet_pton.h"
|
#include "inet_pton.h"
|
||||||
#include "sslgen.h"
|
#include "sslgen.h"
|
||||||
@@ -47,6 +43,8 @@
|
|||||||
#include "curl_memory.h"
|
#include "curl_memory.h"
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
|
#include "hostcheck.h"
|
||||||
|
|
||||||
|
|
||||||
/* SSL_read is opied from axTLS compat layer */
|
/* SSL_read is opied from axTLS compat layer */
|
||||||
static int SSL_read(SSL *ssl, void *buf, int num)
|
static int SSL_read(SSL *ssl, void *buf, int num)
|
||||||
@@ -150,7 +148,11 @@ Curl_axtls_connect(struct connectdata *conn,
|
|||||||
int i, ssl_fcn_return;
|
int i, ssl_fcn_return;
|
||||||
const uint8_t *ssl_sessionid;
|
const uint8_t *ssl_sessionid;
|
||||||
size_t ssl_idsize;
|
size_t ssl_idsize;
|
||||||
const char *x509;
|
const char *peer_CN;
|
||||||
|
uint32_t dns_altname_index;
|
||||||
|
const char *dns_altname;
|
||||||
|
int8_t found_subject_alt_names = 0;
|
||||||
|
int8_t found_subject_alt_name_matching_conn = 0;
|
||||||
|
|
||||||
/* Assuming users will not compile in custom key/cert to axTLS */
|
/* Assuming users will not compile in custom key/cert to axTLS */
|
||||||
uint32_t client_option = SSL_NO_DEFAULT_KEY|SSL_SERVER_VERIFY_LATER;
|
uint32_t client_option = SSL_NO_DEFAULT_KEY|SSL_SERVER_VERIFY_LATER;
|
||||||
@@ -296,19 +298,65 @@ Curl_axtls_connect(struct connectdata *conn,
|
|||||||
/* Here, gtls.c does issuer verification. axTLS has no straightforward
|
/* Here, gtls.c does issuer verification. axTLS has no straightforward
|
||||||
* equivalent, so omitting for now.*/
|
* equivalent, so omitting for now.*/
|
||||||
|
|
||||||
/* See if common name was set in server certificate */
|
|
||||||
x509 = ssl_get_cert_dn(ssl, SSL_X509_CERT_COMMON_NAME);
|
|
||||||
if(x509 == NULL)
|
|
||||||
infof(data, "error fetching CN from cert\n");
|
|
||||||
|
|
||||||
/* Here, gtls.c does the following
|
/* Here, gtls.c does the following
|
||||||
* 1) x509 hostname checking per RFC2818. axTLS doesn't support this, but
|
* 1) x509 hostname checking per RFC2818. axTLS doesn't support this, but
|
||||||
* it seems useful. Omitting for now.
|
* it seems useful. This is now implemented, by Oscar Koeroo
|
||||||
* 2) checks cert validity based on time. axTLS does this in ssl_verify_cert
|
* 2) checks cert validity based on time. axTLS does this in ssl_verify_cert
|
||||||
* 3) displays a bunch of cert information. axTLS doesn't support most of
|
* 3) displays a bunch of cert information. axTLS doesn't support most of
|
||||||
* this, but a couple fields are available.
|
* this, but a couple fields are available.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
/* There is no (DNS) Altnames count in the version 1.4.8 API. There is a
|
||||||
|
risk of an inifite loop */
|
||||||
|
for(dns_altname_index = 0; ; dns_altname_index++) {
|
||||||
|
dns_altname = ssl_get_cert_subject_alt_dnsname(ssl, dns_altname_index);
|
||||||
|
if(dns_altname == NULL) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
found_subject_alt_names = 1;
|
||||||
|
|
||||||
|
infof(data, "\tComparing subject alt name DNS with hostname: %s <-> %s\n",
|
||||||
|
dns_altname, conn->host.name);
|
||||||
|
if(Curl_cert_hostcheck(dns_altname, conn->host.name)) {
|
||||||
|
found_subject_alt_name_matching_conn = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* RFC2818 checks */
|
||||||
|
if(found_subject_alt_names && !found_subject_alt_name_matching_conn) {
|
||||||
|
/* Break connection ! */
|
||||||
|
Curl_axtls_close(conn, sockindex);
|
||||||
|
failf(data, "\tsubjectAltName(s) do not match %s\n", conn->host.dispname);
|
||||||
|
return CURLE_PEER_FAILED_VERIFICATION;
|
||||||
|
}
|
||||||
|
else if(found_subject_alt_names == 0) {
|
||||||
|
/* Per RFC2818, when no Subject Alt Names were available, examine the peer
|
||||||
|
CN as a legacy fallback */
|
||||||
|
peer_CN = ssl_get_cert_dn(ssl, SSL_X509_CERT_COMMON_NAME);
|
||||||
|
if(peer_CN == NULL) {
|
||||||
|
/* Similar behaviour to the OpenSSL interface */
|
||||||
|
Curl_axtls_close(conn, sockindex);
|
||||||
|
failf(data, "unable to obtain common name from peer certificate");
|
||||||
|
return CURLE_PEER_FAILED_VERIFICATION;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(!Curl_cert_hostcheck((const char *)peer_CN, conn->host.name)) {
|
||||||
|
if(data->set.ssl.verifyhost) {
|
||||||
|
/* Break connection ! */
|
||||||
|
Curl_axtls_close(conn, sockindex);
|
||||||
|
failf(data, "\tcommon name \"%s\" does not match \"%s\"\n",
|
||||||
|
peer_CN, conn->host.dispname);
|
||||||
|
return CURLE_PEER_FAILED_VERIFICATION;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
infof(data, "\tcommon name \"%s\" does not match \"%s\"\n",
|
||||||
|
peer_CN, conn->host.dispname);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* General housekeeping */
|
/* General housekeeping */
|
||||||
conn->ssl[sockindex].state = ssl_connection_complete;
|
conn->ssl[sockindex].state = ssl_connection_complete;
|
||||||
conn->ssl[sockindex].ssl = ssl;
|
conn->ssl[sockindex].ssl = ssl;
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __AXTLS_H
|
#ifndef HEADER_CURL_AXTLS_H
|
||||||
#define __AXTLS_H
|
#define HEADER_CURL_AXTLS_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -59,4 +59,5 @@ int Curl_axtls_check_cxn(struct connectdata *conn);
|
|||||||
#define curlssl_data_pending(x,y) (x=x, y=y, 0)
|
#define curlssl_data_pending(x,y) (x=x, y=y, 0)
|
||||||
|
|
||||||
#endif /* USE_AXTLS */
|
#endif /* USE_AXTLS */
|
||||||
#endif
|
#endif /* HEADER_CURL_AXTLS_H */
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
|
|
||||||
/* Base64 encoding/decoding */
|
/* Base64 encoding/decoding */
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
|
|||||||
110
lib/bundles.c
Normal file
110
lib/bundles.c
Normal file
@@ -0,0 +1,110 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, Linus Nielsen Feltzing, <linus@haxx.se>
|
||||||
|
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "curl_setup.h"
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#include "urldata.h"
|
||||||
|
#include "url.h"
|
||||||
|
#include "progress.h"
|
||||||
|
#include "multiif.h"
|
||||||
|
#include "bundles.h"
|
||||||
|
#include "sendf.h"
|
||||||
|
#include "rawstr.h"
|
||||||
|
|
||||||
|
#include "curl_memory.h"
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#include "memdebug.h"
|
||||||
|
|
||||||
|
static void conn_llist_dtor(void *user, void *element)
|
||||||
|
{
|
||||||
|
struct connectdata *data = element;
|
||||||
|
(void)user;
|
||||||
|
|
||||||
|
data->bundle = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
CURLcode Curl_bundle_create(struct SessionHandle *data,
|
||||||
|
struct connectbundle **cb_ptr)
|
||||||
|
{
|
||||||
|
(void)data;
|
||||||
|
DEBUGASSERT(*cb_ptr == NULL);
|
||||||
|
*cb_ptr = malloc(sizeof(struct connectbundle));
|
||||||
|
if(!*cb_ptr)
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
|
(*cb_ptr)->num_connections = 0;
|
||||||
|
(*cb_ptr)->server_supports_pipelining = FALSE;
|
||||||
|
|
||||||
|
(*cb_ptr)->conn_list = Curl_llist_alloc((curl_llist_dtor) conn_llist_dtor);
|
||||||
|
if(!(*cb_ptr)->conn_list) {
|
||||||
|
Curl_safefree(*cb_ptr);
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
}
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Curl_bundle_destroy(struct connectbundle *cb_ptr)
|
||||||
|
{
|
||||||
|
if(!cb_ptr)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(cb_ptr->conn_list) {
|
||||||
|
Curl_llist_destroy(cb_ptr->conn_list, NULL);
|
||||||
|
cb_ptr->conn_list = NULL;
|
||||||
|
}
|
||||||
|
Curl_safefree(cb_ptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Add a connection to a bundle */
|
||||||
|
CURLcode Curl_bundle_add_conn(struct connectbundle *cb_ptr,
|
||||||
|
struct connectdata *conn)
|
||||||
|
{
|
||||||
|
if(!Curl_llist_insert_next(cb_ptr->conn_list, cb_ptr->conn_list->tail, conn))
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
|
conn->bundle = cb_ptr;
|
||||||
|
|
||||||
|
cb_ptr->num_connections++;
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Remove a connection from a bundle */
|
||||||
|
int Curl_bundle_remove_conn(struct connectbundle *cb_ptr,
|
||||||
|
struct connectdata *conn)
|
||||||
|
{
|
||||||
|
struct curl_llist_element *curr;
|
||||||
|
|
||||||
|
curr = cb_ptr->conn_list->head;
|
||||||
|
while(curr) {
|
||||||
|
if(curr->ptr == conn) {
|
||||||
|
Curl_llist_remove(cb_ptr->conn_list, curr, NULL);
|
||||||
|
cb_ptr->num_connections--;
|
||||||
|
conn->bundle = NULL;
|
||||||
|
return 1; /* we removed a handle */
|
||||||
|
}
|
||||||
|
curr = curr->next;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
45
lib/bundles.h
Normal file
45
lib/bundles.h
Normal file
@@ -0,0 +1,45 @@
|
|||||||
|
#ifndef HEADER_CURL_BUNDLES_H
|
||||||
|
#define HEADER_CURL_BUNDLES_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, Linus Nielsen Feltzing, <linus@haxx.se>
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
struct connectbundle {
|
||||||
|
bool server_supports_pipelining; /* TRUE if server supports pipelining,
|
||||||
|
set after first response */
|
||||||
|
size_t num_connections; /* Number of connections in the bundle */
|
||||||
|
struct curl_llist *conn_list; /* The connectdata members of the bundle */
|
||||||
|
};
|
||||||
|
|
||||||
|
CURLcode Curl_bundle_create(struct SessionHandle *data,
|
||||||
|
struct connectbundle **cb_ptr);
|
||||||
|
|
||||||
|
void Curl_bundle_destroy(struct connectbundle *cb_ptr);
|
||||||
|
|
||||||
|
CURLcode Curl_bundle_add_conn(struct connectbundle *cb_ptr,
|
||||||
|
struct connectdata *conn);
|
||||||
|
|
||||||
|
int Curl_bundle_remove_conn(struct connectbundle *cb_ptr,
|
||||||
|
struct connectdata *conn);
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_BUNDLES_H */
|
||||||
|
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
#ifndef HEADER_CONFIG_DOS_H
|
#ifndef HEADER_CURL_CONFIG_DOS_H
|
||||||
#define HEADER_CONFIG_DOS_H
|
#define HEADER_CURL_CONFIG_DOS_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -188,5 +188,5 @@
|
|||||||
#undef word
|
#undef word
|
||||||
#undef byte
|
#undef byte
|
||||||
|
|
||||||
#endif /* HEADER_CONFIG_DOS_H */
|
#endif /* HEADER_CURL_CONFIG_DOS_H */
|
||||||
|
|
||||||
|
|||||||
398
lib/config-vms.h
398
lib/config-vms.h
@@ -1,398 +0,0 @@
|
|||||||
#ifndef HEADER_CONFIG_VMS_H
|
|
||||||
#define HEADER_CONFIG_VMS_H
|
|
||||||
/***************************************************************************
|
|
||||||
* _ _ ____ _
|
|
||||||
* Project ___| | | | _ \| |
|
|
||||||
* / __| | | | |_) | |
|
|
||||||
* | (__| |_| | _ <| |___
|
|
||||||
* \___|\___/|_| \_\_____|
|
|
||||||
*
|
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
||||||
*
|
|
||||||
* This software is licensed as described in the file COPYING, which
|
|
||||||
* you should have received as part of this distribution. The terms
|
|
||||||
* are also available at http://curl.haxx.se/docs/copyright.html.
|
|
||||||
*
|
|
||||||
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
||||||
* copies of the Software, and permit persons to whom the Software is
|
|
||||||
* furnished to do so, under the terms of the COPYING file.
|
|
||||||
*
|
|
||||||
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
||||||
* KIND, either express or implied.
|
|
||||||
*
|
|
||||||
***************************************************************************/
|
|
||||||
|
|
||||||
/* */
|
|
||||||
/* MSK, 02/05/04, Hand edited for trail build on Alpha V7.3, DEC C 6.5-003 */
|
|
||||||
/* MSK, 03/09/04, Seems to work for all platforms I've built on so far. */
|
|
||||||
/* Added HAVE_SYS_IOCTL_H define */
|
|
||||||
/* TES, 10/06/04, Added MAX_INITIAL_POST_SIZE, HAVE_BASENAME */
|
|
||||||
/* MSK, 02/02/05, Changed HAVE_TERMIOS_H to an undef since the change in */
|
|
||||||
/* getpass.c no longer undef'd it during compile. */
|
|
||||||
/* MSK, 02/08/05, turned two config-vms files into one by using USE_SSLEAY */
|
|
||||||
/* MPZ, 12/28/05, changed HAVE_STRTOK_R define to use CRTL_VER */
|
|
||||||
/* MSK, 01/27/07, needed to add HAVE_STRUCT_TIMEVAL define */
|
|
||||||
|
|
||||||
/* Define cpu-machine-OS */
|
|
||||||
#if defined(__alpha)
|
|
||||||
# define OS "ALPHA-HP-VMS"
|
|
||||||
#elif defined(__vax)
|
|
||||||
# define OS "VAX-HP-VMS"
|
|
||||||
#elif defined(__ia64)
|
|
||||||
# define OS "IA64-HP-VMS"
|
|
||||||
#else
|
|
||||||
# define OS "UNKNOWN-HP-VMS"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define if you have the ANSI C header files. */
|
|
||||||
#define STDC_HEADERS 1
|
|
||||||
|
|
||||||
/* Define if you can safely include both <sys/time.h> and <time.h>. */
|
|
||||||
#define TIME_WITH_SYS_TIME 1
|
|
||||||
|
|
||||||
/* The size of `int', as computed by sizeof. */
|
|
||||||
#define SIZEOF_INT 4
|
|
||||||
|
|
||||||
/* The size of `long double', as computed by sizeof. */
|
|
||||||
#define SIZEOF_LONG_DOUBLE 8
|
|
||||||
|
|
||||||
/* The size of `long long', as computed by sizeof. */
|
|
||||||
#define SIZEOF_LONG_LONG 8
|
|
||||||
|
|
||||||
/* The size of `short', as computed by sizeof. */
|
|
||||||
#define SIZEOF_SHORT 2
|
|
||||||
|
|
||||||
/* The size of `size_t', as computed by sizeof. */
|
|
||||||
#define SIZEOF_SIZE_T 4
|
|
||||||
|
|
||||||
/* Define if you have the alarm function. */
|
|
||||||
#define HAVE_ALARM 1
|
|
||||||
|
|
||||||
/* Define if you have the geteuid function. */
|
|
||||||
#define HAVE_GETEUID 1
|
|
||||||
|
|
||||||
/* Define if you have the basename function. */
|
|
||||||
#define HAVE_BASENAME 1
|
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr function. */
|
|
||||||
#define HAVE_GETHOSTBYADDR 1
|
|
||||||
|
|
||||||
/* Define if you have the gethostname function. */
|
|
||||||
#define HAVE_GETHOSTNAME 1
|
|
||||||
|
|
||||||
/* Define if you have the getpwuid function. */
|
|
||||||
#define HAVE_GETPWUID 1
|
|
||||||
|
|
||||||
/* Define if you have the getservbyname function. */
|
|
||||||
#define HAVE_GETSERVBYNAME 1
|
|
||||||
|
|
||||||
/* Define if you have the gettimeofday function. */
|
|
||||||
#define HAVE_GETTIMEOFDAY 1
|
|
||||||
|
|
||||||
/* Define if you have the inet_addr function. */
|
|
||||||
#define HAVE_INET_ADDR 1
|
|
||||||
|
|
||||||
/* Define if you have the ioctl function. */
|
|
||||||
#define HAVE_IOCTL 1
|
|
||||||
|
|
||||||
/* Define if you have a working ioctl FIONBIO function. */
|
|
||||||
#define HAVE_IOCTL_FIONBIO 1
|
|
||||||
|
|
||||||
/* Define if you have a working ioctl SIOCGIFADDR function. */
|
|
||||||
#define HAVE_IOCTL_SIOCGIFADDR 1
|
|
||||||
|
|
||||||
/* Define if you have the perror function. */
|
|
||||||
#define HAVE_PERROR 1
|
|
||||||
|
|
||||||
/* Define if you have the select function. */
|
|
||||||
#define HAVE_SELECT 1
|
|
||||||
|
|
||||||
/* Define if you have the setvbuf function. */
|
|
||||||
#define HAVE_SETVBUF 1
|
|
||||||
|
|
||||||
/* Define if you have the sigaction function. */
|
|
||||||
#define HAVE_SIGACTION 1
|
|
||||||
|
|
||||||
/* Define if you have the signal function. */
|
|
||||||
#define HAVE_SIGNAL 1
|
|
||||||
|
|
||||||
/* Define if you have the socket function. */
|
|
||||||
#define HAVE_SOCKET 1
|
|
||||||
|
|
||||||
/* Define if you have the strcasecmp function. */
|
|
||||||
#define HAVE_STRCASECMP 1
|
|
||||||
|
|
||||||
/* Define if you have the strcmpi function. */
|
|
||||||
/* #define HAVE_STRCMPI 1 */
|
|
||||||
|
|
||||||
/* Define if you have the strdup function. */
|
|
||||||
#define HAVE_STRDUP 1
|
|
||||||
|
|
||||||
/* Define if you have the strftime function. */
|
|
||||||
#define HAVE_STRFTIME 1
|
|
||||||
|
|
||||||
/* Define if you have the stricmp function. */
|
|
||||||
/* #define HAVE_STRICMP 1 */
|
|
||||||
|
|
||||||
/* Define if you have the strstr function. */
|
|
||||||
#define HAVE_STRSTR 1
|
|
||||||
|
|
||||||
/* Define if you have the ftruncate function. */
|
|
||||||
#define HAVE_FTRUNCATE 1
|
|
||||||
|
|
||||||
/* Define if you have the uname function. */
|
|
||||||
#define HAVE_UNAME 1
|
|
||||||
|
|
||||||
/* Define if you have the <errno.h> header file. */
|
|
||||||
#define HAVE_ERRNO_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <err.h> header file. */
|
|
||||||
#define HAVE_ERR_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <fcntl.h> header file. */
|
|
||||||
#define HAVE_FCNTL_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <getopt.h> header file. */
|
|
||||||
#define HAVE_GETOPT_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <malloc.h> header file. */
|
|
||||||
#define HAVE_MALLOC_H 1
|
|
||||||
|
|
||||||
/* Define if you need the malloc.h header header file even with stdlib.h */
|
|
||||||
/* #define NEED_MALLOC_H 1 */
|
|
||||||
|
|
||||||
/* Define if you have the <net/if.h> header file. */
|
|
||||||
#define HAVE_NET_IF_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <netdb.h> header file. */
|
|
||||||
#define HAVE_NETDB_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <netinet/if_ether.h> header file. */
|
|
||||||
#define HAVE_NETINET_IF_ETHER_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <netinet/in.h> header file. */
|
|
||||||
#define HAVE_NETINET_IN_H 1
|
|
||||||
|
|
||||||
/* OpenSSL section starts here */
|
|
||||||
|
|
||||||
/* Define if you have a working OpenSSL installation */
|
|
||||||
#ifdef USE_SSLEAY
|
|
||||||
|
|
||||||
/* if OpenSSL is in use */
|
|
||||||
#define USE_OPENSSL 1
|
|
||||||
|
|
||||||
/* Define if you have the crypto library (-lcrypto). */
|
|
||||||
#define HAVE_LIBCRYPTO 1
|
|
||||||
|
|
||||||
/* Define if you have the ssl library (-lssl). */
|
|
||||||
#define HAVE_LIBSSL 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/crypto.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_CRYPTO_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/err.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_ERR_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/pem.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_PEM_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/rsa.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_RSA_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/ssl.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_SSL_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <openssl/x509.h> header file. */
|
|
||||||
#define HAVE_OPENSSL_X509_H 1
|
|
||||||
|
|
||||||
/*
|
|
||||||
* This needs to be defined for OpenSSL 0.9.7 and other versions that have the
|
|
||||||
* ENGINE stuff supported. If an include of "openssl/engine.h" fails, then
|
|
||||||
* undefine the define below.
|
|
||||||
*/
|
|
||||||
#define HAVE_OPENSSL_ENGINE_H 1
|
|
||||||
|
|
||||||
#endif /* USE_SSLEAY */
|
|
||||||
/* OpenSSL section ends here */
|
|
||||||
|
|
||||||
/* Define if you have the <pwd.h> header file. */
|
|
||||||
#define HAVE_PWD_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <sgtty.h> header file. */
|
|
||||||
#define HAVE_SGTTY_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <stdlib.h> header file. */
|
|
||||||
#define HAVE_STDLIB_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <sys/socket.h> header file. */
|
|
||||||
#define HAVE_SYS_SOCKET_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <sys/stat.h> header file. */
|
|
||||||
#define HAVE_SYS_STAT_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <sys/time.h> header file. */
|
|
||||||
#define HAVE_SYS_TIME_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <sys/types.h> header file. */
|
|
||||||
#define HAVE_SYS_TYPES_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <termios.h> header file. */
|
|
||||||
#undef HAVE_TERMIOS_H
|
|
||||||
|
|
||||||
/* Define if you have the <time.h> header file. */
|
|
||||||
#define HAVE_TIME_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <unistd.h> header file. */
|
|
||||||
#define HAVE_UNISTD_H 1
|
|
||||||
|
|
||||||
/* Define if you have the resolv library (-lresolv). */
|
|
||||||
#define HAVE_LIBRESOLV 1
|
|
||||||
|
|
||||||
/* Define if you have the socket library (-lsocket). */
|
|
||||||
#define HAVE_LIBSOCKET 1
|
|
||||||
|
|
||||||
/* Define if getaddrinfo exists and works */
|
|
||||||
#define HAVE_GETADDRINFO 1
|
|
||||||
|
|
||||||
/* Define if you have the <timeval.h> header file. */
|
|
||||||
#define HAVE_TIMEVAL_H 1
|
|
||||||
|
|
||||||
/* Define if you have the timeval struct. */
|
|
||||||
#define HAVE_STRUCT_TIMEVAL 1
|
|
||||||
|
|
||||||
/* Name of this package! */
|
|
||||||
#define PACKAGE "not-used"
|
|
||||||
|
|
||||||
/* Version number of this archive. */
|
|
||||||
#define VERSION "not-used"
|
|
||||||
|
|
||||||
/* Define if you have the getpass function. */
|
|
||||||
#undef HAVE_GETPASS
|
|
||||||
|
|
||||||
/* Define if you have the <inttypes.h> header file. */
|
|
||||||
#undef HAVE_INTTYPES_H
|
|
||||||
|
|
||||||
/* Define if you have the <strings.h> header file. */
|
|
||||||
#define HAVE_STRINGS_H 1
|
|
||||||
|
|
||||||
/* Define if you have the <string.h> header file. */
|
|
||||||
#define HAVE_STRING_H 1
|
|
||||||
|
|
||||||
/* Define if you have the `strtok_r' function. */
|
|
||||||
/* Condition lifted from <string.h> */
|
|
||||||
#if __CRTL_VER >= 70301000
|
|
||||||
# define HAVE_STRTOK_R 1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Define if you have the `strtoll' function. */
|
|
||||||
#define HAVE_STRTOLL 1
|
|
||||||
|
|
||||||
/* Define if you have the <memory.h> header file. */
|
|
||||||
#define HAVE_MEMORY_H 1
|
|
||||||
|
|
||||||
/* Define to 1 if you need the memory.h header file even with stdlib.h */
|
|
||||||
#define NEED_MEMORY_H 1
|
|
||||||
|
|
||||||
/* Define if you have the `sigsetjmp' function. */
|
|
||||||
#define HAVE_SIGSETJMP 1
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <setjmp.h> header file. */
|
|
||||||
#define HAVE_SETJMP_H 1
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <limits.h> header file. */
|
|
||||||
#define HAVE_LIMITS_H 1
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <sys/ioctl.h> header file. */
|
|
||||||
#define HAVE_SYS_IOCTL_H 1
|
|
||||||
|
|
||||||
/* Define to 1 if you have the <stropts.h> header file. */
|
|
||||||
#define HAVE_STROPTS_H 1
|
|
||||||
|
|
||||||
/* Define if you have the getnameinfo function. */
|
|
||||||
#define HAVE_GETNAMEINFO 1
|
|
||||||
|
|
||||||
/* Define to the type qualifier of arg 1 for getnameinfo. */
|
|
||||||
#define GETNAMEINFO_QUAL_ARG1 const
|
|
||||||
|
|
||||||
/* Define to the type of arg 1 for getnameinfo. */
|
|
||||||
#define GETNAMEINFO_TYPE_ARG1 struct sockaddr *
|
|
||||||
|
|
||||||
/* Define to the type of arg 2 for getnameinfo. */
|
|
||||||
#define GETNAMEINFO_TYPE_ARG2 size_t
|
|
||||||
|
|
||||||
/* Define to the type of args 4 and 6 for getnameinfo. */
|
|
||||||
#define GETNAMEINFO_TYPE_ARG46 size_t
|
|
||||||
|
|
||||||
/* Define to the type of arg 7 for getnameinfo. */
|
|
||||||
#define GETNAMEINFO_TYPE_ARG7 int
|
|
||||||
|
|
||||||
/* Define if you have the recv function. */
|
|
||||||
#define HAVE_RECV 1
|
|
||||||
|
|
||||||
/* Define to the type of arg 1 for recv. */
|
|
||||||
#define RECV_TYPE_ARG1 int
|
|
||||||
|
|
||||||
/* Define to the type of arg 2 for recv. */
|
|
||||||
#define RECV_TYPE_ARG2 void *
|
|
||||||
|
|
||||||
/* Define to the type of arg 3 for recv. */
|
|
||||||
#define RECV_TYPE_ARG3 int
|
|
||||||
|
|
||||||
/* Define to the type of arg 4 for recv. */
|
|
||||||
#define RECV_TYPE_ARG4 int
|
|
||||||
|
|
||||||
/* Define to the function return type for recv. */
|
|
||||||
#define RECV_TYPE_RETV int
|
|
||||||
|
|
||||||
/* Define if you have the recvfrom function. */
|
|
||||||
#define HAVE_RECVFROM 1
|
|
||||||
|
|
||||||
/* Define to the type of arg 1 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG1 int
|
|
||||||
|
|
||||||
/* Define to the type pointed by arg 2 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG2 void
|
|
||||||
|
|
||||||
/* Define if the type pointed by arg 2 for recvfrom is void. */
|
|
||||||
#define RECVFROM_TYPE_ARG2_IS_VOID 1
|
|
||||||
|
|
||||||
/* Define to the type of arg 3 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG3 int
|
|
||||||
|
|
||||||
/* Define to the type of arg 4 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG4 int
|
|
||||||
|
|
||||||
/* Define to the type pointed by arg 5 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG5 struct sockaddr
|
|
||||||
|
|
||||||
/* Define to the type pointed by arg 6 for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_ARG6 int
|
|
||||||
|
|
||||||
/* Define to the function return type for recvfrom. */
|
|
||||||
#define RECVFROM_TYPE_RETV int
|
|
||||||
|
|
||||||
/* Define if you have the send function. */
|
|
||||||
#define HAVE_SEND 1
|
|
||||||
|
|
||||||
/* Define to the type of arg 1 for send. */
|
|
||||||
#define SEND_TYPE_ARG1 int
|
|
||||||
|
|
||||||
/* Define to the type qualifier of arg 2 for send. */
|
|
||||||
#define SEND_QUAL_ARG2 const
|
|
||||||
|
|
||||||
/* Define to the type of arg 2 for send. */
|
|
||||||
#define SEND_TYPE_ARG2 void *
|
|
||||||
|
|
||||||
/* Define to the type of arg 3 for send. */
|
|
||||||
#define SEND_TYPE_ARG3 int
|
|
||||||
|
|
||||||
/* Define to the type of arg 4 for send. */
|
|
||||||
#define SEND_TYPE_ARG4 int
|
|
||||||
|
|
||||||
/* Define to the function return type for send. */
|
|
||||||
#define SEND_TYPE_RETV int
|
|
||||||
|
|
||||||
/* Define to hide dollar sign from compilers in strict ansi mode. */
|
|
||||||
#define decc_translate_vms(__s) decc$translate_vms(__s)
|
|
||||||
|
|
||||||
#endif /* HEADER_CONFIG_VMS_H */
|
|
||||||
282
lib/conncache.c
Normal file
282
lib/conncache.c
Normal file
@@ -0,0 +1,282 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, Linus Nielsen Feltzing, <linus@haxx.se>
|
||||||
|
* Copyright (C) 2012 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
#include "curl_setup.h"
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#include "urldata.h"
|
||||||
|
#include "url.h"
|
||||||
|
#include "progress.h"
|
||||||
|
#include "multiif.h"
|
||||||
|
#include "sendf.h"
|
||||||
|
#include "rawstr.h"
|
||||||
|
#include "bundles.h"
|
||||||
|
#include "conncache.h"
|
||||||
|
|
||||||
|
#include "curl_memory.h"
|
||||||
|
/* The last #include file should be: */
|
||||||
|
#include "memdebug.h"
|
||||||
|
|
||||||
|
#define CONNECTION_HASH_SIZE 97
|
||||||
|
|
||||||
|
static void free_bundle_hash_entry(void *freethis)
|
||||||
|
{
|
||||||
|
struct connectbundle *b = (struct connectbundle *) freethis;
|
||||||
|
|
||||||
|
Curl_bundle_destroy(b);
|
||||||
|
}
|
||||||
|
|
||||||
|
struct conncache *Curl_conncache_init(void)
|
||||||
|
{
|
||||||
|
struct conncache *connc;
|
||||||
|
|
||||||
|
connc = calloc(1, sizeof(struct conncache));
|
||||||
|
if(!connc)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
connc->hash = Curl_hash_alloc(CONNECTION_HASH_SIZE, Curl_hash_str,
|
||||||
|
Curl_str_key_compare, free_bundle_hash_entry);
|
||||||
|
|
||||||
|
if(!connc->hash) {
|
||||||
|
free(connc);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return connc;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Curl_conncache_destroy(struct conncache *connc)
|
||||||
|
{
|
||||||
|
if(connc) {
|
||||||
|
Curl_hash_destroy(connc->hash);
|
||||||
|
connc->hash = NULL;
|
||||||
|
free(connc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct connectbundle *Curl_conncache_find_bundle(struct conncache *connc,
|
||||||
|
char *hostname)
|
||||||
|
{
|
||||||
|
struct connectbundle *bundle = NULL;
|
||||||
|
|
||||||
|
if(connc)
|
||||||
|
bundle = Curl_hash_pick(connc->hash, hostname, strlen(hostname)+1);
|
||||||
|
|
||||||
|
return bundle;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool conncache_add_bundle(struct conncache *connc,
|
||||||
|
char *hostname,
|
||||||
|
struct connectbundle *bundle)
|
||||||
|
{
|
||||||
|
void *p;
|
||||||
|
|
||||||
|
p = Curl_hash_add(connc->hash, hostname, strlen(hostname)+1, bundle);
|
||||||
|
|
||||||
|
return p?TRUE:FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void conncache_remove_bundle(struct conncache *connc,
|
||||||
|
struct connectbundle *bundle)
|
||||||
|
{
|
||||||
|
struct curl_hash_iterator iter;
|
||||||
|
struct curl_hash_element *he;
|
||||||
|
|
||||||
|
if(!connc)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Curl_hash_start_iterate(connc->hash, &iter);
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
while(he) {
|
||||||
|
if(he->ptr == bundle) {
|
||||||
|
/* The bundle is destroyed by the hash destructor function,
|
||||||
|
free_bundle_hash_entry() */
|
||||||
|
Curl_hash_delete(connc->hash, he->key, he->key_len);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CURLcode Curl_conncache_add_conn(struct conncache *connc,
|
||||||
|
struct connectdata *conn)
|
||||||
|
{
|
||||||
|
CURLcode result;
|
||||||
|
struct connectbundle *bundle;
|
||||||
|
struct connectbundle *new_bundle = NULL;
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
|
||||||
|
bundle = Curl_conncache_find_bundle(data->state.conn_cache,
|
||||||
|
conn->host.name);
|
||||||
|
if(!bundle) {
|
||||||
|
result = Curl_bundle_create(data, &new_bundle);
|
||||||
|
if(result != CURLE_OK)
|
||||||
|
return result;
|
||||||
|
|
||||||
|
if(!conncache_add_bundle(data->state.conn_cache,
|
||||||
|
conn->host.name, new_bundle)) {
|
||||||
|
Curl_bundle_destroy(new_bundle);
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
}
|
||||||
|
bundle = new_bundle;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = Curl_bundle_add_conn(bundle, conn);
|
||||||
|
if(result != CURLE_OK) {
|
||||||
|
if(new_bundle)
|
||||||
|
conncache_remove_bundle(data->state.conn_cache, new_bundle);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
connc->num_connections++;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Curl_conncache_remove_conn(struct conncache *connc,
|
||||||
|
struct connectdata *conn)
|
||||||
|
{
|
||||||
|
struct connectbundle *bundle = conn->bundle;
|
||||||
|
|
||||||
|
/* The bundle pointer can be NULL, since this function can be called
|
||||||
|
due to a failed connection attempt, before being added to a bundle */
|
||||||
|
if(bundle) {
|
||||||
|
Curl_bundle_remove_conn(bundle, conn);
|
||||||
|
if(bundle->num_connections == 0) {
|
||||||
|
conncache_remove_bundle(connc, bundle);
|
||||||
|
}
|
||||||
|
connc->num_connections--;
|
||||||
|
|
||||||
|
DEBUGF(infof(conn->data, "The cache now contains %d members\n",
|
||||||
|
connc->num_connections));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This function iterates the entire connection cache and calls the
|
||||||
|
function func() with the connection pointer as the first argument
|
||||||
|
and the supplied 'param' argument as the other,
|
||||||
|
|
||||||
|
Return 0 from func() to continue the loop, return 1 to abort it.
|
||||||
|
*/
|
||||||
|
void Curl_conncache_foreach(struct conncache *connc,
|
||||||
|
void *param,
|
||||||
|
int (*func)(struct connectdata *conn, void *param))
|
||||||
|
{
|
||||||
|
struct curl_hash_iterator iter;
|
||||||
|
struct curl_llist_element *curr;
|
||||||
|
struct curl_hash_element *he;
|
||||||
|
|
||||||
|
if(!connc)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Curl_hash_start_iterate(connc->hash, &iter);
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
while(he) {
|
||||||
|
struct connectbundle *bundle;
|
||||||
|
struct connectdata *conn;
|
||||||
|
|
||||||
|
bundle = he->ptr;
|
||||||
|
|
||||||
|
curr = bundle->conn_list->head;
|
||||||
|
while(curr) {
|
||||||
|
/* Yes, we need to update curr before calling func(), because func()
|
||||||
|
might decide to remove the connection */
|
||||||
|
conn = curr->ptr;
|
||||||
|
curr = curr->next;
|
||||||
|
|
||||||
|
if(1 == func(conn, param))
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Return the first connection found in the cache. Used when closing all
|
||||||
|
connections */
|
||||||
|
struct connectdata *
|
||||||
|
Curl_conncache_find_first_connection(struct conncache *connc)
|
||||||
|
{
|
||||||
|
struct curl_hash_iterator iter;
|
||||||
|
struct curl_llist_element *curr;
|
||||||
|
struct curl_hash_element *he;
|
||||||
|
struct connectbundle *bundle;
|
||||||
|
|
||||||
|
Curl_hash_start_iterate(connc->hash, &iter);
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
while(he) {
|
||||||
|
bundle = he->ptr;
|
||||||
|
|
||||||
|
curr = bundle->conn_list->head;
|
||||||
|
if(curr) {
|
||||||
|
return curr->ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/* Useful for debugging the connection cache */
|
||||||
|
void Curl_conncache_print(struct conncache *connc)
|
||||||
|
{
|
||||||
|
struct curl_hash_iterator iter;
|
||||||
|
struct curl_llist_element *curr;
|
||||||
|
struct curl_hash_element *he;
|
||||||
|
|
||||||
|
if(!connc)
|
||||||
|
return;
|
||||||
|
|
||||||
|
fprintf(stderr, "=Bundle cache=\n");
|
||||||
|
|
||||||
|
Curl_hash_start_iterate(connc->hash, &iter);
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
while(he) {
|
||||||
|
struct connectbundle *bundle;
|
||||||
|
struct connectdata *conn;
|
||||||
|
|
||||||
|
bundle = he->ptr;
|
||||||
|
|
||||||
|
fprintf(stderr, "%s -", he->key);
|
||||||
|
curr = bundle->conn_list->head;
|
||||||
|
while(curr) {
|
||||||
|
conn = curr->ptr;
|
||||||
|
|
||||||
|
fprintf(stderr, " [%p %d]", (void *)conn, conn->inuse);
|
||||||
|
curr = curr->next;
|
||||||
|
}
|
||||||
|
fprintf(stderr, "\n");
|
||||||
|
|
||||||
|
he = Curl_hash_next_element(&iter);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
53
lib/conncache.h
Normal file
53
lib/conncache.h
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
#ifndef HEADER_CURL_CONNCACHE_H
|
||||||
|
#define HEADER_CURL_CONNCACHE_H
|
||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 2012, 2013, Linus Nielsen Feltzing, <linus@haxx.se>
|
||||||
|
*
|
||||||
|
* This software is licensed as described in the file COPYING, which
|
||||||
|
* you should have received as part of this distribution. The terms
|
||||||
|
* are also available at http://curl.haxx.se/docs/copyright.html.
|
||||||
|
*
|
||||||
|
* You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
||||||
|
* copies of the Software, and permit persons to whom the Software is
|
||||||
|
* furnished to do so, under the terms of the COPYING file.
|
||||||
|
*
|
||||||
|
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
||||||
|
* KIND, either express or implied.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
|
||||||
|
struct conncache {
|
||||||
|
struct curl_hash *hash;
|
||||||
|
size_t num_connections;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct conncache *Curl_conncache_init(void);
|
||||||
|
|
||||||
|
void Curl_conncache_destroy(struct conncache *connc);
|
||||||
|
|
||||||
|
struct connectbundle *Curl_conncache_find_bundle(struct conncache *connc,
|
||||||
|
char *hostname);
|
||||||
|
|
||||||
|
CURLcode Curl_conncache_add_conn(struct conncache *connc,
|
||||||
|
struct connectdata *conn);
|
||||||
|
|
||||||
|
void Curl_conncache_remove_conn(struct conncache *connc,
|
||||||
|
struct connectdata *conn);
|
||||||
|
|
||||||
|
void Curl_conncache_foreach(struct conncache *connc,
|
||||||
|
void *param,
|
||||||
|
int (*func)(struct connectdata *conn,
|
||||||
|
void *param));
|
||||||
|
|
||||||
|
struct connectdata *
|
||||||
|
Curl_conncache_find_first_connection(struct conncache *connc);
|
||||||
|
|
||||||
|
void Curl_conncache_print(struct conncache *connc);
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_CONNCACHE_H */
|
||||||
191
lib/connect.c
191
lib/connect.c
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,11 +20,8 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETINET_IN_H
|
#ifdef HAVE_NETINET_IN_H
|
||||||
#include <netinet/in.h> /* <netinet/tcp.h> may need it */
|
#include <netinet/in.h> /* <netinet/tcp.h> may need it */
|
||||||
#endif
|
#endif
|
||||||
@@ -37,9 +34,6 @@
|
|||||||
#ifdef HAVE_SYS_IOCTL_H
|
#ifdef HAVE_SYS_IOCTL_H
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETDB_H
|
#ifdef HAVE_NETDB_H
|
||||||
#include <netdb.h>
|
#include <netdb.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -80,6 +74,8 @@
|
|||||||
#include "sslgen.h" /* for Curl_ssl_check_cxn() */
|
#include "sslgen.h" /* for Curl_ssl_check_cxn() */
|
||||||
#include "progress.h"
|
#include "progress.h"
|
||||||
#include "warnless.h"
|
#include "warnless.h"
|
||||||
|
#include "conncache.h"
|
||||||
|
#include "multihandle.h"
|
||||||
|
|
||||||
/* The last #include file should be: */
|
/* The last #include file should be: */
|
||||||
#include "memdebug.h"
|
#include "memdebug.h"
|
||||||
@@ -132,7 +128,6 @@ tcpkeepalive(struct SessionHandle *data,
|
|||||||
static CURLcode
|
static CURLcode
|
||||||
singleipconnect(struct connectdata *conn,
|
singleipconnect(struct connectdata *conn,
|
||||||
const Curl_addrinfo *ai, /* start connecting to this */
|
const Curl_addrinfo *ai, /* start connecting to this */
|
||||||
long timeout_ms,
|
|
||||||
curl_socket_t *sock,
|
curl_socket_t *sock,
|
||||||
bool *connected);
|
bool *connected);
|
||||||
|
|
||||||
@@ -203,20 +198,19 @@ long Curl_timeleft(struct SessionHandle *data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* waitconnect() waits for a TCP connect on the given socket for the specified
|
* checkconnect() checks for a TCP connect on the given socket.
|
||||||
* number if milliseconds. It returns:
|
* It returns:
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define WAITCONN_CONNECTED 0
|
enum chkconn_t {
|
||||||
#define WAITCONN_SELECT_ERROR -1
|
CHKCONN_SELECT_ERROR = -1,
|
||||||
#define WAITCONN_TIMEOUT 1
|
CHKCONN_CONNECTED = 0,
|
||||||
#define WAITCONN_FDSET_ERROR 2
|
CHKCONN_IDLE = 1,
|
||||||
#define WAITCONN_ABORTED 3
|
CHKCONN_FDSET_ERROR = 2
|
||||||
|
};
|
||||||
|
|
||||||
static
|
static enum chkconn_t
|
||||||
int waitconnect(struct connectdata *conn,
|
checkconnect(curl_socket_t sockfd)
|
||||||
curl_socket_t sockfd, /* socket */
|
|
||||||
long timeout_msec)
|
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
#ifdef mpeix
|
#ifdef mpeix
|
||||||
@@ -226,34 +220,20 @@ int waitconnect(struct connectdata *conn,
|
|||||||
(void)verifyconnect(sockfd, NULL);
|
(void)verifyconnect(sockfd, NULL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
for(;;) {
|
rc = Curl_socket_ready(CURL_SOCKET_BAD, sockfd, 0);
|
||||||
|
|
||||||
/* now select() until we get connect or timeout */
|
|
||||||
rc = Curl_socket_ready(CURL_SOCKET_BAD, sockfd, timeout_msec>1000?
|
|
||||||
1000:timeout_msec);
|
|
||||||
if(Curl_pgrsUpdate(conn))
|
|
||||||
return WAITCONN_ABORTED;
|
|
||||||
|
|
||||||
if(-1 == rc)
|
if(-1 == rc)
|
||||||
/* error, no connect here, try next */
|
/* error, no connect here, try next */
|
||||||
return WAITCONN_SELECT_ERROR;
|
return CHKCONN_SELECT_ERROR;
|
||||||
|
|
||||||
else if(0 == rc) {
|
else if(rc & CURL_CSELECT_ERR)
|
||||||
/* timeout */
|
|
||||||
timeout_msec -= 1000;
|
|
||||||
if(timeout_msec <= 0)
|
|
||||||
return WAITCONN_TIMEOUT;
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(rc & CURL_CSELECT_ERR)
|
|
||||||
/* error condition caught */
|
/* error condition caught */
|
||||||
return WAITCONN_FDSET_ERROR;
|
return CHKCONN_FDSET_ERROR;
|
||||||
|
|
||||||
break;
|
else if(rc)
|
||||||
}
|
return CHKCONN_CONNECTED;
|
||||||
return WAITCONN_CONNECTED;
|
|
||||||
|
return CHKCONN_IDLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static CURLcode bindlocal(struct connectdata *conn,
|
static CURLcode bindlocal(struct connectdata *conn,
|
||||||
@@ -552,7 +532,7 @@ static CURLcode trynextip(struct connectdata *conn,
|
|||||||
ai = conn->ip_addr->ai_next;
|
ai = conn->ip_addr->ai_next;
|
||||||
|
|
||||||
while(ai) {
|
while(ai) {
|
||||||
CURLcode res = singleipconnect(conn, ai, 0L, &sockfd, connected);
|
CURLcode res = singleipconnect(conn, ai, &sockfd, connected);
|
||||||
if(res)
|
if(res)
|
||||||
return res;
|
return res;
|
||||||
if(sockfd != CURL_SOCKET_BAD) {
|
if(sockfd != CURL_SOCKET_BAD) {
|
||||||
@@ -680,21 +660,20 @@ void Curl_updateconninfo(struct connectdata *conn, curl_socket_t sockfd)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Curl_is_connected() is used from the multi interface to check if the
|
* Curl_is_connected() checks if the socket has connected.
|
||||||
* firstsocket has connected.
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
CURLcode Curl_is_connected(struct connectdata *conn,
|
CURLcode Curl_is_connected(struct connectdata *conn,
|
||||||
int sockindex,
|
int sockindex,
|
||||||
bool *connected)
|
bool *connected)
|
||||||
{
|
{
|
||||||
int rc;
|
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
CURLcode code = CURLE_OK;
|
CURLcode code = CURLE_OK;
|
||||||
curl_socket_t sockfd = conn->sock[sockindex];
|
curl_socket_t sockfd = conn->sock[sockindex];
|
||||||
long allow = DEFAULT_CONNECT_TIMEOUT;
|
long allow = DEFAULT_CONNECT_TIMEOUT;
|
||||||
int error = 0;
|
int error = 0;
|
||||||
struct timeval now;
|
struct timeval now;
|
||||||
|
enum chkconn_t chk;
|
||||||
|
|
||||||
DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET);
|
DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET);
|
||||||
|
|
||||||
@@ -717,9 +696,9 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
return CURLE_OPERATION_TIMEDOUT;
|
return CURLE_OPERATION_TIMEDOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for connect without timeout as we want to return immediately */
|
/* check socket for connect */
|
||||||
rc = waitconnect(conn, sockfd, 0);
|
chk = checkconnect(sockfd);
|
||||||
if(WAITCONN_TIMEOUT == rc) {
|
if(CHKCONN_IDLE == chk) {
|
||||||
if(curlx_tvdiff(now, conn->connecttime) >= conn->timeoutms_per_addr) {
|
if(curlx_tvdiff(now, conn->connecttime) >= conn->timeoutms_per_addr) {
|
||||||
infof(data, "After %ldms connect time, move on!\n",
|
infof(data, "After %ldms connect time, move on!\n",
|
||||||
conn->timeoutms_per_addr);
|
conn->timeoutms_per_addr);
|
||||||
@@ -730,7 +709,7 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
return code;
|
return code;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(WAITCONN_CONNECTED == rc) {
|
if(CHKCONN_CONNECTED == chk) {
|
||||||
if(verifyconnect(sockfd, &error)) {
|
if(verifyconnect(sockfd, &error)) {
|
||||||
/* we are connected with TCP, awesome! */
|
/* we are connected with TCP, awesome! */
|
||||||
|
|
||||||
@@ -740,6 +719,7 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
return code;
|
return code;
|
||||||
|
|
||||||
conn->bits.tcpconnect[sockindex] = TRUE;
|
conn->bits.tcpconnect[sockindex] = TRUE;
|
||||||
|
|
||||||
*connected = TRUE;
|
*connected = TRUE;
|
||||||
if(sockindex == FIRSTSOCKET)
|
if(sockindex == FIRSTSOCKET)
|
||||||
Curl_pgrsTime(data, TIMER_CONNECT); /* connect done */
|
Curl_pgrsTime(data, TIMER_CONNECT); /* connect done */
|
||||||
@@ -752,7 +732,7 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
/* nope, not connected */
|
/* nope, not connected */
|
||||||
if(WAITCONN_FDSET_ERROR == rc) {
|
if(CHKCONN_FDSET_ERROR == chk) {
|
||||||
(void)verifyconnect(sockfd, &error);
|
(void)verifyconnect(sockfd, &error);
|
||||||
infof(data, "%s\n",Curl_strerror(conn, error));
|
infof(data, "%s\n",Curl_strerror(conn, error));
|
||||||
}
|
}
|
||||||
@@ -868,12 +848,11 @@ void Curl_sndbufset(curl_socket_t sockfd)
|
|||||||
* CURL_SOCKET_BAD. Other errors will however return proper errors.
|
* CURL_SOCKET_BAD. Other errors will however return proper errors.
|
||||||
*
|
*
|
||||||
* singleipconnect() connects to the given IP only, and it may return without
|
* singleipconnect() connects to the given IP only, and it may return without
|
||||||
* having connected if used from the multi interface.
|
* having connected.
|
||||||
*/
|
*/
|
||||||
static CURLcode
|
static CURLcode
|
||||||
singleipconnect(struct connectdata *conn,
|
singleipconnect(struct connectdata *conn,
|
||||||
const Curl_addrinfo *ai,
|
const Curl_addrinfo *ai,
|
||||||
long timeout_ms,
|
|
||||||
curl_socket_t *sockp,
|
curl_socket_t *sockp,
|
||||||
bool *connected)
|
bool *connected)
|
||||||
{
|
{
|
||||||
@@ -944,17 +923,24 @@ singleipconnect(struct connectdata *conn,
|
|||||||
/* set socket non-blocking */
|
/* set socket non-blocking */
|
||||||
curlx_nonblock(sockfd, TRUE);
|
curlx_nonblock(sockfd, TRUE);
|
||||||
|
|
||||||
|
conn->connecttime = Curl_tvnow();
|
||||||
|
if(conn->num_addr > 1)
|
||||||
|
Curl_expire(data, conn->timeoutms_per_addr);
|
||||||
|
|
||||||
/* Connect TCP sockets, bind UDP */
|
/* Connect TCP sockets, bind UDP */
|
||||||
if(!isconnected && (conn->socktype == SOCK_STREAM)) {
|
if(!isconnected && (conn->socktype == SOCK_STREAM)) {
|
||||||
rc = connect(sockfd, &addr.sa_addr, addr.addrlen);
|
rc = connect(sockfd, &addr.sa_addr, addr.addrlen);
|
||||||
if(-1 == rc)
|
if(-1 == rc)
|
||||||
error = SOCKERRNO;
|
error = SOCKERRNO;
|
||||||
conn->connecttime = Curl_tvnow();
|
|
||||||
if(conn->num_addr > 1)
|
|
||||||
Curl_expire(data, conn->timeoutms_per_addr);
|
|
||||||
}
|
}
|
||||||
else
|
else {
|
||||||
rc = 0;
|
*sockp = sockfd;
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef ENABLE_IPV6
|
||||||
|
conn->bits.ipv6 = (addr.family == AF_INET6)?TRUE:FALSE;
|
||||||
|
#endif
|
||||||
|
|
||||||
if(-1 == rc) {
|
if(-1 == rc) {
|
||||||
switch (error) {
|
switch (error) {
|
||||||
@@ -969,54 +955,23 @@ singleipconnect(struct connectdata *conn,
|
|||||||
case EAGAIN:
|
case EAGAIN:
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
rc = waitconnect(conn, sockfd, timeout_ms);
|
*sockp = sockfd;
|
||||||
if(WAITCONN_ABORTED == rc) {
|
return CURLE_OK;
|
||||||
Curl_closesocket(conn, sockfd);
|
|
||||||
return CURLE_ABORTED_BY_CALLBACK;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
/* unknown error, fallthrough and try another address! */
|
/* unknown error, fallthrough and try another address! */
|
||||||
failf(data, "Failed to connect to %s: %s",
|
failf(data, "Failed to connect to %s: %s",
|
||||||
conn->ip_addr_str, Curl_strerror(conn,error));
|
conn->ip_addr_str, Curl_strerror(conn,error));
|
||||||
data->state.os_errno = error;
|
data->state.os_errno = error;
|
||||||
|
|
||||||
|
/* connect failed */
|
||||||
|
Curl_closesocket(conn, sockfd);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
/* The 'WAITCONN_TIMEOUT == rc' comes from the waitconnect(), and not from
|
|
||||||
connect(). We can be sure of this since connect() cannot return 1. */
|
|
||||||
if((WAITCONN_TIMEOUT == rc) &&
|
|
||||||
(data->state.used_interface == Curl_if_multi)) {
|
|
||||||
/* Timeout when running the multi interface */
|
|
||||||
*sockp = sockfd;
|
*sockp = sockfd;
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(!isconnected)
|
|
||||||
isconnected = verifyconnect(sockfd, &error);
|
|
||||||
|
|
||||||
if(!rc && isconnected) {
|
|
||||||
/* we are connected, awesome! */
|
|
||||||
*connected = TRUE; /* this is a true connect */
|
|
||||||
infof(data, "connected\n");
|
|
||||||
#ifdef ENABLE_IPV6
|
|
||||||
conn->bits.ipv6 = (addr.family == AF_INET6)?TRUE:FALSE;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
Curl_updateconninfo(conn, sockfd);
|
|
||||||
*sockp = sockfd;
|
|
||||||
return CURLE_OK;
|
|
||||||
}
|
|
||||||
else if(WAITCONN_TIMEOUT == rc)
|
|
||||||
infof(data, "Timeout\n");
|
|
||||||
else {
|
|
||||||
data->state.os_errno = error;
|
|
||||||
infof(data, "%s\n", Curl_strerror(conn, error));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* connect failed or timed out */
|
|
||||||
Curl_closesocket(conn, sockfd);
|
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -1078,9 +1033,7 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
|
|
||||||
/* start connecting to the IP curr_addr points to */
|
/* start connecting to the IP curr_addr points to */
|
||||||
res = singleipconnect(conn, curr_addr,
|
res = singleipconnect(conn, curr_addr,
|
||||||
/* don't hang when doing multi */
|
&sockfd, connected);
|
||||||
(data->state.used_interface == Curl_if_multi)?0:
|
|
||||||
conn->timeoutms_per_addr, &sockfd, connected);
|
|
||||||
if(res)
|
if(res)
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
@@ -1101,7 +1054,9 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
|
|
||||||
if(sockfd == CURL_SOCKET_BAD) {
|
if(sockfd == CURL_SOCKET_BAD) {
|
||||||
/* no good connect was made */
|
/* no good connect was made */
|
||||||
failf(data, "couldn't connect to host");
|
failf(data, "couldn't connect to %s at %s:%d",
|
||||||
|
conn->bits.proxy?"proxy":"host",
|
||||||
|
conn->bits.proxy?conn->proxy.name:conn->host.name, conn->port);
|
||||||
return CURLE_COULDNT_CONNECT;
|
return CURLE_COULDNT_CONNECT;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1116,6 +1071,21 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
struct connfind {
|
||||||
|
struct connectdata *tofind;
|
||||||
|
bool found;
|
||||||
|
};
|
||||||
|
|
||||||
|
static int conn_is_conn(struct connectdata *conn, void *param)
|
||||||
|
{
|
||||||
|
struct connfind *f = (struct connfind *)param;
|
||||||
|
if(conn == f->tofind) {
|
||||||
|
f->found = TRUE;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Used to extract socket and connectdata struct for the most recent
|
* Used to extract socket and connectdata struct for the most recent
|
||||||
* transfer on the given SessionHandle.
|
* transfer on the given SessionHandle.
|
||||||
@@ -1129,10 +1099,21 @@ curl_socket_t Curl_getconnectinfo(struct SessionHandle *data,
|
|||||||
|
|
||||||
DEBUGASSERT(data);
|
DEBUGASSERT(data);
|
||||||
|
|
||||||
if((data->state.lastconnect != -1) &&
|
/* this only works for an easy handle that has been used for
|
||||||
(data->state.connc->connects[data->state.lastconnect] != NULL)) {
|
curl_easy_perform()! */
|
||||||
struct connectdata *c =
|
if(data->state.lastconnect && data->multi_easy) {
|
||||||
data->state.connc->connects[data->state.lastconnect];
|
struct connectdata *c = data->state.lastconnect;
|
||||||
|
struct connfind find;
|
||||||
|
find.tofind = data->state.lastconnect;
|
||||||
|
find.found = FALSE;
|
||||||
|
|
||||||
|
Curl_conncache_foreach(data->multi_easy->conn_cache, &find, conn_is_conn);
|
||||||
|
|
||||||
|
if(!find.found) {
|
||||||
|
data->state.lastconnect = NULL;
|
||||||
|
return CURL_SOCKET_BAD;
|
||||||
|
}
|
||||||
|
|
||||||
if(connp)
|
if(connp)
|
||||||
/* only store this if the caller cares for it */
|
/* only store this if the caller cares for it */
|
||||||
*connp = c;
|
*connp = c;
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include "nonblock.h" /* for curlx_nonblock(), formerly Curl_nonblock() */
|
#include "nonblock.h" /* for curlx_nonblock(), formerly Curl_nonblock() */
|
||||||
#include "sockaddr.h"
|
#include "sockaddr.h"
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_LIBZ
|
#ifdef HAVE_LIBZ
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Comma-separated list all supported Content-Encodings ('identity' is implied)
|
* Comma-separated list all supported Content-Encodings ('identity' is implied)
|
||||||
|
|||||||
@@ -77,7 +77,7 @@ Example set of cookies:
|
|||||||
****/
|
****/
|
||||||
|
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if !defined(CURL_DISABLE_HTTP) && !defined(CURL_DISABLE_COOKIES)
|
#if !defined(CURL_DISABLE_HTTP) && !defined(CURL_DISABLE_COOKIES)
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,13 +20,10 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
# include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETINET_IN_H
|
#ifdef HAVE_NETINET_IN_H
|
||||||
# include <netinet/in.h>
|
# include <netinet/in.h>
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -22,11 +22,8 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
# include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_NETINET_IN_H
|
#ifdef HAVE_NETINET_IN_H
|
||||||
# include <netinet/in.h>
|
# include <netinet/in.h>
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -5,8 +5,8 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012, Nick Zitzmann, <nickzman@gmail.com>.
|
* Copyright (C) 2012-2013, Nick Zitzmann, <nickzman@gmail.com>.
|
||||||
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2012-2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -26,21 +26,21 @@
|
|||||||
* TLS/SSL layer. No code but sslgen.c should ever call or use these functions.
|
* TLS/SSL layer. No code but sslgen.c should ever call or use these functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_DARWINSSL
|
#ifdef USE_DARWINSSL
|
||||||
|
|
||||||
#ifdef HAVE_LIMITS_H
|
#ifdef HAVE_LIMITS_H
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
|
||||||
#include <sys/socket.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <Security/Security.h>
|
#include <Security/Security.h>
|
||||||
#include <Security/SecureTransport.h>
|
#include <Security/SecureTransport.h>
|
||||||
#include <CoreFoundation/CoreFoundation.h>
|
#include <CoreFoundation/CoreFoundation.h>
|
||||||
#include <CommonCrypto/CommonDigest.h>
|
#include <CommonCrypto/CommonDigest.h>
|
||||||
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
|
#include <sys/sysctl.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include "sendf.h"
|
#include "sendf.h"
|
||||||
@@ -78,15 +78,15 @@ static OSStatus SocketRead(SSLConnectionRef connection,
|
|||||||
* RETURNED */
|
* RETURNED */
|
||||||
size_t *dataLength) /* IN/OUT */
|
size_t *dataLength) /* IN/OUT */
|
||||||
{
|
{
|
||||||
UInt32 bytesToGo = *dataLength;
|
size_t bytesToGo = *dataLength;
|
||||||
UInt32 initLen = bytesToGo;
|
size_t initLen = bytesToGo;
|
||||||
UInt8 *currData = (UInt8 *)data;
|
UInt8 *currData = (UInt8 *)data;
|
||||||
/*int sock = *(int *)connection;*/
|
/*int sock = *(int *)connection;*/
|
||||||
struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
|
struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
|
||||||
int sock = connssl->ssl_sockfd;
|
int sock = connssl->ssl_sockfd;
|
||||||
OSStatus rtn = noErr;
|
OSStatus rtn = noErr;
|
||||||
UInt32 bytesRead;
|
size_t bytesRead;
|
||||||
int rrtn;
|
ssize_t rrtn;
|
||||||
int theErr;
|
int theErr;
|
||||||
|
|
||||||
*dataLength = 0;
|
*dataLength = 0;
|
||||||
@@ -140,12 +140,12 @@ static OSStatus SocketWrite(SSLConnectionRef connection,
|
|||||||
const void *data,
|
const void *data,
|
||||||
size_t *dataLength) /* IN/OUT */
|
size_t *dataLength) /* IN/OUT */
|
||||||
{
|
{
|
||||||
UInt32 bytesSent = 0;
|
size_t bytesSent = 0;
|
||||||
/*int sock = *(int *)connection;*/
|
/*int sock = *(int *)connection;*/
|
||||||
struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
|
struct ssl_connect_data *connssl = (struct ssl_connect_data *)connection;
|
||||||
int sock = connssl->ssl_sockfd;
|
int sock = connssl->ssl_sockfd;
|
||||||
int length;
|
ssize_t length;
|
||||||
UInt32 dataLen = *dataLength;
|
size_t dataLen = *dataLength;
|
||||||
const UInt8 *dataPtr = (UInt8 *)data;
|
const UInt8 *dataPtr = (UInt8 *)data;
|
||||||
OSStatus ortn;
|
OSStatus ortn;
|
||||||
int theErr;
|
int theErr;
|
||||||
@@ -266,6 +266,44 @@ CF_INLINE const char *SSLCipherNameForNumber(SSLCipherSuite cipher) {
|
|||||||
case SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA:
|
case SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA:
|
||||||
return "SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA";
|
return "SSL_FORTEZZA_DMS_WITH_FORTEZZA_CBC_SHA";
|
||||||
break;
|
break;
|
||||||
|
/* TLS 1.0 with AES (RFC 3268)
|
||||||
|
(Apparently these are used in SSLv3 implementations as well.) */
|
||||||
|
case TLS_RSA_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_RSA_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_DSS_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_DH_DSS_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_RSA_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_DH_RSA_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DHE_DSS_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_DHE_DSS_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DHE_RSA_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_DHE_RSA_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_anon_WITH_AES_128_CBC_SHA:
|
||||||
|
return "TLS_DH_anon_WITH_AES_128_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_RSA_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_RSA_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_DSS_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_DH_DSS_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_RSA_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_DH_RSA_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DHE_DSS_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_DHE_DSS_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DHE_RSA_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_DHE_RSA_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
|
case TLS_DH_anon_WITH_AES_256_CBC_SHA:
|
||||||
|
return "TLS_DH_anon_WITH_AES_256_CBC_SHA";
|
||||||
|
break;
|
||||||
/* SSL version 2.0 */
|
/* SSL version 2.0 */
|
||||||
case SSL_RSA_WITH_RC2_CBC_MD5:
|
case SSL_RSA_WITH_RC2_CBC_MD5:
|
||||||
return "SSL_RSA_WITH_RC2_CBC_MD5";
|
return "SSL_RSA_WITH_RC2_CBC_MD5";
|
||||||
@@ -588,13 +626,47 @@ CF_INLINE const char *TLSCipherNameForNumber(SSLCipherSuite cipher) {
|
|||||||
return "TLS_NULL_WITH_NULL_NULL";
|
return "TLS_NULL_WITH_NULL_NULL";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CF_INLINE bool IsRunningMountainLionOrLater(void)
|
||||||
|
{
|
||||||
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
|
int mib[2];
|
||||||
|
char *os_version;
|
||||||
|
size_t os_version_len;
|
||||||
|
char *os_version_major/*, *os_version_minor, *os_version_point*/;
|
||||||
|
int os_version_major_int;
|
||||||
|
|
||||||
|
/* Get the Darwin kernel version from the kernel using sysctl(): */
|
||||||
|
mib[0] = CTL_KERN;
|
||||||
|
mib[1] = KERN_OSRELEASE;
|
||||||
|
if(sysctl(mib, 2, NULL, &os_version_len, NULL, 0) == -1)
|
||||||
|
return false;
|
||||||
|
os_version = malloc(os_version_len*sizeof(char));
|
||||||
|
if(!os_version)
|
||||||
|
return false;
|
||||||
|
if(sysctl(mib, 2, os_version, &os_version_len, NULL, 0) == -1) {
|
||||||
|
free(os_version);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Parse the version. If it's version 12.0.0 or later, then this user is
|
||||||
|
using Mountain Lion. */
|
||||||
|
os_version_major = strtok(os_version, ".");
|
||||||
|
/*os_version_minor = strtok(NULL, ".");
|
||||||
|
os_version_point = strtok(NULL, ".");*/
|
||||||
|
os_version_major_int = atoi(os_version_major);
|
||||||
|
free(os_version);
|
||||||
|
return os_version_major_int >= 12;
|
||||||
|
#else
|
||||||
|
return true; /* iOS users: this doesn't concern you */
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
||||||
int sockindex)
|
int sockindex)
|
||||||
{
|
{
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
curl_socket_t sockfd = conn->sock[sockindex];
|
curl_socket_t sockfd = conn->sock[sockindex];
|
||||||
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
||||||
bool sni = true;
|
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
struct in6_addr addr;
|
struct in6_addr addr;
|
||||||
#else
|
#else
|
||||||
@@ -614,7 +686,8 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#if TARGET_OS_EMBEDDED == 0 /* the older API does not exist on iOS */
|
/* The old ST API does not exist under iOS, so don't compile it: */
|
||||||
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
if(connssl->ssl_ctx)
|
if(connssl->ssl_ctx)
|
||||||
(void)SSLDisposeContext(connssl->ssl_ctx);
|
(void)SSLDisposeContext(connssl->ssl_ctx);
|
||||||
err = SSLNewContext(false, &(connssl->ssl_ctx));
|
err = SSLNewContext(false, &(connssl->ssl_ctx));
|
||||||
@@ -622,7 +695,7 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
failf(data, "SSL: couldn't create a context: OSStatus %d", err);
|
failf(data, "SSL: couldn't create a context: OSStatus %d", err);
|
||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
#endif /* TARGET_OS_EMBEDDED == 0 */
|
#endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if(connssl->ssl_ctx)
|
if(connssl->ssl_ctx)
|
||||||
@@ -656,7 +729,7 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#if TARGET_OS_EMBEDDED == 0
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
(void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
|
(void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx,
|
||||||
kSSLProtocolAll,
|
kSSLProtocolAll,
|
||||||
false);
|
false);
|
||||||
@@ -697,7 +770,7 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
true);
|
true);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
#endif /* TARGET_OS_EMBEDDED == 0 */
|
#endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
(void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx, kSSLProtocolAll, false);
|
(void)SSLSetProtocolVersionEnabled(connssl->ssl_ctx, kSSLProtocolAll, false);
|
||||||
@@ -737,7 +810,14 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
* anyway. In the latter case the result of the verification is checked with
|
* anyway. In the latter case the result of the verification is checked with
|
||||||
* SSL_get_verify_result() below. */
|
* SSL_get_verify_result() below. */
|
||||||
#if defined(__MAC_10_6) || defined(__IPHONE_5_0)
|
#if defined(__MAC_10_6) || defined(__IPHONE_5_0)
|
||||||
if(SSLSetSessionOption != NULL) {
|
/* Snow Leopard introduced the SSLSetSessionOption() function, but due to
|
||||||
|
a library bug with the way the kSSLSessionOptionBreakOnServerAuth flag
|
||||||
|
works, it doesn't work as expected under Snow Leopard or Lion.
|
||||||
|
So we need to call SSLSetEnableCertVerify() on those older cats in order
|
||||||
|
to disable certificate validation if the user turned that off.
|
||||||
|
(SecureTransport will always validate the certificate chain by
|
||||||
|
default.) */
|
||||||
|
if(SSLSetSessionOption != NULL && IsRunningMountainLionOrLater()) {
|
||||||
err = SSLSetSessionOption(connssl->ssl_ctx,
|
err = SSLSetSessionOption(connssl->ssl_ctx,
|
||||||
kSSLSessionOptionBreakOnServerAuth,
|
kSSLSessionOptionBreakOnServerAuth,
|
||||||
data->set.ssl.verifypeer?false:true);
|
data->set.ssl.verifypeer?false:true);
|
||||||
@@ -747,14 +827,14 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#if TARGET_OS_EMBEDDED == 0
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
err = SSLSetEnableCertVerify(connssl->ssl_ctx,
|
err = SSLSetEnableCertVerify(connssl->ssl_ctx,
|
||||||
data->set.ssl.verifypeer?true:false);
|
data->set.ssl.verifypeer?true:false);
|
||||||
if(err != noErr) {
|
if(err != noErr) {
|
||||||
failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
|
failf(data, "SSL: SSLSetEnableCertVerify() failed: OSStatus %d", err);
|
||||||
return CURLE_SSL_CONNECT_ERROR;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
}
|
}
|
||||||
#endif /* TARGET_OS_EMBEDDED == 0 */
|
#endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
err = SSLSetEnableCertVerify(connssl->ssl_ctx,
|
err = SSLSetEnableCertVerify(connssl->ssl_ctx,
|
||||||
@@ -765,12 +845,14 @@ static CURLcode darwinssl_connect_step1(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
#endif /* defined(__MAC_10_6) || defined(__IPHONE_5_0) */
|
#endif /* defined(__MAC_10_6) || defined(__IPHONE_5_0) */
|
||||||
|
|
||||||
|
/* If this is a domain name and not an IP address, then configure SNI.
|
||||||
|
* Also: the verifyhost setting influences SNI usage */
|
||||||
/* If this is a domain name and not an IP address, then configure SNI: */
|
/* If this is a domain name and not an IP address, then configure SNI: */
|
||||||
if((0 == Curl_inet_pton(AF_INET, conn->host.name, &addr)) &&
|
if((0 == Curl_inet_pton(AF_INET, conn->host.name, &addr)) &&
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
(0 == Curl_inet_pton(AF_INET6, conn->host.name, &addr)) &&
|
(0 == Curl_inet_pton(AF_INET6, conn->host.name, &addr)) &&
|
||||||
#endif
|
#endif
|
||||||
sni) {
|
data->set.ssl.verifyhost) {
|
||||||
err = SSLSetPeerDomainName(connssl->ssl_ctx, conn->host.name,
|
err = SSLSetPeerDomainName(connssl->ssl_ctx, conn->host.name,
|
||||||
strlen(conn->host.name));
|
strlen(conn->host.name));
|
||||||
if(err != noErr) {
|
if(err != noErr) {
|
||||||
@@ -824,7 +906,6 @@ darwinssl_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
connssl->connecting_state = connssl->ssl_direction ?
|
connssl->connecting_state = connssl->ssl_direction ?
|
||||||
ssl_connect_2_writing : ssl_connect_2_reading;
|
ssl_connect_2_writing : ssl_connect_2_reading;
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
break;
|
|
||||||
|
|
||||||
case errSSLServerAuthCompleted:
|
case errSSLServerAuthCompleted:
|
||||||
/* the documentation says we need to call SSLHandshake() again */
|
/* the documentation says we need to call SSLHandshake() again */
|
||||||
@@ -836,13 +917,16 @@ darwinssl_connect_step2(struct connectdata *conn, int sockindex)
|
|||||||
case errSSLCertExpired:
|
case errSSLCertExpired:
|
||||||
failf(data, "SSL certificate problem: OSStatus %d", err);
|
failf(data, "SSL certificate problem: OSStatus %d", err);
|
||||||
return CURLE_SSL_CACERT;
|
return CURLE_SSL_CACERT;
|
||||||
break;
|
|
||||||
|
case errSSLHostNameMismatch:
|
||||||
|
failf(data, "SSL certificate peer verification failed, the "
|
||||||
|
"certificate did not match \"%s\"\n", conn->host.dispname);
|
||||||
|
return CURLE_PEER_FAILED_VERIFICATION;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
failf(data, "Unknown SSL protocol error in connection to %s:%d",
|
failf(data, "Unknown SSL protocol error in connection to %s:%d",
|
||||||
conn->host.name, err);
|
conn->host.name, err);
|
||||||
return CURLE_SSL_CONNECT_ERROR;
|
return CURLE_SSL_CONNECT_ERROR;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -902,7 +986,7 @@ darwinssl_connect_step3(struct connectdata *conn,
|
|||||||
* Well, okay, if verbose mode is on, let's print the details of the
|
* Well, okay, if verbose mode is on, let's print the details of the
|
||||||
* server certificates. */
|
* server certificates. */
|
||||||
#if defined(__MAC_10_7) || defined(__IPHONE_5_0)
|
#if defined(__MAC_10_7) || defined(__IPHONE_5_0)
|
||||||
if(SecTrustEvaluateAsync != NULL) {
|
#if (TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)
|
||||||
#pragma unused(server_certs)
|
#pragma unused(server_certs)
|
||||||
err = SSLCopyPeerTrust(connssl->ssl_ctx, &trust);
|
err = SSLCopyPeerTrust(connssl->ssl_ctx, &trust);
|
||||||
if(err == noErr) {
|
if(err == noErr) {
|
||||||
@@ -921,9 +1005,35 @@ darwinssl_connect_step3(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
CFRelease(trust);
|
CFRelease(trust);
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
/* SSLCopyPeerCertificates() is deprecated as of Mountain Lion.
|
||||||
|
The function SecTrustGetCertificateAtIndex() is officially present
|
||||||
|
in Lion, but it is unfortunately also present in Snow Leopard as
|
||||||
|
private API and doesn't work as expected. So we have to look for
|
||||||
|
a different symbol to make sure this code is only executed under
|
||||||
|
Lion or later. */
|
||||||
|
if(SecTrustEvaluateAsync != NULL) {
|
||||||
|
#pragma unused(server_certs)
|
||||||
|
err = SSLCopyPeerTrust(connssl->ssl_ctx, &trust);
|
||||||
|
if(err == noErr) {
|
||||||
|
count = SecTrustGetCertificateCount(trust);
|
||||||
|
for(i = 0L ; i < count ; i++) {
|
||||||
|
server_cert = SecTrustGetCertificateAtIndex(trust, i);
|
||||||
|
server_cert_summary =
|
||||||
|
SecCertificateCopyLongDescription(NULL, server_cert, NULL);
|
||||||
|
memset(server_cert_summary_c, 0, 128);
|
||||||
|
if(CFStringGetCString(server_cert_summary,
|
||||||
|
server_cert_summary_c,
|
||||||
|
128,
|
||||||
|
kCFStringEncodingUTF8)) {
|
||||||
|
infof(data, "Server certificate: %s\n", server_cert_summary_c);
|
||||||
|
}
|
||||||
|
CFRelease(server_cert_summary);
|
||||||
|
}
|
||||||
|
CFRelease(trust);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
#if TARGET_OS_EMBEDDED == 0
|
|
||||||
err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
|
err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
|
||||||
if(err == noErr) {
|
if(err == noErr) {
|
||||||
count = CFArrayGetCount(server_certs);
|
count = CFArrayGetCount(server_certs);
|
||||||
@@ -943,8 +1053,8 @@ darwinssl_connect_step3(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
CFRelease(server_certs);
|
CFRelease(server_certs);
|
||||||
}
|
}
|
||||||
#endif /* TARGET_OS_EMBEDDED == 0 */
|
|
||||||
}
|
}
|
||||||
|
#endif /* (TARGET_OS_EMBEDDED || TARGET_OS_IPHONE) */
|
||||||
#else
|
#else
|
||||||
#pragma unused(trust)
|
#pragma unused(trust)
|
||||||
err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
|
err = SSLCopyPeerCertificates(connssl->ssl_ctx, &server_certs);
|
||||||
@@ -1120,10 +1230,10 @@ void Curl_darwinssl_close(struct connectdata *conn, int sockindex)
|
|||||||
#if defined(__MAC_10_8) || defined(__IPHONE_5_0)
|
#if defined(__MAC_10_8) || defined(__IPHONE_5_0)
|
||||||
if(SSLCreateContext != NULL)
|
if(SSLCreateContext != NULL)
|
||||||
CFRelease(connssl->ssl_ctx);
|
CFRelease(connssl->ssl_ctx);
|
||||||
#if TARGET_OS_EMBEDDED == 0
|
#if (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE))
|
||||||
else
|
else
|
||||||
(void)SSLDisposeContext(connssl->ssl_ctx);
|
(void)SSLDisposeContext(connssl->ssl_ctx);
|
||||||
#endif /* TARGET_OS_EMBEDDED == 0 */
|
#endif /* (TARGET_OS_MAC && !(TARGET_OS_EMBEDDED || TARGET_OS_IPHONE)) */
|
||||||
#else
|
#else
|
||||||
(void)SSLDisposeContext(connssl->ssl_ctx);
|
(void)SSLDisposeContext(connssl->ssl_ctx);
|
||||||
#endif /* defined(__MAC_10_8) || defined(__IPHONE_5_0) */
|
#endif /* defined(__MAC_10_8) || defined(__IPHONE_5_0) */
|
||||||
@@ -1262,7 +1372,7 @@ void Curl_darwinssl_md5sum(unsigned char *tmp, /* input */
|
|||||||
size_t md5len)
|
size_t md5len)
|
||||||
{
|
{
|
||||||
(void)md5len;
|
(void)md5len;
|
||||||
(void)CC_MD5(tmp, tmplen, md5sum);
|
(void)CC_MD5(tmp, (CC_LONG)tmplen, md5sum);
|
||||||
}
|
}
|
||||||
|
|
||||||
static ssize_t darwinssl_send(struct connectdata *conn,
|
static ssize_t darwinssl_send(struct connectdata *conn,
|
||||||
@@ -1273,12 +1383,14 @@ static ssize_t darwinssl_send(struct connectdata *conn,
|
|||||||
{
|
{
|
||||||
/*struct SessionHandle *data = conn->data;*/
|
/*struct SessionHandle *data = conn->data;*/
|
||||||
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
struct ssl_connect_data *connssl = &conn->ssl[sockindex];
|
||||||
size_t processed;
|
size_t processed = 0UL;
|
||||||
OSStatus err = SSLWrite(connssl->ssl_ctx, mem, len, &processed);
|
OSStatus err = SSLWrite(connssl->ssl_ctx, mem, len, &processed);
|
||||||
|
|
||||||
if(err != noErr) {
|
if(err != noErr) {
|
||||||
switch (err) {
|
switch (err) {
|
||||||
case errSSLWouldBlock: /* we're not done yet; keep sending */
|
case errSSLWouldBlock: /* return how much we sent (if anything) */
|
||||||
|
if(processed)
|
||||||
|
return (ssize_t)processed;
|
||||||
*curlcode = CURLE_AGAIN;
|
*curlcode = CURLE_AGAIN;
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
@@ -1301,16 +1413,23 @@ static ssize_t darwinssl_recv(struct connectdata *conn,
|
|||||||
{
|
{
|
||||||
/*struct SessionHandle *data = conn->data;*/
|
/*struct SessionHandle *data = conn->data;*/
|
||||||
struct ssl_connect_data *connssl = &conn->ssl[num];
|
struct ssl_connect_data *connssl = &conn->ssl[num];
|
||||||
size_t processed;
|
size_t processed = 0UL;
|
||||||
OSStatus err = SSLRead(connssl->ssl_ctx, buf, buffersize, &processed);
|
OSStatus err = SSLRead(connssl->ssl_ctx, buf, buffersize, &processed);
|
||||||
|
|
||||||
if(err != noErr) {
|
if(err != noErr) {
|
||||||
switch (err) {
|
switch (err) {
|
||||||
case errSSLWouldBlock: /* we're not done yet; keep reading */
|
case errSSLWouldBlock: /* return how much we read (if anything) */
|
||||||
|
if(processed)
|
||||||
|
return (ssize_t)processed;
|
||||||
*curlcode = CURLE_AGAIN;
|
*curlcode = CURLE_AGAIN;
|
||||||
return -1;
|
return -1;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case errSSLClosedGraceful: /* they're done; fail gracefully */
|
||||||
|
*curlcode = CURLE_OK;
|
||||||
|
return -1;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
failf(conn->data, "SSLRead() return error %d", err);
|
failf(conn->data, "SSLRead() return error %d", err);
|
||||||
*curlcode = CURLE_RECV_ERROR;
|
*curlcode = CURLE_RECV_ERROR;
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_DARWINSSL
|
#ifdef USE_DARWINSSL
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include "curl_fnmatch.h"
|
#include "curl_fnmatch.h"
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,11 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
# include <unistd.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "curl_gethostname.h"
|
#include "curl_gethostname.h"
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_GSSAPI
|
#ifdef HAVE_GSSAPI
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
|
|
||||||
#ifdef HAVE_GSSAPI
|
#ifdef HAVE_GSSAPI
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
#ifndef __CURL_LDAP_H
|
#ifndef HEADER_CURL_LDAP_H
|
||||||
#define __CURL_LDAP_H
|
#define HEADER_CURL_LDAP_H
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -32,4 +31,5 @@ extern const struct Curl_handler Curl_handler_ldaps;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif /* __CURL_LDAP_H */
|
#endif /* HEADER_CURL_LDAP_H */
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
/* NSS crypto library does not provide the MD4 hash algorithm, so that we have
|
/* NSS crypto library does not provide the MD4 hash algorithm, so that we have
|
||||||
* a local implementation of it */
|
* a local implementation of it */
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include "curl_memrchr.h"
|
#include "curl_memrchr.h"
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef HAVE_MEMRCHR
|
#ifdef HAVE_MEMRCHR
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_WIN32_IDN) || (defined(USE_WINDOWS_SSPI) && defined(UNICODE))
|
#if defined(USE_WIN32_IDN) || (defined(USE_WINDOWS_SSPI) && defined(UNICODE))
|
||||||
|
|
||||||
|
|||||||
@@ -21,7 +21,7 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_WIN32_IDN) || (defined(USE_WINDOWS_SSPI) && defined(UNICODE))
|
#if defined(USE_WIN32_IDN) || (defined(USE_WINDOWS_SSPI) && defined(UNICODE))
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_NTLM
|
#ifdef USE_NTLM
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_NTLM
|
#ifdef USE_NTLM
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_NTLM) && !defined(USE_WINDOWS_SSPI)
|
#if defined(USE_NTLM) && !defined(USE_WINDOWS_SSPI)
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_NTLM) && !defined(USE_WINDOWS_SSPI)
|
#if defined(USE_NTLM) && !defined(USE_WINDOWS_SSPI)
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_NTLM
|
#ifdef USE_NTLM
|
||||||
|
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_NTLM
|
#ifdef USE_NTLM
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2011, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_NTLM) && defined(NTLM_WB_ENABLED)
|
#if defined(USE_NTLM) && defined(NTLM_WB_ENABLED)
|
||||||
|
|
||||||
@@ -33,9 +33,6 @@
|
|||||||
|
|
||||||
#define DEBUG_ME 0
|
#define DEBUG_ME 0
|
||||||
|
|
||||||
#ifdef HAVE_UNISTD_H
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
#ifdef HAVE_SYS_WAIT_H
|
#ifdef HAVE_SYS_WAIT_H
|
||||||
#include <sys/wait.h>
|
#include <sys/wait.h>
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#if defined(USE_NTLM) && defined(NTLM_WB_ENABLED)
|
#if defined(USE_NTLM) && defined(NTLM_WB_ENABLED)
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_LIBRTMP
|
#ifdef USE_LIBRTMP
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2012-2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -20,11 +20,12 @@
|
|||||||
*
|
*
|
||||||
* RFC2195 CRAM-MD5 authentication
|
* RFC2195 CRAM-MD5 authentication
|
||||||
* RFC2831 DIGEST-MD5 authentication
|
* RFC2831 DIGEST-MD5 authentication
|
||||||
|
* RFC4422 Simple Authentication and Security Layer (SASL)
|
||||||
* RFC4616 PLAIN authentication
|
* RFC4616 PLAIN authentication
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
@@ -345,9 +346,7 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data,
|
|||||||
snprintf(&HA1_hex[2 * i], 3, "%02x", digest[i]);
|
snprintf(&HA1_hex[2 * i], 3, "%02x", digest[i]);
|
||||||
|
|
||||||
/* Prepare the URL string */
|
/* Prepare the URL string */
|
||||||
strcpy(uri, service);
|
snprintf(uri, sizeof(uri), "%s/%s", service, realm);
|
||||||
strcat(uri, "/");
|
|
||||||
strcat(uri, realm);
|
|
||||||
|
|
||||||
/* Calculate H(A2) */
|
/* Calculate H(A2) */
|
||||||
ctxt = Curl_MD5_init(Curl_DIGEST_MD5);
|
ctxt = Curl_MD5_init(Curl_DIGEST_MD5);
|
||||||
@@ -391,20 +390,11 @@ CURLcode Curl_sasl_create_digest_md5_message(struct SessionHandle *data,
|
|||||||
for(i = 0; i < MD5_DIGEST_LEN; i++)
|
for(i = 0; i < MD5_DIGEST_LEN; i++)
|
||||||
snprintf(&resp_hash_hex[2 * i], 3, "%02x", digest[i]);
|
snprintf(&resp_hash_hex[2 * i], 3, "%02x", digest[i]);
|
||||||
|
|
||||||
strcpy(response, "username=\"");
|
snprintf(response, sizeof(response),
|
||||||
strcat(response, userp);
|
"username=\"%s\",realm=\"%s\",nonce=\"%s\","
|
||||||
strcat(response, "\",realm=\"");
|
"cnonce=\"%s\",nc=\"%s\",digest-uri=\"%s\",response=%s",
|
||||||
strcat(response, realm);
|
userp, realm, nonce,
|
||||||
strcat(response, "\",nonce=\"");
|
cnonce, nonceCount, uri, resp_hash_hex);
|
||||||
strcat(response, nonce);
|
|
||||||
strcat(response, "\",cnonce=\"");
|
|
||||||
strcat(response, cnonce);
|
|
||||||
strcat(response, "\",nc=");
|
|
||||||
strcat(response, nonceCount);
|
|
||||||
strcat(response, ",digest-uri=\"");
|
|
||||||
strcat(response, uri);
|
|
||||||
strcat(response, "\",response=");
|
|
||||||
strcat(response, resp_hash_hex);
|
|
||||||
|
|
||||||
/* Base64 encode the reply */
|
/* Base64 encode the reply */
|
||||||
return Curl_base64_encode(data, response, 0, outptr, outlen);
|
return Curl_base64_encode(data, response, 0, outptr, outlen);
|
||||||
|
|||||||
@@ -5,9 +5,9 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 2012, Marc Hoersken, <info@marc-hoersken.de>, et al.
|
* Copyright (C) 2012 - 2013, Marc Hoersken, <info@marc-hoersken.de>
|
||||||
* Copyright (C) 2012, Mark Salisbury, <mark.salisbury@hp.com>
|
* Copyright (C) 2012, Mark Salisbury, <mark.salisbury@hp.com>
|
||||||
* Copyright (C) 2012, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 2012 - 2013, Daniel Stenberg, <daniel@haxx.se>, et al.
|
||||||
*
|
*
|
||||||
* This software is licensed as described in the file COPYING, which
|
* This software is licensed as described in the file COPYING, which
|
||||||
* you should have received as part of this distribution. The terms
|
* you should have received as part of this distribution. The terms
|
||||||
@@ -51,7 +51,7 @@
|
|||||||
* http://msdn.microsoft.com/en-us/library/windows/desktop/aa380161.aspx
|
* http://msdn.microsoft.com/en-us/library/windows/desktop/aa380161.aspx
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "setup.h"
|
#include "curl_setup.h"
|
||||||
|
|
||||||
#ifdef USE_SCHANNEL
|
#ifdef USE_SCHANNEL
|
||||||
|
|
||||||
@@ -156,14 +156,22 @@ schannel_connect_step1(struct connectdata *conn, int sockindex)
|
|||||||
infof(data, "schannel: disable server certificate revocation checks\n");
|
infof(data, "schannel: disable server certificate revocation checks\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
if(Curl_inet_pton(AF_INET, conn->host.name, &addr) ||
|
if(Curl_inet_pton(AF_INET, conn->host.name, &addr)
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
Curl_inet_pton(AF_INET6, conn->host.name, &addr6) ||
|
|| Curl_inet_pton(AF_INET6, conn->host.name, &addr6)
|
||||||
#endif
|
#endif
|
||||||
data->set.ssl.verifyhost < 2) {
|
) {
|
||||||
schannel_cred.dwFlags |= SCH_CRED_NO_SERVERNAME_CHECK;
|
schannel_cred.dwFlags |= SCH_CRED_NO_SERVERNAME_CHECK;
|
||||||
infof(data, "schannel: using IP address, disable SNI servername "
|
infof(data, "schannel: using IP address, SNI is being disabled by "
|
||||||
"check\n");
|
"disabling the servername check against the "
|
||||||
|
"subject names in server certificates.\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!data->set.ssl.verifyhost) {
|
||||||
|
schannel_cred.dwFlags |= SCH_CRED_NO_SERVERNAME_CHECK;
|
||||||
|
infof(data, "schannel: verifyhost setting prevents Schannel from "
|
||||||
|
"comparing the supplied target name with the subject "
|
||||||
|
"names in server certificates. Also disables SNI.\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
switch(data->set.ssl.version) {
|
switch(data->set.ssl.version) {
|
||||||
@@ -211,8 +219,8 @@ schannel_connect_step1(struct connectdata *conn, int sockindex)
|
|||||||
|
|
||||||
/* setup request flags */
|
/* setup request flags */
|
||||||
connssl->req_flags = ISC_REQ_SEQUENCE_DETECT | ISC_REQ_REPLAY_DETECT |
|
connssl->req_flags = ISC_REQ_SEQUENCE_DETECT | ISC_REQ_REPLAY_DETECT |
|
||||||
ISC_REQ_CONFIDENTIALITY | ISC_REQ_EXTENDED_ERROR |
|
ISC_REQ_CONFIDENTIALITY | ISC_REQ_ALLOCATE_MEMORY |
|
||||||
ISC_REQ_ALLOCATE_MEMORY | ISC_REQ_STREAM;
|
ISC_REQ_STREAM;
|
||||||
|
|
||||||
/* allocate memory for the security context handle */
|
/* allocate memory for the security context handle */
|
||||||
connssl->ctxt = malloc(sizeof(struct curl_schannel_ctxt));
|
connssl->ctxt = malloc(sizeof(struct curl_schannel_ctxt));
|
||||||
@@ -495,8 +503,6 @@ schannel_connect_step3(struct connectdata *conn, int sockindex)
|
|||||||
failf(data, "schannel: failed to setup replay detection");
|
failf(data, "schannel: failed to setup replay detection");
|
||||||
if(!(connssl->ret_flags & ISC_RET_CONFIDENTIALITY))
|
if(!(connssl->ret_flags & ISC_RET_CONFIDENTIALITY))
|
||||||
failf(data, "schannel: failed to setup confidentiality");
|
failf(data, "schannel: failed to setup confidentiality");
|
||||||
if(!(connssl->ret_flags & ISC_RET_EXTENDED_ERROR))
|
|
||||||
failf(data, "schannel: failed to setup extended errors");
|
|
||||||
if(!(connssl->ret_flags & ISC_RET_ALLOCATED_MEMORY))
|
if(!(connssl->ret_flags & ISC_RET_ALLOCATED_MEMORY))
|
||||||
failf(data, "schannel: failed to setup memory allocation");
|
failf(data, "schannel: failed to setup memory allocation");
|
||||||
if(!(connssl->ret_flags & ISC_RET_STREAM))
|
if(!(connssl->ret_flags & ISC_RET_STREAM))
|
||||||
@@ -1238,10 +1244,7 @@ static CURLcode verify_certificate(struct connectdata *conn, int sockindex)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if(result == CURLE_OK) {
|
if(result == CURLE_OK) {
|
||||||
if(data->set.ssl.verifyhost == 1) {
|
if(data->set.ssl.verifyhost) {
|
||||||
infof(data, "warning: ignoring unsupported value (1) ssl.verifyhost\n");
|
|
||||||
}
|
|
||||||
else if(data->set.ssl.verifyhost == 2) {
|
|
||||||
TCHAR cert_hostname_buff[128];
|
TCHAR cert_hostname_buff[128];
|
||||||
xcharp_u hostname;
|
xcharp_u hostname;
|
||||||
xcharp_u cert_hostname;
|
xcharp_u cert_hostname;
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user