Compare commits
431 Commits
curl-7_23_
...
curl-7_26_
Author | SHA1 | Date | |
---|---|---|---|
![]() |
c262c35676 | ||
![]() |
ef60fdbd73 | ||
![]() |
b1f081f6e6 | ||
![]() |
6cc066a2c5 | ||
![]() |
0fd7fa7daf | ||
![]() |
9258b84673 | ||
![]() |
fdf2517bd9 | ||
![]() |
cc36756aa2 | ||
![]() |
1c58f291cc | ||
![]() |
8ae1e657e8 | ||
![]() |
7ba07c80a1 | ||
![]() |
fec096f153 | ||
![]() |
499ffe2f8c | ||
![]() |
cf41ee3ac9 | ||
![]() |
e315927a1a | ||
![]() |
03c1bcf4bd | ||
![]() |
92f841aef7 | ||
![]() |
9fafa68533 | ||
![]() |
e7257dcf2e | ||
![]() |
3ebcfdda36 | ||
![]() |
77bac26587 | ||
![]() |
d6773834f2 | ||
![]() |
6f998400d9 | ||
![]() |
64f48e884e | ||
![]() |
e146a5f132 | ||
![]() |
1beda0cbb7 | ||
![]() |
72b72fe8ed | ||
![]() |
bd9eb30ffd | ||
![]() |
dd18e714ff | ||
![]() |
d6c449e3b4 | ||
![]() |
071f8d4182 | ||
![]() |
d83233501f | ||
![]() |
419a50f817 | ||
![]() |
975d23480c | ||
![]() |
13211705cd | ||
![]() |
9ec0b7e0c4 | ||
![]() |
412510f974 | ||
![]() |
683bfa60ad | ||
![]() |
77172a242f | ||
![]() |
46cd5f1dad | ||
![]() |
2976de4808 | ||
![]() |
560cd62272 | ||
![]() |
0f54880277 | ||
![]() |
5cd524df18 | ||
![]() |
94111bbbd4 | ||
![]() |
df4205c10a | ||
![]() |
9421b06397 | ||
![]() |
09690be8de | ||
![]() |
ce8a321dd0 | ||
![]() |
3833765ba5 | ||
![]() |
4d28a59fc2 | ||
![]() |
a498daa0e0 | ||
![]() |
bd12c44d35 | ||
![]() |
4c385cf896 | ||
![]() |
7d4ed0b10e | ||
![]() |
48d13b44c6 | ||
![]() |
8b63b48627 | ||
![]() |
b9ac64c2cb | ||
![]() |
4d2c3f0a4d | ||
![]() |
c156b916a4 | ||
![]() |
865893fb14 | ||
![]() |
a60edcc6d4 | ||
![]() |
20cb12db8d | ||
![]() |
42aa796150 | ||
![]() |
2a902738fb | ||
![]() |
bb5d4234e3 | ||
![]() |
930781e168 | ||
![]() |
1c3a99b52c | ||
![]() |
5f04843e5b | ||
![]() |
8c29bf5640 | ||
![]() |
82306ebfba | ||
![]() |
03d4b9f078 | ||
![]() |
51114f07f1 | ||
![]() |
e19917296f | ||
![]() |
8ed40acac6 | ||
![]() |
38ae6ec1a2 | ||
![]() |
9e24b9c7af | ||
![]() |
a144bb8b76 | ||
![]() |
4d3fb91fb4 | ||
![]() |
bbfe118209 | ||
![]() |
e5c14674f0 | ||
![]() |
6dba7608bf | ||
![]() |
21423497ef | ||
![]() |
01b0f1061d | ||
![]() |
3d8c093145 | ||
![]() |
919c97fa65 | ||
![]() |
376b4d48fe | ||
![]() |
118e73306d | ||
![]() |
1dd69921d3 | ||
![]() |
29e68b200c | ||
![]() |
0b516b7162 | ||
![]() |
a0b3535735 | ||
![]() |
5e852ab9d1 | ||
![]() |
f9bb5d2984 | ||
![]() |
ad595c3ba9 | ||
![]() |
7031ff23bb | ||
![]() |
9753c6bec5 | ||
![]() |
b16e3da12a | ||
![]() |
e7661d198f | ||
![]() |
13c7b91133 | ||
![]() |
950b0b770e | ||
![]() |
15e1227ed4 | ||
![]() |
ddfe821bcf | ||
![]() |
54866b68cd | ||
![]() |
05a443adf2 | ||
![]() |
ebf315e6f3 | ||
![]() |
c44d45db86 | ||
![]() |
7a2647e162 | ||
![]() |
9bae9ddad9 | ||
![]() |
004d7251ab | ||
![]() |
33d044a862 | ||
![]() |
a9086e8a4b | ||
![]() |
761c3c5446 | ||
![]() |
66c0e26e28 | ||
![]() |
7d1b715605 | ||
![]() |
9f494fe423 | ||
![]() |
809c809281 | ||
![]() |
0580b60622 | ||
![]() |
4bdb664c33 | ||
![]() |
459435dca1 | ||
![]() |
3fdb7808ef | ||
![]() |
97ff646fc1 | ||
![]() |
9801596fb3 | ||
![]() |
982315573c | ||
![]() |
9f96e6da28 | ||
![]() |
01690ed2bc | ||
![]() |
2da89708ec | ||
![]() |
5c62a551c4 | ||
![]() |
602a8a565c | ||
![]() |
c4a8446c70 | ||
![]() |
456d8db35e | ||
![]() |
e952a7e710 | ||
![]() |
682f0840e7 | ||
![]() |
f85ec43f24 | ||
![]() |
b5713887ae | ||
![]() |
c1babfad8a | ||
![]() |
b8b2cf612b | ||
![]() |
fe93b0a874 | ||
![]() |
e8a32438c2 | ||
![]() |
97b66ebefe | ||
![]() |
d2e5222ebc | ||
![]() |
3aab542e77 | ||
![]() |
3c80309c27 | ||
![]() |
c83de6d076 | ||
![]() |
805788e043 | ||
![]() |
dddcd3b042 | ||
![]() |
c6825b7a6b | ||
![]() |
e6a89cb6c4 | ||
![]() |
fe7613932e | ||
![]() |
ffb67599b3 | ||
![]() |
47236d89c0 | ||
![]() |
ad77420ac7 | ||
![]() |
804da995c5 | ||
![]() |
ede9ad43fc | ||
![]() |
0c8e36c18a | ||
![]() |
862bb7bade | ||
![]() |
b329fc7023 | ||
![]() |
8af4b657d0 | ||
![]() |
97386c3c84 | ||
![]() |
e25590a2b3 | ||
![]() |
79afcbefb4 | ||
![]() |
e650dbde86 | ||
![]() |
b50e9e9e9e | ||
![]() |
9f0e1689f1 | ||
![]() |
f7e2ab629e | ||
![]() |
2764bf2c5b | ||
![]() |
41b0237834 | ||
![]() |
cabd010dd4 | ||
![]() |
c55a0809bb | ||
![]() |
4ee2df4b46 | ||
![]() |
4d71d1b17f | ||
![]() |
d185960a6d | ||
![]() |
79b6f4a2d3 | ||
![]() |
5430007222 | ||
![]() |
779fa13ef9 | ||
![]() |
1a7bba1975 | ||
![]() |
21130dab4f | ||
![]() |
c3cae332c5 | ||
![]() |
9954242980 | ||
![]() |
2f1ad7d6e2 | ||
![]() |
30c44edad3 | ||
![]() |
77a21ff623 | ||
![]() |
035ef06bda | ||
![]() |
3d98aed5b3 | ||
![]() |
4cf742f34f | ||
![]() |
4bf3131979 | ||
![]() |
5c409d03ec | ||
![]() |
a053560cfa | ||
![]() |
674699b212 | ||
![]() |
154c0d4b93 | ||
![]() |
b685481d52 | ||
![]() |
0cf0ab6f30 | ||
![]() |
ee7e4fc1d1 | ||
![]() |
0201280533 | ||
![]() |
69406f0be7 | ||
![]() |
ea4ceca222 | ||
![]() |
714accd090 | ||
![]() |
35e965c9a0 | ||
![]() |
2b26eb9857 | ||
![]() |
e71ac0c6fa | ||
![]() |
7ed25fcc5c | ||
![]() |
ecc93caaeb | ||
![]() |
ebf3138992 | ||
![]() |
8ef8a2b5ac | ||
![]() |
62d15f159e | ||
![]() |
2a699bc6e9 | ||
![]() |
2a266c1c7c | ||
![]() |
705f0f7a5b | ||
![]() |
ea055407fa | ||
![]() |
4405039fdc | ||
![]() |
65103efe49 | ||
![]() |
466150bc64 | ||
![]() |
f710aa40b3 | ||
![]() |
f4d3c0cbfb | ||
![]() |
4d2737bcb2 | ||
![]() |
8ee2576b6f | ||
![]() |
575f3c30ed | ||
![]() |
cf9fb08ca4 | ||
![]() |
5a53409e2c | ||
![]() |
e277d3b52b | ||
![]() |
93e344bbf4 | ||
![]() |
75b6f7d9ef | ||
![]() |
a8e063b087 | ||
![]() |
70f71bb99f | ||
![]() |
c11c30a8c8 | ||
![]() |
75ca568fa1 | ||
![]() |
db1a856b4f | ||
![]() |
ee57e9dea6 | ||
![]() |
6e2fd2c9ea | ||
![]() |
5d7a319a55 | ||
![]() |
7883cd5af3 | ||
![]() |
d7af7de5b2 | ||
![]() |
a7e8f4aabc | ||
![]() |
e64d332e79 | ||
![]() |
00e615de7e | ||
![]() |
b2aaf3c2ad | ||
![]() |
c41f304c43 | ||
![]() |
d56b4c3f89 | ||
![]() |
d1becc3231 | ||
![]() |
f55f95d49c | ||
![]() |
61d31a3caf | ||
![]() |
4b9af77d54 | ||
![]() |
5d70a61b94 | ||
![]() |
51c485342b | ||
![]() |
4563eeb9f4 | ||
![]() |
2cafb0e97c | ||
![]() |
6ea7acf5a9 | ||
![]() |
a20daf90e3 | ||
![]() |
24526d0c0f | ||
![]() |
a752850acc | ||
![]() |
2b9fafd622 | ||
![]() |
0ce2bca741 | ||
![]() |
b15024be4d | ||
![]() |
21401840fa | ||
![]() |
e3e24e5b36 | ||
![]() |
18c6c8a5e7 | ||
![]() |
c731fc58ea | ||
![]() |
6d62c5a6fc | ||
![]() |
f1092b387e | ||
![]() |
8e82ef9c32 | ||
![]() |
d016f5f5f5 | ||
![]() |
d4bf87dc0e | ||
![]() |
54dede4166 | ||
![]() |
9f20379fe4 | ||
![]() |
123c92c904 | ||
![]() |
d28411c3cc | ||
![]() |
2705af6267 | ||
![]() |
f34ddb90e6 | ||
![]() |
dd69a3e868 | ||
![]() |
812fa73057 | ||
![]() |
52824ed1ab | ||
![]() |
4897f4e517 | ||
![]() |
81524cbfa0 | ||
![]() |
8ef7a5706e | ||
![]() |
c358bab809 | ||
![]() |
4bc6c1a026 | ||
![]() |
3a55daee3d | ||
![]() |
7bd2add06f | ||
![]() |
3b06f1fb36 | ||
![]() |
db4f69ef06 | ||
![]() |
277022b2e4 | ||
![]() |
0f8239d5b4 | ||
![]() |
a4202be655 | ||
![]() |
2f4a487a68 | ||
![]() |
82180643f4 | ||
![]() |
585b89a6c3 | ||
![]() |
cc69e56ce3 | ||
![]() |
8e25d1b93b | ||
![]() |
63e2718f8d | ||
![]() |
7f472618de | ||
![]() |
08107111ac | ||
![]() |
a3403db02f | ||
![]() |
c9a3cab6c4 | ||
![]() |
f4949e56eb | ||
![]() |
81ebdd9e28 | ||
![]() |
207cf15032 | ||
![]() |
5e0a44e4d5 | ||
![]() |
9e3f8c4850 | ||
![]() |
90343c76c6 | ||
![]() |
ecd75e8cb8 | ||
![]() |
e63c9f8ff3 | ||
![]() |
ed0364343d | ||
![]() |
5c0ad9581d | ||
![]() |
e99128a5c9 | ||
![]() |
33c2e1cafc | ||
![]() |
84f736981c | ||
![]() |
82c344a347 | ||
![]() |
9f7f6a62ff | ||
![]() |
98292bcdd0 | ||
![]() |
996f2454ba | ||
![]() |
99a12baa34 | ||
![]() |
4f8db8bf95 | ||
![]() |
5ac9ec7205 | ||
![]() |
f8cd217f04 | ||
![]() |
84e7ea2ffc | ||
![]() |
2caa454dc1 | ||
![]() |
3e4181f88e | ||
![]() |
e71e226f6b | ||
![]() |
b0eb963bc7 | ||
![]() |
2cf9e78a22 | ||
![]() |
430527a1d7 | ||
![]() |
1afbccc676 | ||
![]() |
1dd654644a | ||
![]() |
ba238e3a18 | ||
![]() |
4bb140bfc9 | ||
![]() |
926916e28e | ||
![]() |
3d6e2ec925 | ||
![]() |
380bade777 | ||
![]() |
26ce3ac328 | ||
![]() |
130fac6c16 | ||
![]() |
6222ef8052 | ||
![]() |
b06ed249d2 | ||
![]() |
377471f387 | ||
![]() |
dfdac61522 | ||
![]() |
c834213ad5 | ||
![]() |
5527417afa | ||
![]() |
bedfafe38e | ||
![]() |
e9040f2954 | ||
![]() |
51d4885ca0 | ||
![]() |
ce896875f8 | ||
![]() |
eb6e9593c4 | ||
![]() |
5c71544fc6 | ||
![]() |
7799ac434e | ||
![]() |
7cc2e8b349 | ||
![]() |
3c18b38dcc | ||
![]() |
1fc5cd6a1a | ||
![]() |
af9bc1604c | ||
![]() |
b235d5ade8 | ||
![]() |
ee3d3adc6f | ||
![]() |
583a902789 | ||
![]() |
7b8590d1f5 | ||
![]() |
9b185aac43 | ||
![]() |
34f9ec0c54 | ||
![]() |
7111ca6f5f | ||
![]() |
612a61b267 | ||
![]() |
cd4cd66839 | ||
![]() |
4c4e8ba1f0 | ||
![]() |
de6f4f356e | ||
![]() |
66c5076252 | ||
![]() |
b9b772fefe | ||
![]() |
07efe110cc | ||
![]() |
6e4835c795 | ||
![]() |
ba057c2e19 | ||
![]() |
1259ccf747 | ||
![]() |
07e3b7512c | ||
![]() |
50d88bf4b5 | ||
![]() |
1cacf853da | ||
![]() |
9dbe6565d4 | ||
![]() |
2b24dd870e | ||
![]() |
46724b87b7 | ||
![]() |
82a4d26e7f | ||
![]() |
2b0e09b0f9 | ||
![]() |
361cd03d58 | ||
![]() |
7e4daaf908 | ||
![]() |
3bbe219be2 | ||
![]() |
347f951c39 | ||
![]() |
c50dbf670f | ||
![]() |
0cf05af744 | ||
![]() |
d5b5f64bce | ||
![]() |
088ba97a24 | ||
![]() |
9109cdec11 | ||
![]() |
5971d401d4 | ||
![]() |
62d3652b43 | ||
![]() |
d81f5ea3e0 | ||
![]() |
adc88ca203 | ||
![]() |
83350c9cc4 | ||
![]() |
bdb647814e | ||
![]() |
c92234c3bc | ||
![]() |
7e02f7fdee | ||
![]() |
bd94807003 | ||
![]() |
1038d0aa16 | ||
![]() |
f80a508297 | ||
![]() |
af64666434 | ||
![]() |
2d72489f0f | ||
![]() |
dda815b776 | ||
![]() |
8d3efb6be0 | ||
![]() |
11e52ef0a1 | ||
![]() |
71ce2470dc | ||
![]() |
874855b743 | ||
![]() |
ac54d27d4b | ||
![]() |
2d833852f6 | ||
![]() |
0604b2fb90 | ||
![]() |
8f50a5c7e5 | ||
![]() |
703fa0a6a8 | ||
![]() |
97d7a9260e | ||
![]() |
4a4d04446d | ||
![]() |
b9223a17b8 | ||
![]() |
f712ace9d7 | ||
![]() |
2c905fd1f8 | ||
![]() |
4403e82f32 | ||
![]() |
c482e946f7 | ||
![]() |
46bd8b330a | ||
![]() |
78feaff9d8 | ||
![]() |
28bac99674 | ||
![]() |
7248439fec | ||
![]() |
c532604b13 | ||
![]() |
64f328c787 | ||
![]() |
c0db5ff678 | ||
![]() |
66617b79d7 | ||
![]() |
f64812ca63 | ||
![]() |
10ecdf5078 | ||
![]() |
bb4eb58996 | ||
![]() |
fc8809f993 | ||
![]() |
35f61c404d | ||
![]() |
97b73fec7a | ||
![]() |
8d0a504f0d | ||
![]() |
967b2f87a8 | ||
![]() |
b9660dc4b2 | ||
![]() |
591c29aa49 | ||
![]() |
5e0aa3aac9 | ||
![]() |
7cfd10e255 |
@@ -2,7 +2,7 @@
|
|||||||
#
|
#
|
||||||
# Place the curl source (including this makefile) into external/curl/ in the
|
# Place the curl source (including this makefile) into external/curl/ in the
|
||||||
# Android source tree. Then build them with 'make curl' or just 'make libcurl'
|
# Android source tree. Then build them with 'make curl' or just 'make libcurl'
|
||||||
# from the Android root. Tested with Android 1.5 and 2.1
|
# from the Android root. Tested with Android versions 1.5, 2.1-2.3
|
||||||
#
|
#
|
||||||
# Note: you must first create a curl_config.h file by running configure in the
|
# Note: you must first create a curl_config.h file by running configure in the
|
||||||
# Android environment. The only way I've found to do this is tricky. Perform a
|
# Android environment. The only way I've found to do this is tricky. Perform a
|
||||||
@@ -42,7 +42,7 @@
|
|||||||
# into the right place (but see the note about this below).
|
# into the right place (but see the note about this below).
|
||||||
#
|
#
|
||||||
# Dan Fandrich
|
# Dan Fandrich
|
||||||
# August 2010
|
# November 2011
|
||||||
|
|
||||||
LOCAL_PATH:= $(call my-dir)
|
LOCAL_PATH:= $(call my-dir)
|
||||||
|
|
||||||
|
0
CMake/FindCARES.cmake
Executable file → Normal file
0
CMake/FindCARES.cmake
Executable file → Normal file
@@ -57,10 +57,6 @@ set(OS "\"${CMAKE_SYSTEM_NAME}\"")
|
|||||||
include_directories(${PROJECT_BINARY_DIR}/include/curl)
|
include_directories(${PROJECT_BINARY_DIR}/include/curl)
|
||||||
include_directories( ${CURL_SOURCE_DIR}/include )
|
include_directories( ${CURL_SOURCE_DIR}/include )
|
||||||
|
|
||||||
if(WIN32)
|
|
||||||
set(NATIVE_WINDOWS ON)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
option(BUILD_CURL_EXE "Set to ON to build cURL executable." ON)
|
option(BUILD_CURL_EXE "Set to ON to build cURL executable." ON)
|
||||||
option(BUILD_CURL_TESTS "Set to ON to build cURL tests." ON)
|
option(BUILD_CURL_TESTS "Set to ON to build cURL tests." ON)
|
||||||
option(CURL_STATICLIB "Set to ON to build libcurl with static linking." OFF)
|
option(CURL_STATICLIB "Set to ON to build libcurl with static linking." OFF)
|
||||||
@@ -113,22 +109,11 @@ mark_as_advanced(CURL_DISABLE_HTTP)
|
|||||||
|
|
||||||
option(CURL_DISABLE_LDAPS "to disable LDAPS" OFF)
|
option(CURL_DISABLE_LDAPS "to disable LDAPS" OFF)
|
||||||
mark_as_advanced(CURL_DISABLE_LDAPS)
|
mark_as_advanced(CURL_DISABLE_LDAPS)
|
||||||
if(WIN32)
|
|
||||||
set(CURL_DEFAULT_DISABLE_LDAP OFF)
|
|
||||||
# some windows compilers do not have wldap32
|
|
||||||
if( NOT HAVE_WLDAP32)
|
|
||||||
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
|
||||||
message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON")
|
|
||||||
option(CURL_LDAP_WIN "Use Windows LDAP implementation" OFF)
|
|
||||||
else()
|
|
||||||
option(CURL_LDAP_WIN "Use Windows LDAP implementation" ON)
|
|
||||||
endif()
|
|
||||||
mark_as_advanced(CURL_LDAP_WIN)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(HTTP_ONLY)
|
if(HTTP_ONLY)
|
||||||
set(CURL_DISABLE_FTP ON)
|
set(CURL_DISABLE_FTP ON)
|
||||||
set(CURL_DISABLE_LDAP ON)
|
set(CURL_DISABLE_LDAP ON)
|
||||||
|
set(CURL_DISABLE_LDAPS ON)
|
||||||
set(CURL_DISABLE_TELNET ON)
|
set(CURL_DISABLE_TELNET ON)
|
||||||
set(CURL_DISABLE_DICT ON)
|
set(CURL_DISABLE_DICT ON)
|
||||||
set(CURL_DISABLE_FILE ON)
|
set(CURL_DISABLE_FILE ON)
|
||||||
@@ -148,9 +133,9 @@ option(ENABLE_IPV6 "Define if you want to enable IPv6 support" OFF)
|
|||||||
mark_as_advanced(ENABLE_IPV6)
|
mark_as_advanced(ENABLE_IPV6)
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
find_library(WSOCK32_LIBRARY wsock32)
|
# Windows standard libraries are located in C:/Program Files/Microsoft SDKs/[...]
|
||||||
find_library(WS2_32_LIBRARY ws2_32)
|
# They are already included in the default MSVC LIBPATH => no find_library is needed!
|
||||||
list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES ${WSOCK32_LIBRARY} ${WS2_32_LIBRARY}) # bufferoverflowu.lib
|
list_spaces_append_once(CMAKE_C_STANDARD_LIBRARIES wsock32.lib ws2_32.lib) # bufferoverflowu.lib
|
||||||
if(CURL_DISABLE_LDAP)
|
if(CURL_DISABLE_LDAP)
|
||||||
# Remove wldap32.lib from space-separated list
|
# Remove wldap32.lib from space-separated list
|
||||||
string(REPLACE " " ";" _LIST ${CMAKE_C_STANDARD_LIBRARIES})
|
string(REPLACE " " ";" _LIST ${CMAKE_C_STANDARD_LIBRARIES})
|
||||||
@@ -221,6 +206,20 @@ check_library_exists_concat("ws2_32" getch HAVE_LIBWS2_32)
|
|||||||
check_library_exists_concat("winmm" getch HAVE_LIBWINMM)
|
check_library_exists_concat("winmm" getch HAVE_LIBWINMM)
|
||||||
check_library_exists("wldap32" cldap_open "" HAVE_WLDAP32)
|
check_library_exists("wldap32" cldap_open "" HAVE_WLDAP32)
|
||||||
|
|
||||||
|
if(WIN32)
|
||||||
|
set(CURL_DEFAULT_DISABLE_LDAP OFF)
|
||||||
|
# some windows compilers do not have wldap32
|
||||||
|
if(NOT HAVE_WLDAP32)
|
||||||
|
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
||||||
|
message(STATUS "wldap32 not found CURL_DISABLE_LDAP set ON")
|
||||||
|
option(CURL_LDAP_WIN "Use Windows LDAP implementation" OFF)
|
||||||
|
else()
|
||||||
|
option(CURL_LDAP_WIN "Use Windows LDAP implementation" ON)
|
||||||
|
endif()
|
||||||
|
mark_as_advanced(CURL_LDAP_WIN)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
|
||||||
# IF(NOT CURL_SPECIAL_LIBZ)
|
# IF(NOT CURL_SPECIAL_LIBZ)
|
||||||
# CHECK_LIBRARY_EXISTS_CONCAT("z" inflateEnd HAVE_LIBZ)
|
# CHECK_LIBRARY_EXISTS_CONCAT("z" inflateEnd HAVE_LIBZ)
|
||||||
# ENDIF(NOT CURL_SPECIAL_LIBZ)
|
# ENDIF(NOT CURL_SPECIAL_LIBZ)
|
||||||
@@ -387,6 +386,13 @@ if(NOT HAVE_LDAP_H)
|
|||||||
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
set(CURL_DISABLE_LDAP ON CACHE BOOL "" FORCE)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
# No ldap, no ldaps.
|
||||||
|
if(CURL_DISABLE_LDAP)
|
||||||
|
if(NOT CURL_DISABLE_LDAPS)
|
||||||
|
message(STATUS "LDAP needs to be enabled to support LDAPS")
|
||||||
|
set(CURL_DISABLE_LDAPS ON CACHE BOOL "" FORCE)
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
check_type_size(size_t SIZEOF_SIZE_T)
|
check_type_size(size_t SIZEOF_SIZE_T)
|
||||||
check_type_size(ssize_t SIZEOF_SSIZE_T)
|
check_type_size(ssize_t SIZEOF_SSIZE_T)
|
||||||
@@ -426,7 +432,7 @@ if(SIZEOF_LONG EQUAL 8)
|
|||||||
set(CURL_FORMAT_CURL_OFF_TU "lu")
|
set(CURL_FORMAT_CURL_OFF_TU "lu")
|
||||||
set(CURL_FORMAT_OFF_T "%ld")
|
set(CURL_FORMAT_OFF_T "%ld")
|
||||||
set(CURL_SUFFIX_CURL_OFF_T L)
|
set(CURL_SUFFIX_CURL_OFF_T L)
|
||||||
set(CURL_SUFFIX_CURL_OFF_TU LU)
|
set(CURL_SUFFIX_CURL_OFF_TU UL)
|
||||||
endif(SIZEOF_LONG EQUAL 8)
|
endif(SIZEOF_LONG EQUAL 8)
|
||||||
|
|
||||||
if(SIZEOF_LONG_LONG EQUAL 8)
|
if(SIZEOF_LONG_LONG EQUAL 8)
|
||||||
@@ -436,7 +442,7 @@ if(SIZEOF_LONG_LONG EQUAL 8)
|
|||||||
set(CURL_FORMAT_CURL_OFF_TU "llu")
|
set(CURL_FORMAT_CURL_OFF_TU "llu")
|
||||||
set(CURL_FORMAT_OFF_T "%lld")
|
set(CURL_FORMAT_OFF_T "%lld")
|
||||||
set(CURL_SUFFIX_CURL_OFF_T LL)
|
set(CURL_SUFFIX_CURL_OFF_T LL)
|
||||||
set(CURL_SUFFIX_CURL_OFF_TU LLU)
|
set(CURL_SUFFIX_CURL_OFF_TU ULL)
|
||||||
endif(SIZEOF_LONG_LONG EQUAL 8)
|
endif(SIZEOF_LONG_LONG EQUAL 8)
|
||||||
|
|
||||||
if(NOT CURL_TYPEOF_CURL_OFF_T)
|
if(NOT CURL_TYPEOF_CURL_OFF_T)
|
||||||
|
2
COPYING
2
COPYING
@@ -1,6 +1,6 @@
|
|||||||
COPYRIGHT AND PERMISSION NOTICE
|
COPYRIGHT AND PERMISSION NOTICE
|
||||||
|
|
||||||
Copyright (c) 1996 - 2011, Daniel Stenberg, <daniel@haxx.se>.
|
Copyright (c) 1996 - 2012, Daniel Stenberg, <daniel@haxx.se>.
|
||||||
|
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
|
|
||||||
|
@@ -36,7 +36,7 @@ winbuild/MakefileBuild.vc winbuild/Makefile.vc
|
|||||||
EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in \
|
EXTRA_DIST = CHANGES COPYING maketgz Makefile.dist curl-config.in \
|
||||||
curl-style.el sample.emacs RELEASE-NOTES buildconf \
|
curl-style.el sample.emacs RELEASE-NOTES buildconf \
|
||||||
libcurl.pc.in vc6curl.dsw MacOSX-Framework Android.mk $(CMAKE_DIST) \
|
libcurl.pc.in vc6curl.dsw MacOSX-Framework Android.mk $(CMAKE_DIST) \
|
||||||
Makefile.msvc.names $(WINBUILD_DIST)
|
Makefile.msvc.names $(WINBUILD_DIST) lib/libcurl.vers.in
|
||||||
|
|
||||||
bin_SCRIPTS = curl-config
|
bin_SCRIPTS = curl-config
|
||||||
|
|
||||||
|
117
RELEASE-NOTES
117
RELEASE-NOTES
@@ -1,55 +1,54 @@
|
|||||||
Curl and libcurl 7.23.0
|
Curl and libcurl 7.26.0
|
||||||
|
|
||||||
Public curl releases: 125
|
Public curl releases: 127
|
||||||
Command line options: 149
|
Command line options: 151
|
||||||
curl_easy_setopt() options: 192
|
curl_easy_setopt() options: 199
|
||||||
Public functions in libcurl: 58
|
Public functions in libcurl: 58
|
||||||
Known libcurl bindings: 39
|
Known libcurl bindings: 39
|
||||||
Contributors: 873
|
Contributors: 929
|
||||||
|
|
||||||
This release includes the following changes:
|
This release includes the following changes:
|
||||||
|
|
||||||
o Empty headers can be sent in HTTP requests by terminating with a semicolon
|
o nss: the minimal supported version of NSS bumped to 3.12.x
|
||||||
o SSL session sharing support added to curl_share_setopt()
|
o nss: human-readable names are now provided for NSS errors if available
|
||||||
o Added support to MAIL FROM for the optional SIZE parameter
|
o add a manual page for mk-ca-bundle
|
||||||
o smtp: Added support for NTLM authentication
|
o added --post303 and the CURL_REDIR_POST_303 option for CURLOPT_POSTREDIR
|
||||||
o curl tool: code split into tool_*.[ch] files
|
o smtp: Add support for DIGEST-MD5 authentication
|
||||||
|
o pop3: Added support for additional pop3 commands
|
||||||
|
|
||||||
This release includes the following bugfixes:
|
This release includes the following bugfixes:
|
||||||
|
|
||||||
o handle HTTP redirects to "//hostname/path"
|
o nss: libcurl now uses NSS_InitContext() to prevent collisions if available
|
||||||
o SMTP without --mail-from caused segfault
|
[1]
|
||||||
o prevent extra progress meter headers between multiple files
|
o URL parse: reject numerical IPv6 addresses outside brackets [4]
|
||||||
o allow Content-Length to be replaced when sending HTTP requests
|
o MD5: fix OOM memory leak [5]
|
||||||
o curl now always sets postfieldsize to allow --data-binary and --data
|
o OpenSSL cert: provide more details when cert check fails
|
||||||
to be mixed in the same command line
|
o HTTP: empty chunked POST ended up in two zero size chunks [6]
|
||||||
o curl_multi_fdset: avoid FD_SET out of bounds
|
o fixed a regression when curl resolved to multiple addresses and the first
|
||||||
o lots of MinGW build tweaks
|
isn't supported [7]
|
||||||
o Curl_gethostname: return un-qualified machine name
|
o -# progress meter: avoid superfluous updates and duplicate lines [8]
|
||||||
o fixed the openssl version number configure check
|
o headers: surround GCC attribute names with double underscores [9]
|
||||||
o nss: certificates from files are no longer looked up by file base names
|
o PolarSSL: correct return code for CRL matches
|
||||||
o returning abort from the progress function when using the multi interface
|
o PolarSSL: include version number in version string
|
||||||
would not properly cancel the transfer and close the connection
|
o PolarSSL: add support for asynchronous connect
|
||||||
o fix libcurl.m4 to not fail with modern gcc versions
|
o mk-ca-bundle: revert the LWP usage [12]
|
||||||
o ftp: improved the failed PORT host name resolved error message
|
o IPv6 cookie domain: get rid of the first bracket before the second
|
||||||
o TFTP timeout and unexpected block adjustments
|
o connect.c: return changed to CURLE_COULDNT_CONNECT when opensocket fails
|
||||||
o HTTP and GOPHER test server-side connection closing adjustments
|
o OpenSSL: Made cert hostname check conform to RFC 6125 [10]
|
||||||
o fix endless loop upon transport connection timeout
|
o HTTP: reset expected DL/UL sizes on redirects [11]
|
||||||
o don't clobber errno on failed connect
|
o CMake: fix Windows LDAP/LDAPS option handling [2]
|
||||||
o typecheck: allow NULL to unset CURLOPT_ERRORBUFFER
|
o CMake: fix MS Visual Studio x64 unsigned long long literal suffix [3]
|
||||||
o formdata: ack read callback abort
|
o configure: update detection logic of getaddrinfo() thread-safeness
|
||||||
o make --show-error properly position independent
|
o configure: check for gethostbyname in the watt lib
|
||||||
o set the ipv6-connection boolean correctly on connect
|
o curl-config.1: fix curl-config usage in example [13]
|
||||||
o SMTP: fix end-of-body string escaping
|
o smtp: Fixed non-escaping of dot character at beginning of line
|
||||||
o gtls: only call gnutls_transport_set_lowat with <gnutls-2.12.0
|
o MakefileBuild.vc: use the correct IDN variable
|
||||||
o HTTP: handle multiple auths in a single WWW-Authenticate line
|
o autoconf: improve handling of versioned symbols
|
||||||
o curl_multi_fdset: correct fdset with FTP PORT use
|
o curl.1: clarify -x usage
|
||||||
o windbuild: fix the static build
|
o curl: shorten user-agent
|
||||||
o fix builds with GnuTLS version 3
|
o smtp: issue with the multi-interface always sending postdata [14]
|
||||||
o fix calling of OpenSSL's ERR_remove_state(0)
|
o compile error with GnuTLS+Nettle fixed
|
||||||
o HTTP auth: fix proxy Negotiate bug when Negotiate not requested
|
o winbuild: fix IPv6 enabled build
|
||||||
o ftp PORT: don't hang if bind() fails
|
|
||||||
o -# would crash on terminals wider than 256 columns
|
|
||||||
|
|
||||||
This release includes the following known bugs:
|
This release includes the following known bugs:
|
||||||
|
|
||||||
@@ -58,13 +57,29 @@ 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:
|
||||||
|
|
||||||
Yukihiro Kawada, Dave Reisner, Gisle Vanem, Guenter Knauf, Steve Holme,
|
Andrei Cipu, Armel Asselin, Benjamin Johnson, Dag Ekengren, Dave Reisner,
|
||||||
Yang Tse, Christopher Stone, Taneli Vahakangas, Albert Chin,
|
Gokhan Sengun, Guenter Knauf, Jan Schaumann, Jonathan Nieder, Kamil Dudka,
|
||||||
Alejandro Alvarez, Dan Fandrich, Julien Royer, Georg Lippitsch,
|
Lijo Antony, Olaf Flebbe, Rodrigo Silva, Steve Holme, Tatsuhiro Tsujikawa,
|
||||||
Vladimir Grishchenko, Dominique Leuenberger, Marcin Adamski,
|
Tim Heckman, Yang Tse, Arnaud Compan, Blaise Potard, Daniel Theron,
|
||||||
Jerry Wu, Michal Marek, Frank Van Uffelen, Fabian Hiernaux, Anton Bychkov,
|
Michael Mueller, Michael Wallner, Tim Heckman, Roman Mamedov, Julian Taylor,
|
||||||
Andreas Olsson, Kamil Dudka, Thomas L. Shinnick, Tim Harder, Nick Zitzmann,
|
Claes Jakobsson, Pierre Chapuis, Jan Ehrhardt
|
||||||
Gokhan Sengun, Tom Wright, Patrick Monnerat, Rene Bernhardt,
|
|
||||||
Alexey Zakhlestin
|
|
||||||
|
|
||||||
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:
|
||||||
|
|
||||||
|
[1] = https://bugzilla.redhat.com/738456
|
||||||
|
[2] = http://curl.haxx.se/mail/lib-2012-03/0278.html
|
||||||
|
[3] = http://curl.haxx.se/mail/lib-2012-03/0255.html
|
||||||
|
[4] = http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=670126
|
||||||
|
[5] = http://curl.haxx.se/mail/lib-2012-04/0246.html
|
||||||
|
[6] = http://curl.haxx.se/mail/archive-2012-04/0060.html
|
||||||
|
[7] = http://curl.haxx.se/bug/view.cgi?id=3516508
|
||||||
|
[8] = http://curl.haxx.se/bug/view.cgi?id=3517418
|
||||||
|
[9] = http://curl.haxx.se/mail/lib-2012-04/0127.html
|
||||||
|
[10] = http://tools.ietf.org/html/rfc6125#section-6.4.3
|
||||||
|
[11] = http://curl.haxx.se/bug/view.cgi?id=3510057
|
||||||
|
[12] = http://curl.haxx.se/mail/lib-2012-03/0238.html
|
||||||
|
[13] = http://curl.haxx.se/bug/view.cgi?id=3528241
|
||||||
|
[14] = http://curl.haxx.se/mail/lib-2012-05/0108.html
|
||||||
|
|
13
TODO-RELEASE
13
TODO-RELEASE
@@ -1,11 +1,10 @@
|
|||||||
To be addressed in 7.22.1
|
To be addressed in 7.27
|
||||||
=========================
|
=======================
|
||||||
|
|
||||||
295 - "RTSP Authentication (#22)" https://github.com/bagder/curl/pull/22
|
309 - metalink support for the curl tool
|
||||||
|
|
||||||
296 - "OOM leak in multi code" (by Dan Fandrich)
|
310 - a new authentication callback
|
||||||
|
|
||||||
300 - "Polling on stray socket on sequential transfers." Andrew S
|
311 - support for SSPI schannel for SSL on windows
|
||||||
http://curl.haxx.se/mail/lib-2011-07/0053.html
|
|
||||||
|
|
||||||
308 -
|
312 -
|
||||||
|
@@ -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
|
||||||
@@ -228,12 +228,7 @@ AC_DEFUN([CURL_CHECK_NATIVE_WINDOWS], [
|
|||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
case "$ac_cv_native_windows" in
|
AM_CONDITIONAL(DOING_NATIVE_WINDOWS, test "x$ac_cv_native_windows" = xyes)
|
||||||
yes)
|
|
||||||
AC_DEFINE_UNQUOTED(NATIVE_WINDOWS, 1,
|
|
||||||
[Define to 1 if you are building a native Windows target.])
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
165
buildconf
165
buildconf
@@ -6,7 +6,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
|
||||||
@@ -21,9 +21,12 @@
|
|||||||
#
|
#
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
|
#--------------------------------------------------------------------------
|
||||||
|
# die prints argument string to stdout and exits this shell script.
|
||||||
|
#
|
||||||
die(){
|
die(){
|
||||||
echo "$@"
|
echo "buildconf: $@"
|
||||||
exit
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
@@ -33,11 +36,8 @@ die(){
|
|||||||
findtool(){
|
findtool(){
|
||||||
file="$1"
|
file="$1"
|
||||||
|
|
||||||
if { echo $file | grep "/" >/dev/null 2>&1; } then
|
if { echo "$file" | grep "/" >/dev/null 2>&1; } then
|
||||||
# we only check for the explicit file name if the file is given
|
# when file is given with a path check it first
|
||||||
# including a slash. Use ./ for current dir. Previously this would
|
|
||||||
# otherwise always cause findtool to search the local dir first, which
|
|
||||||
# is wrong.
|
|
||||||
if test -f "$file"; then
|
if test -f "$file"; then
|
||||||
echo "$file"
|
echo "$file"
|
||||||
return
|
return
|
||||||
@@ -82,7 +82,8 @@ removethis(){
|
|||||||
if test ! -f configure.ac ||
|
if test ! -f configure.ac ||
|
||||||
test ! -f src/tool_main.c ||
|
test ! -f src/tool_main.c ||
|
||||||
test ! -f lib/urldata.h ||
|
test ! -f lib/urldata.h ||
|
||||||
test ! -f include/curl/curl.h; then
|
test ! -f include/curl/curl.h ||
|
||||||
|
test ! -f m4/curl-functions.m4; then
|
||||||
echo "Can not run buildconf from outside of curl's source subdirectory!"
|
echo "Can not run buildconf from outside of curl's source subdirectory!"
|
||||||
echo "Change to the subdirectory where buildconf is found, and try again."
|
echo "Change to the subdirectory where buildconf is found, and try again."
|
||||||
exit 1
|
exit 1
|
||||||
@@ -188,27 +189,24 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
# libtool check
|
# GNU libtool preliminary check
|
||||||
#
|
#
|
||||||
LIBTOOL_WANTED_MAJOR=1
|
want_lt_major=1
|
||||||
LIBTOOL_WANTED_MINOR=4
|
want_lt_minor=4
|
||||||
LIBTOOL_WANTED_PATCH=2
|
want_lt_patch=2
|
||||||
LIBTOOL_WANTED_VERSION=1.4.2
|
want_lt_version=1.4.2
|
||||||
|
|
||||||
|
# This approach that tries 'glibtool' first is intended for systems that
|
||||||
|
# have GNU libtool named as 'glibtool' and libtool not being GNU's.
|
||||||
|
|
||||||
# this approach that tries 'glibtool' first is some kind of work-around for
|
|
||||||
# some BSD-systems I believe that use to provide the GNU libtool named
|
|
||||||
# glibtool, with 'libtool' being something completely different.
|
|
||||||
libtool=`findtool glibtool 2>/dev/null`
|
libtool=`findtool glibtool 2>/dev/null`
|
||||||
if test ! -x "$libtool"; then
|
if test ! -x "$libtool"; then
|
||||||
libtool=`findtool ${LIBTOOL:-libtool}`
|
libtool=`findtool ${LIBTOOL:-libtool}`
|
||||||
fi
|
fi
|
||||||
|
if test -z "$libtool"; then
|
||||||
if test -z "$LIBTOOLIZE"; then
|
echo "buildconf: libtool not found."
|
||||||
# set the LIBTOOLIZE here so that glibtoolize is used if glibtool was found
|
echo " You need GNU libtool $want_lt_version or newer installed."
|
||||||
# $libtool is already the full path
|
exit 1
|
||||||
libtoolize="${libtool}ize"
|
|
||||||
else
|
|
||||||
libtoolize=`findtool $LIBTOOLIZE`
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
lt_pver=`$libtool --version 2>/dev/null|head -n 1`
|
lt_pver=`$libtool --version 2>/dev/null|head -n 1`
|
||||||
@@ -216,42 +214,55 @@ lt_qver=`echo $lt_pver|sed -e "s/([^)]*)//g" -e "s/^[^0-9]*//g"`
|
|||||||
lt_version=`echo $lt_qver|sed -e "s/[- ].*//" -e "s/\([a-z]*\)$//"`
|
lt_version=`echo $lt_qver|sed -e "s/[- ].*//" -e "s/\([a-z]*\)$//"`
|
||||||
if test -z "$lt_version"; then
|
if test -z "$lt_version"; then
|
||||||
echo "buildconf: libtool not found."
|
echo "buildconf: libtool not found."
|
||||||
echo " You need libtool version $LIBTOOL_WANTED_VERSION or newer installed"
|
echo " You need GNU libtool $want_lt_version or newer installed."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS
|
old_IFS=$IFS; IFS='.'; set $lt_version; IFS=$old_IFS
|
||||||
lt_major=$1
|
lt_major=$1
|
||||||
lt_minor=$2
|
lt_minor=$2
|
||||||
lt_patch=$3
|
lt_patch=$3
|
||||||
lt_status="good"
|
|
||||||
|
|
||||||
if test "$lt_major" = "$LIBTOOL_WANTED_MAJOR"; then
|
if test -z "$lt_major"; then
|
||||||
if test "$lt_minor" -lt "$LIBTOOL_WANTED_MINOR"; then
|
lt_status="bad"
|
||||||
lt_status="bad"
|
elif test "$lt_major" -gt "$want_lt_major"; then
|
||||||
elif test -n "$LIBTOOL_WANTED_PATCH"; then
|
lt_status="good"
|
||||||
if test "$lt_minor" -gt "$LIBTOOL_WANTED_MINOR"; then
|
elif test "$lt_major" -lt "$want_lt_major"; then
|
||||||
lt_status="good"
|
lt_status="bad"
|
||||||
elif test -n "$lt_patch"; then
|
elif test -z "$lt_minor"; then
|
||||||
if test "$lt_patch" -lt "$LIBTOOL_WANTED_PATCH"; then
|
lt_status="bad"
|
||||||
lt_status="bad"
|
elif test "$lt_minor" -gt "$want_lt_minor"; then
|
||||||
fi
|
lt_status="good"
|
||||||
else
|
elif test "$lt_minor" -lt "$want_lt_minor"; then
|
||||||
lt_status="bad"
|
lt_status="bad"
|
||||||
fi
|
elif test -z "$lt_patch"; then
|
||||||
fi
|
lt_status="bad"
|
||||||
|
elif test "$lt_patch" -gt "$want_lt_patch"; then
|
||||||
|
lt_status="good"
|
||||||
|
elif test "$lt_patch" -lt "$want_lt_patch"; then
|
||||||
|
lt_status="bad"
|
||||||
|
else
|
||||||
|
lt_status="good"
|
||||||
fi
|
fi
|
||||||
if test $lt_status != "good"; then
|
if test "$lt_status" != "good"; then
|
||||||
echo "buildconf: libtool version $lt_version found."
|
echo "buildconf: libtool version $lt_version found."
|
||||||
echo " You need libtool version $LIBTOOL_WANTED_VERSION or newer installed"
|
echo " You need GNU libtool $want_lt_version or newer installed."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "buildconf: libtool version $lt_version (ok)"
|
echo "buildconf: libtool version $lt_version (ok)"
|
||||||
|
|
||||||
if test -f "$libtoolize"; then
|
#--------------------------------------------------------------------------
|
||||||
echo "buildconf: libtoolize found"
|
# GNU libtoolize check
|
||||||
|
#
|
||||||
|
if test -z "$LIBTOOLIZE"; then
|
||||||
|
# use (g)libtoolize from same location as (g)libtool
|
||||||
|
libtoolize="${libtool}ize"
|
||||||
else
|
else
|
||||||
echo "buildconf: libtoolize not found. Weird libtool installation!"
|
libtoolize=`findtool $LIBTOOLIZE`
|
||||||
|
fi
|
||||||
|
if test ! -f "$libtoolize"; then
|
||||||
|
echo "buildconf: libtoolize not found."
|
||||||
|
echo " You need GNU libtoolize $want_lt_version or newer installed."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -276,6 +287,10 @@ fi
|
|||||||
# perl check
|
# perl check
|
||||||
#
|
#
|
||||||
PERL=`findtool ${PERL:-perl}`
|
PERL=`findtool ${PERL:-perl}`
|
||||||
|
if test -z "$PERL"; then
|
||||||
|
echo "buildconf: perl not found"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
# Remove files generated on previous buildconf/configure run.
|
# Remove files generated on previous buildconf/configure run.
|
||||||
@@ -311,6 +326,7 @@ for fname in .deps \
|
|||||||
libcurl.pc \
|
libcurl.pc \
|
||||||
libtool \
|
libtool \
|
||||||
libtool.m4 \
|
libtool.m4 \
|
||||||
|
libtool.m4.tmp \
|
||||||
ltmain.sh \
|
ltmain.sh \
|
||||||
ltoptions.m4 \
|
ltoptions.m4 \
|
||||||
ltsugar.m4 \
|
ltsugar.m4 \
|
||||||
@@ -327,32 +343,49 @@ done
|
|||||||
#
|
#
|
||||||
|
|
||||||
echo "buildconf: running libtoolize"
|
echo "buildconf: running libtoolize"
|
||||||
$libtoolize --copy --automake --force || die "The libtoolize command failed"
|
${libtoolize} --copy --automake --force || die "libtoolize command failed"
|
||||||
|
|
||||||
if test ! -f m4/curl-functions.m4; then
|
# When using libtool 1.5.X (X < 26) we copy libtool.m4 to our local m4
|
||||||
echo "buildconf: cURL m4 macros not found"
|
# subdirectory and this local copy is patched to fix some warnings that
|
||||||
exit 1
|
# are triggered when running aclocal and using autoconf 2.62 or later.
|
||||||
|
|
||||||
|
if test "$lt_major" = "1" && test "$lt_minor" = "5"; then
|
||||||
|
if test -z "$lt_patch" || test "$lt_patch" -lt "26"; then
|
||||||
|
echo "buildconf: copying libtool.m4 to local m4 subdir"
|
||||||
|
ac_dir=`${ACLOCAL:-aclocal} --print-ac-dir`
|
||||||
|
if test -f $ac_dir/libtool.m4; then
|
||||||
|
cp -f $ac_dir/libtool.m4 m4/libtool.m4
|
||||||
|
else
|
||||||
|
echo "buildconf: $ac_dir/libtool.m4 not found"
|
||||||
|
fi
|
||||||
|
if test -f m4/libtool.m4; then
|
||||||
|
echo "buildconf: renaming some variables in local m4/libtool.m4"
|
||||||
|
$PERL -i.tmp -pe \
|
||||||
|
's/lt_prog_compiler_pic_works/lt_cv_prog_compiler_pic_works/g; \
|
||||||
|
s/lt_prog_compiler_static_works/lt_cv_prog_compiler_static_works/g;' \
|
||||||
|
m4/libtool.m4
|
||||||
|
rm -f m4/libtool.m4.tmp
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test -f m4/libtool.m4; then
|
||||||
|
echo "buildconf: converting all mv to mv -f in local m4/libtool.m4"
|
||||||
|
$PERL -i.tmp -pe 's/\bmv +([^-\s])/mv -f $1/g' m4/libtool.m4
|
||||||
|
rm -f m4/libtool.m4.tmp
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "buildconf: running aclocal"
|
echo "buildconf: running aclocal"
|
||||||
${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS || die "The aclocal command line failed"
|
${ACLOCAL:-aclocal} -I m4 $ACLOCAL_FLAGS || die "aclocal command failed"
|
||||||
|
|
||||||
if test -n "$PERL"; then
|
echo "buildconf: converting all mv to mv -f in local aclocal.m4"
|
||||||
echo "buildconf: running aclocal hack to convert all mv to mv -f"
|
$PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4
|
||||||
$PERL -i.bak -pe 's/\bmv +([^-\s])/mv -f $1/g' aclocal.m4
|
|
||||||
else
|
|
||||||
echo "buildconf: perl not found"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "buildconf: running autoheader"
|
echo "buildconf: running autoheader"
|
||||||
${AUTOHEADER:-autoheader} || die "The autoheader command failed"
|
${AUTOHEADER:-autoheader} || die "autoheader command failed"
|
||||||
|
|
||||||
echo "buildconf: cp lib/curl_config.h.in src/curl_config.h.in"
|
|
||||||
cp lib/curl_config.h.in src/curl_config.h.in
|
|
||||||
|
|
||||||
echo "buildconf: running autoconf"
|
echo "buildconf: running autoconf"
|
||||||
${AUTOCONF:-autoconf} || die "The autoconf command failed"
|
${AUTOCONF:-autoconf} || die "autoconf command failed"
|
||||||
|
|
||||||
if test -d ares; then
|
if test -d ares; then
|
||||||
cd ares
|
cd ares
|
||||||
@@ -362,14 +395,15 @@ if test -d ares; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
echo "buildconf: running automake"
|
echo "buildconf: running automake"
|
||||||
${AUTOMAKE:-automake} -a -c || die "The automake command failed"
|
${AUTOMAKE:-automake} --add-missing --copy || die "automake command failed"
|
||||||
|
|
||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
|
# GNU libtool complementary check
|
||||||
|
#
|
||||||
# Depending on the libtool and automake versions being used, config.guess
|
# Depending on the libtool and automake versions being used, config.guess
|
||||||
# might not be installed in the subdirectory until automake has finished.
|
# might not be installed in the subdirectory until automake has finished.
|
||||||
# So we can not attempt to use it until this very last buildconf stage.
|
# So we can not attempt to use it until this very last buildconf stage.
|
||||||
#
|
#
|
||||||
|
|
||||||
if test ! -f ./config.guess; then
|
if test ! -f ./config.guess; then
|
||||||
echo "buildconf: config.guess not found"
|
echo "buildconf: config.guess not found"
|
||||||
else
|
else
|
||||||
@@ -413,7 +447,7 @@ else
|
|||||||
if test "$lt_status" != "good"; then
|
if test "$lt_status" != "good"; then
|
||||||
need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch"
|
need_lt_version="$need_lt_major.$need_lt_minor.$need_lt_patch"
|
||||||
echo "buildconf: libtool version $lt_version found."
|
echo "buildconf: libtool version $lt_version found."
|
||||||
echo " $buildhost requires libtool $need_lt_version or newer installed."
|
echo " $buildhost requires GNU libtool $need_lt_version or newer installed."
|
||||||
rm -f configure
|
rm -f configure
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
@@ -423,6 +457,5 @@ fi
|
|||||||
#--------------------------------------------------------------------------
|
#--------------------------------------------------------------------------
|
||||||
# Finished successfully.
|
# Finished successfully.
|
||||||
#
|
#
|
||||||
|
|
||||||
echo "buildconf: OK"
|
echo "buildconf: OK"
|
||||||
exit 0
|
exit 0
|
||||||
|
@@ -27,11 +27,6 @@ if not exist include\curl\curlbuild.h.dist goto end_curlbuild_h
|
|||||||
copy /Y include\curl\curlbuild.h.dist include\curl\curlbuild.h
|
copy /Y include\curl\curlbuild.h.dist include\curl\curlbuild.h
|
||||||
:end_curlbuild_h
|
:end_curlbuild_h
|
||||||
|
|
||||||
REM create src\config-win32.h
|
|
||||||
if not exist lib\config-win32.h goto end_config_win32_h
|
|
||||||
copy /Y lib\config-win32.h src\config-win32.h
|
|
||||||
:end_config_win32_h
|
|
||||||
|
|
||||||
REM setup c-ares git tree
|
REM setup c-ares git tree
|
||||||
if not exist ares\buildconf.bat goto end_c_ares
|
if not exist ares\buildconf.bat goto end_c_ares
|
||||||
cd ares
|
cd ares
|
||||||
|
486
configure.ac
486
configure.ac
@@ -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
|
||||||
@@ -26,6 +26,7 @@ AC_PREREQ(2.57)
|
|||||||
dnl We don't know the version number "statically" so we use a dash here
|
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
|
||||||
CURL_OVERRIDE_AUTOCONF
|
CURL_OVERRIDE_AUTOCONF
|
||||||
|
|
||||||
dnl configure script copyright
|
dnl configure script copyright
|
||||||
@@ -34,7 +35,7 @@ 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 src/curl_config.h include/curl/curlbuild.h)
|
AM_CONFIG_HEADER(lib/curl_config.h include/curl/curlbuild.h)
|
||||||
AC_CONFIG_MACRO_DIR([m4])
|
AC_CONFIG_MACRO_DIR([m4])
|
||||||
AM_MAINTAINER_MODE
|
AM_MAINTAINER_MODE
|
||||||
|
|
||||||
@@ -43,6 +44,7 @@ CURL_CHECK_OPTION_OPTIMIZE
|
|||||||
CURL_CHECK_OPTION_WARNINGS
|
CURL_CHECK_OPTION_WARNINGS
|
||||||
CURL_CHECK_OPTION_WERROR
|
CURL_CHECK_OPTION_WERROR
|
||||||
CURL_CHECK_OPTION_CURLDEBUG
|
CURL_CHECK_OPTION_CURLDEBUG
|
||||||
|
CURL_CHECK_OPTION_SYMBOL_HIDING
|
||||||
CURL_CHECK_OPTION_ARES
|
CURL_CHECK_OPTION_ARES
|
||||||
|
|
||||||
CURL_CHECK_PATH_SEPARATOR_REQUIRED
|
CURL_CHECK_PATH_SEPARATOR_REQUIRED
|
||||||
@@ -154,6 +156,7 @@ curl_tls_srp_msg="no (--enable-tls-srp)"
|
|||||||
curl_ipv6_msg="no (--enable-ipv6)"
|
curl_ipv6_msg="no (--enable-ipv6)"
|
||||||
curl_idn_msg="no (--with-libidn)"
|
curl_idn_msg="no (--with-libidn)"
|
||||||
curl_manual_msg="no (--enable-manual)"
|
curl_manual_msg="no (--enable-manual)"
|
||||||
|
curl_libcurl_msg="enabled (--disable-libcurl-option)"
|
||||||
curl_verbose_msg="enabled (--disable-verbose)"
|
curl_verbose_msg="enabled (--disable-verbose)"
|
||||||
curl_sspi_msg="no (--enable-sspi)"
|
curl_sspi_msg="no (--enable-sspi)"
|
||||||
curl_ldap_msg="no (--enable-ldap / --with-ldap-lib / --with-lber-lib)"
|
curl_ldap_msg="no (--enable-ldap / --with-ldap-lib / --with-lber-lib)"
|
||||||
@@ -234,21 +237,18 @@ esac
|
|||||||
AC_MSG_RESULT($mimpure)
|
AC_MSG_RESULT($mimpure)
|
||||||
AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes)
|
AM_CONDITIONAL(MIMPURE, test x$mimpure = xyes)
|
||||||
|
|
||||||
dnl 'STATICLIB' is, in spite of its name, not generic but only for static-only
|
|
||||||
dnl builds on Windows
|
|
||||||
AM_CONDITIONAL(STATICLIB, false)
|
|
||||||
|
|
||||||
AC_MSG_CHECKING([if we need BUILDING_LIBCURL])
|
AC_MSG_CHECKING([if we need BUILDING_LIBCURL])
|
||||||
|
use_cppflag_building_libcurl="no"
|
||||||
|
use_cppflag_curl_staticlib="no"
|
||||||
case $host in
|
case $host in
|
||||||
*-*-mingw*)
|
*-*-mingw*)
|
||||||
AC_DEFINE(BUILDING_LIBCURL, 1, [when building libcurl itself])
|
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
|
use_cppflag_building_libcurl="yes"
|
||||||
AC_MSG_CHECKING([if we need CURL_STATICLIB])
|
AC_MSG_CHECKING([if we need CURL_STATICLIB])
|
||||||
if test "X$enable_shared" = "Xno"
|
if test "X$enable_shared" = "Xno"
|
||||||
then
|
then
|
||||||
AC_DEFINE(CURL_STATICLIB, 1, [when not building a shared library])
|
|
||||||
AC_MSG_RESULT(yes)
|
AC_MSG_RESULT(yes)
|
||||||
AM_CONDITIONAL(STATICLIB, true)
|
use_cppflag_curl_staticlib="yes"
|
||||||
else
|
else
|
||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
fi
|
fi
|
||||||
@@ -257,6 +257,8 @@ case $host in
|
|||||||
AC_MSG_RESULT(no)
|
AC_MSG_RESULT(no)
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
AM_CONDITIONAL(USE_CPPFLAG_BUILDING_LIBCURL, test x$use_cppflag_building_libcurl = xyes)
|
||||||
|
AM_CONDITIONAL(USE_CPPFLAG_CURL_STATICLIB, test x$use_cppflag_curl_staticlib = xyes)
|
||||||
|
|
||||||
# Determine whether all dependent libraries must be specified when linking
|
# Determine whether all dependent libraries must be specified when linking
|
||||||
if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno"
|
if test "X$enable_shared" = "Xyes" -a "X$link_all_deplibs" = "Xno"
|
||||||
@@ -298,6 +300,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_SYMBOL_HIDING
|
||||||
|
|
||||||
CURL_CHECK_NO_UNDEFINED
|
CURL_CHECK_NO_UNDEFINED
|
||||||
AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes)
|
AM_CONDITIONAL(NO_UNDEFINED, test x$need_no_undefined = xyes)
|
||||||
@@ -650,6 +653,25 @@ AC_HELP_STRING([--disable-manual],[Disable built-in manual]),
|
|||||||
dnl The actual use of the USE_MANUAL variable is done much later in this
|
dnl The actual use of the USE_MANUAL variable is done much later in this
|
||||||
dnl script to allow other actions to disable it as well.
|
dnl script to allow other actions to disable it as well.
|
||||||
|
|
||||||
|
dnl ************************************************************
|
||||||
|
dnl disable C code generation support
|
||||||
|
dnl
|
||||||
|
AC_MSG_CHECKING([whether to enable generation of C code])
|
||||||
|
AC_ARG_ENABLE(libcurl_option,
|
||||||
|
AC_HELP_STRING([--enable-libcurl-option],[Enable --libcurl C code generation support])
|
||||||
|
AC_HELP_STRING([--disable-libcurl-option],[Disable --libcurl C code generation support]),
|
||||||
|
[ case "$enableval" in
|
||||||
|
no)
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_DEFINE(CURL_DISABLE_LIBCURL_OPTION, 1, [to disable --libcurl C code generation option])
|
||||||
|
curl_libcurl_msg="no"
|
||||||
|
;;
|
||||||
|
*) AC_MSG_RESULT(yes)
|
||||||
|
;;
|
||||||
|
esac ],
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
)
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Checks for libraries.
|
dnl Checks for libraries.
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
@@ -675,6 +697,17 @@ then
|
|||||||
])
|
])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
||||||
|
then
|
||||||
|
dnl gethostbyname in the watt lib?
|
||||||
|
AC_CHECK_LIB(watt, gethostbyname,
|
||||||
|
[HAVE_GETHOSTBYNAME="1"
|
||||||
|
CPPFLAGS="-I/dev/env/WATT_ROOT/inc"
|
||||||
|
LDFLAGS="-L/dev/env/WATT_ROOT/lib"
|
||||||
|
LIBS="$LIBS -lwatt"
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
|
||||||
dnl At least one system has been identified to require BOTH nsl and socket
|
dnl At least one system has been identified to require BOTH nsl and socket
|
||||||
dnl libs at the same time to link properly.
|
dnl libs at the same time to link properly.
|
||||||
if test "$HAVE_GETHOSTBYNAME" != "1"
|
if test "$HAVE_GETHOSTBYNAME" != "1"
|
||||||
@@ -1514,7 +1547,8 @@ if test X"$OPT_SSL" != Xno; then
|
|||||||
RAND_egd \
|
RAND_egd \
|
||||||
ENGINE_cleanup \
|
ENGINE_cleanup \
|
||||||
CRYPTO_cleanup_all_ex_data \
|
CRYPTO_cleanup_all_ex_data \
|
||||||
SSL_get_shutdown )
|
SSL_get_shutdown \
|
||||||
|
SSLv2_client_method )
|
||||||
|
|
||||||
dnl Make an attempt to detect if this is actually yassl's headers and
|
dnl Make an attempt to detect if this is actually yassl's headers and
|
||||||
dnl OpenSSL emulation layer. We still leave everything else believing
|
dnl OpenSSL emulation layer. We still leave everything else believing
|
||||||
@@ -1546,10 +1580,11 @@ if test X"$OPT_SSL" != Xno; then
|
|||||||
dnl when the ssl shared libs were found in a path that the run-time
|
dnl when the ssl shared libs were found in a path that the run-time
|
||||||
dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH
|
dnl linker doesn't search through, we need to add it to LD_LIBRARY_PATH
|
||||||
dnl to prevent further configure tests to fail due to this
|
dnl to prevent further configure tests to fail due to this
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$LIB_OPENSSL"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $LIB_OPENSSL to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
CURL_CHECK_OPENSSL_API
|
CURL_CHECK_OPENSSL_API
|
||||||
fi
|
fi
|
||||||
@@ -1785,10 +1820,11 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
dnl linker doesn't search through, we need to add it to
|
dnl linker doesn't search through, we need to add it to
|
||||||
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
||||||
dnl due to this
|
dnl due to this
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$gtlslib"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $gtlslib to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -1799,17 +1835,33 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
fi dnl OPENSSL != 1
|
fi dnl OPENSSL != 1
|
||||||
|
|
||||||
dnl ---
|
dnl ---
|
||||||
dnl If GnuTLS is enabled, we MUST verify that it uses libgcrypt since
|
dnl Check which crypto backend GnuTLS uses
|
||||||
dnl curl code relies on that but recent GnuTLS versions can in fact build
|
|
||||||
dnl with different crypto libraries which curl right now cannot handle
|
|
||||||
dnl ---
|
dnl ---
|
||||||
|
|
||||||
if test "$GNUTLS_ENABLED" = "1"; then
|
if test "$GNUTLS_ENABLED" = "1"; then
|
||||||
AC_CHECK_LIB(gcrypt,
|
USE_GNUTLS_NETTLE=
|
||||||
gcry_control, ,
|
# First check if we can detect either crypto library via transitive linking
|
||||||
[
|
AC_CHECK_LIB(gnutls, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ])
|
||||||
AC_MSG_ERROR([need GnuTLS built with gcrypt to function with GnuTLS])
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
||||||
])
|
AC_CHECK_LIB(gnutls, gcry_control, [ USE_GNUTLS_NETTLE=0 ])
|
||||||
|
fi
|
||||||
|
# If not, try linking directly to both of them to see if they are available
|
||||||
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
||||||
|
AC_CHECK_LIB(nettle, nettle_MD5Init, [ USE_GNUTLS_NETTLE=1 ])
|
||||||
|
fi
|
||||||
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
||||||
|
AC_CHECK_LIB(gcrypt, gcry_control, [ USE_GNUTLS_NETTLE=0 ])
|
||||||
|
fi
|
||||||
|
if test "$USE_GNUTLS_NETTLE" = ""; then
|
||||||
|
AC_MSG_ERROR([GnuTLS found, but neither gcrypt nor nettle found])
|
||||||
|
fi
|
||||||
|
if test "$USE_GNUTLS_NETTLE" = "1"; then
|
||||||
|
AC_DEFINE(USE_GNUTLS_NETTLE, 1, [if GnuTLS uses nettle as crypto backend])
|
||||||
|
AC_SUBST(USE_GNUTLS_NETTLE, [1])
|
||||||
|
LIBS="$LIBS -lnettle"
|
||||||
|
else
|
||||||
|
LIBS="$LIBS -lgcrypt"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dnl ---
|
dnl ---
|
||||||
@@ -1895,12 +1947,12 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
dnl linker doesn't search through, we need to add it to
|
dnl linker doesn't search through, we need to add it to
|
||||||
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
||||||
dnl due to this
|
dnl due to this
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$polarssllib"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $polarssllib to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi dnl PolarSSL not disabled
|
fi dnl PolarSSL not disabled
|
||||||
@@ -1917,7 +1969,7 @@ OPT_CYASSL=no
|
|||||||
_cppflags=$CPPFLAGS
|
_cppflags=$CPPFLAGS
|
||||||
_ldflags=$LDFLAGS
|
_ldflags=$LDFLAGS
|
||||||
AC_ARG_WITH(cyassl,dnl
|
AC_ARG_WITH(cyassl,dnl
|
||||||
AC_HELP_STRING([--with-cyassl=PATH],[where to look for CyaSSL, PATH points to the installation root (default: /usr/local/cyassl)])
|
AC_HELP_STRING([--with-cyassl=PATH],[where to look for CyaSSL, PATH points to the installation root (default: system lib default)])
|
||||||
AC_HELP_STRING([--without-cyassl], [disable CyaSSL detection]),
|
AC_HELP_STRING([--without-cyassl], [disable CyaSSL detection]),
|
||||||
OPT_CYASSL=$withval)
|
OPT_CYASSL=$withval)
|
||||||
|
|
||||||
@@ -1930,14 +1982,9 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if test -z "$OPT_CYASSL" ; then
|
if test -z "$OPT_CYASSL" ; then
|
||||||
dnl check for lib in default first
|
dnl check for lib in system default first
|
||||||
|
|
||||||
trycyassldir="/usr/local/cyassl"
|
AC_CHECK_LIB(cyassl, CyaSSL_Init,
|
||||||
|
|
||||||
LDFLAGS="$LDFLAGS -L$trycyassldir/lib"
|
|
||||||
CPPFLAGS="$CPPFLAGS -I$trycyassldir/include"
|
|
||||||
|
|
||||||
AC_CHECK_LIB(cyassl, InitCyaSSL,
|
|
||||||
dnl libcyassl found, set the variable
|
dnl libcyassl found, set the variable
|
||||||
[
|
[
|
||||||
AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled])
|
AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled])
|
||||||
@@ -1959,7 +2006,7 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
CPPFLAGS="$CPPFLAGS $addcflags"
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AC_CHECK_LIB(cyassl, InitCyaSSL,
|
AC_CHECK_LIB(cyassl, CyaSSL_Init,
|
||||||
[
|
[
|
||||||
AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled])
|
AC_DEFINE(USE_CYASSL, 1, [if CyaSSL is enabled])
|
||||||
AC_SUBST(USE_CYASSL, [1])
|
AC_SUBST(USE_CYASSL, [1])
|
||||||
@@ -1984,10 +2031,11 @@ if test "$OPENSSL_ENABLED" != "1"; then
|
|||||||
dnl linker doesn't search through, we need to add it to
|
dnl linker doesn't search through, we need to add it to
|
||||||
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
||||||
dnl due to this
|
dnl due to this
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$cyassllib"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $cyassllib to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
@@ -2043,13 +2091,6 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then
|
|||||||
nssprefix=$OPT_NSS
|
nssprefix=$OPT_NSS
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dnl Check for functionPK11_CreateGenericObject
|
|
||||||
dnl this is needed for using the PEM PKCS#11 module
|
|
||||||
AC_CHECK_LIB(nss3, PK11_CreateGenericObject,
|
|
||||||
[
|
|
||||||
AC_DEFINE(HAVE_PK11_CREATEGENERICOBJECT, 1, [if you have the function PK11_CreateGenericObject])
|
|
||||||
AC_SUBST(HAVE_PK11_CREATEGENERICOBJECT, [1])
|
|
||||||
])
|
|
||||||
if test -n "$addlib"; then
|
if test -n "$addlib"; then
|
||||||
|
|
||||||
CLEANLIBS="$LIBS"
|
CLEANLIBS="$LIBS"
|
||||||
@@ -2060,7 +2101,8 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then
|
|||||||
CPPFLAGS="$CPPFLAGS $addcflags"
|
CPPFLAGS="$CPPFLAGS $addcflags"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
AC_CHECK_LIB(nss3, NSS_Initialize,
|
dnl The function PK11_CreateGenericObject is needed to load libnsspem.so
|
||||||
|
AC_CHECK_LIB(nss3, PK11_CreateGenericObject,
|
||||||
[
|
[
|
||||||
AC_DEFINE(USE_NSS, 1, [if NSS is enabled])
|
AC_DEFINE(USE_NSS, 1, [if NSS is enabled])
|
||||||
AC_SUBST(USE_NSS, [1])
|
AC_SUBST(USE_NSS, [1])
|
||||||
@@ -2076,14 +2118,23 @@ if test "$OPENSSL_ENABLED" != "1" -a "$GNUTLS_ENABLED" != "1"; then
|
|||||||
if test "x$USE_NSS" = "xyes"; then
|
if test "x$USE_NSS" = "xyes"; then
|
||||||
AC_MSG_NOTICE([detected NSS version $version])
|
AC_MSG_NOTICE([detected NSS version $version])
|
||||||
|
|
||||||
|
dnl NSS_InitContext() was introduced in NSS 3.12.5 and helps to prevent
|
||||||
|
dnl collisions on NSS initialization/shutdown with other libraries
|
||||||
|
AC_CHECK_FUNC(NSS_InitContext,
|
||||||
|
[
|
||||||
|
AC_DEFINE(HAVE_NSS_INITCONTEXT, 1, [if you have the NSS_InitContext function])
|
||||||
|
AC_SUBST(HAVE_NSS_INITCONTEXT, [1])
|
||||||
|
])
|
||||||
|
|
||||||
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
|
||||||
dnl linker doesn't search through, we need to add it to
|
dnl linker doesn't search through, we need to add it to
|
||||||
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
dnl LD_LIBRARY_PATH to prevent further configure tests to fail
|
||||||
dnl due to this
|
dnl due to this
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$nssprefix/lib$libsuff"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $nssprefix/lib$libsuff to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
@@ -2240,10 +2291,11 @@ if test X"$OPT_LIBSSH2" != Xno; then
|
|||||||
dnl libssh2_session_handshake was added in 1.2.8
|
dnl libssh2_session_handshake was added in 1.2.8
|
||||||
AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \
|
AC_CHECK_FUNCS( libssh2_version libssh2_init libssh2_exit \
|
||||||
libssh2_scp_send64 libssh2_session_handshake)
|
libssh2_scp_send64 libssh2_session_handshake)
|
||||||
|
if test "x$cross_compiling" != "xyes"; then
|
||||||
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2"
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$DIR_SSH2"
|
||||||
export LD_LIBRARY_PATH
|
export LD_LIBRARY_PATH
|
||||||
AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH])
|
AC_MSG_NOTICE([Added $DIR_SSH2 to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
dnl no libssh2, revert back to clean variables
|
dnl no libssh2, revert back to clean variables
|
||||||
@@ -2331,56 +2383,197 @@ if test X"$OPT_LIBRTMP" != Xno; then
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
dnl **********************************************************************
|
||||||
|
dnl Check for linker switch for versioned symbols
|
||||||
|
dnl **********************************************************************
|
||||||
|
|
||||||
|
versioned_symbols_flavour=
|
||||||
|
AC_MSG_CHECKING([whether versioned symbols are wanted])
|
||||||
|
AC_ARG_ENABLE(versioned-symbols,
|
||||||
|
AC_HELP_STRING([--enable-versioned-symbols], [Enable versioned symbols in shared library])
|
||||||
|
AC_HELP_STRING([--disable-versioned-symbols], [Disable versioned symbols in shared library]),
|
||||||
|
[ case "$enableval" in
|
||||||
|
yes) AC_MSG_RESULT(yes)
|
||||||
|
AC_MSG_CHECKING([if libraries can be versioned])
|
||||||
|
GLD=`$LD --help < /dev/null 2>/dev/null | grep version-script`
|
||||||
|
if test -z "$GLD"; then
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
AC_MSG_WARN([You need an ld version supporting the --version-script option])
|
||||||
|
else
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
if test "x$OPENSSL_ENABLED" = "x1"; then
|
||||||
|
versioned_symbols_flavour="OPENSSL_"
|
||||||
|
elif test "x$GNUTLS_ENABLED" == "x1"; then
|
||||||
|
versioned_symbols_flavour="GNUTLS_"
|
||||||
|
elif test "x$NSS_ENABLED" == "x1"; then
|
||||||
|
versioned_symbols_flavour="NSS_"
|
||||||
|
elif test "x$POLARSSL_ENABLED" == "x1"; then
|
||||||
|
versioned_symbols_flavour="POLARSSL_"
|
||||||
|
elif test "x$CYASSL_ENABLED" == "x1"; then
|
||||||
|
versioned_symbols_flavour="CYASSL_"
|
||||||
|
elif test "x$AXTLS_ENABLED" == "x1"; then
|
||||||
|
versioned_symbols_flavour="AXTLS_"
|
||||||
|
else
|
||||||
|
versioned_symbols_flavour=""
|
||||||
|
fi
|
||||||
|
versioned_symbols="yes"
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
|
||||||
|
*) AC_MSG_RESULT(no)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
], [
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
AC_SUBST(VERSIONED_FLAVOUR, ["$versioned_symbols_flavour"])
|
||||||
|
AM_CONDITIONAL(VERSIONED_SYMBOLS, test "x$versioned_symbols" = "xyes")
|
||||||
|
|
||||||
|
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
dnl Check for the presence of IDN libraries and headers
|
dnl Check for the presence of IDN libraries and headers
|
||||||
dnl **********************************************************************
|
dnl **********************************************************************
|
||||||
|
|
||||||
AC_MSG_CHECKING([whether to build with libidn])
|
AC_MSG_CHECKING([whether to build with libidn])
|
||||||
|
OPT_IDN="default"
|
||||||
AC_ARG_WITH(libidn,
|
AC_ARG_WITH(libidn,
|
||||||
AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage])
|
AC_HELP_STRING([--with-libidn=PATH],[Enable libidn usage])
|
||||||
AC_HELP_STRING([--without-libidn],[Disable libidn usage]),
|
AC_HELP_STRING([--without-libidn],[Disable libidn usage]),
|
||||||
[LIBIDN="$withval"])
|
[OPT_IDN=$withval])
|
||||||
|
case "$OPT_IDN" in
|
||||||
case "$LIBIDN" in
|
|
||||||
no)
|
no)
|
||||||
AC_MSG_RESULT(no)
|
dnl --without-libidn option used
|
||||||
;;
|
want_idn="no"
|
||||||
*) AC_MSG_RESULT(yes)
|
AC_MSG_RESULT([no])
|
||||||
|
;;
|
||||||
idn=""
|
default)
|
||||||
dnl if there is a given path, check that FIRST
|
dnl configure option not specified
|
||||||
if test -n "$LIBIDN"; then
|
want_idn="yes"
|
||||||
if test "x$LIBIDN" != "xyes"; then
|
want_idn_path="default"
|
||||||
oldLDFLAGS=$LDFLAGS
|
AC_MSG_RESULT([(assumed) yes])
|
||||||
oldCPPFLAGS=$CPPFLAGS
|
;;
|
||||||
LDFLAGS="$LDFLAGS -L$LIBIDN/lib"
|
yes)
|
||||||
CPPFLAGS="$CPPFLAGS -I$LIBIDN/include"
|
dnl --with-libidn option used without path
|
||||||
idn="yes"
|
want_idn="yes"
|
||||||
AC_CHECK_LIB(idn, idna_to_ascii_4i, ,
|
want_idn_path="default"
|
||||||
idn=""
|
AC_MSG_RESULT([yes])
|
||||||
LDFLAGS=$oldLDFLAGS
|
;;
|
||||||
CPPFLAGS=$oldCPPFLAGS)
|
*)
|
||||||
fi
|
dnl --with-libidn option used with path
|
||||||
fi
|
want_idn="yes"
|
||||||
|
want_idn_path="$withval"
|
||||||
if test "x$idn" != "xyes"; then
|
AC_MSG_RESULT([yes ($withval)])
|
||||||
dnl check with default paths
|
;;
|
||||||
idn="yes"
|
|
||||||
AC_CHECK_LIB(idn, idna_to_ascii_lz, ,
|
|
||||||
idn="")
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test "x$idn" = "xyes"; then
|
|
||||||
curl_idn_msg="enabled"
|
|
||||||
AC_SUBST(IDN_ENABLED, [1])
|
|
||||||
dnl different versions of libidn have different setups of these:
|
|
||||||
AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror)
|
|
||||||
AC_CHECK_HEADERS( idn-free.h tld.h )
|
|
||||||
fi
|
|
||||||
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
if test "$want_idn" = "yes"; then
|
||||||
|
dnl idn library support has been requested
|
||||||
|
clean_CPPFLAGS="$CPPFLAGS"
|
||||||
|
clean_LDFLAGS="$LDFLAGS"
|
||||||
|
clean_LIBS="$LIBS"
|
||||||
|
PKGCONFIG="no"
|
||||||
|
#
|
||||||
|
if test "$want_idn_path" != "default"; then
|
||||||
|
dnl path has been specified
|
||||||
|
IDN_PCDIR="$want_idn_path/lib$libsuff/pkgconfig"
|
||||||
|
CURL_CHECK_PKGCONFIG(libidn, [$IDN_PCDIR])
|
||||||
|
if test "$PKGCONFIG" != "no"; then
|
||||||
|
IDN_LIBS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
||||||
|
$PKGCONFIG --libs-only-l libidn 2>/dev/null`
|
||||||
|
IDN_LDFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
||||||
|
$PKGCONFIG --libs-only-L libidn 2>/dev/null`
|
||||||
|
IDN_CPPFLAGS=`CURL_EXPORT_PCDIR([$IDN_PCDIR]) dnl
|
||||||
|
$PKGCONFIG --cflags-only-I libidn 2>/dev/null`
|
||||||
|
IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'`
|
||||||
|
else
|
||||||
|
dnl pkg-config not available or provides no info
|
||||||
|
IDN_LIBS="-lidn"
|
||||||
|
IDN_LDFLAGS="-L$want_idn_path/lib$libsuff"
|
||||||
|
IDN_CPPFLAGS="-I$want_idn_path/include"
|
||||||
|
IDN_DIR="$want_idn_path/lib$libsuff"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
dnl path not specified
|
||||||
|
CURL_CHECK_PKGCONFIG(libidn)
|
||||||
|
if test "$PKGCONFIG" != "no"; then
|
||||||
|
IDN_LIBS=`$PKGCONFIG --libs-only-l libidn 2>/dev/null`
|
||||||
|
IDN_LDFLAGS=`$PKGCONFIG --libs-only-L libidn 2>/dev/null`
|
||||||
|
IDN_CPPFLAGS=`$PKGCONFIG --cflags-only-I libidn 2>/dev/null`
|
||||||
|
IDN_DIR=`echo $IDN_LDFLAGS | $SED -e 's/-L//'`
|
||||||
|
else
|
||||||
|
dnl pkg-config not available or provides no info
|
||||||
|
IDN_LIBS="-lidn"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
if test "$PKGCONFIG" != "no"; then
|
||||||
|
AC_MSG_NOTICE([pkg-config: IDN_LIBS: "$IDN_LIBS"])
|
||||||
|
AC_MSG_NOTICE([pkg-config: IDN_LDFLAGS: "$IDN_LDFLAGS"])
|
||||||
|
AC_MSG_NOTICE([pkg-config: IDN_CPPFLAGS: "$IDN_CPPFLAGS"])
|
||||||
|
AC_MSG_NOTICE([pkg-config: IDN_DIR: "$IDN_DIR"])
|
||||||
|
else
|
||||||
|
AC_MSG_NOTICE([IDN_LIBS: "$IDN_LIBS"])
|
||||||
|
AC_MSG_NOTICE([IDN_LDFLAGS: "$IDN_LDFLAGS"])
|
||||||
|
AC_MSG_NOTICE([IDN_CPPFLAGS: "$IDN_CPPFLAGS"])
|
||||||
|
AC_MSG_NOTICE([IDN_DIR: "$IDN_DIR"])
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
CPPFLAGS="$IDN_CPPFLAGS $CPPFLAGS"
|
||||||
|
LDFLAGS="$IDN_LDFLAGS $LDFLAGS"
|
||||||
|
LIBS="$IDN_LIBS $LIBS"
|
||||||
|
#
|
||||||
|
AC_MSG_CHECKING([if idna_to_ascii_4i can be linked])
|
||||||
|
AC_LINK_IFELSE([
|
||||||
|
AC_LANG_FUNC_LINK_TRY([idna_to_ascii_4i])
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT([yes])
|
||||||
|
tst_links_libidn="yes"
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT([no])
|
||||||
|
tst_links_libidn="no"
|
||||||
|
])
|
||||||
|
if test "$tst_links_libidn" = "no"; then
|
||||||
|
AC_MSG_CHECKING([if idna_to_ascii_lz can be linked])
|
||||||
|
AC_LINK_IFELSE([
|
||||||
|
AC_LANG_FUNC_LINK_TRY([idna_to_ascii_lz])
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT([yes])
|
||||||
|
tst_links_libidn="yes"
|
||||||
|
],[
|
||||||
|
AC_MSG_RESULT([no])
|
||||||
|
tst_links_libidn="no"
|
||||||
|
])
|
||||||
|
fi
|
||||||
|
#
|
||||||
|
if test "$tst_links_libidn" = "yes"; then
|
||||||
|
AC_DEFINE(HAVE_LIBIDN, 1, [Define to 1 if you have the `idn' library (-lidn).])
|
||||||
|
dnl different versions of libidn have different setups of these:
|
||||||
|
AC_CHECK_FUNCS( idn_free idna_strerror tld_strerror )
|
||||||
|
AC_CHECK_HEADERS( idn-free.h tld.h )
|
||||||
|
if test "x$ac_cv_header_tld_h" = "xyes"; then
|
||||||
|
AC_SUBST([IDN_ENABLED], [1])
|
||||||
|
curl_idn_msg="enabled"
|
||||||
|
if test -n "$IDN_DIR"; then
|
||||||
|
LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$IDN_DIR"
|
||||||
|
export LD_LIBRARY_PATH
|
||||||
|
AC_MSG_NOTICE([Added $IDN_DIR to LD_LIBRARY_PATH])
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
AC_MSG_WARN([Libraries for IDN support too old: IDN disabled])
|
||||||
|
CPPFLAGS="$clean_CPPFLAGS"
|
||||||
|
LDFLAGS="$clean_LDFLAGS"
|
||||||
|
LIBS="$clean_LIBS"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
AC_MSG_WARN([Cannot find libraries for IDN support: IDN disabled])
|
||||||
|
CPPFLAGS="$clean_CPPFLAGS"
|
||||||
|
LDFLAGS="$clean_LDFLAGS"
|
||||||
|
LIBS="$clean_LIBS"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
dnl Let's hope this split URL remains working:
|
dnl Let's hope this split URL remains working:
|
||||||
dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \
|
dnl http://publibn.boulder.ibm.com/doc_link/en_US/a_doc_lib/aixprggd/ \
|
||||||
@@ -2866,48 +3059,9 @@ AC_HELP_STRING([--disable-cookies],[Disable cookies support]),
|
|||||||
)
|
)
|
||||||
|
|
||||||
dnl ************************************************************
|
dnl ************************************************************
|
||||||
dnl Enable hiding of internal symbols in library to reduce its size and
|
dnl hiding of library internal symbols
|
||||||
dnl speed dynamic linking of applications. This currently is only supported
|
|
||||||
dnl on gcc >= 4.0 and SunPro C.
|
|
||||||
dnl
|
dnl
|
||||||
AC_MSG_CHECKING([whether to enable hidden symbols in the library])
|
CURL_CONFIGURE_SYMBOL_HIDING
|
||||||
AC_ARG_ENABLE(hidden-symbols,
|
|
||||||
AC_HELP_STRING([--enable-hidden-symbols],[Hide internal symbols in library])
|
|
||||||
AC_HELP_STRING([--disable-hidden-symbols],[Leave all symbols with default visibility in library]),
|
|
||||||
[ case "$enableval" in
|
|
||||||
no)
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
AC_MSG_CHECKING([whether $CC supports it])
|
|
||||||
if test "$GCC" = yes ; then
|
|
||||||
if $CC --help --verbose 2>&1 | grep fvisibility= > /dev/null ||
|
|
||||||
dnl clang always supports -fvisibility= but it doesn't show up
|
|
||||||
dnl under --help.
|
|
||||||
test "$compiler_id" = "CLANG"; then
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols])
|
|
||||||
AC_DEFINE(CURL_EXTERN_SYMBOL, [__attribute__ ((visibility ("default")))], [to make a symbol visible])
|
|
||||||
CFLAGS="$CFLAGS -fvisibility=hidden"
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi
|
|
||||||
|
|
||||||
else
|
|
||||||
dnl Test for SunPro cc
|
|
||||||
if $CC 2>&1 | grep flags >/dev/null && $CC -flags | grep xldscope= >/dev/null ; then
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(CURL_HIDDEN_SYMBOLS, 1, [to enable hidden symbols])
|
|
||||||
AC_DEFINE(CURL_EXTERN_SYMBOL, [__global], [to make a symbol visible])
|
|
||||||
CFLAGS="$CFLAGS -xldscope=hidden"
|
|
||||||
else
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac ],
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
)
|
|
||||||
|
|
||||||
dnl ************************************************************
|
dnl ************************************************************
|
||||||
dnl enforce SONAME bump
|
dnl enforce SONAME bump
|
||||||
@@ -3108,6 +3262,7 @@ AC_CONFIG_FILES([Makefile \
|
|||||||
include/curl/Makefile \
|
include/curl/Makefile \
|
||||||
src/Makefile \
|
src/Makefile \
|
||||||
lib/Makefile \
|
lib/Makefile \
|
||||||
|
lib/libcurl.vers \
|
||||||
tests/Makefile \
|
tests/Makefile \
|
||||||
tests/data/Makefile \
|
tests/data/Makefile \
|
||||||
tests/server/Makefile \
|
tests/server/Makefile \
|
||||||
@@ -3136,31 +3291,32 @@ CURL_GENERATE_CONFIGUREHELP_PM
|
|||||||
|
|
||||||
AC_MSG_NOTICE([Configured to build curl/libcurl:
|
AC_MSG_NOTICE([Configured to build curl/libcurl:
|
||||||
|
|
||||||
curl version: ${CURLVERSION}
|
curl version: ${CURLVERSION}
|
||||||
Host setup: ${host}
|
Host setup: ${host}
|
||||||
Install prefix: ${prefix}
|
Install prefix: ${prefix}
|
||||||
Compiler: ${CC}
|
Compiler: ${CC}
|
||||||
SSL support: ${curl_ssl_msg}
|
SSL support: ${curl_ssl_msg}
|
||||||
SSH support: ${curl_ssh_msg}
|
SSH support: ${curl_ssh_msg}
|
||||||
zlib support: ${curl_zlib_msg}
|
zlib support: ${curl_zlib_msg}
|
||||||
krb4 support: ${curl_krb4_msg}
|
krb4 support: ${curl_krb4_msg}
|
||||||
GSSAPI support: ${curl_gss_msg}
|
GSSAPI support: ${curl_gss_msg}
|
||||||
SPNEGO support: ${curl_spnego_msg}
|
SPNEGO support: ${curl_spnego_msg}
|
||||||
TLS-SRP support: ${curl_tls_srp_msg}
|
TLS-SRP support: ${curl_tls_srp_msg}
|
||||||
resolver: ${curl_res_msg}
|
resolver: ${curl_res_msg}
|
||||||
ipv6 support: ${curl_ipv6_msg}
|
ipv6 support: ${curl_ipv6_msg}
|
||||||
IDN support: ${curl_idn_msg}
|
IDN support: ${curl_idn_msg}
|
||||||
Build libcurl: Shared=${enable_shared}, Static=${enable_static}
|
Build libcurl: Shared=${enable_shared}, Static=${enable_static}
|
||||||
Built-in manual: ${curl_manual_msg}
|
Built-in manual: ${curl_manual_msg}
|
||||||
Verbose errors: ${curl_verbose_msg}
|
--libcurl option: ${curl_libcurl_msg}
|
||||||
SSPI support: ${curl_sspi_msg}
|
Verbose errors: ${curl_verbose_msg}
|
||||||
ca cert bundle: ${ca}
|
SSPI support: ${curl_sspi_msg}
|
||||||
ca cert path: ${capath}
|
ca cert bundle: ${ca}
|
||||||
LDAP support: ${curl_ldap_msg}
|
ca cert path: ${capath}
|
||||||
LDAPS support: ${curl_ldaps_msg}
|
LDAP support: ${curl_ldap_msg}
|
||||||
RTSP support: ${curl_rtsp_msg}
|
LDAPS support: ${curl_ldaps_msg}
|
||||||
RTMP support: ${curl_rtmp_msg}
|
RTSP support: ${curl_rtsp_msg}
|
||||||
Protocols: ${SUPPORT_PROTOCOLS}
|
RTMP support: ${curl_rtmp_msg}
|
||||||
|
Protocols: ${SUPPORT_PROTOCOLS}
|
||||||
])
|
])
|
||||||
|
|
||||||
if test "x$soname_bump" = "xyes"; then
|
if test "x$soname_bump" = "xyes"; then
|
||||||
|
@@ -142,9 +142,9 @@ 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 @LDFLAGS@ @LIBCURL_LIBS@ @LIBS@
|
echo ${CURLLIBDIR}-lcurl @LIBCURL_LIBS@ @LIBS@
|
||||||
else
|
else
|
||||||
echo ${CURLLIBDIR}-lcurl @LDFLAGS@ @LIBS@
|
echo ${CURLLIBDIR}-lcurl @LIBS@
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
@@ -34,6 +34,7 @@
|
|||||||
3.3 How To Make a Patch without git
|
3.3 How To Make a Patch without git
|
||||||
3.4 How to get your changes into the main sources
|
3.4 How to get your changes into the main sources
|
||||||
3.5 Write good commit messages
|
3.5 Write good commit messages
|
||||||
|
3.6 Please don't send pull requests
|
||||||
|
|
||||||
==============================================================================
|
==============================================================================
|
||||||
|
|
||||||
@@ -276,3 +277,27 @@
|
|||||||
and make sure that you have your own user and email setup correctly in git
|
and make sure that you have your own user and email setup correctly in git
|
||||||
before you commit
|
before you commit
|
||||||
|
|
||||||
|
3.6 Please don't send pull requests
|
||||||
|
|
||||||
|
With git (and expecially github) it is easy and tempting to send a pull
|
||||||
|
request to one or more people in the curl project to have changes merged this
|
||||||
|
way instead of mailing patches to the curl-library mailing list.
|
||||||
|
|
||||||
|
We don't like that. We want them mailed for these reasons:
|
||||||
|
|
||||||
|
- Peer review. Anyone and everyone on the list can review, comment and
|
||||||
|
improve on the patch. Pull requests limit this ability.
|
||||||
|
|
||||||
|
- Anyone can merge the patch into their own trees for testing and those who
|
||||||
|
have push rights can push it to the main repo. It doesn't have to be anyone
|
||||||
|
the patch author knows beforehand.
|
||||||
|
|
||||||
|
- Commit messages can be tweaked and changed if merged locally instead of
|
||||||
|
using github. Merges directly on github requires the changes to be perfect
|
||||||
|
already, which they seldomly are.
|
||||||
|
|
||||||
|
- Merges on github prevents rebases and even enforces --no-ff which is a git
|
||||||
|
style we don't otherwise use in the project
|
||||||
|
|
||||||
|
However: once patches have been reviewed and deemed fine on list they are
|
||||||
|
perfectly OK to be pulled from a published git tree.
|
||||||
|
45
docs/FAQ
45
docs/FAQ
@@ -1,4 +1,4 @@
|
|||||||
Updated: March 8, 2011 (http://curl.haxx.se/docs/faq.html)
|
Updated: December 7, 2011 (http://curl.haxx.se/docs/faq.html)
|
||||||
_ _ ____ _
|
_ _ ____ _
|
||||||
___| | | | _ \| |
|
___| | | | _ \| |
|
||||||
/ __| | | | |_) | |
|
/ __| | | | |_) | |
|
||||||
@@ -306,41 +306,10 @@ FAQ
|
|||||||
We don't know how many users that downloaded or installed curl and then
|
We don't know how many users that downloaded or installed curl and then
|
||||||
never use it.
|
never use it.
|
||||||
|
|
||||||
Some facts to use as input to the math:
|
In May 2012 Daniel did a counting game and came up with a number that may
|
||||||
|
be completely wrong or somewhat accurate. 300 million!
|
||||||
|
|
||||||
curl packages are downloaded from the curl.haxx.se and mirrors over a
|
See http://daniel.haxx.se/blog/2012/05/16/300m-users/
|
||||||
million times per year. curl is installed by default with most Linux
|
|
||||||
distributions. curl is installed by default with Mac OS X. curl and libcurl
|
|
||||||
as used by numerous applications that include libcurl binaries in their
|
|
||||||
distribution packages (like Adobe Acrobat Reader and Google Earth).
|
|
||||||
|
|
||||||
More than a hundred known named companies use curl in commercial
|
|
||||||
environments and products and more than a hundred known named open source
|
|
||||||
projects depend on (lib)curl.
|
|
||||||
|
|
||||||
In a poll on the curl web site mid-2005, more than 50% of the 300+ answers
|
|
||||||
estimated a user base of one million users or more.
|
|
||||||
|
|
||||||
In March 2005, the "Linux Counter project" estimated a total Linux user base
|
|
||||||
of some 29 millions, while Netcraft detected some 4 million "active" Linux
|
|
||||||
based web servers. A guess is that a fair amount of these Linux
|
|
||||||
installations have curl installed.
|
|
||||||
|
|
||||||
The Debian project maintains statistics on packages installed by people
|
|
||||||
who have voluntarily run their package counting application. In mid-2010,
|
|
||||||
libcurl3 was installed on over 55000 such systems (62% of reporting systems)
|
|
||||||
and was one of the 320 most popular installed packages (out of about 107000
|
|
||||||
possible packages).
|
|
||||||
|
|
||||||
All this taken together, there is no doubt that there are millions of
|
|
||||||
(lib)curl users.
|
|
||||||
|
|
||||||
http://curl.haxx.se/docs/companies.html
|
|
||||||
http://curl.haxx.se/docs/programs.html
|
|
||||||
http://curl.haxx.se/libcurl/using/apps.html
|
|
||||||
http://counter.li.org/estimates.php
|
|
||||||
http://news.netcraft.com/archives/2005/03/14/fedora_makes_rapid_progress.html
|
|
||||||
http://qa.debian.org/popcon.php?package=curl
|
|
||||||
|
|
||||||
1.11 Why don't you update ca-bundle.crt
|
1.11 Why don't you update ca-bundle.crt
|
||||||
|
|
||||||
@@ -726,6 +695,12 @@ FAQ
|
|||||||
|
|
||||||
curl --header "Host: www.example.com" http://127.0.0.1/
|
curl --header "Host: www.example.com" http://127.0.0.1/
|
||||||
|
|
||||||
|
You can also opt to add faked host name entries to curl with the --resolve
|
||||||
|
option. That has the added benefit that things like redirects will also work
|
||||||
|
properly. The above operation would instead be done as:
|
||||||
|
|
||||||
|
curl --resolve www.example.com:80:127.0.0.1 http://www.example.com/
|
||||||
|
|
||||||
3.20 How to SFTP from my user's home directory?
|
3.20 How to SFTP from my user's home directory?
|
||||||
|
|
||||||
Contrary to how FTP works, SFTP and SCP URLs specify the exact directory to
|
Contrary to how FTP works, SFTP and SCP URLs specify the exact directory to
|
||||||
|
35
docs/INSTALL
35
docs/INSTALL
@@ -217,9 +217,9 @@ Win32
|
|||||||
adjust as necessary. It is also possible to override these paths with
|
adjust as necessary. It is also possible to override these paths with
|
||||||
environment variables, for example:
|
environment variables, for example:
|
||||||
|
|
||||||
set ZLIB_PATH=c:\zlib-1.2.5
|
set ZLIB_PATH=c:\zlib-1.2.7
|
||||||
set OPENSSL_PATH=c:\openssl-0.9.8r
|
set OPENSSL_PATH=c:\openssl-0.9.8x
|
||||||
set LIBSSH2_PATH=c:\libssh2-1.2.8
|
set LIBSSH2_PATH=c:\libssh2-1.4.2
|
||||||
|
|
||||||
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!
|
||||||
@@ -320,7 +320,7 @@ Win32
|
|||||||
documentation on how to compile zlib. Define the ZLIB_PATH environment
|
documentation on how to compile zlib. Define the ZLIB_PATH environment
|
||||||
variable to the location of zlib.h and zlib.lib, for example:
|
variable to the location of zlib.h and zlib.lib, for example:
|
||||||
|
|
||||||
set ZLIB_PATH=c:\zlib-1.2.5
|
set ZLIB_PATH=c:\zlib-1.2.7
|
||||||
|
|
||||||
Then run 'nmake vc-zlib' in curl's root directory.
|
Then run 'nmake vc-zlib' in curl's root directory.
|
||||||
|
|
||||||
@@ -334,7 +334,7 @@ Win32
|
|||||||
Before running nmake define the OPENSSL_PATH environment variable with
|
Before running nmake define the OPENSSL_PATH environment variable with
|
||||||
the root/base directory of OpenSSL, for example:
|
the root/base directory of OpenSSL, for example:
|
||||||
|
|
||||||
set OPENSSL_PATH=c:\openssl-0.9.8q
|
set OPENSSL_PATH=c:\openssl-0.9.8x
|
||||||
|
|
||||||
Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root
|
Then run 'nmake vc-ssl' or 'nmake vc-ssl-dll' in curl's root
|
||||||
directory. 'nmake vc-ssl' will create a libcurl static and dynamic
|
directory. 'nmake vc-ssl' will create a libcurl static and dynamic
|
||||||
@@ -840,7 +840,30 @@ VxWorks
|
|||||||
|
|
||||||
Android
|
Android
|
||||||
=======
|
=======
|
||||||
See the build notes in the Android.mk file.
|
Method using the static makefile:
|
||||||
|
- see the build notes in the Android.mk file.
|
||||||
|
|
||||||
|
Method using a configure cross-compile (tested with Android NDK r7b):
|
||||||
|
- prepare the toolchain of the Android NDK for standalone use; this can
|
||||||
|
be done by invoking the script:
|
||||||
|
./tools/make-standalone-toolchain.sh
|
||||||
|
which creates a usual cross-compile toolchain. Lets assume that you put
|
||||||
|
this toolchain below /opt then invoke configure with something like:
|
||||||
|
export PATH=/opt/arm-linux-androideabi-4.4.3/bin:$PATH
|
||||||
|
./configure --host=arm-linux-androideabi [more configure options]
|
||||||
|
make
|
||||||
|
- if you want to compile directly from our GIT repo you might run into
|
||||||
|
this issue with older automake stuff:
|
||||||
|
checking host system type...
|
||||||
|
Invalid configuration `arm-linux-androideabi':
|
||||||
|
system `androideabi' not recognized
|
||||||
|
configure: error: /bin/sh ./config.sub arm-linux-androideabi failed
|
||||||
|
this issue can be fixed with using more recent versions of config.sub
|
||||||
|
and config.guess which can be obtained here:
|
||||||
|
http://git.savannah.gnu.org/gitweb/?p=config.git;a=tree
|
||||||
|
you need to replace your system-own versions which usually can be
|
||||||
|
found in your automake folder:
|
||||||
|
find /usr -name config.sub
|
||||||
|
|
||||||
|
|
||||||
CROSS COMPILE
|
CROSS COMPILE
|
||||||
|
0
docs/INSTALL.cmake
Executable file → Normal file
0
docs/INSTALL.cmake
Executable file → Normal file
@@ -39,11 +39,11 @@ Portability
|
|||||||
libssh2 0.16
|
libssh2 0.16
|
||||||
c-ares 1.6.0
|
c-ares 1.6.0
|
||||||
libidn 0.4.1
|
libidn 0.4.1
|
||||||
cyassl 1.4.0
|
cyassl 2.0.0
|
||||||
openldap 2.0
|
openldap 2.0
|
||||||
MIT krb5 lib 1.2.4
|
MIT krb5 lib 1.2.4
|
||||||
qsossl V5R2M0
|
qsossl V5R2M0
|
||||||
NSS 3.11.x
|
NSS 3.12.x
|
||||||
axTLS 1.2.7
|
axTLS 1.2.7
|
||||||
Heimdal ?
|
Heimdal ?
|
||||||
|
|
||||||
@@ -68,7 +68,7 @@ Portability
|
|||||||
GNU Autoconf 2.57
|
GNU Autoconf 2.57
|
||||||
GNU Automake 1.7 (we currently avoid 1.10 due to Solaris-related bugs)
|
GNU Automake 1.7 (we currently avoid 1.10 due to Solaris-related bugs)
|
||||||
GNU M4 1.4
|
GNU M4 1.4
|
||||||
perl 4
|
perl 5.004
|
||||||
roffit 0.5
|
roffit 0.5
|
||||||
groff ? (any version that supports "groff -Tps -man [in] [out]")
|
groff ? (any version that supports "groff -Tps -man [in] [out]")
|
||||||
ps2pdf (gs) ?
|
ps2pdf (gs) ?
|
||||||
@@ -104,9 +104,9 @@ Windows vs Unix
|
|||||||
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
Inside the source code, We make an effort to avoid '#ifdef [Your OS]'. All
|
||||||
conditionals that deal with features *should* instead be in the format
|
conditionals that deal with features *should* instead be in the format
|
||||||
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
'#ifdef HAVE_THAT_WEIRD_FUNCTION'. Since Windows can't run configure scripts,
|
||||||
we maintain two curl_config-win32.h files (one in lib/ and one in src/) that
|
we maintain a curl_config-win32.h file in lib directory that is supposed to
|
||||||
are supposed to look exactly as a curl_config.h file would have looked like on
|
look exactly as a curl_config.h file would have looked like on a Windows
|
||||||
a Windows machine!
|
machine!
|
||||||
|
|
||||||
Generally speaking: always remember that this will be compiled on dozens of
|
Generally speaking: always remember that this will be compiled on dozens of
|
||||||
operating systems. Don't walk on the edge.
|
operating systems. Don't walk on the edge.
|
||||||
|
@@ -3,6 +3,15 @@ join in and help us correct one or more of these! Also be sure to check the
|
|||||||
changelog of the current development status, as one or more of these problems
|
changelog of the current development status, as one or more of these problems
|
||||||
may have been fixed since this was written!
|
may have been fixed since this was written!
|
||||||
|
|
||||||
|
78. curl and libcurl don't always signal the client properly when "sending"
|
||||||
|
zero bytes files - it makes for example the command line client not creating
|
||||||
|
any file at all. Like when using FTP.
|
||||||
|
http://curl.haxx.se/bug/view.cgi?id=3438362
|
||||||
|
|
||||||
|
77. CURLOPT_FORBID_REUSE on a handle prevents NTLM from working since it
|
||||||
|
"absuses" the underlying connection re-use system and if connections are
|
||||||
|
forced to close they break the NTLM support.
|
||||||
|
|
||||||
76. The SOCKET type in Win64 is 64 bits large (and thus so is curl_socket_t on
|
76. The SOCKET type in Win64 is 64 bits large (and thus so is curl_socket_t on
|
||||||
that platform), and long is only 32 bits. It makes it impossible for
|
that platform), and long is only 32 bits. It makes it impossible for
|
||||||
curl_easy_getinfo() to return a socket properly with the CURLINFO_LASTSOCKET
|
curl_easy_getinfo() to return a socket properly with the CURLINFO_LASTSOCKET
|
||||||
|
@@ -13,6 +13,7 @@ MAIL ETIQUETTE
|
|||||||
1.4 Subscription Required
|
1.4 Subscription Required
|
||||||
1.5 Moderation of new posters
|
1.5 Moderation of new posters
|
||||||
1.6 Handling trolls and spam
|
1.6 Handling trolls and spam
|
||||||
|
1.7 How to unsubscribe
|
||||||
|
|
||||||
2. Sending mail
|
2. Sending mail
|
||||||
2.1 Reply or New Mail
|
2.1 Reply or New Mail
|
||||||
@@ -110,6 +111,20 @@ MAIL ETIQUETTE
|
|||||||
|
|
||||||
Don't feed the trolls!
|
Don't feed the trolls!
|
||||||
|
|
||||||
|
1.7 How to unsubscribe
|
||||||
|
|
||||||
|
You unsubscribe the same way you subscribed in the first place. You go to
|
||||||
|
the page for the particular mailing list you're subscribed to and you enter
|
||||||
|
your email address and password and press the unsubscribe button.
|
||||||
|
|
||||||
|
Also, this information is included in the headers of every mail that is sent
|
||||||
|
out to all curl related mailing lists and there's footer in each mail that
|
||||||
|
links to the "admin" page on which you can unsubscribe and change other
|
||||||
|
options.
|
||||||
|
|
||||||
|
You NEVER EVER email the mailing list requesting someone else to get you off
|
||||||
|
the list.
|
||||||
|
|
||||||
|
|
||||||
2. Sending mail
|
2. Sending mail
|
||||||
|
|
||||||
|
@@ -328,7 +328,7 @@ POST (HTTP)
|
|||||||
If the content-type is not specified, curl will try to guess from the file
|
If the content-type is not specified, curl will try to guess from the file
|
||||||
extension (it only knows a few), or use the previously specified type (from
|
extension (it only knows a few), or use the previously specified type (from
|
||||||
an earlier file if several files are specified in a list) or else it will
|
an earlier file if several files are specified in a list) or else it will
|
||||||
using the default type 'text/plain'.
|
use the default type 'application/octet-stream'.
|
||||||
|
|
||||||
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
Emulate a fill-in form with -F. Let's say you fill in three fields in a
|
||||||
form. One field is a file name which to post, one field is your name and one
|
form. One field is a file name which to post, one field is your name and one
|
||||||
|
@@ -22,9 +22,9 @@
|
|||||||
|
|
||||||
AUTOMAKE_OPTIONS = foreign no-dependencies
|
AUTOMAKE_OPTIONS = foreign no-dependencies
|
||||||
|
|
||||||
man_MANS = curl.1 curl-config.1
|
man_MANS = curl.1 curl-config.1 mk-ca-bundle.1
|
||||||
GENHTMLPAGES = curl.html curl-config.html
|
GENHTMLPAGES = curl.html curl-config.html mk-ca-bundle.html
|
||||||
PDFPAGES = curl.pdf curl-config.pdf
|
PDFPAGES = curl.pdf curl-config.pdf mk-ca-bundle.pdf
|
||||||
|
|
||||||
HTMLPAGES = $(GENHTMLPAGES) index.html
|
HTMLPAGES = $(GENHTMLPAGES) index.html
|
||||||
|
|
||||||
|
0
docs/README.cmake
Executable file → Normal file
0
docs/README.cmake
Executable file → Normal file
48
docs/THANKS
48
docs/THANKS
@@ -14,15 +14,19 @@ Adrian Schuur
|
|||||||
Adriano Meirelles
|
Adriano Meirelles
|
||||||
Akos Pasztory
|
Akos Pasztory
|
||||||
Alan Pinstein
|
Alan Pinstein
|
||||||
|
Albert Chin
|
||||||
Albert Chin-A-Young
|
Albert Chin-A-Young
|
||||||
Albert Choy
|
Albert Choy
|
||||||
Ale Vesely
|
Ale Vesely
|
||||||
|
Alejandro Alvarez
|
||||||
Aleksandar Milivojevic
|
Aleksandar Milivojevic
|
||||||
|
Alessandro Ghedini
|
||||||
Alessandro Vesely
|
Alessandro Vesely
|
||||||
Alex Bligh
|
Alex Bligh
|
||||||
Alex Fishman
|
Alex Fishman
|
||||||
Alex Neblett
|
Alex Neblett
|
||||||
Alex Suykov
|
Alex Suykov
|
||||||
|
Alex Vinnik
|
||||||
Alex aka WindEagle
|
Alex aka WindEagle
|
||||||
Alexander Beedie
|
Alexander Beedie
|
||||||
Alexander Kourakos
|
Alexander Kourakos
|
||||||
@@ -32,6 +36,7 @@ Alexander Zhuravlev
|
|||||||
Alexey Borzov
|
Alexey Borzov
|
||||||
Alexey Pesternikov
|
Alexey Pesternikov
|
||||||
Alexey Simak
|
Alexey Simak
|
||||||
|
Alexey Zakhlestin
|
||||||
Alexis Carvalho
|
Alexis Carvalho
|
||||||
Alfred Gebert
|
Alfred Gebert
|
||||||
Allen Pulsifer
|
Allen Pulsifer
|
||||||
@@ -50,6 +55,7 @@ Andreas Rieke
|
|||||||
Andreas Schuldei
|
Andreas Schuldei
|
||||||
Andreas Wurf
|
Andreas Wurf
|
||||||
Andrei Benea
|
Andrei Benea
|
||||||
|
Andrei Cipu
|
||||||
Andres Garcia
|
Andres Garcia
|
||||||
Andrew Benham
|
Andrew Benham
|
||||||
Andrew Biggs
|
Andrew Biggs
|
||||||
@@ -66,10 +72,12 @@ Andy Tsouladze
|
|||||||
Angus Mackay
|
Angus Mackay
|
||||||
Anthony Bryan
|
Anthony Bryan
|
||||||
Antoine Calando
|
Antoine Calando
|
||||||
|
Anton Bychkov
|
||||||
Anton Kalmykov
|
Anton Kalmykov
|
||||||
Arkadiusz Miskiewicz
|
Arkadiusz Miskiewicz
|
||||||
Armel Asselin
|
Armel Asselin
|
||||||
Arnaud Ebalard
|
Arnaud Ebalard
|
||||||
|
Arthur Murray
|
||||||
Arve Knudsen
|
Arve Knudsen
|
||||||
Ates Goral
|
Ates Goral
|
||||||
Augustus Saunders
|
Augustus Saunders
|
||||||
@@ -87,6 +95,7 @@ Ben Winslow
|
|||||||
Benbuck Nason
|
Benbuck Nason
|
||||||
Benjamin Gerard
|
Benjamin Gerard
|
||||||
Bernard Leak
|
Bernard Leak
|
||||||
|
Bernhard Reutner-Fischer
|
||||||
Bertrand Demiddelaer
|
Bertrand Demiddelaer
|
||||||
Bill Egert
|
Bill Egert
|
||||||
Bill Hoffman
|
Bill Hoffman
|
||||||
@@ -101,6 +110,7 @@ Brad Burdick
|
|||||||
Brad Hards
|
Brad Hards
|
||||||
Brad King
|
Brad King
|
||||||
Bradford Bruce
|
Bradford Bruce
|
||||||
|
Brandon Wang
|
||||||
Brendan Jurd
|
Brendan Jurd
|
||||||
Brent Beardsley
|
Brent Beardsley
|
||||||
Brian Akins
|
Brian Akins
|
||||||
@@ -117,7 +127,9 @@ Camille Moncelier
|
|||||||
Caolan McNamara
|
Caolan McNamara
|
||||||
Carsten Lange
|
Carsten Lange
|
||||||
Casey O'Donnell
|
Casey O'Donnell
|
||||||
|
Cedric Deltheil
|
||||||
Chad Monroe
|
Chad Monroe
|
||||||
|
Chandrakant Bagul
|
||||||
Charles Kerr
|
Charles Kerr
|
||||||
Chih-Chung Chang
|
Chih-Chung Chang
|
||||||
Chris "Bob Bob"
|
Chris "Bob Bob"
|
||||||
@@ -129,6 +141,7 @@ Chris Gaukroger
|
|||||||
Chris Maltby
|
Chris Maltby
|
||||||
Chris Mumford
|
Chris Mumford
|
||||||
Chris Smowton
|
Chris Smowton
|
||||||
|
Christian Grothoff
|
||||||
Christian Hagele
|
Christian Hagele
|
||||||
Christian Krause
|
Christian Krause
|
||||||
Christian Kurz
|
Christian Kurz
|
||||||
@@ -140,6 +153,7 @@ Christophe Legry
|
|||||||
Christopher Conroy
|
Christopher Conroy
|
||||||
Christopher Palow
|
Christopher Palow
|
||||||
Christopher R. Palmer
|
Christopher R. Palmer
|
||||||
|
Christopher Stone
|
||||||
Ciprian Badescu
|
Ciprian Badescu
|
||||||
Claes Jakobsson
|
Claes Jakobsson
|
||||||
Clarence Gardner
|
Clarence Gardner
|
||||||
@@ -225,6 +239,7 @@ Dmitry Rechkin
|
|||||||
Dolbneff A.V
|
Dolbneff A.V
|
||||||
Domenico Andreoli
|
Domenico Andreoli
|
||||||
Dominick Meglio
|
Dominick Meglio
|
||||||
|
Dominique Leuenberger
|
||||||
Doug Kaufman
|
Doug Kaufman
|
||||||
Doug Porter
|
Doug Porter
|
||||||
Douglas E. Wegscheid
|
Douglas E. Wegscheid
|
||||||
@@ -265,6 +280,7 @@ Erwin Authried
|
|||||||
Eugene Kotlyarov
|
Eugene Kotlyarov
|
||||||
Evan Jordan
|
Evan Jordan
|
||||||
Eygene Ryabinkin
|
Eygene Ryabinkin
|
||||||
|
Fabian Hiernaux
|
||||||
Fabian Keil
|
Fabian Keil
|
||||||
Fabrizio Ammollo
|
Fabrizio Ammollo
|
||||||
Fedor Karpelevitch
|
Fedor Karpelevitch
|
||||||
@@ -277,6 +293,7 @@ Frank Keeney
|
|||||||
Frank McGeough
|
Frank McGeough
|
||||||
Frank Meier
|
Frank Meier
|
||||||
Frank Ticheler
|
Frank Ticheler
|
||||||
|
Frank Van Uffelen
|
||||||
Fred Machado
|
Fred Machado
|
||||||
Fred New
|
Fred New
|
||||||
Fred Noz
|
Fred Noz
|
||||||
@@ -306,6 +323,7 @@ Giuseppe Attardi
|
|||||||
Giuseppe D'Ambrosio
|
Giuseppe D'Ambrosio
|
||||||
Glen Nakamura
|
Glen Nakamura
|
||||||
Glen Scott
|
Glen Scott
|
||||||
|
Gokhan Sengun
|
||||||
Grant Erickson
|
Grant Erickson
|
||||||
Greg Hewgill
|
Greg Hewgill
|
||||||
Greg Morse
|
Greg Morse
|
||||||
@@ -373,6 +391,8 @@ Jan Kunder
|
|||||||
Jan Van Boghout
|
Jan Van Boghout
|
||||||
Jared Lundell
|
Jared Lundell
|
||||||
Jari Sundell
|
Jari Sundell
|
||||||
|
Jason Glasgow
|
||||||
|
Jason Liu
|
||||||
Jason McDonald
|
Jason McDonald
|
||||||
Jason S. Priebe
|
Jason S. Priebe
|
||||||
Jay Austin
|
Jay Austin
|
||||||
@@ -393,6 +413,7 @@ Jeffrey Pohlmeyer
|
|||||||
Jeremy Friesner
|
Jeremy Friesner
|
||||||
Jerome Muffat-Meridol
|
Jerome Muffat-Meridol
|
||||||
Jerome Vouillon
|
Jerome Vouillon
|
||||||
|
Jerry Wu
|
||||||
Jes Badwal
|
Jes Badwal
|
||||||
Jesper Jensen
|
Jesper Jensen
|
||||||
Jesse Noller
|
Jesse Noller
|
||||||
@@ -408,11 +429,13 @@ Jofell Gallardo
|
|||||||
Johan Anderson
|
Johan Anderson
|
||||||
Johan Nilsson
|
Johan Nilsson
|
||||||
Johan van Selst
|
Johan van Selst
|
||||||
|
Johannes Bauer
|
||||||
John Bradshaw
|
John Bradshaw
|
||||||
John Crow
|
John Crow
|
||||||
John Dennis
|
John Dennis
|
||||||
John E. Malmberg
|
John E. Malmberg
|
||||||
John Janssen
|
John Janssen
|
||||||
|
John Joseph Bachir
|
||||||
John Kelly
|
John Kelly
|
||||||
John Lask
|
John Lask
|
||||||
John Lightsey
|
John Lightsey
|
||||||
@@ -427,6 +450,7 @@ Jon Sargeant
|
|||||||
Jon Travis
|
Jon Travis
|
||||||
Jon Turner
|
Jon Turner
|
||||||
Jonas Forsman
|
Jonas Forsman
|
||||||
|
Jonas Schnelli
|
||||||
Jonatan Lander
|
Jonatan Lander
|
||||||
Jonathan Hseu
|
Jonathan Hseu
|
||||||
Jongki Suwandi
|
Jongki Suwandi
|
||||||
@@ -435,6 +459,7 @@ Josef Wolf
|
|||||||
Josh Kapell
|
Josh Kapell
|
||||||
Joshua Kwan
|
Joshua Kwan
|
||||||
Josue Andrade Gomes
|
Josue Andrade Gomes
|
||||||
|
Juan Barreto
|
||||||
Juan F. Codagnone
|
Juan F. Codagnone
|
||||||
Juan Ignacio Herv<72>s
|
Juan Ignacio Herv<72>s
|
||||||
Judson Bishop
|
Judson Bishop
|
||||||
@@ -442,6 +467,7 @@ Juergen Wilke
|
|||||||
Jukka Pihl
|
Jukka Pihl
|
||||||
Julian Noble
|
Julian Noble
|
||||||
Julien Chaffraix
|
Julien Chaffraix
|
||||||
|
Julien Royer
|
||||||
Jun-ichiro itojun Hagino
|
Jun-ichiro itojun Hagino
|
||||||
Jurij Smakov
|
Jurij Smakov
|
||||||
Justin Fletcher
|
Justin Fletcher
|
||||||
@@ -513,6 +539,7 @@ Luke Call
|
|||||||
Luong Dinh Dung
|
Luong Dinh Dung
|
||||||
Maciej Karpiuk
|
Maciej Karpiuk
|
||||||
Maciej W. Rozycki
|
Maciej W. Rozycki
|
||||||
|
Mamoru Tasaka
|
||||||
Mandy Wu
|
Mandy Wu
|
||||||
Manfred Schwarb
|
Manfred Schwarb
|
||||||
Manuel Massing
|
Manuel Massing
|
||||||
@@ -520,12 +547,14 @@ Marc Boucher
|
|||||||
Marc Kleine-Budde
|
Marc Kleine-Budde
|
||||||
Marcel Roelofs
|
Marcel Roelofs
|
||||||
Marcelo Juchem
|
Marcelo Juchem
|
||||||
|
Marcin Adamski
|
||||||
Marcin Konicki
|
Marcin Konicki
|
||||||
Marco G. Salvagno
|
Marco G. Salvagno
|
||||||
Marco Maggi
|
Marco Maggi
|
||||||
Marcus Sundberg
|
Marcus Sundberg
|
||||||
Marcus Webster
|
Marcus Webster
|
||||||
Mario Schroeder
|
Mario Schroeder
|
||||||
|
Mark Brand
|
||||||
Mark Butler
|
Mark Butler
|
||||||
Mark Davies
|
Mark Davies
|
||||||
Mark Eichin
|
Mark Eichin
|
||||||
@@ -564,6 +593,7 @@ Mauro Iorio
|
|||||||
Max Katsev
|
Max Katsev
|
||||||
Maxim Ivanov
|
Maxim Ivanov
|
||||||
Maxim Perenesenko
|
Maxim Perenesenko
|
||||||
|
Maxim Prohorov
|
||||||
Mehmet Bozkurt
|
Mehmet Bozkurt
|
||||||
Mekonikum
|
Mekonikum
|
||||||
Mettgut Jamalla
|
Mettgut Jamalla
|
||||||
@@ -571,6 +601,7 @@ Michael Benedict
|
|||||||
Michael Calmer
|
Michael Calmer
|
||||||
Michael Cronenworth
|
Michael Cronenworth
|
||||||
Michael Curtis
|
Michael Curtis
|
||||||
|
Michael Day
|
||||||
Michael Goffioul
|
Michael Goffioul
|
||||||
Michael Jahn
|
Michael Jahn
|
||||||
Michael Jerris
|
Michael Jerris
|
||||||
@@ -601,6 +632,7 @@ Moonesamy
|
|||||||
Nathan Coulter
|
Nathan Coulter
|
||||||
Nathan O'Sullivan
|
Nathan O'Sullivan
|
||||||
Nathanael Nerode
|
Nathanael Nerode
|
||||||
|
Naveen Chandran
|
||||||
Naveen Noel
|
Naveen Noel
|
||||||
Neil Dunbar
|
Neil Dunbar
|
||||||
Neil Spring
|
Neil Spring
|
||||||
@@ -618,6 +650,7 @@ Nikita Schmidt
|
|||||||
Nikitinskit Dmitriy
|
Nikitinskit Dmitriy
|
||||||
Niklas Angebrand
|
Niklas Angebrand
|
||||||
Nikolai Kondrashov
|
Nikolai Kondrashov
|
||||||
|
Nikos Mavrogiannopoulos
|
||||||
Ning Dong
|
Ning Dong
|
||||||
Nir Soffer
|
Nir Soffer
|
||||||
Nis Jorgensen
|
Nis Jorgensen
|
||||||
@@ -634,6 +667,7 @@ Paolo Piacentini
|
|||||||
Pascal Terjan
|
Pascal Terjan
|
||||||
Pasha Kuznetsov
|
Pasha Kuznetsov
|
||||||
Pat Ray
|
Pat Ray
|
||||||
|
Patrice Guerin
|
||||||
Patrick Bihan-Faou
|
Patrick Bihan-Faou
|
||||||
Patrick Monnerat
|
Patrick Monnerat
|
||||||
Patrick Scott
|
Patrick Scott
|
||||||
@@ -681,6 +715,7 @@ Philippe Vaucher
|
|||||||
Pierre
|
Pierre
|
||||||
Pierre Brico
|
Pierre Brico
|
||||||
Pierre Joye
|
Pierre Joye
|
||||||
|
Pierre Ynard
|
||||||
Pooyan McSporran
|
Pooyan McSporran
|
||||||
Pramod Sharma
|
Pramod Sharma
|
||||||
Puneet Pawaia
|
Puneet Pawaia
|
||||||
@@ -707,6 +742,7 @@ Renaud Duhaut
|
|||||||
Rene Bernhardt
|
Rene Bernhardt
|
||||||
Rene Rebe
|
Rene Rebe
|
||||||
Reuven Wachtfogel
|
Reuven Wachtfogel
|
||||||
|
Reza Arbab
|
||||||
Ricardo Cadime
|
Ricardo Cadime
|
||||||
Rich Gray
|
Rich Gray
|
||||||
Rich Rauenzahn
|
Rich Rauenzahn
|
||||||
@@ -723,11 +759,13 @@ Rick Richardson
|
|||||||
Rob Crittenden
|
Rob Crittenden
|
||||||
Rob Jones
|
Rob Jones
|
||||||
Rob Stanzel
|
Rob Stanzel
|
||||||
|
Rob Ward
|
||||||
Robert A. Monat
|
Robert A. Monat
|
||||||
Robert D. Young
|
Robert D. Young
|
||||||
Robert Foreman
|
Robert Foreman
|
||||||
Robert Iakobashvili
|
Robert Iakobashvili
|
||||||
Robert Olson
|
Robert Olson
|
||||||
|
Robert Schumann
|
||||||
Robert Weaver
|
Robert Weaver
|
||||||
Robin Cornelius
|
Robin Cornelius
|
||||||
Robin Johnson
|
Robin Johnson
|
||||||
@@ -796,6 +834,7 @@ Stephen Kick
|
|||||||
Stephen More
|
Stephen More
|
||||||
Sterling Hughes
|
Sterling Hughes
|
||||||
Steve Green
|
Steve Green
|
||||||
|
Steve H Truong
|
||||||
Steve Holme
|
Steve Holme
|
||||||
Steve Lhomme
|
Steve Lhomme
|
||||||
Steve Little
|
Steve Little
|
||||||
@@ -813,10 +852,12 @@ Sven Wegener
|
|||||||
S<EFBFBD>bastien Willemijns
|
S<EFBFBD>bastien Willemijns
|
||||||
T. Bharath
|
T. Bharath
|
||||||
T. Yamada
|
T. Yamada
|
||||||
|
Taneli Vahakangas
|
||||||
Tanguy Fautre
|
Tanguy Fautre
|
||||||
Temprimus
|
Temprimus
|
||||||
Thomas J. Moore
|
Thomas J. Moore
|
||||||
Thomas Klausner
|
Thomas Klausner
|
||||||
|
Thomas L. Shinnick
|
||||||
Thomas Lopatic
|
Thomas Lopatic
|
||||||
Thomas Schwinge
|
Thomas Schwinge
|
||||||
Thomas Tonino
|
Thomas Tonino
|
||||||
@@ -825,6 +866,7 @@ Tim Baker
|
|||||||
Tim Bartley
|
Tim Bartley
|
||||||
Tim Chen
|
Tim Chen
|
||||||
Tim Costello
|
Tim Costello
|
||||||
|
Tim Harder
|
||||||
Tim Newsome
|
Tim Newsome
|
||||||
Tim Sneddon
|
Tim Sneddon
|
||||||
Tinus van den Berg
|
Tinus van den Berg
|
||||||
@@ -832,6 +874,7 @@ Tobias Rundstr
|
|||||||
Toby Peterson
|
Toby Peterson
|
||||||
Todd A Ouska
|
Todd A Ouska
|
||||||
Todd Kulesza
|
Todd Kulesza
|
||||||
|
Todd Ouska
|
||||||
Todd Vierling
|
Todd Vierling
|
||||||
Tom Benoist
|
Tom Benoist
|
||||||
Tom Donovan
|
Tom Donovan
|
||||||
@@ -840,6 +883,7 @@ Tom Mattison
|
|||||||
Tom Moers
|
Tom Moers
|
||||||
Tom Mueller
|
Tom Mueller
|
||||||
Tom Regner
|
Tom Regner
|
||||||
|
Tom Wright
|
||||||
Tom Zerucha
|
Tom Zerucha
|
||||||
Tomas Pospisek
|
Tomas Pospisek
|
||||||
Tomas Szepe
|
Tomas Szepe
|
||||||
@@ -847,6 +891,7 @@ Tomasz Lacki
|
|||||||
Tommie Gannert
|
Tommie Gannert
|
||||||
Tommy Tam
|
Tommy Tam
|
||||||
Ton Voon
|
Ton Voon
|
||||||
|
Toni Moreno
|
||||||
Toon Verwaest
|
Toon Verwaest
|
||||||
Tor Arntsen
|
Tor Arntsen
|
||||||
Torsten Foertsch
|
Torsten Foertsch
|
||||||
@@ -869,11 +914,13 @@ Vincent Sanders
|
|||||||
Vincent Torri
|
Vincent Torri
|
||||||
Vlad Grachov
|
Vlad Grachov
|
||||||
Vlad Ureche
|
Vlad Ureche
|
||||||
|
Vladimir Grishchenko
|
||||||
Vladimir Lazarenko
|
Vladimir Lazarenko
|
||||||
Vojtech Janota
|
Vojtech Janota
|
||||||
Vojtech Minarik
|
Vojtech Minarik
|
||||||
Vsevolod Novikov
|
Vsevolod Novikov
|
||||||
Walter J. Mack
|
Walter J. Mack
|
||||||
|
Ward Willats
|
||||||
Wayne Haigh
|
Wayne Haigh
|
||||||
Werner Koch
|
Werner Koch
|
||||||
Wesley Laxton
|
Wesley Laxton
|
||||||
@@ -886,6 +933,7 @@ Xavier Bouchoux
|
|||||||
Yang Tse
|
Yang Tse
|
||||||
Yarram Sunil
|
Yarram Sunil
|
||||||
Yehoshua Hershberg
|
Yehoshua Hershberg
|
||||||
|
Yukihiro Kawada
|
||||||
Yuriy Sosov
|
Yuriy Sosov
|
||||||
Yves Lejeune
|
Yves Lejeune
|
||||||
Zmey Petroff
|
Zmey Petroff
|
||||||
|
213
docs/TODO
213
docs/TODO
@@ -17,6 +17,7 @@
|
|||||||
1.4 signal-based resolver timeouts
|
1.4 signal-based resolver timeouts
|
||||||
1.5 get rid of PATH_MAX
|
1.5 get rid of PATH_MAX
|
||||||
1.6 progress callback without doubles
|
1.6 progress callback without doubles
|
||||||
|
1.7 Happy Eyeball dual stack connect
|
||||||
|
|
||||||
2. libcurl - multi interface
|
2. libcurl - multi interface
|
||||||
2.1 More non-blocking
|
2.1 More non-blocking
|
||||||
@@ -60,46 +61,57 @@
|
|||||||
8.3 check connection
|
8.3 check connection
|
||||||
8.4 non-gcrypt
|
8.4 non-gcrypt
|
||||||
|
|
||||||
9. Other protocols
|
9. SMTP
|
||||||
|
9.1 Other authentication mechanims
|
||||||
|
9.2 Specify the preferred authentication mechanism
|
||||||
|
9.3 Initial response
|
||||||
|
9.4 Pipelining
|
||||||
|
|
||||||
10. New protocols
|
10. POP3
|
||||||
10.1 RSYNC
|
10.1 APOP Authentication
|
||||||
|
10.2 Other authentication mechanims
|
||||||
|
10.3 auth= in URLs
|
||||||
|
|
||||||
11. Client
|
11. Other protocols
|
||||||
11.1 sync
|
|
||||||
11.2 glob posts
|
|
||||||
11.3 prevent file overwriting
|
|
||||||
11.4 simultaneous parallel transfers
|
|
||||||
11.5 provide formpost headers
|
|
||||||
11.6 url-specific options
|
|
||||||
11.7 metalink support
|
|
||||||
11.8 warning when setting an option
|
|
||||||
11.9 IPv6 addresses with globbing
|
|
||||||
|
|
||||||
12. Build
|
12. New protocols
|
||||||
12.1 roffit
|
12.1 RSYNC
|
||||||
|
|
||||||
13. Test suite
|
13. Client
|
||||||
13.1 SSL tunnel
|
13.1 sync
|
||||||
13.2 nicer lacking perl message
|
13.2 glob posts
|
||||||
13.3 more protocols supported
|
13.3 prevent file overwriting
|
||||||
13.4 more platforms supported
|
13.4 simultaneous parallel transfers
|
||||||
|
13.5 provide formpost headers
|
||||||
|
13.6 url-specific options
|
||||||
|
13.7 metalink support
|
||||||
|
13.8 warning when setting an option
|
||||||
|
13.9 IPv6 addresses with globbing
|
||||||
|
|
||||||
14. Next SONAME bump
|
14. Build
|
||||||
14.1 http-style HEAD output for ftp
|
14.1 roffit
|
||||||
14.2 combine error codes
|
|
||||||
14.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
|
||||||
|
|
||||||
15. Next major release
|
15. Test suite
|
||||||
15.1 cleanup return codes
|
15.1 SSL tunnel
|
||||||
15.2 remove obsolete defines
|
15.2 nicer lacking perl message
|
||||||
15.3 size_t
|
15.3 more protocols supported
|
||||||
15.4 remove several functions
|
15.4 more platforms supported
|
||||||
15.5 remove CURLOPT_FAILONERROR
|
|
||||||
15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
16. Next SONAME bump
|
||||||
15.7 remove progress meter from libcurl
|
16.1 http-style HEAD output for ftp
|
||||||
15.8 remove 'curl_httppost' from public
|
16.2 combine error codes
|
||||||
15.9 have form functions use CURL handle argument
|
16.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
||||||
|
|
||||||
|
17. Next major release
|
||||||
|
17.1 cleanup return codes
|
||||||
|
17.2 remove obsolete defines
|
||||||
|
17.3 size_t
|
||||||
|
17.4 remove several functions
|
||||||
|
17.5 remove CURLOPT_FAILONERROR
|
||||||
|
17.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
||||||
|
17.7 remove progress meter from libcurl
|
||||||
|
17.8 remove 'curl_httppost' from public
|
||||||
|
17.9 have form functions use CURL handle argument
|
||||||
|
|
||||||
==============================================================================
|
==============================================================================
|
||||||
|
|
||||||
@@ -147,6 +159,19 @@
|
|||||||
have both co-exist for a forseeable time until we can remove the double-using
|
have both co-exist for a forseeable time until we can remove the double-using
|
||||||
one.
|
one.
|
||||||
|
|
||||||
|
1.7 Happy Eyeball dual stack connect
|
||||||
|
|
||||||
|
In order to make alternative technologies not suffer when transitioning, like
|
||||||
|
when introducing IPv6 as an alternative to IPv4 and there are more than one
|
||||||
|
option existing simultaneously there are reasons to reconsider internal
|
||||||
|
choices.
|
||||||
|
|
||||||
|
To make libcurl do blazing fast IPv6 in a dual-stack configuration, this needs
|
||||||
|
to be addressed:
|
||||||
|
|
||||||
|
http://tools.ietf.org/html/rfc6555
|
||||||
|
|
||||||
|
|
||||||
2. libcurl - multi interface
|
2. libcurl - multi interface
|
||||||
|
|
||||||
2.1 More non-blocking
|
2.1 More non-blocking
|
||||||
@@ -156,7 +181,6 @@
|
|||||||
|
|
||||||
- Name resolves on non-windows unless c-ares is used
|
- Name resolves on non-windows unless c-ares is used
|
||||||
- NSS SSL connections
|
- NSS SSL connections
|
||||||
- Active FTP connections
|
|
||||||
- HTTP proxy CONNECT operations
|
- HTTP proxy CONNECT operations
|
||||||
- SOCKS proxy handshakes
|
- SOCKS proxy handshakes
|
||||||
- file:// transfers
|
- file:// transfers
|
||||||
@@ -347,18 +371,65 @@ to provide the data to send.
|
|||||||
The correct fix would be to detect which crypto layer that is in use and
|
The correct fix would be to detect which crypto layer that is in use and
|
||||||
adapt our code to use that instead of blindly assuming gcrypt.
|
adapt our code to use that instead of blindly assuming gcrypt.
|
||||||
|
|
||||||
9. Other protocols
|
9. SMTP
|
||||||
|
|
||||||
10. New protocols
|
9.1 Other authentication mechanims
|
||||||
|
|
||||||
10.1 RSYNC
|
Add support for other authentication mechanisms such as digest-md5 and
|
||||||
|
gssapi.
|
||||||
|
|
||||||
There's no RFC for protocol nor URI/URL format. An implementation should
|
9.2 Specify the preferred authentication mechanism
|
||||||
most probably use an existing rsync library, such as librsync.
|
|
||||||
|
|
||||||
11. Client
|
Add the ability to specify the preferred authentication mechanism or a list
|
||||||
|
of mechanims that should be used. Not only that, but the order that is
|
||||||
|
returned by the server during the EHLO response should be honored by curl.
|
||||||
|
|
||||||
11.1 sync
|
9.3 Initial response
|
||||||
|
|
||||||
|
Add the ability for the user to specify whether the initial response is
|
||||||
|
included in the AUTH command. Some email servers, such as Microsoft
|
||||||
|
Exchange, can work with either whilst others need to have the initial
|
||||||
|
response sent separately:
|
||||||
|
|
||||||
|
http://curl.haxx.se/mail/lib-2012-03/0114.html
|
||||||
|
|
||||||
|
9.4 Pipelining
|
||||||
|
|
||||||
|
Add support for pipelining emails.
|
||||||
|
|
||||||
|
10. POP3
|
||||||
|
|
||||||
|
10.1 APOP Authentication
|
||||||
|
|
||||||
|
Add support for the APOP command rather than using plain text authentication
|
||||||
|
(USER and PASS) as this is very week security wise. Note: The APOP command
|
||||||
|
is specified as "APOP <username> <md5 password>", however, it isn't
|
||||||
|
supported by all mail servers.
|
||||||
|
|
||||||
|
10.2 Other authentication mechanims
|
||||||
|
|
||||||
|
SASL offers support for additional authentication mechanisms via the AUTH
|
||||||
|
command. Detection of an email server's support for SASL authentication
|
||||||
|
can be detected via the CAPA command whilst a list of supported mechanisms
|
||||||
|
can be retrieved with an empty AUTH command.
|
||||||
|
|
||||||
|
10.3 auth= in URLs
|
||||||
|
|
||||||
|
Being able to specify the preferred authentication mechanim in the URL as
|
||||||
|
per RFC-2384 (http://tools.ietf.org/html/rfc2384).
|
||||||
|
|
||||||
|
11. Other protocols
|
||||||
|
|
||||||
|
12. New protocols
|
||||||
|
|
||||||
|
12.1 RSYNC
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
13. Client
|
||||||
|
|
||||||
|
13.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"
|
||||||
@@ -367,12 +438,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.
|
||||||
|
|
||||||
11.2 glob posts
|
13.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.
|
||||||
|
|
||||||
11.3 prevent file overwriting
|
13.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
|
||||||
@@ -380,14 +451,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.
|
||||||
|
|
||||||
11.4 simultaneous parallel transfers
|
13.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
|
||||||
|
|
||||||
11.5 provide formpost headers
|
13.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
|
||||||
@@ -401,7 +472,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...)
|
||||||
|
|
||||||
11.6 url-specific options
|
13.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,
|
||||||
@@ -415,62 +486,62 @@ 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.
|
||||||
|
|
||||||
11.7 metalink support
|
13.7 metalink support
|
||||||
|
|
||||||
Add metalink support to curl (http://www.metalinker.org/). This is most useful
|
Add metalink support to curl (http://www.metalinker.org/). This is most useful
|
||||||
with simultaneous parallel transfers (11.6) but not necessary.
|
with simultaneous parallel transfers (11.6) but not necessary.
|
||||||
|
|
||||||
11.8 warning when setting an option
|
13.8 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.
|
||||||
|
|
||||||
11.9 IPv6 addresses with globbing
|
13.9 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.
|
||||||
|
|
||||||
12. Build
|
14. Build
|
||||||
|
|
||||||
12.1 roffit
|
14.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/hugehelp.c
|
||||||
|
|
||||||
13. Test suite
|
15. Test suite
|
||||||
|
|
||||||
13.1 SSL tunnel
|
15.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
|
||||||
|
|
||||||
13.2 nicer lacking perl message
|
15.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.
|
||||||
|
|
||||||
13.3 more protocols supported
|
15.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).
|
||||||
|
|
||||||
13.4 more platforms supported
|
15.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.
|
||||||
|
|
||||||
14. Next SONAME bump
|
16. Next SONAME bump
|
||||||
|
|
||||||
14.1 http-style HEAD output for ftp
|
16.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
|
||||||
|
|
||||||
14.2 combine error codes
|
16.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
|
||||||
@@ -488,29 +559,29 @@ to provide the data to send.
|
|||||||
CURLE_TFTP_NOTFOUND => CURLE_REMOTE_FILE_NOT_FOUND
|
CURLE_TFTP_NOTFOUND => CURLE_REMOTE_FILE_NOT_FOUND
|
||||||
CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED
|
CURLE_TFTP_PERM => CURLE_REMOTE_ACCESS_DENIED
|
||||||
|
|
||||||
14.3 extend CURLOPT_SOCKOPTFUNCTION prototype
|
16.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.
|
||||||
|
|
||||||
15. Next major release
|
17. Next major release
|
||||||
|
|
||||||
15.1 cleanup return codes
|
17.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.
|
||||||
|
|
||||||
15.2 remove obsolete defines
|
17.2 remove obsolete defines
|
||||||
|
|
||||||
remove obsolete defines from curl/curl.h
|
remove obsolete defines from curl/curl.h
|
||||||
|
|
||||||
15.3 size_t
|
17.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
|
||||||
|
|
||||||
15.4 remove several functions
|
17.4 remove several functions
|
||||||
|
|
||||||
remove the following functions from the public API:
|
remove the following functions from the public API:
|
||||||
|
|
||||||
@@ -531,18 +602,18 @@ to provide the data to send.
|
|||||||
|
|
||||||
curl_multi_socket_all
|
curl_multi_socket_all
|
||||||
|
|
||||||
15.5 remove CURLOPT_FAILONERROR
|
17.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.
|
||||||
|
|
||||||
15.6 remove CURLOPT_DNS_USE_GLOBAL_CACHE
|
17.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".
|
||||||
|
|
||||||
15.7 remove progress meter from libcurl
|
17.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
|
||||||
@@ -552,7 +623,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.
|
||||||
|
|
||||||
15.8 remove 'curl_httppost' from public
|
17.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
|
||||||
@@ -561,7 +632,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.
|
||||||
|
|
||||||
15.9 have form functions use CURL handle argument
|
17.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
|
||||||
|
@@ -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
|
||||||
@@ -93,7 +93,6 @@ What's the installed libcurl version?
|
|||||||
|
|
||||||
How do I build a single file with a one-line command?
|
How do I build a single file with a one-line command?
|
||||||
|
|
||||||
$ `curl-config --cc --cflags --libs` -o example example.c
|
$ `curl-config --cc --cflags` -o example example.c `curl-config --libs`
|
||||||
|
|
||||||
.SH "SEE ALSO"
|
.SH "SEE ALSO"
|
||||||
.BR curl (1)
|
.BR curl (1)
|
||||||
|
65
docs/curl.1
65
docs/curl.1
@@ -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 @@
|
|||||||
.\" *
|
.\" *
|
||||||
.\" **************************************************************************
|
.\" **************************************************************************
|
||||||
.\"
|
.\"
|
||||||
.TH curl 1 "14 April 2009" "Curl 7.21.6" "Curl Manual"
|
.TH curl 1 "16 February 2012" "Curl 7.25.0" "Curl Manual"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
curl \- transfer a URL
|
curl \- transfer a URL
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
@@ -434,13 +434,15 @@ 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>"
|
||||||
(SSL) Tells curl to use the specified certificate directory to verify the
|
(SSL) Tells curl to use the specified certificate directory to verify the
|
||||||
peer. The certificates must be in PEM format, and if curl is built against
|
peer. Multiple paths can be provided by separating them with ":" (e.g.
|
||||||
OpenSSL, the directory must have been processed using the c_rehash utility
|
\&"path1:path2:path3"). The certificates must be in PEM format, and if curl is
|
||||||
supplied with OpenSSL. Using \fI--capath\fP can allow OpenSSL-powered curl to
|
built against OpenSSL, the directory must have been processed using the
|
||||||
make SSL-connections much more efficiently than using \fI--cacert\fP if the
|
c_rehash utility supplied with OpenSSL. Using \fI--capath\fP can allow
|
||||||
\fI--cacert\fP file contains many CA certificates.
|
OpenSSL-powered curl to make SSL-connections much more efficiently than using
|
||||||
|
\fI--cacert\fP if the \fI--cacert\fP file contains many CA certificates.
|
||||||
|
|
||||||
If this option is used several times, the last one will be used.
|
If this option is set, the default capath value will be ignored, and if it is
|
||||||
|
used several times, the last one will be used.
|
||||||
.IP "-f, --fail"
|
.IP "-f, --fail"
|
||||||
(HTTP) Fail silently (no output at all) on server errors. This is mostly done
|
(HTTP) Fail silently (no output at all) on server errors. This is mostly done
|
||||||
to better enable scripts etc to better deal with failed attempts. In
|
to better enable scripts etc to better deal with failed attempts. In
|
||||||
@@ -709,7 +711,8 @@ currently effective on operating systems offering the TCP_KEEPIDLE and
|
|||||||
TCP_KEEPINTVL socket options (meaning Linux, recent AIX, HP-UX and more). This
|
TCP_KEEPINTVL socket options (meaning Linux, recent AIX, HP-UX and more). This
|
||||||
option has no effect if \fI--no-keepalive\fP is used. (Added in 7.18.0)
|
option has no effect if \fI--no-keepalive\fP is used. (Added in 7.18.0)
|
||||||
|
|
||||||
If this option is used multiple times, the last occurrence sets the amount.
|
If this option is used multiple times, the last occurrence sets the amount. If
|
||||||
|
unspecified, the option defaults to 60 seconds.
|
||||||
.IP "--key <key>"
|
.IP "--key <key>"
|
||||||
(SSL/SSH) Private key file name. Allows you to provide your private key in this
|
(SSL/SSH) Private key file name. Allows you to provide your private key in this
|
||||||
separate file.
|
separate file.
|
||||||
@@ -759,13 +762,9 @@ was 301, 302, or 303. If the response code was any other 3xx code, curl will
|
|||||||
re-send the following request using the same unmodified method.
|
re-send the following request using the same unmodified method.
|
||||||
.IP "--libcurl <file>"
|
.IP "--libcurl <file>"
|
||||||
Append this option to any ordinary curl command line, and you will get a
|
Append this option to any ordinary curl command line, and you will get a
|
||||||
libcurl-using source code written to the file that does the equivalent
|
libcurl-using C source code written to the file that does the equivalent
|
||||||
of what your command-line operation does!
|
of what your command-line operation does!
|
||||||
|
|
||||||
NOTE: this does not properly support -F and the sending of multipart
|
|
||||||
formposts, so in those cases the output program will be missing necessary
|
|
||||||
calls to \fIcurl_formadd(3)\fP, and possibly more.
|
|
||||||
|
|
||||||
If this option is used several times, the last given file name will be
|
If this option is used several times, the last given file name will be
|
||||||
used. (Added in 7.16.1)
|
used. (Added in 7.16.1)
|
||||||
.IP "--limit-rate <speed>"
|
.IP "--limit-rate <speed>"
|
||||||
@@ -803,6 +802,12 @@ useful for preventing your batch jobs from hanging for hours due to slow
|
|||||||
networks or links going down. See also the \fI--connect-timeout\fP option.
|
networks or links going down. See also the \fI--connect-timeout\fP option.
|
||||||
|
|
||||||
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 "--mail-auth <address>"
|
||||||
|
(SMTP) Specify a single address. This will be used to specify the
|
||||||
|
authentication address (identity) of a submitted message that is being relayed
|
||||||
|
to another server.
|
||||||
|
|
||||||
|
(Added in 7.25.0)
|
||||||
.IP "--mail-from <address>"
|
.IP "--mail-from <address>"
|
||||||
(SMTP) Specify a single address that the given mail should get sent from.
|
(SMTP) Specify a single address that the given mail should get sent from.
|
||||||
|
|
||||||
@@ -1256,6 +1261,12 @@ connection if the server doesn't support SSL/TLS. (Added in 7.20.0)
|
|||||||
|
|
||||||
This option was formerly known as \fI--ftp-ssl-reqd\fP (added in 7.15.5). That
|
This option was formerly known as \fI--ftp-ssl-reqd\fP (added in 7.15.5). That
|
||||||
option name can still be used but will be removed in a future version.
|
option name can still be used but will be removed in a future version.
|
||||||
|
.IP "--ssl-allow-beast"
|
||||||
|
(SSL) This option tells curl to not work around a security flaw in the SSL3
|
||||||
|
and TLS1.0 protocols known as BEAST. If this option isn't used, the SSL layer
|
||||||
|
may use work-arounds known to cause interoperability problems with some older
|
||||||
|
SSL implementations. WARNING: this option loosens the SSL security, and by
|
||||||
|
using this flag you ask for exactly that. (Added in 7.25.0)
|
||||||
.IP "--socks4 <host[:port]>"
|
.IP "--socks4 <host[:port]>"
|
||||||
Use the specified SOCKS4 proxy. If the port number is not specified, it is
|
Use the specified SOCKS4 proxy. If the port number is not specified, it is
|
||||||
assumed at port 1080. (Added in 7.15.2)
|
assumed at port 1080. (Added in 7.15.2)
|
||||||
@@ -1322,8 +1333,7 @@ implementation does not. The option \fI--socks5-gssapi-nec\fP allows the
|
|||||||
unprotected exchange of the protection mode negotiation. (Added in 7.19.4).
|
unprotected exchange of the protection mode negotiation. (Added in 7.19.4).
|
||||||
.IP "--stderr <file>"
|
.IP "--stderr <file>"
|
||||||
Redirect all writes to stderr to the specified file instead. If the file name
|
Redirect all writes to stderr to the specified file instead. If the file name
|
||||||
is a plain '-', it is instead written to stdout. This option has no point when
|
is a plain '-', it is instead written to stdout.
|
||||||
you're using a shell with decent redirecting capabilities.
|
|
||||||
|
|
||||||
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 "-t, --telnet-option <OPT=val>"
|
.IP "-t, --telnet-option <OPT=val>"
|
||||||
@@ -1475,6 +1485,11 @@ The variables available at this point are:
|
|||||||
The URL that was fetched last. This is most meaningful if you've told curl
|
The URL that was fetched last. This is most meaningful if you've told curl
|
||||||
to follow location: headers.
|
to follow location: headers.
|
||||||
.TP
|
.TP
|
||||||
|
.B filename_effective
|
||||||
|
The ultimate filename that curl writes out to. This is only meaningful if curl
|
||||||
|
is told to write to a file with the --remote-name or --output option. It's most
|
||||||
|
useful in combination with the --remote-header-name option. (Added in 7.25.1)
|
||||||
|
.TP
|
||||||
.B http_code
|
.B http_code
|
||||||
The numerical response code that was found in the last retrieved HTTP(S) or
|
The numerical response code that was found in the last retrieved HTTP(S) or
|
||||||
FTP(s) transfer. In 7.18.2 the alias \fBresponse_code\fP was added to show the
|
FTP(s) transfer. In 7.18.2 the alias \fBresponse_code\fP was added to show the
|
||||||
@@ -1559,7 +1574,7 @@ means the verification was successful. (Added in 7.19.0)
|
|||||||
.RE
|
.RE
|
||||||
|
|
||||||
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 "-x, --proxy <[protocol://][user@password]proxyhost[:port]>"
|
.IP "-x, --proxy <[protocol://][user:password@]proxyhost[:port]>"
|
||||||
Use the specified HTTP proxy. If the port number is not specified, it is
|
Use the specified HTTP proxy. If the port number is not specified, it is
|
||||||
assumed at port 1080.
|
assumed at port 1080.
|
||||||
|
|
||||||
@@ -1572,6 +1587,10 @@ converted to HTTP. It means that certain protocol specific operations might
|
|||||||
not be available. This is not the case if you can tunnel through the proxy, as
|
not be available. This is not the case if you can tunnel through the proxy, as
|
||||||
one with the \fI-p, --proxytunnel\fP option.
|
one with the \fI-p, --proxytunnel\fP option.
|
||||||
|
|
||||||
|
User and password that might be provided in the proxy string are URL decoded
|
||||||
|
by libcurl. This allows you to pass in special characters such as @ by using
|
||||||
|
%40 or pass in a colon with %3a.
|
||||||
|
|
||||||
The proxy host can be specified the exact same way as the proxy environment
|
The proxy host can be specified the exact same way as the proxy environment
|
||||||
variables, including the protocol prefix (http://) and the embedded user +
|
variables, including the protocol prefix (http://) and the embedded user +
|
||||||
password.
|
password.
|
||||||
@@ -1618,12 +1637,12 @@ speed-time seconds it gets aborted. speed-time is set with -y and is 30 if
|
|||||||
not set.
|
not set.
|
||||||
|
|
||||||
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 "-z, --time-cond <date expression>"
|
.IP "-z/--time-cond <date expression>|<file>"
|
||||||
(HTTP/FTP/FILE) Request a file that has been modified later than the given time
|
(HTTP/FTP) Request a file that has been modified later than the given time and
|
||||||
and date, or one that has been modified before that time. The date expression
|
date, or one that has been modified before that time. The <date expression> can
|
||||||
can be all sorts of date strings or if it doesn't match any internal ones, it
|
be all sorts of date strings or if it doesn't match any internal ones, it is
|
||||||
tries to get the time from a given file name instead! See the
|
taken as a filename and tries to get the modification date (mtime) from <file>
|
||||||
\fIcurl_getdate(3)\fP man pages for date expression details.
|
instead. See the \fIcurl_getdate(3)\fP man pages for date expression details.
|
||||||
|
|
||||||
Start the date expression with a dash (-) to make it request for a document
|
Start the date expression with a dash (-) to make it request for a document
|
||||||
that is older than the given date/time, default is a document that is newer
|
that is older than the given date/time, default is a document that is newer
|
||||||
|
4
docs/examples/.gitignore
vendored
4
docs/examples/.gitignore
vendored
@@ -18,12 +18,15 @@ http-post
|
|||||||
httpcustomheader
|
httpcustomheader
|
||||||
httpput
|
httpput
|
||||||
https
|
https
|
||||||
|
imap
|
||||||
multi-app
|
multi-app
|
||||||
multi-debugcallback
|
multi-debugcallback
|
||||||
multi-double
|
multi-double
|
||||||
multi-post
|
multi-post
|
||||||
multi-single
|
multi-single
|
||||||
persistant
|
persistant
|
||||||
|
pop3s
|
||||||
|
pop3slist
|
||||||
post-callback
|
post-callback
|
||||||
postit2
|
postit2
|
||||||
progressfunc
|
progressfunc
|
||||||
@@ -37,3 +40,4 @@ simplesmtp
|
|||||||
simplessl
|
simplessl
|
||||||
smtp-multi
|
smtp-multi
|
||||||
smtp-tls
|
smtp-tls
|
||||||
|
url2file
|
||||||
|
@@ -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
|
||||||
@@ -23,7 +23,7 @@
|
|||||||
AUTOMAKE_OPTIONS = foreign nostdinc
|
AUTOMAKE_OPTIONS = foreign nostdinc
|
||||||
|
|
||||||
EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \
|
EXTRA_DIST = README Makefile.example Makefile.inc Makefile.m32 \
|
||||||
Makefile.netware makefile.dj printf_macro.h $(COMPLICATED_EXAMPLES)
|
Makefile.netware makefile.dj $(COMPLICATED_EXAMPLES)
|
||||||
|
|
||||||
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
||||||
# $(top_builddir), to ensure that these paths which belong to the library
|
# $(top_builddir), to ensure that these paths which belong to the library
|
||||||
@@ -40,12 +40,12 @@ INCLUDES = -I$(top_builddir)/include/curl \
|
|||||||
|
|
||||||
LIBDIR = $(top_builddir)/lib
|
LIBDIR = $(top_builddir)/lib
|
||||||
|
|
||||||
if STATICLIB
|
AM_CPPFLAGS = -DCURL_NO_OLDIES
|
||||||
# we need this define when building with a static lib on Windows
|
|
||||||
STATICCPPFLAGS = -DCURL_STATICLIB
|
|
||||||
endif
|
|
||||||
|
|
||||||
CPPFLAGS = -DCURL_NO_OLDIES $(STATICCPPFLAGS)
|
# Mostly for Windows build targets, when using static libcurl
|
||||||
|
if USE_CPPFLAG_CURL_STATICLIB
|
||||||
|
AM_CPPFLAGS += -DCURL_STATICLIB
|
||||||
|
endif
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
LDADD = $(LIBDIR)/libcurl.la
|
LDADD = $(LIBDIR)/libcurl.la
|
||||||
|
@@ -5,7 +5,7 @@ check_PROGRAMS = 10-at-a-time anyauthput cookie_interface debug fileupload \
|
|||||||
persistant post-callback postit2 sepheaders simple simplepost simplessl \
|
persistant post-callback postit2 sepheaders simple simplepost simplessl \
|
||||||
sendrecv httpcustomheader certinfo chkspeed ftpgetinfo ftp-wildcard \
|
sendrecv httpcustomheader certinfo chkspeed ftpgetinfo ftp-wildcard \
|
||||||
smtp-multi simplesmtp smtp-tls rtsp externalsocket resolve \
|
smtp-multi simplesmtp smtp-tls rtsp externalsocket resolve \
|
||||||
progressfunc
|
progressfunc pop3s pop3slist imap url2file
|
||||||
|
|
||||||
# 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.
|
||||||
|
@@ -27,18 +27,18 @@
|
|||||||
## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-spi-winidn
|
## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-spi-winidn
|
||||||
##
|
##
|
||||||
## Hint: you can also set environment vars to control the build, f.e.:
|
## Hint: you can also set environment vars to control the build, f.e.:
|
||||||
## set ZLIB_PATH=c:/zlib-1.2.5
|
## set ZLIB_PATH=c:/zlib-1.2.7
|
||||||
## set ZLIB=1
|
## set ZLIB=1
|
||||||
#
|
#
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../../zlib-1.2.5
|
ZLIB_PATH = ../../../zlib-1.2.7
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../../openssl-0.9.8r
|
OPENSSL_PATH = ../../../openssl-0.9.8x
|
||||||
endif
|
endif
|
||||||
ifndef OPENSSL_LIBPATH
|
ifndef OPENSSL_LIBPATH
|
||||||
OPENSSL_LIBPATH = $(OPENSSL_PATH)/out
|
OPENSSL_LIBPATH = $(OPENSSL_PATH)/out
|
||||||
@@ -48,7 +48,7 @@ OPENSSL_LIBS = -leay32 -lssl32
|
|||||||
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.3.0
|
LIBSSH2_PATH = ../../../libssh2-1.4.2
|
||||||
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
|
||||||
@@ -58,7 +58,7 @@ endif
|
|||||||
ifndef LIBIDN_PATH
|
ifndef LIBIDN_PATH
|
||||||
LIBIDN_PATH = ../../../libidn-1.18
|
LIBIDN_PATH = ../../../libidn-1.18
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your MS idndlpackage.
|
# Edit the path below to point to the base of your MS IDN package.
|
||||||
# Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1
|
# Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1
|
||||||
# http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815
|
# http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815
|
||||||
ifndef WINIDN_PATH
|
ifndef WINIDN_PATH
|
||||||
|
@@ -14,17 +14,17 @@ endif
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../../zlib-1.2.5
|
ZLIB_PATH = ../../../zlib-1.2.7
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../../openssl-0.9.8r
|
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.3.0
|
LIBSSH2_PATH = ../../../libssh2-1.4.2
|
||||||
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.
|
||||||
|
@@ -55,6 +55,7 @@ htmltitle.cc - download a HTML file and extract the <title> tag from a HTML
|
|||||||
http-post.c - HTTP POST
|
http-post.c - HTTP POST
|
||||||
httpput.c - HTTP PUT a local file
|
httpput.c - HTTP PUT a local file
|
||||||
https.c - simple HTTPS transfer
|
https.c - simple HTTPS transfer
|
||||||
|
imap.c - simple IMAP transfer
|
||||||
multi-app.c - a multi-interface app
|
multi-app.c - a multi-interface app
|
||||||
multi-debugcallback.c - a multi-interface app using the debug callback
|
multi-debugcallback.c - a multi-interface app using the debug callback
|
||||||
multi-double.c - a multi-interface app doing two simultaneous transfers
|
multi-double.c - a multi-interface app doing two simultaneous transfers
|
||||||
@@ -63,6 +64,8 @@ multi-single.c - a multi-interface app getting a single file
|
|||||||
multithread.c - an example using multi-treading transferring multiple files
|
multithread.c - an example using multi-treading transferring multiple files
|
||||||
opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded
|
opensslthreadlock.c - show how to do locking when using OpenSSL multi-threaded
|
||||||
persistant.c - request two URLs with a persistent connection
|
persistant.c - request two URLs with a persistent connection
|
||||||
|
pop3s.c - POP3S transfer
|
||||||
|
pop3slist.c - POP3S LIST
|
||||||
post-callback.c - send a HTTP POST using a callback
|
post-callback.c - send a HTTP POST using a callback
|
||||||
postit2.c - send a HTTP multipart formpost
|
postit2.c - send a HTTP multipart formpost
|
||||||
sampleconv.c - showing how a program on a non-ASCII platform would invoke
|
sampleconv.c - showing how a program on a non-ASCII platform would invoke
|
||||||
@@ -73,4 +76,5 @@ simple.c - the most simple download a URL source
|
|||||||
simplepost.c - HTTP POST
|
simplepost.c - HTTP POST
|
||||||
simplessl.c - HTTPS example with certificates many options set
|
simplessl.c - HTTPS example with certificates many options set
|
||||||
synctime.c - Sync local time by extracting date from remote HTTP servers
|
synctime.c - Sync local time by extracting date from remote HTTP servers
|
||||||
|
url2file.c - download a document and store it in a file
|
||||||
10-at-a-time.c - Download many files simultaneously, 10 at a time.
|
10-at-a-time.c - Download many files simultaneously, 10 at a time.
|
||||||
|
@@ -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
|
||||||
@@ -27,6 +27,7 @@
|
|||||||
# ifdef __VMS
|
# ifdef __VMS
|
||||||
typedef int intptr_t;
|
typedef int intptr_t;
|
||||||
# endif
|
# endif
|
||||||
|
# include <stdint.h>
|
||||||
# include <unistd.h>
|
# include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
@@ -41,7 +42,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "printf_macro.h"
|
|
||||||
|
|
||||||
#if LIBCURL_VERSION_NUM < 0x070c03
|
#if LIBCURL_VERSION_NUM < 0x070c03
|
||||||
#error "upgrade your libcurl to no less than 7.12.3"
|
#error "upgrade your libcurl to no less than 7.12.3"
|
||||||
@@ -88,12 +88,16 @@ static curlioerr my_ioctl(CURL *handle, curliocmd cmd, void *userp)
|
|||||||
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
size_t retcode;
|
size_t retcode;
|
||||||
|
curl_off_t nread;
|
||||||
|
|
||||||
intptr_t fd = (intptr_t)stream;
|
intptr_t fd = (intptr_t)stream;
|
||||||
|
|
||||||
retcode = read(fd, ptr, size * nmemb);
|
retcode = read(fd, ptr, size * nmemb);
|
||||||
|
|
||||||
fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode);
|
nread = (curl_off_t)retcode;
|
||||||
|
|
||||||
|
fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T
|
||||||
|
" bytes from file\n", nread);
|
||||||
|
|
||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
@@ -239,8 +239,7 @@ static CURLcode sslctxfun(CURL * curl, void * sslctx, void * parm) {
|
|||||||
SSL_CTX_set_cipher_list(ctx,"RC4-MD5");
|
SSL_CTX_set_cipher_list(ctx,"RC4-MD5");
|
||||||
SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
|
SSL_CTX_set_mode(ctx, SSL_MODE_AUTO_RETRY);
|
||||||
|
|
||||||
X509_STORE_add_cert(ctx->cert_store,sk_X509_value(p->ca,
|
X509_STORE_add_cert(SSL_CTX_get_cert_store(ctx), sk_X509_value(p->ca, sk_X509_num(p->ca)-1));
|
||||||
sk_X509_num(p->ca)-1));
|
|
||||||
|
|
||||||
SSL_CTX_set_verify_depth(ctx,2);
|
SSL_CTX_set_verify_depth(ctx,2);
|
||||||
|
|
||||||
|
@@ -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
|
||||||
@@ -36,6 +36,7 @@
|
|||||||
#else
|
#else
|
||||||
#include <sys/types.h> /* socket types */
|
#include <sys/types.h> /* socket types */
|
||||||
#include <sys/socket.h> /* socket definitions */
|
#include <sys/socket.h> /* socket definitions */
|
||||||
|
#include <netinet/in.h>
|
||||||
#include <arpa/inet.h> /* inet (3) funtions */
|
#include <arpa/inet.h> /* inet (3) funtions */
|
||||||
#include <unistd.h> /* misc. UNIX functions */
|
#include <unistd.h> /* misc. UNIX functions */
|
||||||
#endif
|
#endif
|
||||||
@@ -56,7 +57,10 @@ static curl_socket_t opensocket(void *clientp,
|
|||||||
curlsocktype purpose,
|
curlsocktype purpose,
|
||||||
struct curl_sockaddr *address)
|
struct curl_sockaddr *address)
|
||||||
{
|
{
|
||||||
curl_socket_t sockfd = *(curl_socket_t *)clientp;
|
curl_socket_t sockfd;
|
||||||
|
(void)purpose;
|
||||||
|
(void)address;
|
||||||
|
sockfd = *(curl_socket_t *)clientp;
|
||||||
/* the actual externally set socket is passed in via the OPENSOCKETDATA
|
/* the actual externally set socket is passed in via the OPENSOCKETDATA
|
||||||
option */
|
option */
|
||||||
return sockfd;
|
return sockfd;
|
||||||
@@ -65,6 +69,9 @@ static curl_socket_t opensocket(void *clientp,
|
|||||||
static int sockopt_callback(void *clientp, curl_socket_t curlfd,
|
static int sockopt_callback(void *clientp, curl_socket_t curlfd,
|
||||||
curlsocktype purpose)
|
curlsocktype purpose)
|
||||||
{
|
{
|
||||||
|
(void)clientp;
|
||||||
|
(void)curlfd;
|
||||||
|
(void)purpose;
|
||||||
/* This return code was added in libcurl 7.21.5 */
|
/* This return code was added in libcurl 7.21.5 */
|
||||||
return CURL_SOCKOPT_ALREADY_CONNECTED;
|
return CURL_SOCKOPT_ALREADY_CONNECTED;
|
||||||
}
|
}
|
||||||
@@ -95,7 +102,7 @@ int main(void)
|
|||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://99.99.99.99:9999");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://99.99.99.99:9999");
|
||||||
|
|
||||||
/* Create the socket "manually" */
|
/* Create the socket "manually" */
|
||||||
if( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0 ) {
|
if( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) == CURL_SOCKET_BAD ) {
|
||||||
printf("Error creating listening socket.\n");
|
printf("Error creating listening socket.\n");
|
||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
@@ -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
|
||||||
@@ -33,7 +33,7 @@ static long file_is_comming(struct curl_fileinfo *finfo,
|
|||||||
static long file_is_downloaded(struct callback_data *data);
|
static long file_is_downloaded(struct callback_data *data);
|
||||||
|
|
||||||
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
||||||
struct callback_data *data);
|
void *cb_data);
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
@@ -135,8 +135,9 @@ static long file_is_downloaded(struct callback_data *data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
static size_t write_it(char *buff, size_t size, size_t nmemb,
|
||||||
struct callback_data *data)
|
void *cb_data)
|
||||||
{
|
{
|
||||||
|
struct callback_data *data = cb_data;
|
||||||
size_t written = 0;
|
size_t written = 0;
|
||||||
if(data->output)
|
if(data->output)
|
||||||
written = fwrite(buff, size, nmemb, data->output);
|
written = fwrite(buff, size, nmemb, data->output);
|
||||||
|
@@ -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
|
||||||
@@ -32,7 +32,6 @@
|
|||||||
#else
|
#else
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
#include "printf_macro.h"
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This example shows an FTP upload, with a rename of the file just after
|
* This example shows an FTP upload, with a rename of the file just after
|
||||||
@@ -52,12 +51,16 @@
|
|||||||
variable's memory when passed in to it from an app like this. */
|
variable's memory when passed in to it from an app like this. */
|
||||||
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
|
curl_off_t nread;
|
||||||
/* in real-world cases, this would probably get this data differently
|
/* in real-world cases, this would probably get this data differently
|
||||||
as this fread() stuff is exactly what the library already would do
|
as this fread() stuff is exactly what the library already would do
|
||||||
by default internally */
|
by default internally */
|
||||||
size_t retcode = fread(ptr, size, nmemb, stream);
|
size_t retcode = fread(ptr, size, nmemb, stream);
|
||||||
|
|
||||||
fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode);
|
nread = (curl_off_t)retcode;
|
||||||
|
|
||||||
|
fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T
|
||||||
|
" bytes from file\n", nread);
|
||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -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
|
||||||
@@ -25,7 +25,6 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "printf_macro.h"
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This example shows a HTTP PUT operation. PUTs a file given as a command
|
* This example shows a HTTP PUT operation. PUTs a file given as a command
|
||||||
@@ -40,13 +39,17 @@
|
|||||||
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
{
|
{
|
||||||
size_t retcode;
|
size_t retcode;
|
||||||
|
curl_off_t nread;
|
||||||
|
|
||||||
/* in real-world cases, this would probably get this data differently
|
/* in real-world cases, this would probably get this data differently
|
||||||
as this fread() stuff is exactly what the library already would do
|
as this fread() stuff is exactly what the library already would do
|
||||||
by default internally */
|
by default internally */
|
||||||
retcode = fread(ptr, size, nmemb, stream);
|
retcode = fread(ptr, size, nmemb, stream);
|
||||||
|
|
||||||
fprintf(stderr, "*** We read %" _FMT_SIZE_T " bytes from file\n", retcode);
|
nread = (curl_off_t)retcode;
|
||||||
|
|
||||||
|
fprintf(stderr, "*** We read %" CURL_FORMAT_CURL_OFF_T
|
||||||
|
" bytes from file\n", nread);
|
||||||
|
|
||||||
return retcode;
|
return retcode;
|
||||||
}
|
}
|
||||||
|
@@ -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
|
||||||
@@ -19,27 +19,26 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
/* Simple hack trying to get a valid printf format string for size_t.
|
#include <stdio.h>
|
||||||
* If that fails for your platform you can define your own _FMT_SIZE_T,
|
#include <curl/curl.h>
|
||||||
* f.e.: -D_FMT_SIZE_T="zd"
|
|
||||||
*/
|
|
||||||
#ifndef _PRINTF_MACRO_H
|
|
||||||
#define _PRINTF_MACRO_H
|
|
||||||
|
|
||||||
#ifndef _FMT_SIZE_T
|
int main(void)
|
||||||
#ifdef WIN32
|
{
|
||||||
#define _FMT_SIZE_T "Id"
|
CURL *curl;
|
||||||
#else
|
CURLcode res = CURLE_OK;
|
||||||
/*
|
|
||||||
"zd" is a GNU extension to POSIX; so we dont use it for size_t but hack around
|
|
||||||
#define _FMT_SIZE_T "zd"
|
|
||||||
*/
|
|
||||||
#ifdef __x86_64__
|
|
||||||
#define _FMT_SIZE_T "lu"
|
|
||||||
#else
|
|
||||||
#define _FMT_SIZE_T "u"
|
|
||||||
#endif /* __x86_64__ */
|
|
||||||
#endif /* WIN32 */
|
|
||||||
#endif /* !_FMT_SIZE_T */
|
|
||||||
|
|
||||||
#endif /* !_PRINTF_MACRO_H */
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Set username and password */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password");
|
||||||
|
|
||||||
|
/* This will fetch the mailbox named "foobar" */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "imap://imap.example.com/foobar");
|
||||||
|
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return (int)res;
|
||||||
|
}
|
68
docs/examples/pop3s.c
Normal file
68
docs/examples/pop3s.c
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Set username and password */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password");
|
||||||
|
|
||||||
|
/* This will only fetch the message with ID "1" of the given mailbox */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "pop3s://user@pop.example.com/1");
|
||||||
|
|
||||||
|
#ifdef SKIP_PEER_VERIFICATION
|
||||||
|
/*
|
||||||
|
* If you want to connect to a site who isn't using a certificate that is
|
||||||
|
* signed by one of the certs in the CA bundle you have, you can skip the
|
||||||
|
* verification of the server's certificate. This makes the connection
|
||||||
|
* A LOT LESS SECURE.
|
||||||
|
*
|
||||||
|
* If you have a CA cert for the server stored someplace else than in the
|
||||||
|
* default bundle, then the CURLOPT_CAPATH option might come handy for
|
||||||
|
* you.
|
||||||
|
*/
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SKIP_HOSTNAME_VERFICATION
|
||||||
|
/*
|
||||||
|
* If the site you're connecting to uses a different host name that what
|
||||||
|
* they have mentioned in their server certificate's commonName (or
|
||||||
|
* subjectAltName) fields, libcurl will refuse to connect. You can skip
|
||||||
|
* this check, but this will make the connection less secure.
|
||||||
|
*/
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
68
docs/examples/pop3slist.c
Normal file
68
docs/examples/pop3slist.c
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* 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.
|
||||||
|
*
|
||||||
|
***************************************************************************/
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
int main(void)
|
||||||
|
{
|
||||||
|
CURL *curl;
|
||||||
|
CURLcode res;
|
||||||
|
|
||||||
|
curl = curl_easy_init();
|
||||||
|
if(curl) {
|
||||||
|
/* Set username and password */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_USERPWD, "user:password");
|
||||||
|
|
||||||
|
/* This will list every message of the given mailbox */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_URL, "pop3s://user@pop.example.com/");
|
||||||
|
|
||||||
|
#ifdef SKIP_PEER_VERIFICATION
|
||||||
|
/*
|
||||||
|
* If you want to connect to a site who isn't using a certificate that is
|
||||||
|
* signed by one of the certs in the CA bundle you have, you can skip the
|
||||||
|
* verification of the server's certificate. This makes the connection
|
||||||
|
* A LOT LESS SECURE.
|
||||||
|
*
|
||||||
|
* If you have a CA cert for the server stored someplace else than in the
|
||||||
|
* default bundle, then the CURLOPT_CAPATH option might come handy for
|
||||||
|
* you.
|
||||||
|
*/
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYPEER, 0L);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef SKIP_HOSTNAME_VERFICATION
|
||||||
|
/*
|
||||||
|
* If the site you're connecting to uses a different host name that what
|
||||||
|
* they have mentioned in their server certificate's commonName (or
|
||||||
|
* subjectAltName) fields, libcurl will refuse to connect. You can skip
|
||||||
|
* this check, but this will make the connection less secure.
|
||||||
|
*/
|
||||||
|
curl_easy_setopt(curl, CURLOPT_SSL_VERIFYHOST, 0L);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
res = curl_easy_perform(curl);
|
||||||
|
|
||||||
|
/* always cleanup */
|
||||||
|
curl_easy_cleanup(curl);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -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
|
||||||
@@ -30,7 +30,7 @@ const char data[]="this is what we post to the silly web server";
|
|||||||
|
|
||||||
struct WriteThis {
|
struct WriteThis {
|
||||||
const char *readptr;
|
const char *readptr;
|
||||||
int sizeleft;
|
long sizeleft;
|
||||||
};
|
};
|
||||||
|
|
||||||
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp)
|
static size_t read_callback(void *ptr, size_t size, size_t nmemb, void *userp)
|
||||||
@@ -96,7 +96,7 @@ int main(void)
|
|||||||
#else
|
#else
|
||||||
/* Set the expected POST size. If you want to POST large amounts of data,
|
/* Set the expected POST size. If you want to POST large amounts of data,
|
||||||
consider CURLOPT_POSTFIELDSIZE_LARGE */
|
consider CURLOPT_POSTFIELDSIZE_LARGE */
|
||||||
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (curl_off_t)pooh.sizeleft);
|
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, pooh.sizeleft);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef DISABLE_EXPECT
|
#ifdef DISABLE_EXPECT
|
||||||
|
@@ -22,12 +22,32 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
|
|
||||||
#define STOP_DOWNLOAD_AFTER_THIS_MANY_BYTES 6000
|
#define STOP_DOWNLOAD_AFTER_THIS_MANY_BYTES 6000
|
||||||
|
#define MINIMAL_PROGRESS_FUNCTIONALITY_INTERVAL 3
|
||||||
|
|
||||||
|
struct myprogress {
|
||||||
|
double lastruntime;
|
||||||
|
CURL *curl;
|
||||||
|
};
|
||||||
|
|
||||||
static int progress(void *p,
|
static int progress(void *p,
|
||||||
double dltotal, double dlnow,
|
double dltotal, double dlnow,
|
||||||
double ultotal, double ulnow)
|
double ultotal, double ulnow)
|
||||||
{
|
{
|
||||||
|
struct myprogress *myp = (struct myprogress *)p;
|
||||||
|
CURL *curl = myp->curl;
|
||||||
|
double curtime = 0;
|
||||||
|
|
||||||
|
curl_easy_getinfo(curl, CURLINFO_TOTAL_TIME, &curtime);
|
||||||
|
|
||||||
|
/* under certain circumstances it may be desirable for certain functionality
|
||||||
|
to only run every N seconds, in order to do this the transaction time can
|
||||||
|
be used */
|
||||||
|
if((curtime - myp->lastruntime) >= MINIMAL_PROGRESS_FUNCTIONALITY_INTERVAL) {
|
||||||
|
myp->lastruntime = curtime;
|
||||||
|
fprintf(stderr, "TOTAL TIME: %f \r\n", curtime);
|
||||||
|
}
|
||||||
|
|
||||||
fprintf(stderr, "UP: %g of %g DOWN: %g of %g\r\n",
|
fprintf(stderr, "UP: %g of %g DOWN: %g of %g\r\n",
|
||||||
ulnow, ultotal, dlnow, dltotal);
|
ulnow, ultotal, dlnow, dltotal);
|
||||||
|
|
||||||
@@ -40,11 +60,17 @@ int main(void)
|
|||||||
{
|
{
|
||||||
CURL *curl;
|
CURL *curl;
|
||||||
CURLcode res=0;
|
CURLcode res=0;
|
||||||
|
struct myprogress prog;
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
|
prog.lastruntime = 0;
|
||||||
|
prog.curl = curl;
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
curl_easy_setopt(curl, CURLOPT_URL, "http://example.com/");
|
||||||
curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, progress);
|
curl_easy_setopt(curl, CURLOPT_PROGRESSFUNCTION, progress);
|
||||||
|
/* pass the struct pointer into the progress function */
|
||||||
|
curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, &prog);
|
||||||
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L);
|
curl_easy_setopt(curl, CURLOPT_NOPROGRESS, 0L);
|
||||||
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
|
||||||
@@ -24,7 +24,6 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <curl/curl.h>
|
#include <curl/curl.h>
|
||||||
#include "printf_macro.h"
|
|
||||||
|
|
||||||
/* Auxiliary function that waits on the socket. */
|
/* Auxiliary function that waits on the socket. */
|
||||||
static int wait_on_socket(curl_socket_t sockfd, int for_recv, long timeout_ms)
|
static int wait_on_socket(curl_socket_t sockfd, int for_recv, long timeout_ms)
|
||||||
@@ -65,6 +64,7 @@ int main(void)
|
|||||||
curl_socket_t sockfd; /* socket */
|
curl_socket_t sockfd; /* socket */
|
||||||
long sockextr;
|
long sockextr;
|
||||||
size_t iolen;
|
size_t iolen;
|
||||||
|
curl_off_t nread;
|
||||||
|
|
||||||
curl = curl_easy_init();
|
curl = curl_easy_init();
|
||||||
if(curl) {
|
if(curl) {
|
||||||
@@ -123,7 +123,9 @@ int main(void)
|
|||||||
if(CURLE_OK != res)
|
if(CURLE_OK != res)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
printf("Received %" _FMT_SIZE_T " bytes.\n", iolen);
|
nread = (curl_off_t)iolen;
|
||||||
|
|
||||||
|
printf("Received %" CURL_FORMAT_CURL_OFF_T " bytes.\n", nread);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* always cleanup */
|
/* always cleanup */
|
||||||
|
81
docs/examples/url2file.c
Normal file
81
docs/examples/url2file.c
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
/***************************************************************************
|
||||||
|
* _ _ ____ _
|
||||||
|
* Project ___| | | | _ \| |
|
||||||
|
* / __| | | | |_) | |
|
||||||
|
* | (__| |_| | _ <| |___
|
||||||
|
* \___|\___/|_| \_\_____|
|
||||||
|
*
|
||||||
|
* Copyright (C) 1998 - 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 <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
static size_t write_data(void *ptr, size_t size, size_t nmemb, void *stream)
|
||||||
|
{
|
||||||
|
size_t written = fwrite(ptr, size, nmemb, (FILE *)stream);
|
||||||
|
return written;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
CURL *curl_handle;
|
||||||
|
static const char *pagefilename = "page.out";
|
||||||
|
FILE *pagefile;
|
||||||
|
|
||||||
|
if(argc < 2 ) {
|
||||||
|
printf("Usage: %s <URL>\n", argv[0]);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
curl_global_init(CURL_GLOBAL_ALL);
|
||||||
|
|
||||||
|
/* init the curl session */
|
||||||
|
curl_handle = curl_easy_init();
|
||||||
|
|
||||||
|
/* set URL to get here */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_URL, argv[1]);
|
||||||
|
|
||||||
|
/* Switch on full protocol/debug output while testing */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_VERBOSE, 1L);
|
||||||
|
|
||||||
|
/* disable progress meter, set to 0L to enable and disable debug output */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_NOPROGRESS, 1L);
|
||||||
|
|
||||||
|
/* send all data to this function */
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_WRITEFUNCTION, write_data);
|
||||||
|
|
||||||
|
/* open the file */
|
||||||
|
pagefile = fopen(pagefilename, "wb");
|
||||||
|
if (pagefile) {
|
||||||
|
|
||||||
|
/* write the page body to this file handle. CURLOPT_FILE is also known as
|
||||||
|
CURLOPT_WRITEDATA*/
|
||||||
|
curl_easy_setopt(curl_handle, CURLOPT_FILE, pagefile);
|
||||||
|
|
||||||
|
/* get it! */
|
||||||
|
curl_easy_perform(curl_handle);
|
||||||
|
|
||||||
|
/* close the header file */
|
||||||
|
fclose(pagefile);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* cleanup curl stuff */
|
||||||
|
curl_easy_cleanup(curl_handle);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
@@ -82,7 +82,7 @@ PDFPAGES = curl_easy_cleanup.pdf curl_easy_getinfo.pdf \
|
|||||||
CLEANFILES = $(HTMLPAGES) $(PDFPAGES)
|
CLEANFILES = $(HTMLPAGES) $(PDFPAGES)
|
||||||
|
|
||||||
EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 ABI \
|
EXTRA_DIST = $(man_MANS) $(HTMLPAGES) index.html $(PDFPAGES) libcurl.m4 ABI \
|
||||||
symbols-in-versions
|
symbols-in-versions symbols.pl
|
||||||
MAN2HTML= roffit --mandir=. < $< >$@
|
MAN2HTML= roffit --mandir=. < $< >$@
|
||||||
|
|
||||||
SUFFIXES = .3 .html
|
SUFFIXES = .3 .html
|
||||||
|
@@ -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
|
||||||
@@ -44,11 +44,13 @@ The following information can be extracted:
|
|||||||
.IP CURLINFO_EFFECTIVE_URL
|
.IP CURLINFO_EFFECTIVE_URL
|
||||||
Pass a pointer to a char pointer to receive the last used effective URL.
|
Pass a pointer to a char pointer to receive the last used effective URL.
|
||||||
.IP CURLINFO_RESPONSE_CODE
|
.IP CURLINFO_RESPONSE_CODE
|
||||||
Pass a pointer to a long to receive the last received HTTP or FTP code. This
|
Pass a pointer to a long to receive the last received HTTP, FTP or SMTP
|
||||||
option was known as CURLINFO_HTTP_CODE in libcurl 7.10.7 and earlier. This
|
response code. This option was previously known as CURLINFO_HTTP_CODE in
|
||||||
will be zero if no server response code has been received. Note that a proxy's
|
libcurl 7.10.7 and earlier. The value will be zero if no server response code
|
||||||
CONNECT response should be read with \fICURLINFO_HTTP_CONNECTCODE\fP and not
|
has been received. Note that a proxy's CONNECT response should be read with
|
||||||
this.
|
\fICURLINFO_HTTP_CONNECTCODE\fP and not this.
|
||||||
|
|
||||||
|
Support for SMTP responses added in 7.25.0.
|
||||||
.IP CURLINFO_HTTP_CONNECTCODE
|
.IP CURLINFO_HTTP_CONNECTCODE
|
||||||
Pass a pointer to a long to receive the last received proxy response code to a
|
Pass a pointer to a long to receive the last received proxy response code to a
|
||||||
CONNECT request.
|
CONNECT request.
|
||||||
|
@@ -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
|
||||||
@@ -266,7 +266,7 @@ If you forward the input arguments directly to "fseek" or "lseek", note that
|
|||||||
the data type for \fIoffset\fP is not the same as defined for curl_off_t on
|
the data type for \fIoffset\fP is not the same as defined for curl_off_t on
|
||||||
many systems! (Option added in 7.18.0)
|
many systems! (Option added in 7.18.0)
|
||||||
.IP CURLOPT_SEEKDATA
|
.IP CURLOPT_SEEKDATA
|
||||||
Data pointer to pass to the file read function. If you use the
|
Data pointer to pass to the file seek function. If you use the
|
||||||
\fICURLOPT_SEEKFUNCTION\fP option, this is the pointer you'll get as input. If
|
\fICURLOPT_SEEKFUNCTION\fP option, this is the pointer you'll get as input. If
|
||||||
you don't specify a seek callback, NULL is passed. (Option added in 7.18.0)
|
you don't specify a seek callback, NULL is passed. (Option added in 7.18.0)
|
||||||
.IP CURLOPT_SOCKOPTFUNCTION
|
.IP CURLOPT_SOCKOPTFUNCTION
|
||||||
@@ -281,7 +281,7 @@ socket descriptor so additional setsockopt() calls can be done at the user's
|
|||||||
discretion. Return 0 (zero) from the callback on success. Return 1 from the
|
discretion. Return 0 (zero) from the callback on success. Return 1 from the
|
||||||
callback function to signal an unrecoverable error to the library and it will
|
callback function to signal an unrecoverable error to the library and it will
|
||||||
close the socket and return \fICURLE_COULDNT_CONNECT\fP. (Option added in
|
close the socket and return \fICURLE_COULDNT_CONNECT\fP. (Option added in
|
||||||
7.15.6.)
|
7.16.0)
|
||||||
|
|
||||||
Added in 7.21.5, the callback function may return
|
Added in 7.21.5, the callback function may return
|
||||||
\fICURL_SOCKOPT_ALREADY_CONNECTED\fP, which tells libcurl that the socket is
|
\fICURL_SOCKOPT_ALREADY_CONNECTED\fP, which tells libcurl that the socket is
|
||||||
@@ -289,15 +289,14 @@ in fact already connected and then libcurl will not attempt to connect it.
|
|||||||
.IP CURLOPT_SOCKOPTDATA
|
.IP CURLOPT_SOCKOPTDATA
|
||||||
Pass a pointer that will be untouched by libcurl and passed as the first
|
Pass a pointer that will be untouched by libcurl and passed as the first
|
||||||
argument in the sockopt callback set with \fICURLOPT_SOCKOPTFUNCTION\fP.
|
argument in the sockopt callback set with \fICURLOPT_SOCKOPTFUNCTION\fP.
|
||||||
(Option added in 7.15.6.)
|
(Option added in 7.16.0)
|
||||||
.IP CURLOPT_OPENSOCKETFUNCTION
|
.IP CURLOPT_OPENSOCKETFUNCTION
|
||||||
Function pointer that should match the \fIcurl_opensocket_callback\fP
|
Function pointer that should match the \fIcurl_opensocket_callback\fP
|
||||||
prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl
|
prototype found in \fI<curl/curl.h>\fP. This function gets called by libcurl
|
||||||
instead of the \fIsocket(2)\fP call. The callback's \fIpurpose\fP argument
|
instead of the \fIsocket(2)\fP call. The callback's \fIpurpose\fP argument
|
||||||
identifies the exact purpose for this particular socket, and currently only
|
identifies the exact purpose for this particular socket:
|
||||||
one value is supported: \fICURLSOCKTYPE_IPCXN\fP for the primary connection
|
\fICURLSOCKTYPE_IPCXN\fP is for IP based connections. Future versions of
|
||||||
(meaning the control connection in the FTP case). Future versions of libcurl
|
libcurl may support more purposes. It passes the resolved peer address as a
|
||||||
may support more purposes. It passes the resolved peer address as a
|
|
||||||
\fIaddress\fP argument so the callback can modify the address or refuse to
|
\fIaddress\fP argument so the callback can modify the address or refuse to
|
||||||
connect at all. The callback function should return the socket or
|
connect at all. The callback function should return the socket or
|
||||||
\fICURL_SOCKET_BAD\fP in case no connection should be established or any error
|
\fICURL_SOCKET_BAD\fP in case no connection should be established or any error
|
||||||
@@ -323,7 +322,7 @@ to the \fICURLOPT_OPENSOCKETFUNCTION\fP option. Return 0 to signal success and
|
|||||||
1 if there was an error. (Option added in 7.21.7)
|
1 if there was an error. (Option added in 7.21.7)
|
||||||
.IP CURLOPT_CLOSESOCKETDATA
|
.IP CURLOPT_CLOSESOCKETDATA
|
||||||
Pass a pointer that will be untouched by libcurl and passed as the first
|
Pass a pointer that will be untouched by libcurl and passed as the first
|
||||||
argument in the opensocket callback set with
|
argument in the closesocket callback set with
|
||||||
\fICURLOPT_CLOSESOCKETFUNCTION\fP. (Option added in 7.21.7)
|
\fICURLOPT_CLOSESOCKETFUNCTION\fP. (Option added in 7.21.7)
|
||||||
.IP CURLOPT_PROGRESSFUNCTION
|
.IP CURLOPT_PROGRESSFUNCTION
|
||||||
Function pointer that should match the \fIcurl_progress_callback\fP prototype
|
Function pointer that should match the \fIcurl_progress_callback\fP prototype
|
||||||
@@ -358,7 +357,7 @@ of bytes actually taken care of. If that amount differs from the amount passed
|
|||||||
to your function, it'll signal an error to the library. This will abort the
|
to your function, it'll signal an error to the library. This will abort the
|
||||||
transfer and return \fICURL_WRITE_ERROR\fP.
|
transfer and return \fICURL_WRITE_ERROR\fP.
|
||||||
|
|
||||||
A complete header that is passed to this function can be up to
|
A complete HTTP header that is passed to this function can be up to
|
||||||
\fICURL_MAX_HTTP_HEADER\fP (100K) bytes.
|
\fICURL_MAX_HTTP_HEADER\fP (100K) bytes.
|
||||||
|
|
||||||
If this option is not set, or if it is set to NULL, but
|
If this option is not set, or if it is set to NULL, but
|
||||||
@@ -381,6 +380,9 @@ to detect it being a trailer and not an ordinary header: 1) it comes after the
|
|||||||
response-body. 2) it comes after the final header line (CR LF) 3) a Trailer:
|
response-body. 2) it comes after the final header line (CR LF) 3) a Trailer:
|
||||||
header among the regular response-headers mention what header(s) to expect in
|
header among the regular response-headers mention what header(s) to expect in
|
||||||
the trailer.
|
the trailer.
|
||||||
|
|
||||||
|
For non-HTTP protocols like FTP, POP3, IMAP and SMTP this function will get
|
||||||
|
called with the server responses to the commands that libcurl sends.
|
||||||
.IP CURLOPT_WRITEHEADER
|
.IP CURLOPT_WRITEHEADER
|
||||||
(This option is also known as \fBCURLOPT_HEADERDATA\fP) Pass a pointer to be
|
(This option is also known as \fBCURLOPT_HEADERDATA\fP) Pass a pointer to be
|
||||||
used to write the header part of the received data to. If you don't use
|
used to write the header part of the received data to. If you don't use
|
||||||
@@ -420,7 +422,7 @@ built against another SSL library, this functionality is absent.
|
|||||||
|
|
||||||
Function pointer that should match the following prototype: \fBCURLcode
|
Function pointer that should match the following prototype: \fBCURLcode
|
||||||
sslctxfun(CURL *curl, void *sslctx, void *parm);\fP This function gets called
|
sslctxfun(CURL *curl, void *sslctx, void *parm);\fP This function gets called
|
||||||
by libcurl just before the initialization of an SSL connection after having
|
by libcurl just before the initialization of a SSL connection after having
|
||||||
processed all other SSL related options to give a last chance to an
|
processed all other SSL related options to give a last chance to an
|
||||||
application to modify the behaviour of openssl's ssl initialization. The
|
application to modify the behaviour of openssl's ssl initialization. The
|
||||||
\fIsslctx\fP parameter is actually a pointer to an openssl \fISSL_CTX\fP. If
|
\fIsslctx\fP parameter is actually a pointer to an openssl \fISSL_CTX\fP. If
|
||||||
@@ -435,7 +437,7 @@ the SSL negotiation. The SSL_CTX pointer will be a new one every time.
|
|||||||
To use this properly, a non-trivial amount of knowledge of the openssl
|
To use this properly, a non-trivial amount of knowledge of the openssl
|
||||||
libraries is necessary. For example, using this function allows you to use
|
libraries is necessary. For example, using this function allows you to use
|
||||||
openssl callbacks to add additional validation code for certificates, and even
|
openssl callbacks to add additional validation code for certificates, and even
|
||||||
to change the actual URI of an HTTPS request (example used in the lib509 test
|
to change the actual URI of a HTTPS request (example used in the lib509 test
|
||||||
case). See also the example section for a replacement of the key, certificate
|
case). See also the example section for a replacement of the key, certificate
|
||||||
and trust file settings.
|
and trust file settings.
|
||||||
.IP CURLOPT_SSL_CTX_DATA
|
.IP CURLOPT_SSL_CTX_DATA
|
||||||
@@ -595,8 +597,8 @@ terminated string which must be URL-encoded in the following format:
|
|||||||
|
|
||||||
scheme://host:port/path
|
scheme://host:port/path
|
||||||
|
|
||||||
For a greater explanation of the format please see RFC 2396
|
For a greater explanation of the format please see RFC 3986
|
||||||
(http://curl.haxx.se/rfc/rfc2396.txt).
|
(http://curl.haxx.se/rfc/rfc3986.txt).
|
||||||
|
|
||||||
If the given URL lacks the scheme, or protocol, part ("http://" or "ftp://"
|
If the given URL lacks the scheme, or protocol, part ("http://" or "ftp://"
|
||||||
etc), libcurl will attempt to resolve which protocol to use based on the
|
etc), libcurl will attempt to resolve which protocol to use based on the
|
||||||
@@ -712,7 +714,7 @@ pop3://user:password@mail.domain.com/1 - This retrieves the first message
|
|||||||
|
|
||||||
.B SCP
|
.B SCP
|
||||||
|
|
||||||
The path part of an SCP request specifies the file to retrieve and from what
|
The path part of a SCP request specifies the file to retrieve and from what
|
||||||
directory. The file part may not be omitted. The file is taken as an absolute
|
directory. The file part may not be omitted. The file is taken as an absolute
|
||||||
path from the root directory on the server. To specify a path relative to
|
path from the root directory on the server. To specify a path relative to
|
||||||
the user's home directory on the server, prepend ~/ to the path portion.
|
the user's home directory on the server, prepend ~/ to the path portion.
|
||||||
@@ -726,7 +728,7 @@ user's home directory on the server
|
|||||||
|
|
||||||
.B SFTP
|
.B SFTP
|
||||||
|
|
||||||
The path part of an SFTP request specifies the file to retrieve and from what
|
The path part of a SFTP request specifies the file to retrieve and from what
|
||||||
directory. If the file part is omitted then libcurl downloads the directory
|
directory. If the file part is omitted then libcurl downloads the directory
|
||||||
listing for the directory specified. If the path ends in a / then a directory
|
listing for the directory specified. If the path ends in a / then a directory
|
||||||
listing is returned instead of a file. If the path is omitted entirely then
|
listing is returned instead of a file. If the path is omitted entirely then
|
||||||
@@ -779,7 +781,7 @@ proxy's port number may optionally be specified with the separate option. If
|
|||||||
not specified, libcurl will default to using port 1080 for proxies.
|
not specified, libcurl will default to using port 1080 for proxies.
|
||||||
\fICURLOPT_PROXYPORT\fP.
|
\fICURLOPT_PROXYPORT\fP.
|
||||||
|
|
||||||
When you tell the library to use an HTTP proxy, libcurl will transparently
|
When you tell the library to use a HTTP proxy, libcurl will transparently
|
||||||
convert operations to HTTP even if you specify an FTP URL etc. This may have
|
convert operations to HTTP even if you specify an FTP URL etc. This may have
|
||||||
an impact on what other features of the library you can use, such as
|
an impact on what other features of the library you can use, such as
|
||||||
\fICURLOPT_QUOTE\fP and similar FTP specifics that don't work unless you
|
\fICURLOPT_QUOTE\fP and similar FTP specifics that don't work unless you
|
||||||
@@ -809,7 +811,7 @@ specified in the proxy string \fICURLOPT_PROXY\fP.
|
|||||||
.IP CURLOPT_PROXYTYPE
|
.IP CURLOPT_PROXYTYPE
|
||||||
Pass a long with this option to set type of the proxy. Available options for
|
Pass a long with this option to set type of the proxy. Available options for
|
||||||
this are \fICURLPROXY_HTTP\fP, \fICURLPROXY_HTTP_1_0\fP (added in 7.19.4),
|
this are \fICURLPROXY_HTTP\fP, \fICURLPROXY_HTTP_1_0\fP (added in 7.19.4),
|
||||||
\fICURLPROXY_SOCKS4\fP (added in 7.15.2), \fICURLPROXY_SOCKS5\fP,
|
\fICURLPROXY_SOCKS4\fP (added in 7.10), \fICURLPROXY_SOCKS5\fP,
|
||||||
\fICURLPROXY_SOCKS4A\fP (added in 7.18.0) and \fICURLPROXY_SOCKS5_HOSTNAME\fP
|
\fICURLPROXY_SOCKS4A\fP (added in 7.18.0) and \fICURLPROXY_SOCKS5_HOSTNAME\fP
|
||||||
(added in 7.18.0). The HTTP type is default. (Added in 7.10)
|
(added in 7.18.0). The HTTP type is default. (Added in 7.10)
|
||||||
|
|
||||||
@@ -818,7 +820,7 @@ affect how libcurl speaks to a proxy when CONNECT is used. The HTTP version
|
|||||||
used for "regular" HTTP requests is instead controlled with
|
used for "regular" HTTP requests is instead controlled with
|
||||||
\fICURLOPT_HTTP_VERSION\fP.
|
\fICURLOPT_HTTP_VERSION\fP.
|
||||||
.IP CURLOPT_NOPROXY
|
.IP CURLOPT_NOPROXY
|
||||||
Pass a pointer to a zero terminated string. The should be a comma separated
|
Pass a pointer to a zero terminated string. This should be a comma separated
|
||||||
list of hosts which do not use a proxy, if one is specified. The only
|
list of hosts which do not use a proxy, if one is specified. The only
|
||||||
wildcard is a single * character, which matches all hosts, and effectively
|
wildcard is a single * character, which matches all hosts, and effectively
|
||||||
disables the proxy. Each name in this list is matched as either a domain which
|
disables the proxy. Each name in this list is matched as either a domain which
|
||||||
@@ -844,6 +846,15 @@ negotiation. (Added in 7.19.4).
|
|||||||
Pass a char * as parameter. This sets the interface name to use as outgoing
|
Pass a char * as parameter. This sets the interface name to use as outgoing
|
||||||
network interface. The name can be an interface name, an IP address, or a host
|
network interface. The name can be an interface name, an IP address, or a host
|
||||||
name.
|
name.
|
||||||
|
|
||||||
|
Starting with 7.24.0: If the parameter starts with "if!" then it is treated as
|
||||||
|
only as interface name and no attempt will ever be named to do treat it as an
|
||||||
|
IP address or to do name resolution on it. If the parameter starts with
|
||||||
|
\&"host!" it is treated as either an IP address or a hostname. Hostnames are
|
||||||
|
resolved synchronously. Using the if! format is highly recommended when using
|
||||||
|
the multi interfaces to avoid allowing the code to block. If "if!" is
|
||||||
|
specified but the parameter does not match an existing interface,
|
||||||
|
CURLE_INTERFACE_FAILED is returned.
|
||||||
.IP CURLOPT_LOCALPORT
|
.IP CURLOPT_LOCALPORT
|
||||||
Pass a long. This sets the local port number of the socket used for
|
Pass a long. This sets the local port number of the socket used for
|
||||||
connection. This can be used in combination with \fICURLOPT_INTERFACE\fP and
|
connection. This can be used in combination with \fICURLOPT_INTERFACE\fP and
|
||||||
@@ -907,6 +918,20 @@ overdone.
|
|||||||
.IP CURLOPT_ADDRESS_SCOPE
|
.IP CURLOPT_ADDRESS_SCOPE
|
||||||
Pass a long specifying the scope_id value to use when connecting to IPv6
|
Pass a long specifying the scope_id value to use when connecting to IPv6
|
||||||
link-local or site-local addresses. (Added in 7.19.0)
|
link-local or site-local addresses. (Added in 7.19.0)
|
||||||
|
.IP CURLOPT_TCP_KEEPALIVE
|
||||||
|
Pass a long. If set to 1, TCP keepalive probes will be sent. The delay and
|
||||||
|
frequency of these probes can be controlled by the \fICURLOPT_TCP_KEEPIDLE\fP
|
||||||
|
and \fICURLOPT_TCP_KEEPINTVL\fP options, provided the operating system supports
|
||||||
|
them. Set to 0 (default behavior) to disable keepalive probes (Added in
|
||||||
|
7.25.0).
|
||||||
|
.IP CURLOPT_TCP_KEEPIDLE
|
||||||
|
Pass a long. Sets the delay, in seconds, that the operating system will wait
|
||||||
|
while the connection is idle before sending keepalive probes. Not all operating
|
||||||
|
systems support this option. (Added in 7.25.0)
|
||||||
|
.IP CURLOPT_TCP_KEEPINTVL
|
||||||
|
Pass a long. Sets the interval, in seconds, that the operating system will wait
|
||||||
|
between sending keepalive probes. Not all operating systems support this
|
||||||
|
option. (Added in 7.25.0)
|
||||||
.SH NAMES and PASSWORDS OPTIONS (Authentication)
|
.SH NAMES and PASSWORDS OPTIONS (Authentication)
|
||||||
.IP CURLOPT_NETRC
|
.IP CURLOPT_NETRC
|
||||||
This parameter controls the preference of libcurl between using user names and
|
This parameter controls the preference of libcurl between using user names and
|
||||||
@@ -1039,8 +1064,8 @@ HTTP NTLM authentication. A proprietary protocol invented and used by
|
|||||||
Microsoft. It uses a challenge-response and hash concept similar to Digest, to
|
Microsoft. It uses a challenge-response and hash concept similar to Digest, to
|
||||||
prevent the password from being eavesdropped.
|
prevent the password from being eavesdropped.
|
||||||
|
|
||||||
You need to build libcurl with OpenSSL support for this option to work, or
|
You need to build libcurl with either OpenSSL, GnuTLS or NSS support for this
|
||||||
build libcurl on Windows.
|
option to work, or build libcurl on Windows.
|
||||||
.IP CURLAUTH_NTLM_WB
|
.IP CURLAUTH_NTLM_WB
|
||||||
NTLM delegating to winbind helper. Authentication is performed by a separate
|
NTLM delegating to winbind helper. Authentication is performed by a separate
|
||||||
binary application that is executed when needed. The name of the application
|
binary application that is executed when needed. The name of the application
|
||||||
@@ -1107,7 +1132,7 @@ Pass a parameter set to 1 to enable this. When enabled, libcurl will
|
|||||||
automatically set the Referer: field in requests where it follows a Location:
|
automatically set the Referer: field in requests where it follows a Location:
|
||||||
redirect.
|
redirect.
|
||||||
.IP CURLOPT_ACCEPT_ENCODING
|
.IP CURLOPT_ACCEPT_ENCODING
|
||||||
Sets the contents of the Accept-Encoding: header sent in an HTTP request, and
|
Sets the contents of the Accept-Encoding: header sent in a HTTP request, and
|
||||||
enables decoding of a response when a Content-Encoding: header is received.
|
enables decoding of a response when a Content-Encoding: header is received.
|
||||||
Three encodings are supported: \fIidentity\fP, which does nothing,
|
Three encodings are supported: \fIidentity\fP, which does nothing,
|
||||||
\fIdeflate\fP which requests the server to compress its response using the
|
\fIdeflate\fP which requests the server to compress its response using the
|
||||||
@@ -1135,7 +1160,7 @@ by both HTTP clients and HTTP servers.
|
|||||||
(Added in 7.21.6)
|
(Added in 7.21.6)
|
||||||
.IP CURLOPT_FOLLOWLOCATION
|
.IP CURLOPT_FOLLOWLOCATION
|
||||||
A parameter set to 1 tells the library to follow any Location: header that the
|
A parameter set to 1 tells the library to follow any Location: header that the
|
||||||
server sends as part of an HTTP header.
|
server sends as part of a HTTP header.
|
||||||
|
|
||||||
This means that the library will re-send the same request on the new location
|
This means that the library will re-send the same request on the new location
|
||||||
and follow new Location: headers all the way until no more such headers are
|
and follow new Location: headers all the way until no more such headers are
|
||||||
@@ -1158,12 +1183,13 @@ Setting the limit to 0 will make libcurl refuse any redirect. Set it to -1 for
|
|||||||
an infinite number of redirects (which is the default)
|
an infinite number of redirects (which is the default)
|
||||||
.IP CURLOPT_POSTREDIR
|
.IP CURLOPT_POSTREDIR
|
||||||
Pass a bitmask to control how libcurl acts on redirects after POSTs that get a
|
Pass a bitmask to control how libcurl acts on redirects after POSTs that get a
|
||||||
301 or 302 response back. A parameter with bit 0 set (value
|
301, 302 or 303 response back. A parameter with bit 0 set (value
|
||||||
\fBCURL_REDIR_POST_301\fP) tells the library to respect RFC 2616/10.3.2 and
|
\fBCURL_REDIR_POST_301\fP) tells the library to respect RFC 2616/10.3.2 and
|
||||||
not convert POST requests into GET requests when following a 301
|
not convert POST requests into GET requests when following a 301
|
||||||
redirection. Setting bit 1 (value CURL_REDIR_POST_302) makes libcurl maintain
|
redirection. Setting bit 1 (value CURL_REDIR_POST_302) makes libcurl maintain
|
||||||
the request method after a 302 redirect. CURL_REDIR_POST_ALL is a convenience
|
the request method after a 302 redirect. Setting bit 2 (value
|
||||||
define that sets both bits.
|
\fBCURL_REDIR_POST_303) makes libcurl maintain the request method after a 302
|
||||||
|
redirect. CURL_REDIR_POST_ALL is a convenience define that sets both bits.
|
||||||
|
|
||||||
The non-RFC behaviour is ubiquitous in web browsers, so the library does the
|
The non-RFC behaviour is ubiquitous in web browsers, so the library does the
|
||||||
conversion by default to maintain consistency. However, a server may require a
|
conversion by default to maintain consistency. However, a server may require a
|
||||||
@@ -1215,7 +1241,7 @@ If you issue a POST request and then want to make a HEAD or GET using the same
|
|||||||
re-used handle, you must explicitly set the new request type using
|
re-used handle, you must explicitly set the new request type using
|
||||||
\fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar.
|
\fICURLOPT_NOBODY\fP or \fICURLOPT_HTTPGET\fP or similar.
|
||||||
.IP CURLOPT_POSTFIELDS
|
.IP CURLOPT_POSTFIELDS
|
||||||
Pass a void * as parameter, which should be the full data to post in an HTTP
|
Pass a void * as parameter, which should be the full data to post in a HTTP
|
||||||
POST operation. You must make sure that the data is formatted the way you want
|
POST operation. You must make sure that the data is formatted the way you want
|
||||||
the server to receive it. libcurl will not convert or encode it for you. Most
|
the server to receive it. libcurl will not convert or encode it for you. Most
|
||||||
web servers will assume this data to be url-encoded.
|
web servers will assume this data to be url-encoded.
|
||||||
@@ -1250,7 +1276,7 @@ Pass a curl_off_t as parameter. Use this to set the size of the
|
|||||||
data to figure out the size. This is the large file version of the
|
data to figure out the size. This is the large file version of the
|
||||||
\fICURLOPT_POSTFIELDSIZE\fP option. (Added in 7.11.1)
|
\fICURLOPT_POSTFIELDSIZE\fP option. (Added in 7.11.1)
|
||||||
.IP CURLOPT_COPYPOSTFIELDS
|
.IP CURLOPT_COPYPOSTFIELDS
|
||||||
Pass a char * as parameter, which should be the full data to post in an HTTP
|
Pass a char * as parameter, which should be the full data to post in a HTTP
|
||||||
POST operation. It behaves as the \fICURLOPT_POSTFIELDS\fP option, but the
|
POST operation. It behaves as the \fICURLOPT_POSTFIELDS\fP option, but the
|
||||||
original data are copied by the library, allowing the application to overwrite
|
original data are copied by the library, allowing the application to overwrite
|
||||||
the original data after setting this option.
|
the original data after setting this option.
|
||||||
@@ -1337,7 +1363,7 @@ option and thus you need to concatenate them all in one single string. Set
|
|||||||
multiple cookies in one string like this: "name1=content1; name2=content2;"
|
multiple cookies in one string like this: "name1=content1; name2=content2;"
|
||||||
etc.
|
etc.
|
||||||
|
|
||||||
This option sets the cookie header explictly in the outgoing request(s). If
|
This option sets the cookie header explicitly in the outgoing request(s). If
|
||||||
multiple requests are done due to authentication, followed redirections or
|
multiple requests are done due to authentication, followed redirections or
|
||||||
similar, they will all get this cookie passed on.
|
similar, they will all get this cookie passed on.
|
||||||
|
|
||||||
@@ -1422,25 +1448,48 @@ transfer decoding will be disabled, if set to 1 it is enabled
|
|||||||
option is set to zero. (added in 7.16.2)
|
option is set to zero. (added in 7.16.2)
|
||||||
.SH SMTP OPTIONS
|
.SH SMTP OPTIONS
|
||||||
.IP CURLOPT_MAIL_FROM
|
.IP CURLOPT_MAIL_FROM
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used to
|
Pass a pointer to a zero terminated string as parameter. This should be used
|
||||||
specify the sender address in a mail when sending an SMTP mail with libcurl.
|
to specify the sender's email address when sending SMTP mail with libcurl.
|
||||||
|
|
||||||
An originator email address in SMTP lingo is specified within angle brackets
|
An originator email address should be specified with angled brackets (<>)
|
||||||
(<>) which libcurl will not add for you before version 7.21.4. Failing to
|
around it, which if not specified, will be added by libcurl from version
|
||||||
provide such brackets may cause the server to reject your mail.
|
7.21.4 onwards. Failing to provide such brackets may cause the server to
|
||||||
|
reject the email.
|
||||||
|
|
||||||
|
If this parameter is not specified then an empty address will be sent to the
|
||||||
|
mail server which may or may not cause the email to be rejected.
|
||||||
|
|
||||||
(Added in 7.20.0)
|
(Added in 7.20.0)
|
||||||
.IP CURLOPT_MAIL_RCPT
|
.IP CURLOPT_MAIL_RCPT
|
||||||
Pass a pointer to a linked list of recipients to pass to the server in your
|
Pass a pointer to a linked list of recipients to pass to the server in your
|
||||||
SMTP mail request. The linked list should be a fully valid list of \fBstruct
|
SMTP mail request. The linked list should be a fully valid list of \fBstruct
|
||||||
curl_slist\fP structs properly filled in. Use \fIcurl_slist_append(3)\fP to
|
curl_slist\fP structs properly filled in. Use \fIcurl_slist_append(3)\fP to
|
||||||
create the list and \fIcurl_slist_free_all(3)\fP to clean up an entire list.
|
create the list and \fIcurl_slist_free_all(3)\fP to clean up an entire list.
|
||||||
|
|
||||||
Each recipient in SMTP lingo is specified with angle brackets (<>), but should
|
Each recipient should be specified within a pair of angled brackets (<>),
|
||||||
you not use an angle bracket as first letter libcurl will assume you provide a
|
however, should you not use an angled bracket as the first character libcurl
|
||||||
single email address only and enclose that with angle brackets for you.
|
will assume you provided a single email address and enclose that address
|
||||||
|
within brackets for you.
|
||||||
|
|
||||||
(Added in 7.20.0)
|
(Added in 7.20.0)
|
||||||
|
.IP CURLOPT_MAIL_AUTH
|
||||||
|
Pass a pointer to a zero terminated string as parameter. This will be used
|
||||||
|
to specify the authentication address (identity) of a submitted message that
|
||||||
|
is being relayed to another server.
|
||||||
|
|
||||||
|
This optional parameter allows co-operating agents in a trusted environment to
|
||||||
|
communicate the authentication of individual messages and should only be used
|
||||||
|
by the application program, using libcurl, if the application is itself a
|
||||||
|
mail server acting in such an environment. If the application is operating as
|
||||||
|
such and the AUTH address is not known or is invalid, then an empty string
|
||||||
|
should be used for this parameter.
|
||||||
|
|
||||||
|
Unlike CURLOPT_MAIL_FROM and CURLOPT_MAIL_RCPT, the address should not be
|
||||||
|
specified within a pair of angled brackets (<>). However, if an empty string
|
||||||
|
is used then a pair of brackets will be sent by libcurl as required by
|
||||||
|
RFC-2554.
|
||||||
|
|
||||||
|
(Added in 7.24.0)
|
||||||
.SH TFTP OPTIONS
|
.SH TFTP OPTIONS
|
||||||
.IP CURLOPT_TFTP_BLKSIZE
|
.IP CURLOPT_TFTP_BLKSIZE
|
||||||
Specify block size to use for TFTP data transmission. Valid range as per RFC
|
Specify block size to use for TFTP data transmission. Valid range as per RFC
|
||||||
@@ -1485,9 +1534,9 @@ fully valid list of 'struct curl_slist' structs properly filled in with text
|
|||||||
strings. Use \fIcurl_slist_append(3)\fP to append strings (commands) to the
|
strings. Use \fIcurl_slist_append(3)\fP to append strings (commands) to the
|
||||||
list, and clear the entire list afterwards with
|
list, and clear the entire list afterwards with
|
||||||
\fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a NULL
|
\fIcurl_slist_free_all(3)\fP. Disable this operation again by setting a NULL
|
||||||
to this option. When speaking to a FTP server, prefix the command with an
|
to this option. When speaking to a FTP (or SFTP since 7.24.0) server, prefix
|
||||||
asterisk (*) to make libcurl continue even if the command fails as by default
|
the command with an asterisk (*) to make libcurl continue even if the command
|
||||||
libcurl will stop at first failure.
|
fails as by default libcurl will stop at first failure.
|
||||||
|
|
||||||
The set of valid FTP commands depends on the server (see RFC959 for a list of
|
The set of valid FTP commands depends on the server (see RFC959 for a list of
|
||||||
mandatory commands).
|
mandatory commands).
|
||||||
@@ -1507,7 +1556,7 @@ Pass a pointer to a linked list of FTP commands to pass to the server after
|
|||||||
the transfer type is set. The linked list should be a fully valid list of
|
the transfer type is set. The linked list should be a fully valid list of
|
||||||
struct curl_slist structs properly filled in as described for
|
struct curl_slist structs properly filled in as described for
|
||||||
\fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this
|
\fICURLOPT_QUOTE\fP. Disable this operation again by setting a NULL to this
|
||||||
option. Before version 7.15.6, if you also set \fICURLOPT_NOBODY\fP to 1, this
|
option. Before version 7.16.0, if you also set \fICURLOPT_NOBODY\fP to 1, this
|
||||||
option didn't work.
|
option didn't work.
|
||||||
.IP CURLOPT_DIRLISTONLY
|
.IP CURLOPT_DIRLISTONLY
|
||||||
A parameter set to 1 tells the library to just list the names of files in a
|
A parameter set to 1 tells the library to just list the names of files in a
|
||||||
@@ -1662,7 +1711,7 @@ needed for this method)\fP (Added in 7.20.0)
|
|||||||
When sent by a client, this method changes the description of the session. For
|
When sent by a client, this method changes the description of the session. For
|
||||||
example, if a client is using the server to record a meeting, the client can
|
example, if a client is using the server to record a meeting, the client can
|
||||||
use Announce to inform the server of all the meta-information about the
|
use Announce to inform the server of all the meta-information about the
|
||||||
session. ANNOUNCE acts like an HTTP PUT or POST just like
|
session. ANNOUNCE acts like a HTTP PUT or POST just like
|
||||||
\fICURL_RTSPREQ_SET_PARAMETER\fP (Added in 7.20.0)
|
\fICURL_RTSPREQ_SET_PARAMETER\fP (Added in 7.20.0)
|
||||||
.IP CURL_RTSPREQ_SETUP
|
.IP CURL_RTSPREQ_SETUP
|
||||||
Setup is used to initialize the transport layer for the session. The
|
Setup is used to initialize the transport layer for the session. The
|
||||||
@@ -1685,7 +1734,7 @@ different connections. (Added in 7.20.0)
|
|||||||
.IP CURL_RTSPREQ_GET_PARAMETER
|
.IP CURL_RTSPREQ_GET_PARAMETER
|
||||||
Retrieve a parameter from the server. By default, libcurl will automatically
|
Retrieve a parameter from the server. By default, libcurl will automatically
|
||||||
include a \fIContent-Type: text/parameters\fP header on all non-empty requests
|
include a \fIContent-Type: text/parameters\fP header on all non-empty requests
|
||||||
unless a custom one is set. GET_PARAMETER acts just like an HTTP PUT or POST
|
unless a custom one is set. GET_PARAMETER acts just like a HTTP PUT or POST
|
||||||
(see \fICURL_RTSPREQ_SET_PARAMETER\fP).
|
(see \fICURL_RTSPREQ_SET_PARAMETER\fP).
|
||||||
Applications wishing to send a heartbeat message (e.g. in the presence of a
|
Applications wishing to send a heartbeat message (e.g. in the presence of a
|
||||||
server-specified timeout) should send use an empty GET_PARAMETER request.
|
server-specified timeout) should send use an empty GET_PARAMETER request.
|
||||||
@@ -1693,9 +1742,9 @@ server-specified timeout) should send use an empty GET_PARAMETER request.
|
|||||||
.IP CURL_RTSPREQ_SET_PARAMETER
|
.IP CURL_RTSPREQ_SET_PARAMETER
|
||||||
Set a parameter on the server. By default, libcurl will automatically include
|
Set a parameter on the server. By default, libcurl will automatically include
|
||||||
a \fIContent-Type: text/parameters\fP header unless a custom one is set. The
|
a \fIContent-Type: text/parameters\fP header unless a custom one is set. The
|
||||||
interaction with SET_PARAMTER is much like an HTTP PUT or POST. An application
|
interaction with SET_PARAMTER is much like a HTTP PUT or POST. An application
|
||||||
may either use \fICURLOPT_UPLOAD\fP with \fICURLOPT_READDATA\fP like an HTTP
|
may either use \fICURLOPT_UPLOAD\fP with \fICURLOPT_READDATA\fP like a HTTP
|
||||||
PUT, or it may use \fICURLOPT_POSTFIELDS\fP like an HTTP POST. No chunked
|
PUT, or it may use \fICURLOPT_POSTFIELDS\fP like a HTTP POST. No chunked
|
||||||
transfers are allowed, so the application must set the
|
transfers are allowed, so the application must set the
|
||||||
\fICURLOPT_INFILESIZE\fP in the former and \fICURLOPT_POSTFIELDSIZE\fP in the
|
\fICURLOPT_INFILESIZE\fP in the former and \fICURLOPT_POSTFIELDSIZE\fP in the
|
||||||
latter. Also, there is no use of multi-part POSTs within RTSP. (Added in
|
latter. Also, there is no use of multi-part POSTs within RTSP. (Added in
|
||||||
@@ -1757,7 +1806,7 @@ over FTP. This is a known limitation/flaw that nobody has rectified. libcurl
|
|||||||
simply sets the mode to ASCII and performs a standard transfer.
|
simply sets the mode to ASCII and performs a standard transfer.
|
||||||
.IP CURLOPT_PROXY_TRANSFER_MODE
|
.IP CURLOPT_PROXY_TRANSFER_MODE
|
||||||
Pass a long. If the value is set to 1 (one), it tells libcurl to set the
|
Pass a long. If the value is set to 1 (one), it tells libcurl to set the
|
||||||
transfer mode (binary or ASCII) for FTP transfers done via an HTTP proxy, by
|
transfer mode (binary or ASCII) for FTP transfers done via a HTTP proxy, by
|
||||||
appending ;type=a or ;type=i to the URL. Without this setting, or it being set
|
appending ;type=a or ;type=i to the URL. Without this setting, or it being set
|
||||||
to 0 (zero, the default), \fICURLOPT_TRANSFERTEXT\fP has no effect when doing
|
to 0 (zero, the default), \fICURLOPT_TRANSFERTEXT\fP has no effect when doing
|
||||||
FTP via a proxy. Beware that not all proxies support this feature. (Added in
|
FTP via a proxy. Beware that not all proxies support this feature. (Added in
|
||||||
@@ -1794,16 +1843,20 @@ source file to the remote target file.
|
|||||||
Pass a curl_off_t as parameter. It contains the offset in number of bytes that
|
Pass a curl_off_t as parameter. It contains the offset in number of bytes that
|
||||||
you want the transfer to start from. (Added in 7.11.0)
|
you want the transfer to start from. (Added in 7.11.0)
|
||||||
.IP CURLOPT_CUSTOMREQUEST
|
.IP CURLOPT_CUSTOMREQUEST
|
||||||
Pass a pointer to a zero terminated string as parameter. It will be used
|
Pass a pointer to a zero terminated string as parameter. It can be used to
|
||||||
instead of GET or HEAD when doing an HTTP request, or instead of LIST or NLST
|
specify the request instead of GET or HEAD when performing HTTP based
|
||||||
when doing a FTP directory listing. This is useful for doing DELETE or other
|
requests, instead of LIST and NLST when performing FTP directory listings and
|
||||||
more or less obscure HTTP requests. Don't do this at will, make sure your
|
instead of LIST and RETR when issuing POP3 based commands. This is
|
||||||
server supports the command first.
|
particularly useful, for example, for performing a HTTP DELETE request or a
|
||||||
|
POP3 DELE command.
|
||||||
|
|
||||||
|
Please don't perform this at will, on HTTP based requests, by making sure
|
||||||
|
your server supports the command you are sending first.
|
||||||
|
|
||||||
When you change the request method by setting \fBCURLOPT_CUSTOMREQUEST\fP to
|
When you change the request method by setting \fBCURLOPT_CUSTOMREQUEST\fP to
|
||||||
something, you don't actually change how libcurl behaves or acts in regards to
|
something, you don't actually change how libcurl behaves or acts in regards
|
||||||
the particular request method, it will only change the actual string sent in
|
to the particular request method, it will only change the actual string sent
|
||||||
the request.
|
in the request.
|
||||||
|
|
||||||
For example: if you tell libcurl to do a HEAD request, but then change the
|
For example: if you tell libcurl to do a HEAD request, but then change the
|
||||||
request to a "GET" with \fBCURLOPT_CUSTOMREQUEST\fP you'll still see libcurl
|
request to a "GET" with \fBCURLOPT_CUSTOMREQUEST\fP you'll still see libcurl
|
||||||
@@ -1815,12 +1868,14 @@ POST, use \fICURLOPT_POST\fP or \fICURLOPT_POSTFIELDS\fP and so on.
|
|||||||
Restore to the internal default by setting this to NULL.
|
Restore to the internal default by setting this to NULL.
|
||||||
|
|
||||||
Many people have wrongly used this option to replace the entire request with
|
Many people have wrongly used this option to replace the entire request with
|
||||||
their own, including multiple headers and POST contents. While that might work
|
their own, including multiple headers and POST contents. While that might
|
||||||
in many cases, it will cause libcurl to send invalid requests and it could
|
work in many cases, it will cause libcurl to send invalid requests and it
|
||||||
possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and
|
could possibly confuse the remote server badly. Use \fICURLOPT_POST\fP and
|
||||||
\fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to
|
\fICURLOPT_POSTFIELDS\fP to set POST data. Use \fICURLOPT_HTTPHEADER\fP to
|
||||||
replace or extend the set of headers sent by libcurl. Use
|
replace or extend the set of headers sent by libcurl. Use
|
||||||
\fICURLOPT_HTTP_VERSION\fP to change HTTP version.
|
\fICURLOPT_HTTP_VERSION\fP to change HTTP version.
|
||||||
|
|
||||||
|
(Support for POP3 added in 7.26.0)
|
||||||
.IP CURLOPT_FILETIME
|
.IP CURLOPT_FILETIME
|
||||||
Pass a long. If it is 1, libcurl will attempt to get the modification date of
|
Pass a long. If it is 1, libcurl will attempt to get the modification date of
|
||||||
the remote document in this operation. This requires that the remote server
|
the remote document in this operation. This requires that the remote server
|
||||||
@@ -1829,11 +1884,11 @@ sends the time or replies to a time querying command. The
|
|||||||
can be used after a transfer to extract the received time (if any).
|
can be used after a transfer to extract the received time (if any).
|
||||||
.IP CURLOPT_NOBODY
|
.IP CURLOPT_NOBODY
|
||||||
A parameter set to 1 tells the library to not include the body-part in the
|
A parameter set to 1 tells the library to not include the body-part in the
|
||||||
output. This is only relevant for protocols that have separate header and body
|
output. This is only relevant for protocols that have separate header and
|
||||||
parts. On HTTP(S) servers, this will make libcurl do a HEAD request.
|
body parts. On HTTP(S) servers, this will make libcurl do a HEAD request.
|
||||||
|
|
||||||
To change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change request
|
To change request to GET, you should use \fICURLOPT_HTTPGET\fP. Change
|
||||||
to POST with \fICURLOPT_POST\fP etc.
|
request to POST with \fICURLOPT_POST\fP etc.
|
||||||
.IP CURLOPT_INFILESIZE
|
.IP CURLOPT_INFILESIZE
|
||||||
When uploading a file to a remote site, this option should be used to tell
|
When uploading a file to a remote site, this option should be used to tell
|
||||||
libcurl what the expected size of the infile is. This value should be passed
|
libcurl what the expected size of the infile is. This value should be passed
|
||||||
@@ -1842,6 +1897,9 @@ as a long. See also \fICURLOPT_INFILESIZE_LARGE\fP.
|
|||||||
For uploading using SCP, this option or \fICURLOPT_INFILESIZE_LARGE\fP is
|
For uploading using SCP, this option or \fICURLOPT_INFILESIZE_LARGE\fP is
|
||||||
mandatory.
|
mandatory.
|
||||||
|
|
||||||
|
When sending emails using SMTP, this command can be used to specify the
|
||||||
|
optional SIZE parameter for the MAIL FROM command. (Added in 7.23.0)
|
||||||
|
|
||||||
This option does not limit how much data libcurl will actually send, as that
|
This option does not limit how much data libcurl will actually send, as that
|
||||||
is controlled entirely by what the read callback returns.
|
is controlled entirely by what the read callback returns.
|
||||||
.IP CURLOPT_INFILESIZE_LARGE
|
.IP CURLOPT_INFILESIZE_LARGE
|
||||||
@@ -1910,6 +1968,8 @@ SIGALRM to enable time-outing system calls.
|
|||||||
|
|
||||||
In unix-like systems, this might cause signals to be used unless
|
In unix-like systems, this might cause signals to be used unless
|
||||||
\fICURLOPT_NOSIGNAL\fP is set.
|
\fICURLOPT_NOSIGNAL\fP is set.
|
||||||
|
|
||||||
|
Default timeout is 0 (zero) which means it never times out.
|
||||||
.IP CURLOPT_TIMEOUT_MS
|
.IP CURLOPT_TIMEOUT_MS
|
||||||
Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If
|
Like \fICURLOPT_TIMEOUT\fP but takes number of milliseconds instead. If
|
||||||
libcurl is built to use the standard system name resolver, that portion
|
libcurl is built to use the standard system name resolver, that portion
|
||||||
@@ -1971,9 +2031,9 @@ re-use (default behavior).
|
|||||||
.IP CURLOPT_CONNECTTIMEOUT
|
.IP CURLOPT_CONNECTTIMEOUT
|
||||||
Pass a long. It should contain the maximum time in seconds that you allow the
|
Pass a long. It should contain the maximum time in seconds that you allow the
|
||||||
connection to the server to take. This only limits the connection phase, once
|
connection to the server to take. This only limits the connection phase, once
|
||||||
it has connected, this option is of no more use. Set to zero to disable
|
it has connected, this option is of no more use. Set to zero to switch to the
|
||||||
connection timeout (it will then only timeout on the system's internal
|
default built-in connection timeout - 300 seconds. See also the
|
||||||
timeouts). See also the \fICURLOPT_TIMEOUT\fP option.
|
\fICURLOPT_TIMEOUT\fP option.
|
||||||
|
|
||||||
In unix-like systems, this might cause signals to be used unless
|
In unix-like systems, this might cause signals to be used unless
|
||||||
\fICURLOPT_NOSIGNAL\fP is set.
|
\fICURLOPT_NOSIGNAL\fP is set.
|
||||||
@@ -2045,6 +2105,24 @@ resolves, by including a string in the linked list that uses the format
|
|||||||
and port number must exactly match what was already added previously.
|
and port number must exactly match what was already added previously.
|
||||||
|
|
||||||
(Added in 7.21.3)
|
(Added in 7.21.3)
|
||||||
|
.IP CURLOPT_DNS_SERVERS
|
||||||
|
Set the list of DNS servers to be used instead of the system default.
|
||||||
|
The format of the dns servers option is:
|
||||||
|
|
||||||
|
host[:port][,host[:port]]...
|
||||||
|
|
||||||
|
For example:
|
||||||
|
|
||||||
|
192.168.1.100,192.168.1.101,3.4.5.6
|
||||||
|
|
||||||
|
This option requires that libcurl was built with a resolver backend that
|
||||||
|
supports this operation. The c-ares backend is the only such one.
|
||||||
|
|
||||||
|
(Added in 7.24.0)
|
||||||
|
.IP CURLOPT_ACCEPTTIMEOUT_MS
|
||||||
|
Pass a long telling libcurl the maximum number of milliseconds to wait for a
|
||||||
|
server to connect back to libcurl when an active FTP connection is used. If no
|
||||||
|
timeout is set, the internal default of 60000 will be used. (Added in 7.24.0)
|
||||||
.SH SSL and SECURITY OPTIONS
|
.SH SSL and SECURITY OPTIONS
|
||||||
.IP CURLOPT_SSLCERT
|
.IP CURLOPT_SSLCERT
|
||||||
Pass a pointer to a zero terminated string as parameter. The string should be
|
Pass a pointer to a zero terminated string as parameter. The string should be
|
||||||
@@ -2117,7 +2195,7 @@ Pass a long as parameter. By default, curl assumes a value of 1.
|
|||||||
This option determines whether curl verifies the authenticity of the peer's
|
This option determines whether curl verifies the authenticity of the peer's
|
||||||
certificate. A value of 1 means curl verifies; 0 (zero) means it doesn't.
|
certificate. A value of 1 means curl verifies; 0 (zero) means it doesn't.
|
||||||
|
|
||||||
When negotiating an SSL connection, the server sends a certificate indicating
|
When negotiating a SSL connection, the server sends a certificate indicating
|
||||||
its identity. Curl verifies whether the certificate is authentic, i.e. that
|
its identity. Curl verifies whether the certificate is authentic, i.e. that
|
||||||
you can trust that the server is who the certificate says it is. This trust
|
you can trust that the server is who the certificate says it is. This trust
|
||||||
is based on a chain of digital signatures, rooted in certification authority
|
is based on a chain of digital signatures, rooted in certification authority
|
||||||
@@ -2266,6 +2344,16 @@ this to 1 to enable it. By default all transfers are done using the
|
|||||||
cache. While nothing ever should get hurt by attempting to reuse SSL
|
cache. While nothing ever should get hurt by attempting to reuse SSL
|
||||||
session-IDs, there seem to be broken SSL implementations in the wild that may
|
session-IDs, there seem to be broken SSL implementations in the wild that may
|
||||||
require you to disable this in order for you to succeed. (Added in 7.16.0)
|
require you to disable this in order for you to succeed. (Added in 7.16.0)
|
||||||
|
.IP CURLOPT_SSL_OPTIONS
|
||||||
|
Pass a long with a bitmask to tell libcurl about specific SSL behaviors.
|
||||||
|
|
||||||
|
CURLSSLOPT_ALLOW_BEAST is the only supported bit and by setting this the user
|
||||||
|
will tell libcurl to not attempt to use any work-arounds for a security flaw
|
||||||
|
in the SSL3 and TLS1.0 protocols. If this option isn't used or this bit is
|
||||||
|
set to 0, the SSL layer libcurl uses may use a work-around for this flaw
|
||||||
|
although it might cause interoperability problems with some (older) SSL
|
||||||
|
implementations. WARNING: avoiding this work-around loosens the security, and
|
||||||
|
by setting this option to 1 you ask for exactly that. (Added in 7.25.0)
|
||||||
.IP CURLOPT_KRBLEVEL
|
.IP CURLOPT_KRBLEVEL
|
||||||
Pass a char * as parameter. Set the kerberos security level for FTP; this also
|
Pass a char * as parameter. Set the kerberos security level for FTP; this also
|
||||||
enables kerberos awareness. This is a string, \&'clear', \&'safe',
|
enables kerberos awareness. This is a string, \&'clear', \&'safe',
|
||||||
@@ -2286,8 +2374,8 @@ GSS_C_DELEG_POLICY_FLAG was available at compile-time.
|
|||||||
.IP CURLOPT_SSH_AUTH_TYPES
|
.IP CURLOPT_SSH_AUTH_TYPES
|
||||||
Pass a long set to a bitmask consisting of one or more of
|
Pass a long set to a bitmask consisting of one or more of
|
||||||
CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST,
|
CURLSSH_AUTH_PUBLICKEY, CURLSSH_AUTH_PASSWORD, CURLSSH_AUTH_HOST,
|
||||||
CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one.
|
CURLSSH_AUTH_KEYBOARD. Set CURLSSH_AUTH_ANY to let libcurl pick one. Currently
|
||||||
(Added in 7.16.1)
|
CURLSSH_AUTH_HOST has no effect. (Added in 7.16.1)
|
||||||
.IP CURLOPT_SSH_HOST_PUBLIC_KEY_MD5
|
.IP CURLOPT_SSH_HOST_PUBLIC_KEY_MD5
|
||||||
Pass a char * pointing to a string containing 32 hexadecimal digits. The
|
Pass a char * pointing to a string containing 32 hexadecimal digits. The
|
||||||
string should be the 128 bit MD5 checksum of the remote host's public key, and
|
string should be the 128 bit MD5 checksum of the remote host's public key, and
|
||||||
@@ -2298,6 +2386,9 @@ Pass a char * pointing to a file name for your public key. If not used,
|
|||||||
libcurl defaults to \fB$HOME/.ssh/id_dsa.pub\fP if the HOME environment
|
libcurl defaults to \fB$HOME/.ssh/id_dsa.pub\fP if the HOME environment
|
||||||
variable is set, and just "id_dsa.pub" in the current directory if HOME is not
|
variable is set, and just "id_dsa.pub" in the current directory if HOME is not
|
||||||
set. (Added in 7.16.1)
|
set. (Added in 7.16.1)
|
||||||
|
If an empty string is passed, libcurl will pass no public key to libssh2
|
||||||
|
which then tries to compute it from the private key, this is known to work
|
||||||
|
when libssh2 1.4.0+ is linked against OpenSSL. (Added in 7.26.0)
|
||||||
.IP CURLOPT_SSH_PRIVATE_KEYFILE
|
.IP CURLOPT_SSH_PRIVATE_KEYFILE
|
||||||
Pass a char * pointing to a file name for your private key. If not used,
|
Pass a char * pointing to a file name for your private key. If not used,
|
||||||
libcurl defaults to \fB$HOME/.ssh/id_dsa\fP if the HOME environment variable
|
libcurl defaults to \fB$HOME/.ssh/id_dsa\fP if the HOME environment variable
|
||||||
|
@@ -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
|
||||||
@@ -23,9 +23,9 @@
|
|||||||
.SH NAME
|
.SH NAME
|
||||||
curl_easy_strerror - return string describing error code
|
curl_easy_strerror - return string describing error code
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.nf
|
#include <curl/curl.h>
|
||||||
.B #include <curl/curl.h>
|
|
||||||
.BI "const char *curl_easy_strerror(CURLcode " errornum ");"
|
const char *curl_easy_strerror(CURLcode errornum);
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
The curl_easy_strerror() function returns a string describing the CURLcode
|
The curl_easy_strerror() function returns a string describing the CURLcode
|
||||||
error code passed in the argument \fIerrornum\fP.
|
error code passed in the argument \fIerrornum\fP.
|
||||||
|
@@ -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
|
||||||
@@ -66,20 +66,21 @@ remote server is probably not an OK FTP server.
|
|||||||
.IP "CURLE_REMOTE_ACCESS_DENIED (9)"
|
.IP "CURLE_REMOTE_ACCESS_DENIED (9)"
|
||||||
We were denied access to the resource given in the URL. For FTP, this occurs
|
We were denied access to the resource given in the URL. For FTP, this occurs
|
||||||
while trying to change to the remote directory.
|
while trying to change to the remote directory.
|
||||||
|
.IP "CURLE_FTP_ACCEPT_FAILED (10)"
|
||||||
|
While waiting for the server to connect back when an active FTP session is
|
||||||
|
used, an error code was sent over the control connection or similar.
|
||||||
.IP "CURLE_FTP_WEIRD_PASS_REPLY (11)"
|
.IP "CURLE_FTP_WEIRD_PASS_REPLY (11)"
|
||||||
After having sent the FTP password to the server, libcurl expects a proper
|
After having sent the FTP password to the server, libcurl expects a proper
|
||||||
reply. This error code indicates that an unexpected code was returned.
|
reply. This error code indicates that an unexpected code was returned.
|
||||||
|
.IP "CURLE_FTP_ACCEPT_TIMEOUT (12)"
|
||||||
|
During an active FTP session while waiting for the server to connect, the
|
||||||
|
\fICURLOPT_ACCEPTTIMOUT_MS\fP (or the internal default) timeout expired.
|
||||||
.IP "CURLE_FTP_WEIRD_PASV_REPLY (13)"
|
.IP "CURLE_FTP_WEIRD_PASV_REPLY (13)"
|
||||||
libcurl failed to get a sensible result back from the server as a response to
|
libcurl failed to get a sensible result back from the server as a response to
|
||||||
either a PASV or a EPSV command. The server is flawed.
|
either a PASV or a EPSV command. The server is flawed.
|
||||||
.IP "CURLE_FTP_WEIRD_227_FORMAT (14)"
|
.IP "CURLE_FTP_WEIRD_227_FORMAT (14)"
|
||||||
FTP servers return a 227-line as a response to a PASV command. If libcurl
|
FTP servers return a 227-line as a response to a PASV command. If libcurl
|
||||||
fails to parse that line, this return code is passed back.
|
fails to parse that line, this return code is passed back.
|
||||||
.IP "CURLE_FTP_PRET_FAILED (84)"
|
|
||||||
The FTP server does not understand the PRET command at all or does not support
|
|
||||||
the given argument. Be careful when using \fICURLOPT_CUSTOMREQUEST\fP, a
|
|
||||||
custom LIST command will be sent with PRET CMD before PASV as well. (Added in
|
|
||||||
7.20.0)
|
|
||||||
.IP "CURLE_FTP_CANT_GET_HOST (15)"
|
.IP "CURLE_FTP_CANT_GET_HOST (15)"
|
||||||
An internal failure to lookup the host used for the new connection.
|
An internal failure to lookup the host used for the new connection.
|
||||||
.IP "CURLE_FTP_COULDNT_SET_TYPE (17)"
|
.IP "CURLE_FTP_COULDNT_SET_TYPE (17)"
|
||||||
@@ -227,7 +228,10 @@ Failed to load CRL file (Added in 7.19.0)
|
|||||||
.IP "CURLE_SSL_ISSUER_ERROR (83)"
|
.IP "CURLE_SSL_ISSUER_ERROR (83)"
|
||||||
Issuer check failed (Added in 7.19.0)
|
Issuer check failed (Added in 7.19.0)
|
||||||
.IP "CURLE_FTP_PRET_FAILED (84)"
|
.IP "CURLE_FTP_PRET_FAILED (84)"
|
||||||
PRET command failed
|
The FTP server does not understand the PRET command at all or does not support
|
||||||
|
the given argument. Be careful when using \fICURLOPT_CUSTOMREQUEST\fP, a
|
||||||
|
custom LIST command will be sent with PRET CMD before PASV as well. (Added in
|
||||||
|
7.20.0)
|
||||||
.IP "CURLE_RTSP_CSEQ_ERROR (85)"
|
.IP "CURLE_RTSP_CSEQ_ERROR (85)"
|
||||||
Mismatch of RTSP CSeq numbers.
|
Mismatch of RTSP CSeq numbers.
|
||||||
.IP "CURLE_RTSP_SESSION_ERROR (86)"
|
.IP "CURLE_RTSP_SESSION_ERROR (86)"
|
||||||
|
@@ -144,7 +144,6 @@ the future, you should be aware of the following current restrictions:
|
|||||||
.nf
|
.nf
|
||||||
- Name resolves unless the c-ares or threaded-resolver backends are used
|
- Name resolves unless the c-ares or threaded-resolver backends are used
|
||||||
- NSS SSL connections
|
- NSS SSL connections
|
||||||
- Active FTP connections
|
|
||||||
- HTTP proxy CONNECT operations
|
- HTTP proxy CONNECT operations
|
||||||
- SOCKS proxy handshakes
|
- SOCKS proxy handshakes
|
||||||
- file:// transfers
|
- file:// transfers
|
||||||
|
@@ -817,10 +817,6 @@ This header is required by HTTP 1.1 and even many 1.0 servers and should be
|
|||||||
the name of the server we want to talk to. This includes the port number if
|
the name of the server we want to talk to. This includes the port number if
|
||||||
anything but default.
|
anything but default.
|
||||||
|
|
||||||
.IP "Pragma"
|
|
||||||
\&"no-cache". Tells a possible proxy to not grab a copy from the cache but to
|
|
||||||
fetch a fresh one.
|
|
||||||
|
|
||||||
.IP "Accept"
|
.IP "Accept"
|
||||||
\&"*/*".
|
\&"*/*".
|
||||||
|
|
||||||
@@ -1303,9 +1299,7 @@ ones at any time), you start the transfers by calling
|
|||||||
|
|
||||||
\fIcurl_multi_perform(3)\fP is asynchronous. It will only execute as little as
|
\fIcurl_multi_perform(3)\fP is asynchronous. It will only execute as little as
|
||||||
possible and then return back control to your program. It is designed to never
|
possible and then return back control to your program. It is designed to never
|
||||||
block. If it returns CURLM_CALL_MULTI_PERFORM you better call it again soon,
|
block.
|
||||||
as that is a signal that it still has local data to send or remote data to
|
|
||||||
receive.
|
|
||||||
|
|
||||||
The best usage of this interface is when you do a select() on all possible
|
The best usage of this interface is when you do a select() on all possible
|
||||||
file descriptors or sockets to know when to call libcurl again. This also
|
file descriptors or sockets to know when to call libcurl again. This also
|
||||||
@@ -1341,9 +1335,21 @@ to figure out success on each individual transfer.
|
|||||||
[ seeding, passwords, keys, certificates, ENGINE, ca certs ]
|
[ seeding, passwords, keys, certificates, ENGINE, ca certs ]
|
||||||
|
|
||||||
.SH "Sharing Data Between Easy Handles"
|
.SH "Sharing Data Between Easy Handles"
|
||||||
|
You can share some data between easy handles when the easy interface is used,
|
||||||
|
and some data is share automatically when you use the multi interface.
|
||||||
|
|
||||||
[ fill in ]
|
When you add easy handles to a multi handle, these easy handles will
|
||||||
|
automatically share a lot of the data that otherwise would be kept on a
|
||||||
|
per-easy handle basis when the easy interface is used.
|
||||||
|
|
||||||
|
The DNS cache is shared between handles within a multi handle, making
|
||||||
|
subsequent name resolvings faster and the connection pool that is kept to
|
||||||
|
better allow persistent connections and connection re-use is shared. If you're
|
||||||
|
using the easy interface, you can still share these between specific easy
|
||||||
|
handles by using the share interface, see \fIlibcurl-share(3)\fP.
|
||||||
|
|
||||||
|
Some things are never shared automatically, not within multi handles, like for
|
||||||
|
example cookies so the only way to share that is with the share interface.
|
||||||
.SH "Footnotes"
|
.SH "Footnotes"
|
||||||
|
|
||||||
.IP "[1]"
|
.IP "[1]"
|
||||||
|
@@ -146,7 +146,7 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
|
|||||||
_libcurl_save_libs=$LIBS
|
_libcurl_save_libs=$LIBS
|
||||||
LIBS="$LIBCURL $LIBS"
|
LIBS="$LIBCURL $LIBS"
|
||||||
|
|
||||||
AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <curl/curl.h>],[
|
AC_LINK_IFELSE([AC_LANG_PROGRAM([[#include <curl/curl.h>]],[[
|
||||||
/* Try and use a few common options to force a failure if we are
|
/* Try and use a few common options to force a failure if we are
|
||||||
missing symbols or can't link. */
|
missing symbols or can't link. */
|
||||||
int x;
|
int x;
|
||||||
@@ -158,7 +158,7 @@ x=CURLOPT_ERRORBUFFER;
|
|||||||
x=CURLOPT_STDERR;
|
x=CURLOPT_STDERR;
|
||||||
x=CURLOPT_VERBOSE;
|
x=CURLOPT_VERBOSE;
|
||||||
if (x) ;
|
if (x) ;
|
||||||
])],libcurl_cv_lib_curl_usable=yes,libcurl_cv_lib_curl_usable=no)
|
]])],libcurl_cv_lib_curl_usable=yes,libcurl_cv_lib_curl_usable=no)
|
||||||
|
|
||||||
CPPFLAGS=$_libcurl_save_cppflags
|
CPPFLAGS=$_libcurl_save_cppflags
|
||||||
LIBS=$_libcurl_save_libs
|
LIBS=$_libcurl_save_libs
|
||||||
|
@@ -45,6 +45,8 @@ CURLE_COULDNT_RESOLVE_PROXY 7.1
|
|||||||
CURLE_FAILED_INIT 7.1
|
CURLE_FAILED_INIT 7.1
|
||||||
CURLE_FILESIZE_EXCEEDED 7.10.8
|
CURLE_FILESIZE_EXCEEDED 7.10.8
|
||||||
CURLE_FILE_COULDNT_READ_FILE 7.1
|
CURLE_FILE_COULDNT_READ_FILE 7.1
|
||||||
|
CURLE_FTP_ACCEPT_FAILED 7.24.0
|
||||||
|
CURLE_FTP_ACCEPT_TIMEOUT 7.24.0
|
||||||
CURLE_FTP_ACCESS_DENIED 7.1
|
CURLE_FTP_ACCESS_DENIED 7.1
|
||||||
CURLE_FTP_BAD_DOWNLOAD_RESUME 7.1 7.1
|
CURLE_FTP_BAD_DOWNLOAD_RESUME 7.1 7.1
|
||||||
CURLE_FTP_BAD_FILE_LIST 7.21.0
|
CURLE_FTP_BAD_FILE_LIST 7.21.0
|
||||||
@@ -286,6 +288,7 @@ CURLOPTTYPE_FUNCTIONPOINT 7.1
|
|||||||
CURLOPTTYPE_LONG 7.1
|
CURLOPTTYPE_LONG 7.1
|
||||||
CURLOPTTYPE_OBJECTPOINT 7.1
|
CURLOPTTYPE_OBJECTPOINT 7.1
|
||||||
CURLOPTTYPE_OFF_T 7.11.0
|
CURLOPTTYPE_OFF_T 7.11.0
|
||||||
|
CURLOPT_ACCEPTTIMEOUT_MS 7.24.0
|
||||||
CURLOPT_ACCEPT_ENCODING 7.21.6
|
CURLOPT_ACCEPT_ENCODING 7.21.6
|
||||||
CURLOPT_ADDRESS_SCOPE 7.19.0
|
CURLOPT_ADDRESS_SCOPE 7.19.0
|
||||||
CURLOPT_APPEND 7.17.0
|
CURLOPT_APPEND 7.17.0
|
||||||
@@ -320,6 +323,7 @@ CURLOPT_DEBUGDATA 7.9.6
|
|||||||
CURLOPT_DEBUGFUNCTION 7.9.6
|
CURLOPT_DEBUGFUNCTION 7.9.6
|
||||||
CURLOPT_DIRLISTONLY 7.17.0
|
CURLOPT_DIRLISTONLY 7.17.0
|
||||||
CURLOPT_DNS_CACHE_TIMEOUT 7.9.3
|
CURLOPT_DNS_CACHE_TIMEOUT 7.9.3
|
||||||
|
CURLOPT_DNS_SERVERS 7.24.0
|
||||||
CURLOPT_DNS_USE_GLOBAL_CACHE 7.9.3 7.11.1
|
CURLOPT_DNS_USE_GLOBAL_CACHE 7.9.3 7.11.1
|
||||||
CURLOPT_EGDSOCKET 7.7
|
CURLOPT_EGDSOCKET 7.7
|
||||||
CURLOPT_ENCODING 7.10
|
CURLOPT_ENCODING 7.10
|
||||||
@@ -380,6 +384,7 @@ CURLOPT_LOCALPORT 7.15.2
|
|||||||
CURLOPT_LOCALPORTRANGE 7.15.2
|
CURLOPT_LOCALPORTRANGE 7.15.2
|
||||||
CURLOPT_LOW_SPEED_LIMIT 7.1
|
CURLOPT_LOW_SPEED_LIMIT 7.1
|
||||||
CURLOPT_LOW_SPEED_TIME 7.1
|
CURLOPT_LOW_SPEED_TIME 7.1
|
||||||
|
CURLOPT_MAIL_AUTH 7.25.0
|
||||||
CURLOPT_MAIL_FROM 7.20.0
|
CURLOPT_MAIL_FROM 7.20.0
|
||||||
CURLOPT_MAIL_RCPT 7.20.0
|
CURLOPT_MAIL_RCPT 7.20.0
|
||||||
CURLOPT_MAXCONNECTS 7.7
|
CURLOPT_MAXCONNECTS 7.7
|
||||||
@@ -403,7 +408,7 @@ CURLOPT_OPENSOCKETFUNCTION 7.17.1
|
|||||||
CURLOPT_PASSWDDATA 7.4.2 7.11.1 7.15.5
|
CURLOPT_PASSWDDATA 7.4.2 7.11.1 7.15.5
|
||||||
CURLOPT_PASSWDFUNCTION 7.4.2 7.11.1 7.15.5
|
CURLOPT_PASSWDFUNCTION 7.4.2 7.11.1 7.15.5
|
||||||
CURLOPT_PASSWORD 7.19.1
|
CURLOPT_PASSWORD 7.19.1
|
||||||
CURLOPT_PASV_HOST 7.12.1 7.15.6 7.15.5
|
CURLOPT_PASV_HOST 7.12.1 7.16.0 7.15.5
|
||||||
CURLOPT_PORT 7.1
|
CURLOPT_PORT 7.1
|
||||||
CURLOPT_POST 7.1
|
CURLOPT_POST 7.1
|
||||||
CURLOPT_POST301 7.17.1 7.19.1
|
CURLOPT_POST301 7.17.1 7.19.1
|
||||||
@@ -478,10 +483,14 @@ CURLOPT_SSLVERSION 7.1
|
|||||||
CURLOPT_SSL_CIPHER_LIST 7.9
|
CURLOPT_SSL_CIPHER_LIST 7.9
|
||||||
CURLOPT_SSL_CTX_DATA 7.10.6
|
CURLOPT_SSL_CTX_DATA 7.10.6
|
||||||
CURLOPT_SSL_CTX_FUNCTION 7.10.6
|
CURLOPT_SSL_CTX_FUNCTION 7.10.6
|
||||||
|
CURLOPT_SSL_OPTIONS 7.25.0
|
||||||
CURLOPT_SSL_SESSIONID_CACHE 7.16.0
|
CURLOPT_SSL_SESSIONID_CACHE 7.16.0
|
||||||
CURLOPT_SSL_VERIFYHOST 7.8.1
|
CURLOPT_SSL_VERIFYHOST 7.8.1
|
||||||
CURLOPT_SSL_VERIFYPEER 7.4.2
|
CURLOPT_SSL_VERIFYPEER 7.4.2
|
||||||
CURLOPT_STDERR 7.1
|
CURLOPT_STDERR 7.1
|
||||||
|
CURLOPT_TCP_KEEPALIVE 7.25.0
|
||||||
|
CURLOPT_TCP_KEEPIDLE 7.25.0
|
||||||
|
CURLOPT_TCP_KEEPINTVL 7.25.0
|
||||||
CURLOPT_TCP_NODELAY 7.11.2
|
CURLOPT_TCP_NODELAY 7.11.2
|
||||||
CURLOPT_TELNETOPTIONS 7.7
|
CURLOPT_TELNETOPTIONS 7.7
|
||||||
CURLOPT_TFTP_BLKSIZE 7.19.4
|
CURLOPT_TFTP_BLKSIZE 7.19.4
|
||||||
@@ -558,7 +567,7 @@ CURLSHOPT_SHARE 7.10.3
|
|||||||
CURLSHOPT_UNLOCKFUNC 7.10.3
|
CURLSHOPT_UNLOCKFUNC 7.10.3
|
||||||
CURLSHOPT_UNSHARE 7.10.3
|
CURLSHOPT_UNSHARE 7.10.3
|
||||||
CURLSHOPT_USERDATA 7.10.3
|
CURLSHOPT_USERDATA 7.10.3
|
||||||
CURLSOCKTYPE_IPCXN 7.15.6
|
CURLSOCKTYPE_IPCXN 7.16.0
|
||||||
CURLSSH_AUTH_ANY 7.16.1
|
CURLSSH_AUTH_ANY 7.16.1
|
||||||
CURLSSH_AUTH_DEFAULT 7.16.1
|
CURLSSH_AUTH_DEFAULT 7.16.1
|
||||||
CURLSSH_AUTH_HOST 7.16.1
|
CURLSSH_AUTH_HOST 7.16.1
|
||||||
@@ -566,6 +575,7 @@ CURLSSH_AUTH_KEYBOARD 7.16.1
|
|||||||
CURLSSH_AUTH_NONE 7.16.1
|
CURLSSH_AUTH_NONE 7.16.1
|
||||||
CURLSSH_AUTH_PASSWORD 7.16.1
|
CURLSSH_AUTH_PASSWORD 7.16.1
|
||||||
CURLSSH_AUTH_PUBLICKEY 7.16.1
|
CURLSSH_AUTH_PUBLICKEY 7.16.1
|
||||||
|
CURLSSLOPT_ALLOW_BEAST 7.25.0
|
||||||
CURLUSESSL_ALL 7.17.0
|
CURLUSESSL_ALL 7.17.0
|
||||||
CURLUSESSL_CONTROL 7.17.0
|
CURLUSESSL_CONTROL 7.17.0
|
||||||
CURLUSESSL_NONE 7.17.0
|
CURLUSESSL_NONE 7.17.0
|
||||||
@@ -639,6 +649,7 @@ CURL_READFUNC_PAUSE 7.18.0
|
|||||||
CURL_REDIR_GET_ALL 7.19.1
|
CURL_REDIR_GET_ALL 7.19.1
|
||||||
CURL_REDIR_POST_301 7.19.1
|
CURL_REDIR_POST_301 7.19.1
|
||||||
CURL_REDIR_POST_302 7.19.1
|
CURL_REDIR_POST_302 7.19.1
|
||||||
|
CURL_REDIR_POST_303 7.25.1
|
||||||
CURL_REDIR_POST_ALL 7.19.1
|
CURL_REDIR_POST_ALL 7.19.1
|
||||||
CURL_RTSPREQ_ANNOUNCE 7.20.0
|
CURL_RTSPREQ_ANNOUNCE 7.20.0
|
||||||
CURL_RTSPREQ_DESCRIBE 7.20.0
|
CURL_RTSPREQ_DESCRIBE 7.20.0
|
||||||
|
100
docs/libcurl/symbols.pl
Executable file
100
docs/libcurl/symbols.pl
Executable file
@@ -0,0 +1,100 @@
|
|||||||
|
#!/usr/bin/perl
|
||||||
|
#***************************************************************************
|
||||||
|
# _ _ ____ _
|
||||||
|
# Project ___| | | | _ \| |
|
||||||
|
# / __| | | | |_) | |
|
||||||
|
# | (__| |_| | _ <| |___
|
||||||
|
# \___|\___/|_| \_\_____|
|
||||||
|
#
|
||||||
|
# Copyright (C) 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.
|
||||||
|
#
|
||||||
|
###########################################################################
|
||||||
|
#
|
||||||
|
# Experience has shown that the symbols-in-versions file is very useful to
|
||||||
|
# applications that want to build with a wide range of libcurl versions.
|
||||||
|
# It is however easy to get it wrong and the source gets a bit messy with all
|
||||||
|
# the fixed numerical comparisions.
|
||||||
|
#
|
||||||
|
# The point of this script is to provide an easy-to-use macro for libcurl-
|
||||||
|
# using applications to do preprocessor checks for specific libcurl defines,
|
||||||
|
# and yet make the code clearly show what the macro is used for.
|
||||||
|
#
|
||||||
|
# Run this script and generate libcurl-symbols.h and then use that header in
|
||||||
|
# a fashion similar to:
|
||||||
|
#
|
||||||
|
# #include "libcurl-symbols.h"
|
||||||
|
#
|
||||||
|
# #if LIBCURL_HAS(CURLOPT_MUTE)
|
||||||
|
# has mute
|
||||||
|
# #else
|
||||||
|
# no mute
|
||||||
|
# #endif
|
||||||
|
#
|
||||||
|
#
|
||||||
|
open F, "<symbols-in-versions";
|
||||||
|
|
||||||
|
sub str2num {
|
||||||
|
my ($str)=@_;
|
||||||
|
if($str =~ /([0-9]*)\.([0-9]*)\.*([0-9]*)/) {
|
||||||
|
return sprintf("0x%06x", $1<<16 | $2 << 8 | $3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
print <<EOS
|
||||||
|
|
||||||
|
#include <curl/curl.h>
|
||||||
|
|
||||||
|
#define LIBCURL_HAS(x) \\
|
||||||
|
(defined(x ## _FIRST) && (x ## _FIRST <= LIBCURL_VERSION_NUM) && \\
|
||||||
|
(!defined(x ## _LAST) || ( x ## _LAST >= LIBCURL_VERSION_NUM)))
|
||||||
|
|
||||||
|
EOS
|
||||||
|
;
|
||||||
|
|
||||||
|
while(<F>) {
|
||||||
|
if(/^(CURL[^ ]*)[ \t]*(.*)/) {
|
||||||
|
my ($sym, $vers)=($1, $2);
|
||||||
|
|
||||||
|
my $intr;
|
||||||
|
my $rm;
|
||||||
|
my $dep;
|
||||||
|
|
||||||
|
# is there removed info?
|
||||||
|
if($vers =~ /([\d.]+)[ \t-]+([\d.]+)[ \t]+([\d.]+)/) {
|
||||||
|
($intr, $dep, $rm)=($1, $2, $3);
|
||||||
|
}
|
||||||
|
# is it a dep-only line?
|
||||||
|
elsif($vers =~ /([\d.]+)[ \t-]+([\d.]+)/) {
|
||||||
|
($intr, $dep)=($1, $2);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$intr = $vers;
|
||||||
|
}
|
||||||
|
|
||||||
|
my $inum = str2num($intr);
|
||||||
|
|
||||||
|
print <<EOS
|
||||||
|
#define ${sym}_FIRST $inum /* Added in $intr */
|
||||||
|
EOS
|
||||||
|
;
|
||||||
|
my $irm = str2num($rm);
|
||||||
|
if($rm) {
|
||||||
|
print <<EOS
|
||||||
|
#define ${sym}_LAST $irm /* Last featured in $rm */
|
||||||
|
EOS
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
51
docs/mk-ca-bundle.1
Normal file
51
docs/mk-ca-bundle.1
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
.Dd April 27, 2012
|
||||||
|
.Dt MK-CA-BUNDLE 1
|
||||||
|
.Os
|
||||||
|
.Sh NAME
|
||||||
|
.Nm mk-ca-bundle
|
||||||
|
.Nd create a new ca-bundle.crt from mozilla's certdata.txt
|
||||||
|
.Sh SYNOPSIS
|
||||||
|
.Nm
|
||||||
|
.Op Fl bilnqtuv
|
||||||
|
.Or outputfile
|
||||||
|
.Sh DESCRIPTION
|
||||||
|
The
|
||||||
|
.Nm
|
||||||
|
tool downloads the certdata.txt file from Mozilla's source tree, 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.crt file.
|
||||||
|
.Sh OPTIONS
|
||||||
|
The following options are supported by
|
||||||
|
.Nm :
|
||||||
|
.Bl -tag -width _h
|
||||||
|
.It Fl b
|
||||||
|
backup an existing version of ca-bundle.crt
|
||||||
|
.It Fl i
|
||||||
|
print version info about used modules
|
||||||
|
.It Fl l
|
||||||
|
print license info about certdata.txt
|
||||||
|
.It Fl n
|
||||||
|
no download of certdata.txt (to use existing)
|
||||||
|
.It Fl q
|
||||||
|
be really quiet (no progress output at all)
|
||||||
|
.It Fl t
|
||||||
|
include plain text listing of certificates
|
||||||
|
.It Fl u
|
||||||
|
unlink (remove) certdata.txt after processing
|
||||||
|
.It Fl v
|
||||||
|
be verbose and print out processed CAs
|
||||||
|
.El
|
||||||
|
.Sh EXIT STATUS
|
||||||
|
.Ex -std
|
||||||
|
.Sh SEE ALSO
|
||||||
|
.Xr curl 1
|
||||||
|
.Sh HISTORY
|
||||||
|
.Nm
|
||||||
|
was based on the parse-certs script written by
|
||||||
|
.An Roland Krikava
|
||||||
|
and hacked by
|
||||||
|
.An Guenter Knauf .
|
||||||
|
This manual page was written by
|
||||||
|
.An Jan Schaumann
|
||||||
|
.Aq jschauma@netmeister.org .
|
1
include/curl/.gitignore
vendored
1
include/curl/.gitignore
vendored
@@ -1,3 +1,4 @@
|
|||||||
curlbuild.h
|
curlbuild.h
|
||||||
|
stamp-h2
|
||||||
stamp-h3
|
stamp-h3
|
||||||
curlver.h.dist
|
curlver.h.dist
|
||||||
|
@@ -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
|
||||||
@@ -69,7 +69,7 @@
|
|||||||
require it! */
|
require it! */
|
||||||
#if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \
|
#if defined(_AIX) || defined(__NOVELL_LIBC__) || defined(__NetBSD__) || \
|
||||||
defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \
|
defined(__minix) || defined(__SYMBIAN32__) || defined(__INTEGRITY) || \
|
||||||
defined(ANDROID) || \
|
defined(ANDROID) || defined(__ANDROID__) || \
|
||||||
(defined(__FreeBSD_version) && (__FreeBSD_version < 800000))
|
(defined(__FreeBSD_version) && (__FreeBSD_version < 800000))
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
#endif
|
#endif
|
||||||
@@ -411,9 +411,12 @@ typedef enum {
|
|||||||
CURLE_REMOTE_ACCESS_DENIED, /* 9 a service was denied by the server
|
CURLE_REMOTE_ACCESS_DENIED, /* 9 a service was denied by the server
|
||||||
due to lack of access - when login fails
|
due to lack of access - when login fails
|
||||||
this is not returned. */
|
this is not returned. */
|
||||||
CURLE_OBSOLETE10, /* 10 - NOT USED */
|
CURLE_FTP_ACCEPT_FAILED, /* 10 - [was obsoleted in April 2006 for
|
||||||
|
7.15.4, reused in Dec 2011 for 7.24.0]*/
|
||||||
CURLE_FTP_WEIRD_PASS_REPLY, /* 11 */
|
CURLE_FTP_WEIRD_PASS_REPLY, /* 11 */
|
||||||
CURLE_OBSOLETE12, /* 12 - NOT USED */
|
CURLE_FTP_ACCEPT_TIMEOUT, /* 12 - timeout occurred accepting server
|
||||||
|
[was obsoleted in August 2007 for 7.17.0,
|
||||||
|
reused in Dec 2011 for 7.24.0]*/
|
||||||
CURLE_FTP_WEIRD_PASV_REPLY, /* 13 */
|
CURLE_FTP_WEIRD_PASV_REPLY, /* 13 */
|
||||||
CURLE_FTP_WEIRD_227_FORMAT, /* 14 */
|
CURLE_FTP_WEIRD_227_FORMAT, /* 14 */
|
||||||
CURLE_FTP_CANT_GET_HOST, /* 15 */
|
CURLE_FTP_CANT_GET_HOST, /* 15 */
|
||||||
@@ -511,13 +514,16 @@ typedef enum {
|
|||||||
CURLE_RTSP_SESSION_ERROR, /* 86 - mismatch of RTSP Session Ids */
|
CURLE_RTSP_SESSION_ERROR, /* 86 - mismatch of RTSP Session Ids */
|
||||||
CURLE_FTP_BAD_FILE_LIST, /* 87 - unable to parse FTP file list */
|
CURLE_FTP_BAD_FILE_LIST, /* 87 - unable to parse FTP file list */
|
||||||
CURLE_CHUNK_FAILED, /* 88 - chunk callback reported error */
|
CURLE_CHUNK_FAILED, /* 88 - chunk callback reported error */
|
||||||
|
|
||||||
CURL_LAST /* never use! */
|
CURL_LAST /* never use! */
|
||||||
} CURLcode;
|
} CURLcode;
|
||||||
|
|
||||||
#ifndef CURL_NO_OLDIES /* define this to test if your app builds with all
|
#ifndef CURL_NO_OLDIES /* define this to test if your app builds with all
|
||||||
the obsolete stuff removed! */
|
the obsolete stuff removed! */
|
||||||
|
|
||||||
|
/* Previously obsoletes error codes re-used in 7.24.0 */
|
||||||
|
#define CURLE_OBSOLETE10 CURLE_FTP_ACCEPT_FAILED
|
||||||
|
#define CURLE_OBSOLETE12 CURLE_FTP_ACCEPT_TIMEOUT
|
||||||
|
|
||||||
/* compatibility with older names */
|
/* compatibility with older names */
|
||||||
#define CURLOPT_ENCODING CURLOPT_ACCEPT_ENCODING
|
#define CURLOPT_ENCODING CURLOPT_ACCEPT_ENCODING
|
||||||
|
|
||||||
@@ -592,18 +598,32 @@ typedef enum {
|
|||||||
in 7.18.0 */
|
in 7.18.0 */
|
||||||
} curl_proxytype; /* this enum was added in 7.10 */
|
} curl_proxytype; /* this enum was added in 7.10 */
|
||||||
|
|
||||||
#define CURLAUTH_NONE 0 /* nothing */
|
/*
|
||||||
#define CURLAUTH_BASIC (1<<0) /* Basic (default) */
|
* Bitmasks for CURLOPT_HTTPAUTH and CURLOPT_PROXYAUTH options:
|
||||||
#define CURLAUTH_DIGEST (1<<1) /* Digest */
|
*
|
||||||
#define CURLAUTH_GSSNEGOTIATE (1<<2) /* GSS-Negotiate */
|
* CURLAUTH_NONE - No HTTP authentication
|
||||||
#define CURLAUTH_NTLM (1<<3) /* NTLM */
|
* CURLAUTH_BASIC - HTTP Basic authentication (default)
|
||||||
#define CURLAUTH_DIGEST_IE (1<<4) /* Digest with IE flavour */
|
* CURLAUTH_DIGEST - HTTP Digest authentication
|
||||||
#define CURLAUTH_NTLM_WB (1<<5) /* NTLM delegating to winbind helper */
|
* CURLAUTH_GSSNEGOTIATE - HTTP GSS-Negotiate authentication
|
||||||
#define CURLAUTH_ONLY (1<<31) /* used together with a single other
|
* CURLAUTH_NTLM - HTTP NTLM authentication
|
||||||
type to force no auth or just that
|
* CURLAUTH_DIGEST_IE - HTTP Digest authentication with IE flavour
|
||||||
single type */
|
* CURLAUTH_NTLM_WB - HTTP NTLM authentication delegated to winbind helper
|
||||||
#define CURLAUTH_ANY (~CURLAUTH_DIGEST_IE) /* all fine types set */
|
* CURLAUTH_ONLY - Use together with a single other type to force no
|
||||||
#define CURLAUTH_ANYSAFE (~(CURLAUTH_BASIC|CURLAUTH_DIGEST_IE))
|
* authentication or just that single type
|
||||||
|
* CURLAUTH_ANY - All fine types set
|
||||||
|
* CURLAUTH_ANYSAFE - All fine types except Basic
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define CURLAUTH_NONE ((unsigned long)0)
|
||||||
|
#define CURLAUTH_BASIC (((unsigned long)1)<<0)
|
||||||
|
#define CURLAUTH_DIGEST (((unsigned long)1)<<1)
|
||||||
|
#define CURLAUTH_GSSNEGOTIATE (((unsigned long)1)<<2)
|
||||||
|
#define CURLAUTH_NTLM (((unsigned long)1)<<3)
|
||||||
|
#define CURLAUTH_DIGEST_IE (((unsigned long)1)<<4)
|
||||||
|
#define CURLAUTH_NTLM_WB (((unsigned long)1)<<5)
|
||||||
|
#define CURLAUTH_ONLY (((unsigned long)1)<<31)
|
||||||
|
#define CURLAUTH_ANY (~CURLAUTH_DIGEST_IE)
|
||||||
|
#define CURLAUTH_ANYSAFE (~(CURLAUTH_BASIC|CURLAUTH_DIGEST_IE))
|
||||||
|
|
||||||
#define CURLSSH_AUTH_ANY ~0 /* all types supported by the server */
|
#define CURLSSH_AUTH_ANY ~0 /* all types supported by the server */
|
||||||
#define CURLSSH_AUTH_NONE 0 /* none allowed, silly but complete */
|
#define CURLSSH_AUTH_NONE 0 /* none allowed, silly but complete */
|
||||||
@@ -667,6 +687,15 @@ typedef enum {
|
|||||||
CURLUSESSL_LAST /* not an option, never use */
|
CURLUSESSL_LAST /* not an option, never use */
|
||||||
} curl_usessl;
|
} curl_usessl;
|
||||||
|
|
||||||
|
/* Definition of bits for the CURLOPT_SSL_OPTIONS argument: */
|
||||||
|
|
||||||
|
/* - ALLOW_BEAST tells libcurl to allow the BEAST SSL vulnerability in the
|
||||||
|
name of improving interoperability with older servers. Some SSL libraries
|
||||||
|
have introduced work-arounds for this flaw but those work-arounds sometimes
|
||||||
|
make the SSL communication fail. To regain functionality with those broken
|
||||||
|
servers, a user can this way allow the vulnerability back. */
|
||||||
|
#define CURLSSLOPT_ALLOW_BEAST (1<<0)
|
||||||
|
|
||||||
#ifndef CURL_NO_OLDIES /* define this to test if your app builds with all
|
#ifndef CURL_NO_OLDIES /* define this to test if your app builds with all
|
||||||
the obsolete stuff removed! */
|
the obsolete stuff removed! */
|
||||||
|
|
||||||
@@ -1486,6 +1515,26 @@ typedef enum {
|
|||||||
/* allow GSSAPI credential delegation */
|
/* allow GSSAPI credential delegation */
|
||||||
CINIT(GSSAPI_DELEGATION, LONG, 210),
|
CINIT(GSSAPI_DELEGATION, LONG, 210),
|
||||||
|
|
||||||
|
/* Set the name servers to use for DNS resolution */
|
||||||
|
CINIT(DNS_SERVERS, OBJECTPOINT, 211),
|
||||||
|
|
||||||
|
/* Time-out accept operations (currently for FTP only) after this amount
|
||||||
|
of miliseconds. */
|
||||||
|
CINIT(ACCEPTTIMEOUT_MS, LONG, 212),
|
||||||
|
|
||||||
|
/* Set TCP keepalive */
|
||||||
|
CINIT(TCP_KEEPALIVE, LONG, 213),
|
||||||
|
|
||||||
|
/* non-universal keepalive knobs (Linux, AIX, HP-UX, more) */
|
||||||
|
CINIT(TCP_KEEPIDLE, LONG, 214),
|
||||||
|
CINIT(TCP_KEEPINTVL, LONG, 215),
|
||||||
|
|
||||||
|
/* Enable/disable specific SSL features with a bitmask, see CURLSSLOPT_* */
|
||||||
|
CINIT(SSL_OPTIONS, LONG, 216),
|
||||||
|
|
||||||
|
/* set the SMTP auth originator */
|
||||||
|
CINIT(MAIL_AUTH, OBJECTPOINT, 217),
|
||||||
|
|
||||||
CURLOPT_LASTENTRY /* the last unused */
|
CURLOPT_LASTENTRY /* the last unused */
|
||||||
} CURLoption;
|
} CURLoption;
|
||||||
|
|
||||||
@@ -1589,13 +1638,16 @@ enum CURL_TLSAUTH {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* symbols to use with CURLOPT_POSTREDIR.
|
/* symbols to use with CURLOPT_POSTREDIR.
|
||||||
CURL_REDIR_POST_301 and CURL_REDIR_POST_302 can be bitwise ORed so that
|
CURL_REDIR_POST_301, CURL_REDIR_POST_302 and CURL_REDIR_POST_303
|
||||||
CURL_REDIR_POST_301 | CURL_REDIR_POST_302 == CURL_REDIR_POST_ALL */
|
can be bitwise ORed so that CURL_REDIR_POST_301 | CURL_REDIR_POST_302
|
||||||
|
| CURL_REDIR_POST_303 == CURL_REDIR_POST_ALL */
|
||||||
|
|
||||||
#define CURL_REDIR_GET_ALL 0
|
#define CURL_REDIR_GET_ALL 0
|
||||||
#define CURL_REDIR_POST_301 1
|
#define CURL_REDIR_POST_301 1
|
||||||
#define CURL_REDIR_POST_302 2
|
#define CURL_REDIR_POST_302 2
|
||||||
#define CURL_REDIR_POST_ALL (CURL_REDIR_POST_301|CURL_REDIR_POST_302)
|
#define CURL_REDIR_POST_303 4
|
||||||
|
#define CURL_REDIR_POST_ALL \
|
||||||
|
(CURL_REDIR_POST_301|CURL_REDIR_POST_302|CURL_REDIR_POST_303)
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
CURL_TIMECOND_NONE,
|
CURL_TIMECOND_NONE,
|
||||||
|
@@ -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
|
||||||
@@ -26,16 +26,16 @@
|
|||||||
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 - 2011 Daniel Stenberg, <daniel@haxx.se>."
|
#define LIBCURL_COPYRIGHT "1996 - 2012 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.23.0-DEV"
|
#define LIBCURL_VERSION "7.26.0-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 23
|
#define LIBCURL_VERSION_MINOR 26
|
||||||
#define LIBCURL_VERSION_PATCH 0
|
#define LIBCURL_VERSION_PATCH 0
|
||||||
|
|
||||||
/* 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
|
||||||
@@ -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 0x071700
|
#define LIBCURL_VERSION_NUM 0x071A00
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 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
|
||||||
|
@@ -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
|
||||||
@@ -141,8 +141,9 @@ __extension__ ({ \
|
|||||||
|
|
||||||
/* To define a new warning, use _CURL_WARNING(identifier, "message") */
|
/* To define a new warning, use _CURL_WARNING(identifier, "message") */
|
||||||
#define _CURL_WARNING(id, message) \
|
#define _CURL_WARNING(id, message) \
|
||||||
static void __attribute__((warning(message))) __attribute__((unused)) \
|
static void __attribute__((__warning__(message))) \
|
||||||
__attribute__((noinline)) id(void) { __asm__(""); }
|
__attribute__((__unused__)) __attribute__((__noinline__)) \
|
||||||
|
id(void) { __asm__(""); }
|
||||||
|
|
||||||
_CURL_WARNING(_curl_easy_setopt_err_long,
|
_CURL_WARNING(_curl_easy_setopt_err_long,
|
||||||
"curl_easy_setopt expects a long argument for this option")
|
"curl_easy_setopt expects a long argument for this option")
|
||||||
|
1
lib/.gitignore
vendored
1
lib/.gitignore
vendored
@@ -10,3 +10,4 @@ libcurl.plist.dist
|
|||||||
libcurl.vcproj
|
libcurl.vcproj
|
||||||
vc6libcurl.dsp
|
vc6libcurl.dsp
|
||||||
Makefile.vc10.dist
|
Makefile.vc10.dist
|
||||||
|
libcurl.vers
|
||||||
|
@@ -83,13 +83,13 @@ CFLAGS += -dWANT_IDN_PROTOTYPES
|
|||||||
!ifdef %zlib_root
|
!ifdef %zlib_root
|
||||||
ZLIB_ROOT = $(%zlib_root)
|
ZLIB_ROOT = $(%zlib_root)
|
||||||
!else
|
!else
|
||||||
ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.5
|
ZLIB_ROOT = ..$(DS)..$(DS)zlib-1.2.7
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifdef %libssh2_root
|
!ifdef %libssh2_root
|
||||||
LIBSSH2_ROOT = $(%libssh2_root)
|
LIBSSH2_ROOT = $(%libssh2_root)
|
||||||
!else
|
!else
|
||||||
LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.3.0
|
LIBSSH2_ROOT = ..$(DS)..$(DS)libssh2-1.4.2
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifdef %librtmp_root
|
!ifdef %librtmp_root
|
||||||
@@ -101,7 +101,7 @@ LIBRTMP_ROOT = ..$(DS)..$(DS)rtmpdump-2.3
|
|||||||
!ifdef %openssl_root
|
!ifdef %openssl_root
|
||||||
OPENSSL_ROOT = $(%openssl_root)
|
OPENSSL_ROOT = $(%openssl_root)
|
||||||
!else
|
!else
|
||||||
OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8r
|
OPENSSL_ROOT = ..$(DS)..$(DS)openssl-0.9.8x
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
!ifdef %ares_root
|
!ifdef %ares_root
|
||||||
|
@@ -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
|
||||||
@@ -33,7 +33,7 @@ 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 amigaos.c amigaos.h makefile.amiga \
|
libcurl.rc config-amigaos.h makefile.amiga \
|
||||||
Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot \
|
Makefile.netware nwlib.c nwos.c libcurl.imp msvcproj.head msvcproj.foot \
|
||||||
config-win32ce.h config-os400.h setup-os400.h config-symbian.h \
|
config-win32ce.h config-os400.h setup-os400.h config-symbian.h \
|
||||||
Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl \
|
Makefile.Watcom config-tpf.h $(DOCS) $(VCPROJ) mk-ca-bundle.pl \
|
||||||
@@ -48,6 +48,8 @@ LIBCURL_LIBS = @LIBCURL_LIBS@
|
|||||||
# This might hold -Werror
|
# This might hold -Werror
|
||||||
CFLAGS += @CURL_CFLAG_EXTRAS@
|
CFLAGS += @CURL_CFLAG_EXTRAS@
|
||||||
|
|
||||||
|
CFLAG_CURL_SYMBOL_HIDING = @CFLAG_CURL_SYMBOL_HIDING@
|
||||||
|
|
||||||
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
# Specify our include paths here, and do it relative to $(top_srcdir) and
|
||||||
# $(top_builddir), to ensure that these paths which belong to the library
|
# $(top_builddir), to ensure that these paths which belong to the library
|
||||||
# being currently built and tested are searched before the library which
|
# being currently built and tested are searched before the library which
|
||||||
@@ -77,6 +79,18 @@ INCLUDES = -I$(top_builddir)/include/curl \
|
|||||||
-I$(top_srcdir)/lib
|
-I$(top_srcdir)/lib
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
AM_CPPFLAGS =
|
||||||
|
|
||||||
|
# Mostly for Windows build targets, when building libcurl library
|
||||||
|
if USE_CPPFLAG_BUILDING_LIBCURL
|
||||||
|
AM_CPPFLAGS += -DBUILDING_LIBCURL
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Mostly for Windows build targets, when building static libcurl
|
||||||
|
if USE_CPPFLAG_CURL_STATICLIB
|
||||||
|
AM_CPPFLAGS += -DCURL_STATICLIB
|
||||||
|
endif
|
||||||
|
|
||||||
if SONAME_BUMP
|
if SONAME_BUMP
|
||||||
#
|
#
|
||||||
# Bumping of SONAME conditionally may seem like a weird thing to do, and yeah
|
# Bumping of SONAME conditionally may seem like a weird thing to do, and yeah
|
||||||
@@ -116,7 +130,19 @@ if MIMPURE
|
|||||||
MIMPURE = -mimpure-text
|
MIMPURE = -mimpure-text
|
||||||
endif
|
endif
|
||||||
|
|
||||||
libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(LIBCURL_LIBS)
|
if VERSIONED_SYMBOLS
|
||||||
|
VERSIONED_SYMBOLS = -Wl,--version-script=libcurl.vers
|
||||||
|
endif
|
||||||
|
|
||||||
|
libcurl_la_LDFLAGS = $(UNDEF) $(VERSIONINFO) $(MIMPURE) $(VERSIONED_SYMBOLS) $(LIBCURL_LIBS)
|
||||||
|
|
||||||
|
if DOING_CURL_SYMBOL_HIDING
|
||||||
|
libcurl_la_CPPFLAGS = $(AM_CPPFLAGS) -DCURL_HIDDEN_SYMBOLS
|
||||||
|
libcurl_la_CFLAGS = $(AM_CFLAGS) $(CFLAG_CURL_SYMBOL_HIDING)
|
||||||
|
else
|
||||||
|
libcurl_la_CPPFLAGS = $(AM_CPPFLAGS)
|
||||||
|
libcurl_la_CFLAGS = $(AM_CFLAGS)
|
||||||
|
endif
|
||||||
|
|
||||||
# unit testing static library built only along with unit tests
|
# unit testing static library built only along with unit tests
|
||||||
if BUILD_UNITTESTS
|
if BUILD_UNITTESTS
|
||||||
@@ -127,6 +153,7 @@ endif
|
|||||||
|
|
||||||
libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS
|
libcurlu_la_CPPFLAGS = $(AM_CPPFLAGS) -DUNITTESTS
|
||||||
libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS)
|
libcurlu_la_LDFLAGS = -static $(LIBCURL_LIBS)
|
||||||
|
libcurlu_la_CFLAGS = $(AM_CFLAGS)
|
||||||
|
|
||||||
# Makefile.inc provides the CSOURCES and HHEADERS defines
|
# Makefile.inc provides the CSOURCES and HHEADERS defines
|
||||||
include Makefile.inc
|
include Makefile.inc
|
||||||
|
@@ -22,12 +22,12 @@ BCCDIR = $(MAKEDIR)\..
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
!ifndef ZLIB_PATH
|
!ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ..\..\zlib-1.2.5
|
ZLIB_PATH = ..\..\zlib-1.2.7
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
!ifndef OPENSSL_PATH
|
!ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ..\..\openssl-0.9.8q
|
OPENSSL_PATH = ..\..\openssl-0.9.8x
|
||||||
!endif
|
!endif
|
||||||
|
|
||||||
# Set libcurl static lib, dll and import lib
|
# Set libcurl static lib, dll and import lib
|
||||||
|
@@ -14,7 +14,7 @@ CSOURCES = file.c timeval.c base64.c hostip.c progress.c formdata.c \
|
|||||||
curl_fnmatch.c fileinfo.c ftplistparser.c wildcard.c krb5.c \
|
curl_fnmatch.c fileinfo.c ftplistparser.c wildcard.c krb5.c \
|
||||||
memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c multi.c \
|
memdebug.c http_chunks.c strtok.c connect.c llist.c hash.c multi.c \
|
||||||
content_encoding.c share.c http_digest.c md4.c md5.c curl_rand.c \
|
content_encoding.c share.c http_digest.c md4.c md5.c curl_rand.c \
|
||||||
http_negotiate.c inet_pton.c strtoofft.c strerror.c \
|
http_negotiate.c inet_pton.c strtoofft.c strerror.c amigaos.c \
|
||||||
hostasyn.c hostip4.c hostip6.c hostsyn.c inet_ntop.c parsedate.c \
|
hostasyn.c hostip4.c hostip6.c hostsyn.c inet_ntop.c parsedate.c \
|
||||||
select.c gtls.c sslgen.c tftp.c splay.c strdup.c socks.c ssh.c nss.c \
|
select.c gtls.c sslgen.c tftp.c splay.c strdup.c socks.c ssh.c nss.c \
|
||||||
qssl.c rawstr.c curl_addrinfo.c socks_gssapi.c socks_sspi.c \
|
qssl.c rawstr.c curl_addrinfo.c socks_gssapi.c socks_sspi.c \
|
||||||
@@ -31,7 +31,7 @@ HHEADERS = arpa_telnet.h netrc.h file.h timeval.h qssl.h hostip.h \
|
|||||||
getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.h \
|
getinfo.h strequal.h krb4.h memdebug.h http_chunks.h curl_rand.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 \
|
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 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 setup_once.h socks.h ssh.h nssg.h \
|
||||||
|
@@ -7,18 +7,18 @@
|
|||||||
## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-sspi-winidn
|
## Example: mingw32-make -f Makefile.m32 CFG=-zlib-ssl-sspi-winidn
|
||||||
##
|
##
|
||||||
## Hint: you can also set environment vars to control the build, f.e.:
|
## Hint: you can also set environment vars to control the build, f.e.:
|
||||||
## set ZLIB_PATH=c:/zlib-1.2.5
|
## set ZLIB_PATH=c:/zlib-1.2.7
|
||||||
## set ZLIB=1
|
## set ZLIB=1
|
||||||
#
|
#
|
||||||
###########################################################################
|
###########################################################################
|
||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.5
|
ZLIB_PATH = ../../zlib-1.2.7
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8r
|
OPENSSL_PATH = ../../openssl-0.9.8x
|
||||||
endif
|
endif
|
||||||
ifndef OPENSSL_INCLUDE
|
ifndef OPENSSL_INCLUDE
|
||||||
OPENSSL_INCLUDE = $(OPENSSL_PATH)/outinc
|
OPENSSL_INCLUDE = $(OPENSSL_PATH)/outinc
|
||||||
@@ -31,7 +31,7 @@ OPENSSL_LIBS = -leay32 -lssl32
|
|||||||
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.3.0
|
LIBSSH2_PATH = ../../libssh2-1.4.2
|
||||||
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
|
||||||
@@ -41,7 +41,7 @@ endif
|
|||||||
ifndef LIBIDN_PATH
|
ifndef LIBIDN_PATH
|
||||||
LIBIDN_PATH = ../../libidn-1.18
|
LIBIDN_PATH = ../../libidn-1.18
|
||||||
endif
|
endif
|
||||||
# Edit the path below to point to the base of your MS idndlpackage.
|
# Edit the path below to point to the base of your MS IDN package.
|
||||||
# Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1
|
# Microsoft Internationalized Domain Names (IDN) Mitigation APIs 1.1
|
||||||
# http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815
|
# http://www.microsoft.com/downloads/en/details.aspx?FamilyID=ad6158d7-ddba-416a-9109-07607425a815
|
||||||
ifndef WINIDN_PATH
|
ifndef WINIDN_PATH
|
||||||
|
@@ -14,17 +14,17 @@ endif
|
|||||||
|
|
||||||
# Edit the path below to point to the base of your Zlib sources.
|
# Edit the path below to point to the base of your Zlib sources.
|
||||||
ifndef ZLIB_PATH
|
ifndef ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.5
|
ZLIB_PATH = ../../zlib-1.2.7
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# Edit the path below to point to the base of your OpenSSL package.
|
# Edit the path below to point to the base of your OpenSSL package.
|
||||||
ifndef OPENSSL_PATH
|
ifndef OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8r
|
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.3.0
|
LIBSSH2_PATH = ../../libssh2-1.4.2
|
||||||
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.
|
||||||
|
@@ -65,15 +65,15 @@
|
|||||||
!INCLUDE ..\Makefile.msvc.names
|
!INCLUDE ..\Makefile.msvc.names
|
||||||
|
|
||||||
!IFNDEF OPENSSL_PATH
|
!IFNDEF OPENSSL_PATH
|
||||||
OPENSSL_PATH = ../../openssl-0.9.8r
|
OPENSSL_PATH = ../../openssl-0.9.8x
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF LIBSSH2_PATH
|
!IFNDEF LIBSSH2_PATH
|
||||||
LIBSSH2_PATH = ../../libssh2-1.2.8
|
LIBSSH2_PATH = ../../libssh2-1.4.2
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF ZLIB_PATH
|
!IFNDEF ZLIB_PATH
|
||||||
ZLIB_PATH = ../../zlib-1.2.5
|
ZLIB_PATH = ../../zlib-1.2.7
|
||||||
!ENDIF
|
!ENDIF
|
||||||
|
|
||||||
!IFNDEF MACHINE
|
!IFNDEF MACHINE
|
||||||
|
@@ -33,10 +33,10 @@ BUILD_TYPE := debug
|
|||||||
USER_CFLAGS:=
|
USER_CFLAGS:=
|
||||||
|
|
||||||
# directories where to seek for includes and libraries
|
# directories where to seek for includes and libraries
|
||||||
OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3/include
|
OPENSSL_INC := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3/include
|
||||||
OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8a-vxWorks6.3
|
OPENSSL_LIB := D:/libraries/openssl/openssl-0.9.8x-vxWorks6.3
|
||||||
ZLIB_INC := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/zlib-1.2.3
|
ZLIB_INC := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/zlib-1.2.7
|
||||||
ZLIB_LIB := D:/libraries/zlib/zlib-1.2.3-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib
|
ZLIB_LIB := D:/libraries/zlib/zlib-1.2.7-VxWorks6.3/binaries/vxworks_3.1_gnu/Debug/lib
|
||||||
ARES_INC :=
|
ARES_INC :=
|
||||||
ARES_LIB :=
|
ARES_LIB :=
|
||||||
|
|
||||||
|
@@ -5,7 +5,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2009, 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,10 +20,13 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
#ifdef __AMIGA__ /* Any AmigaOS flavour */
|
#include "setup.h"
|
||||||
|
|
||||||
|
#if defined(__AMIGA__) && !defined(__ixemul__)
|
||||||
|
|
||||||
|
#include <amitcp/socketbasetags.h>
|
||||||
|
|
||||||
#include "amigaos.h"
|
#include "amigaos.h"
|
||||||
#include <amitcp/socketbasetags.h>
|
|
||||||
|
|
||||||
struct Library *SocketBase = NULL;
|
struct Library *SocketBase = NULL;
|
||||||
extern int errno, h_errno;
|
extern int errno, h_errno;
|
||||||
@@ -35,7 +38,7 @@ void __request(const char *msg);
|
|||||||
# define __request( msg ) Printf( msg "\n\a")
|
# define __request( msg ) Printf( msg "\n\a")
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void amiga_cleanup()
|
void Curl_amiga_cleanup()
|
||||||
{
|
{
|
||||||
if(SocketBase) {
|
if(SocketBase) {
|
||||||
CloseLibrary(SocketBase);
|
CloseLibrary(SocketBase);
|
||||||
@@ -43,7 +46,7 @@ void amiga_cleanup()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL amiga_init()
|
bool Curl_amiga_init()
|
||||||
{
|
{
|
||||||
if(!SocketBase)
|
if(!SocketBase)
|
||||||
SocketBase = OpenLibrary("bsdsocket.library", 4);
|
SocketBase = OpenLibrary("bsdsocket.library", 4);
|
||||||
@@ -61,20 +64,14 @@ BOOL amiga_init()
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef __libnix__
|
#ifndef __libnix__
|
||||||
atexit(amiga_cleanup);
|
atexit(Curl_amiga_cleanup);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __libnix__
|
#ifdef __libnix__
|
||||||
ADD2EXIT(amiga_cleanup,-50);
|
ADD2EXIT(Curl_amiga_cleanup,-50);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#else /* __AMIGA__ */
|
#endif /* __AMIGA__ && ! __ixemul__ */
|
||||||
|
|
||||||
#ifdef __POCC__
|
|
||||||
# pragma warn(disable:2024) /* Disable warning #2024: Empty input file */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* __AMIGA__ */
|
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef LIBCURL_AMIGAOS_H
|
#ifndef HEADER_CURL_AMIGAOS_H
|
||||||
#define LIBCURL_AMIGAOS_H
|
#define HEADER_CURL_AMIGAOS_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2007, 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
|
||||||
@@ -21,37 +21,19 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
#include "setup.h"
|
||||||
|
|
||||||
#ifdef __AMIGA__ /* Any AmigaOS flavour */
|
#if defined(__AMIGA__) && !defined(__ixemul__)
|
||||||
|
|
||||||
#ifndef __ixemul__
|
bool Curl_amiga_init();
|
||||||
|
void Curl_amiga_cleanup();
|
||||||
|
|
||||||
#include <exec/types.h>
|
#else
|
||||||
#include <exec/execbase.h>
|
|
||||||
|
|
||||||
#include <proto/exec.h>
|
#define Curl_amiga_init() 1
|
||||||
#include <proto/dos.h>
|
#define Curl_amiga_cleanup() Curl_nop_stmt
|
||||||
|
|
||||||
#include <sys/socket.h>
|
|
||||||
|
|
||||||
#include "config-amigaos.h"
|
|
||||||
|
|
||||||
#ifndef select
|
|
||||||
# define select(args...) WaitSelect( args, NULL)
|
|
||||||
#endif
|
#endif
|
||||||
#ifndef ioctl
|
|
||||||
# define ioctl(a,b,c,d) IoctlSocket( (LONG)a, (ULONG)b, (char*)c)
|
|
||||||
#endif
|
|
||||||
#define _AMIGASF 1
|
|
||||||
|
|
||||||
extern void amiga_cleanup();
|
#endif /* HEADER_CURL_AMIGAOS_H */
|
||||||
extern BOOL amiga_init();
|
|
||||||
|
|
||||||
#else /* __ixemul__ */
|
|
||||||
|
|
||||||
#warning compiling with ixemul...
|
|
||||||
|
|
||||||
#endif /* __ixemul__ */
|
|
||||||
#endif /* __AMIGA__ */
|
|
||||||
#endif /* LIBCURL_AMIGAOS_H */
|
|
||||||
|
|
||||||
|
@@ -7,7 +7,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2010, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2011, 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,9 +26,11 @@
|
|||||||
* Telnet option defines. Add more here if in need.
|
* Telnet option defines. Add more here if in need.
|
||||||
*/
|
*/
|
||||||
#define CURL_TELOPT_BINARY 0 /* binary 8bit data */
|
#define CURL_TELOPT_BINARY 0 /* binary 8bit data */
|
||||||
|
#define CURL_TELOPT_ECHO 1 /* just echo! */
|
||||||
#define CURL_TELOPT_SGA 3 /* Suppress Go Ahead */
|
#define CURL_TELOPT_SGA 3 /* Suppress Go Ahead */
|
||||||
#define CURL_TELOPT_EXOPL 255 /* EXtended OPtions List */
|
#define CURL_TELOPT_EXOPL 255 /* EXtended OPtions List */
|
||||||
#define CURL_TELOPT_TTYPE 24 /* Terminal TYPE */
|
#define CURL_TELOPT_TTYPE 24 /* Terminal TYPE */
|
||||||
|
#define CURL_TELOPT_NAWS 31 /* Negotiate About Window Size */
|
||||||
#define CURL_TELOPT_XDISPLOC 35 /* X DISPlay LOCation */
|
#define CURL_TELOPT_XDISPLOC 35 /* X DISPlay LOCation */
|
||||||
|
|
||||||
#define CURL_TELOPT_NEW_ENVIRON 39 /* NEW ENVIRONment variables */
|
#define CURL_TELOPT_NEW_ENVIRON 39 /* NEW ENVIRONment variables */
|
||||||
|
@@ -227,18 +227,19 @@ int Curl_resolver_getsock(struct connectdata *conn,
|
|||||||
struct timeval maxtime;
|
struct timeval maxtime;
|
||||||
struct timeval timebuf;
|
struct timeval timebuf;
|
||||||
struct timeval *timeout;
|
struct timeval *timeout;
|
||||||
|
long milli;
|
||||||
int max = ares_getsock((ares_channel)conn->data->state.resolver,
|
int max = ares_getsock((ares_channel)conn->data->state.resolver,
|
||||||
(ares_socket_t *)socks, numsocks);
|
(ares_socket_t *)socks, numsocks);
|
||||||
|
|
||||||
|
|
||||||
maxtime.tv_sec = CURL_TIMEOUT_RESOLVE;
|
maxtime.tv_sec = CURL_TIMEOUT_RESOLVE;
|
||||||
maxtime.tv_usec = 0;
|
maxtime.tv_usec = 0;
|
||||||
|
|
||||||
timeout = ares_timeout((ares_channel)conn->data->state.resolver, &maxtime,
|
timeout = ares_timeout((ares_channel)conn->data->state.resolver, &maxtime,
|
||||||
&timebuf);
|
&timebuf);
|
||||||
|
milli = (timeout->tv_sec * 1000) + (timeout->tv_usec/1000);
|
||||||
Curl_expire(conn->data,
|
if(milli == 0)
|
||||||
(timeout->tv_sec * 1000) + (timeout->tv_usec/1000));
|
milli += 10;
|
||||||
|
Curl_expire(conn->data, milli);
|
||||||
|
|
||||||
return max;
|
return max;
|
||||||
}
|
}
|
||||||
@@ -330,9 +331,12 @@ CURLcode Curl_resolver_is_resolved(struct connectdata *conn,
|
|||||||
res->temp_ai = NULL;
|
res->temp_ai = NULL;
|
||||||
destroy_async_data(&conn->async);
|
destroy_async_data(&conn->async);
|
||||||
if(!conn->async.dns) {
|
if(!conn->async.dns) {
|
||||||
failf(data, "Could not resolve host: %s (%s)", conn->host.dispname,
|
failf(data, "Could not resolve %s: %s (%s)",
|
||||||
|
conn->bits.proxy?"proxy":"host",
|
||||||
|
conn->host.dispname,
|
||||||
ares_strerror(conn->async.status));
|
ares_strerror(conn->async.status));
|
||||||
return CURLE_COULDNT_RESOLVE_HOST;
|
return conn->bits.proxy?CURLE_COULDNT_RESOLVE_PROXY:
|
||||||
|
CURLE_COULDNT_RESOLVE_HOST;
|
||||||
}
|
}
|
||||||
*dns = conn->async.dns;
|
*dns = conn->async.dns;
|
||||||
}
|
}
|
||||||
@@ -418,7 +422,7 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn,
|
|||||||
if(!conn->async.dns) {
|
if(!conn->async.dns) {
|
||||||
/* a name was not resolved */
|
/* a name was not resolved */
|
||||||
if((timeout < 0) || (conn->async.status == ARES_ETIMEOUT)) {
|
if((timeout < 0) || (conn->async.status == ARES_ETIMEOUT)) {
|
||||||
if(conn->bits.httpproxy) {
|
if(conn->bits.proxy) {
|
||||||
failf(data, "Resolving proxy timed out: %s", conn->proxy.dispname);
|
failf(data, "Resolving proxy timed out: %s", conn->proxy.dispname);
|
||||||
rc = CURLE_COULDNT_RESOLVE_PROXY;
|
rc = CURLE_COULDNT_RESOLVE_PROXY;
|
||||||
}
|
}
|
||||||
@@ -428,7 +432,7 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if(conn->async.done) {
|
else if(conn->async.done) {
|
||||||
if(conn->bits.httpproxy) {
|
if(conn->bits.proxy) {
|
||||||
failf(data, "Could not resolve proxy: %s (%s)", conn->proxy.dispname,
|
failf(data, "Could not resolve proxy: %s (%s)", conn->proxy.dispname,
|
||||||
ares_strerror(conn->async.status));
|
ares_strerror(conn->async.status));
|
||||||
rc = CURLE_COULDNT_RESOLVE_PROXY;
|
rc = CURLE_COULDNT_RESOLVE_PROXY;
|
||||||
@@ -578,13 +582,22 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn,
|
|||||||
res->last_status = ARES_ENOTFOUND;
|
res->last_status = ARES_ENOTFOUND;
|
||||||
#ifdef ENABLE_IPV6 /* CURLRES_IPV6 */
|
#ifdef ENABLE_IPV6 /* CURLRES_IPV6 */
|
||||||
if(family == PF_UNSPEC) {
|
if(family == PF_UNSPEC) {
|
||||||
res->num_pending = 2;
|
if(Curl_ipv6works()) {
|
||||||
|
res->num_pending = 2;
|
||||||
|
|
||||||
/* areschannel is already setup in the Curl_open() function */
|
/* areschannel is already setup in the Curl_open() function */
|
||||||
ares_gethostbyname((ares_channel)data->state.resolver, hostname,
|
ares_gethostbyname((ares_channel)data->state.resolver, hostname,
|
||||||
PF_INET, query_completed_cb, conn);
|
PF_INET, query_completed_cb, conn);
|
||||||
ares_gethostbyname((ares_channel)data->state.resolver, hostname,
|
ares_gethostbyname((ares_channel)data->state.resolver, hostname,
|
||||||
PF_INET6, query_completed_cb, conn);
|
PF_INET6, query_completed_cb, conn);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
res->num_pending = 1;
|
||||||
|
|
||||||
|
/* areschannel is already setup in the Curl_open() function */
|
||||||
|
ares_gethostbyname((ares_channel)data->state.resolver, hostname,
|
||||||
|
PF_INET, query_completed_cb, conn);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif /* CURLRES_IPV6 */
|
#endif /* CURLRES_IPV6 */
|
||||||
@@ -600,4 +613,31 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
return NULL; /* no struct yet */
|
return NULL; /* no struct yet */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CURLcode Curl_set_dns_servers(struct SessionHandle *data,
|
||||||
|
char *servers)
|
||||||
|
{
|
||||||
|
CURLcode result = CURLE_NOT_BUILT_IN;
|
||||||
|
#if (ARES_VERSION >= 0x010704)
|
||||||
|
int ares_result = ares_set_servers_csv(data->state.resolver, servers);
|
||||||
|
switch(ares_result) {
|
||||||
|
case ARES_SUCCESS:
|
||||||
|
result = CURLE_OK;
|
||||||
|
break;
|
||||||
|
case ARES_ENOMEM:
|
||||||
|
result = CURLE_OUT_OF_MEMORY;
|
||||||
|
break;
|
||||||
|
case ARES_ENOTINITIALIZED:
|
||||||
|
case ARES_ENODATA:
|
||||||
|
case ARES_EBADSTR:
|
||||||
|
default:
|
||||||
|
result = CURLE_BAD_FUNCTION_ARGUMENT;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#else /* too old c-ares version! */
|
||||||
|
(void)data;
|
||||||
|
(void)servers;
|
||||||
|
#endif
|
||||||
|
return result;
|
||||||
|
}
|
||||||
#endif /* CURLRES_ARES */
|
#endif /* CURLRES_ARES */
|
||||||
|
@@ -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
|
||||||
@@ -175,7 +175,6 @@ struct thread_sync_data {
|
|||||||
|
|
||||||
struct thread_data {
|
struct thread_data {
|
||||||
curl_thread_t thread_hnd;
|
curl_thread_t thread_hnd;
|
||||||
curl_socket_t dummy_sock;
|
|
||||||
unsigned int poll_interval;
|
unsigned int poll_interval;
|
||||||
int interval_end;
|
int interval_end;
|
||||||
struct thread_sync_data tsd;
|
struct thread_sync_data tsd;
|
||||||
@@ -329,9 +328,6 @@ static void destroy_async_data (struct Curl_async *async)
|
|||||||
if(async->os_specific) {
|
if(async->os_specific) {
|
||||||
struct thread_data *td = (struct thread_data*) async->os_specific;
|
struct thread_data *td = (struct thread_data*) async->os_specific;
|
||||||
|
|
||||||
if(td->dummy_sock != CURL_SOCKET_BAD)
|
|
||||||
sclose(td->dummy_sock);
|
|
||||||
|
|
||||||
if(td->thread_hnd != curl_thread_t_null)
|
if(td->thread_hnd != curl_thread_t_null)
|
||||||
Curl_thread_join(&td->thread_hnd);
|
Curl_thread_join(&td->thread_hnd);
|
||||||
|
|
||||||
@@ -364,7 +360,6 @@ static bool init_resolve_thread (struct connectdata *conn,
|
|||||||
conn->async.done = FALSE;
|
conn->async.done = FALSE;
|
||||||
conn->async.status = 0;
|
conn->async.status = 0;
|
||||||
conn->async.dns = NULL;
|
conn->async.dns = NULL;
|
||||||
td->dummy_sock = CURL_SOCKET_BAD;
|
|
||||||
td->thread_hnd = curl_thread_t_null;
|
td->thread_hnd = curl_thread_t_null;
|
||||||
|
|
||||||
if(!init_thread_sync_data(&td->tsd, hostname, port, hints))
|
if(!init_thread_sync_data(&td->tsd, hostname, port, hints))
|
||||||
@@ -375,16 +370,6 @@ static bool init_resolve_thread (struct connectdata *conn,
|
|||||||
if(!conn->async.hostname)
|
if(!conn->async.hostname)
|
||||||
goto err_exit;
|
goto err_exit;
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
/* This socket is only to keep Curl_resolver_fdset() and select() happy;
|
|
||||||
* should never become signalled for read since it's unbound but
|
|
||||||
* Windows needs at least 1 socket in select().
|
|
||||||
*/
|
|
||||||
td->dummy_sock = socket(AF_INET, SOCK_DGRAM, 0);
|
|
||||||
if(td->dummy_sock == CURL_SOCKET_BAD)
|
|
||||||
goto err_exit;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef HAVE_GETADDRINFO
|
#ifdef HAVE_GETADDRINFO
|
||||||
td->thread_hnd = Curl_thread_create(getaddrinfo_thread, &td->tsd);
|
td->thread_hnd = Curl_thread_create(getaddrinfo_thread, &td->tsd);
|
||||||
#else
|
#else
|
||||||
@@ -574,17 +559,9 @@ int Curl_resolver_getsock(struct connectdata *conn,
|
|||||||
curl_socket_t *socks,
|
curl_socket_t *socks,
|
||||||
int numsocks)
|
int numsocks)
|
||||||
{
|
{
|
||||||
const struct thread_data *td =
|
(void)conn;
|
||||||
(const struct thread_data *) conn->async.os_specific;
|
(void)socks;
|
||||||
|
(void)numsocks;
|
||||||
if(td && td->dummy_sock != CURL_SOCKET_BAD) {
|
|
||||||
if(numsocks) {
|
|
||||||
/* return one socket waiting for readable, even though this is just
|
|
||||||
a dummy */
|
|
||||||
socks[0] = td->dummy_sock;
|
|
||||||
return GETSOCK_READSOCK(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -696,4 +673,13 @@ Curl_addrinfo *Curl_resolver_getaddrinfo(struct connectdata *conn,
|
|||||||
|
|
||||||
#endif /* !HAVE_GETADDRINFO */
|
#endif /* !HAVE_GETADDRINFO */
|
||||||
|
|
||||||
|
CURLcode Curl_set_dns_servers(struct SessionHandle *data,
|
||||||
|
char *servers)
|
||||||
|
{
|
||||||
|
(void)data;
|
||||||
|
(void)servers;
|
||||||
|
return CURLE_NOT_BUILT_IN;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* CURLRES_THREADED */
|
#endif /* CURLRES_THREADED */
|
||||||
|
@@ -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
|
||||||
@@ -58,11 +58,11 @@ static void decodeQuantum(unsigned char *dest, const char *src)
|
|||||||
x = (x << 6);
|
x = (x << 6);
|
||||||
}
|
}
|
||||||
|
|
||||||
dest[2] = curlx_ultouc(x);
|
dest[2] = curlx_ultouc(x & 0xFFUL);
|
||||||
x >>= 8;
|
x >>= 8;
|
||||||
dest[1] = curlx_ultouc(x);
|
dest[1] = curlx_ultouc(x & 0xFFUL);
|
||||||
x >>= 8;
|
x >>= 8;
|
||||||
dest[0] = curlx_ultouc(x);
|
dest[0] = curlx_ultouc(x & 0xFFUL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef LIBCURL_CONFIG_AMIGAOS_H
|
#ifndef HEADER_CURL_CONFIG_AMIGAOS_H
|
||||||
#define LIBCURL_CONFIG_AMIGAOS_H
|
#define HEADER_CURL_CONFIG_AMIGAOS_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -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
|
||||||
@@ -22,6 +22,10 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
/* ================================================================ */
|
||||||
|
/* Hand crafted config file for AmigaOS */
|
||||||
|
/* ================================================================ */
|
||||||
|
|
||||||
#ifdef __AMIGA__ /* Any AmigaOS flavour */
|
#ifdef __AMIGA__ /* Any AmigaOS flavour */
|
||||||
|
|
||||||
#define HAVE_ARPA_INET_H 1
|
#define HAVE_ARPA_INET_H 1
|
||||||
@@ -72,8 +76,6 @@
|
|||||||
#define HAVE_SYS_STAT_H 1
|
#define HAVE_SYS_STAT_H 1
|
||||||
#define HAVE_SYS_TIME_H 1
|
#define HAVE_SYS_TIME_H 1
|
||||||
#define HAVE_SYS_TYPES_H 1
|
#define HAVE_SYS_TYPES_H 1
|
||||||
#define HAVE_TERMIOS_H 1
|
|
||||||
#define HAVE_TERMIO_H 1
|
|
||||||
#define HAVE_TIME_H 1
|
#define HAVE_TIME_H 1
|
||||||
#define HAVE_UNAME 1
|
#define HAVE_UNAME 1
|
||||||
#define HAVE_UNISTD_H 1
|
#define HAVE_UNISTD_H 1
|
||||||
@@ -89,11 +91,11 @@
|
|||||||
#define SIZEOF_SHORT 2
|
#define SIZEOF_SHORT 2
|
||||||
#define SIZEOF_SIZE_T 4
|
#define SIZEOF_SIZE_T 4
|
||||||
|
|
||||||
|
#define USE_MANUAL 1
|
||||||
#define USE_OPENSSL 1
|
#define USE_OPENSSL 1
|
||||||
#define USE_SSLEAY 1
|
#define USE_SSLEAY 1
|
||||||
#define CURL_DISABLE_LDAP 1
|
#define CURL_DISABLE_LDAP 1
|
||||||
|
|
||||||
|
|
||||||
#define OS "AmigaOS"
|
#define OS "AmigaOS"
|
||||||
|
|
||||||
#define PACKAGE "curl"
|
#define PACKAGE "curl"
|
||||||
@@ -114,8 +116,20 @@
|
|||||||
|
|
||||||
#define in_addr_t int
|
#define in_addr_t int
|
||||||
|
|
||||||
|
#ifndef F_OK
|
||||||
|
# define F_OK 0
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef O_RDONLY
|
#ifndef O_RDONLY
|
||||||
# define O_RDONLY 0x0000
|
# define O_RDONLY 0x0000
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LONG_MAX
|
||||||
|
# define LONG_MAX 0x7fffffffL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LONG_MIN
|
||||||
|
# define LONG_MIN (-0x7fffffffL-1)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define HAVE_GETNAMEINFO 1
|
#define HAVE_GETNAMEINFO 1
|
||||||
@@ -150,4 +164,4 @@
|
|||||||
#define SEND_TYPE_RETV int
|
#define SEND_TYPE_RETV int
|
||||||
|
|
||||||
#endif /* __AMIGA__ */
|
#endif /* __AMIGA__ */
|
||||||
#endif /* LIBCURL_CONFIG_AMIGAOS_H */
|
#endif /* HEADER_CURL_CONFIG_AMIGAOS_H */
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __LIB_CONFIG_MAC_H
|
#ifndef HEADER_CURL_CONFIG_MAC_H
|
||||||
#define __LIB_CONFIG_MAC_H
|
#define HEADER_CURL_CONFIG_MAC_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -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
|
||||||
@@ -23,13 +23,16 @@
|
|||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/* =================================================================== */
|
/* =================================================================== */
|
||||||
/* lib/config-mac.h - Hand crafted config file for Mac OS 9 */
|
/* Hand crafted config file for Mac OS 9 */
|
||||||
/* =================================================================== */
|
/* =================================================================== */
|
||||||
/* On Mac OS X you must run configure to generate curl_config.h file */
|
/* On Mac OS X you must run configure to generate curl_config.h file */
|
||||||
/* =================================================================== */
|
/* =================================================================== */
|
||||||
|
|
||||||
#define OS "mac"
|
#define OS "mac"
|
||||||
|
|
||||||
|
/* Define if you want the built-in manual */
|
||||||
|
#define USE_MANUAL 1
|
||||||
|
|
||||||
#define HAVE_ERRNO_H 1
|
#define HAVE_ERRNO_H 1
|
||||||
#define HAVE_NETINET_IN_H 1
|
#define HAVE_NETINET_IN_H 1
|
||||||
#define HAVE_SYS_SOCKET_H 1
|
#define HAVE_SYS_SOCKET_H 1
|
||||||
@@ -43,15 +46,16 @@
|
|||||||
#define HAVE_FCNTL_H 1
|
#define HAVE_FCNTL_H 1
|
||||||
#define HAVE_SYS_STAT_H 1
|
#define HAVE_SYS_STAT_H 1
|
||||||
#define HAVE_ALLOCA_H 1
|
#define HAVE_ALLOCA_H 1
|
||||||
#define HAVE_TIME_H 1
|
|
||||||
#define HAVE_STDLIB_H 1
|
#define HAVE_STDLIB_H 1
|
||||||
|
#define HAVE_TIME_H 1
|
||||||
#define HAVE_UTIME_H 1
|
#define HAVE_UTIME_H 1
|
||||||
#define HAVE_SYS_TIME_H 1
|
#define HAVE_SYS_TIME_H 1
|
||||||
|
#define HAVE_SYS_UTIME_H 1
|
||||||
|
|
||||||
#define TIME_WITH_SYS_TIME 1
|
#define TIME_WITH_SYS_TIME 1
|
||||||
|
|
||||||
#define HAVE_ALARM 1
|
#define HAVE_ALARM 1
|
||||||
#define HAVE_STRDUP 1
|
#define HAVE_FTRUNCATE 1
|
||||||
#define HAVE_UTIME 1
|
#define HAVE_UTIME 1
|
||||||
#define HAVE_SETVBUF 1
|
#define HAVE_SETVBUF 1
|
||||||
#define HAVE_STRFTIME 1
|
#define HAVE_STRFTIME 1
|
||||||
@@ -61,14 +65,13 @@
|
|||||||
#define HAVE_SOCKET 1
|
#define HAVE_SOCKET 1
|
||||||
#define HAVE_STRUCT_TIMEVAL 1
|
#define HAVE_STRUCT_TIMEVAL 1
|
||||||
|
|
||||||
//#define HAVE_STRICMP 1
|
|
||||||
#define HAVE_SIGACTION 1
|
#define HAVE_SIGACTION 1
|
||||||
#define HAVE_SIGNAL_H 1
|
#define HAVE_SIGNAL_H 1
|
||||||
#define HAVE_SIG_ATOMIC_T 1
|
#define HAVE_SIG_ATOMIC_T 1
|
||||||
|
|
||||||
#ifdef MACOS_SSL_SUPPORT
|
#ifdef MACOS_SSL_SUPPORT
|
||||||
# define USE_SSLEAY 1
|
# define USE_SSLEAY 1
|
||||||
# define USE_OPENSSL 1
|
# define USE_OPENSSL 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define CURL_DISABLE_LDAP 1
|
#define CURL_DISABLE_LDAP 1
|
||||||
@@ -120,4 +123,4 @@
|
|||||||
#define HAVE_EXTRA_STRICMP_H 1
|
#define HAVE_EXTRA_STRICMP_H 1
|
||||||
#define HAVE_EXTRA_STRDUP_H 1
|
#define HAVE_EXTRA_STRDUP_H 1
|
||||||
|
|
||||||
#endif /* __LIB_CONFIG_MAC_H */
|
#endif /* HEADER_CURL_CONFIG_MAC_H */
|
||||||
|
@@ -1,6 +1,5 @@
|
|||||||
/* ================================================================ */
|
#ifndef HEADER_CURL_CONFIG_OS400_H
|
||||||
/* lib/config-os400.h - Hand crafted config file for OS/400 */
|
#define HEADER_CURL_CONFIG_OS400_H
|
||||||
/* ================================================================ */
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -8,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
|
||||||
@@ -23,6 +22,10 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
|
/* ================================================================ */
|
||||||
|
/* Hand crafted config file for OS/400 */
|
||||||
|
/* ================================================================ */
|
||||||
|
|
||||||
#pragma enum(int)
|
#pragma enum(int)
|
||||||
|
|
||||||
#undef PACKAGE
|
#undef PACKAGE
|
||||||
@@ -434,10 +437,7 @@
|
|||||||
/* To disable LDAP */
|
/* To disable LDAP */
|
||||||
#undef CURL_DISABLE_LDAP
|
#undef CURL_DISABLE_LDAP
|
||||||
|
|
||||||
/* To avoid external use of library hidden symbols */
|
/* Definition to make a library symbol externally visible. */
|
||||||
#define CURL_HIDDEN_SYMBOLS
|
|
||||||
|
|
||||||
/* External symbols need no special keyword. */
|
|
||||||
#define CURL_EXTERN_SYMBOL
|
#define CURL_EXTERN_SYMBOL
|
||||||
|
|
||||||
/* Define if you have the ldap_url_parse procedure. */
|
/* Define if you have the ldap_url_parse procedure. */
|
||||||
@@ -542,3 +542,4 @@
|
|||||||
#define qadrt_use_fread_inline /* Generate fread() wrapper inline. */
|
#define qadrt_use_fread_inline /* Generate fread() wrapper inline. */
|
||||||
#define qadrt_use_fwrite_inline /* Generate fwrite() wrapper inline. */
|
#define qadrt_use_fwrite_inline /* Generate fwrite() wrapper inline. */
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_CONFIG_OS400_H */
|
||||||
|
@@ -1,11 +1,13 @@
|
|||||||
/* curl_config.h.in. Generated automatically from configure.in by autoheader. /***************************************************************************
|
#ifndef HEADER_CURL_CONFIG_RISCOS_H
|
||||||
|
#define HEADER_CURL_CONFIG_RISCOS_H
|
||||||
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
* / __| | | | |_) | |
|
* / __| | | | |_) | |
|
||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* 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
|
||||||
@@ -19,7 +21,11 @@
|
|||||||
* KIND, either express or implied.
|
* KIND, either express or implied.
|
||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
*/
|
|
||||||
|
/* ================================================================ */
|
||||||
|
/* Hand crafted config file for RISC OS */
|
||||||
|
/* ================================================================ */
|
||||||
|
|
||||||
/* Name of this package! */
|
/* Name of this package! */
|
||||||
#undef PACKAGE
|
#undef PACKAGE
|
||||||
|
|
||||||
@@ -32,6 +38,9 @@
|
|||||||
/* Define cpu-machine-OS */
|
/* Define cpu-machine-OS */
|
||||||
#define OS "ARM-RISC OS"
|
#define OS "ARM-RISC OS"
|
||||||
|
|
||||||
|
/* Define if you want the built-in manual */
|
||||||
|
#define USE_MANUAL
|
||||||
|
|
||||||
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
/* Define if you have the gethostbyaddr_r() function with 5 arguments */
|
||||||
#undef HAVE_GETHOSTBYADDR_R_5
|
#undef HAVE_GETHOSTBYADDR_R_5
|
||||||
|
|
||||||
@@ -74,8 +83,8 @@
|
|||||||
/* Define if you want to enable IPv6 support */
|
/* Define if you want to enable IPv6 support */
|
||||||
#undef ENABLE_IPV6
|
#undef ENABLE_IPV6
|
||||||
|
|
||||||
/* Define to 1 if you have the alarm function. */
|
/* Define if you have the alarm function. */
|
||||||
#define HAVE_ALARM 1
|
#define HAVE_ALARM
|
||||||
|
|
||||||
/* Define if you have the <alloca.h> header file. */
|
/* Define if you have the <alloca.h> header file. */
|
||||||
#define HAVE_ALLOCA_H
|
#define HAVE_ALLOCA_H
|
||||||
@@ -101,6 +110,9 @@
|
|||||||
/* Define if you have the <fcntl.h> header file. */
|
/* Define if you have the <fcntl.h> header file. */
|
||||||
#define HAVE_FCNTL_H
|
#define HAVE_FCNTL_H
|
||||||
|
|
||||||
|
/* Define if you have the `ftruncate' function. */
|
||||||
|
#define HAVE_FTRUNCATE
|
||||||
|
|
||||||
/* Define if getaddrinfo exists and works */
|
/* Define if getaddrinfo exists and works */
|
||||||
#define HAVE_GETADDRINFO
|
#define HAVE_GETADDRINFO
|
||||||
|
|
||||||
@@ -144,7 +156,7 @@
|
|||||||
#define HAVE_INTTYPES_H
|
#define HAVE_INTTYPES_H
|
||||||
|
|
||||||
/* Define if you have the <io.h> header file. */
|
/* Define if you have the <io.h> header file. */
|
||||||
#define HAVE_IO_H
|
#undef HAVE_IO_H
|
||||||
|
|
||||||
/* Define if you have the `krb_get_our_ip_for_realm' function. */
|
/* Define if you have the `krb_get_our_ip_for_realm' function. */
|
||||||
#undef HAVE_KRB_GET_OUR_IP_FOR_REALM
|
#undef HAVE_KRB_GET_OUR_IP_FOR_REALM
|
||||||
@@ -462,8 +474,8 @@
|
|||||||
/* Define to the type pointed by arg 2 for recvfrom. */
|
/* Define to the type pointed by arg 2 for recvfrom. */
|
||||||
#define RECVFROM_TYPE_ARG2 void
|
#define RECVFROM_TYPE_ARG2 void
|
||||||
|
|
||||||
/* Define to 1 if the type pointed by arg 2 for recvfrom is void. */
|
/* Define if the type pointed by arg 2 for recvfrom is void. */
|
||||||
#define RECVFROM_TYPE_ARG2_IS_VOID 1
|
#define RECVFROM_TYPE_ARG2_IS_VOID
|
||||||
|
|
||||||
/* Define to the type of arg 3 for recvfrom. */
|
/* Define to the type of arg 3 for recvfrom. */
|
||||||
#define RECVFROM_TYPE_ARG3 size_t
|
#define RECVFROM_TYPE_ARG3 size_t
|
||||||
@@ -500,3 +512,5 @@
|
|||||||
|
|
||||||
/* Define to the function return type for send. */
|
/* Define to the function return type for send. */
|
||||||
#define SEND_TYPE_RETV ssize_t
|
#define SEND_TYPE_RETV ssize_t
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_CONFIG_RISCOS_H */
|
||||||
|
@@ -1,4 +1,5 @@
|
|||||||
/* config-symbian.h. Manually generated. */
|
#ifndef HEADER_CURL_CONFIG_SYMBIAN_H
|
||||||
|
#define HEADER_CURL_CONFIG_SYMBIAN_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -6,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
|
||||||
@@ -21,8 +22,9 @@
|
|||||||
*
|
*
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/* when building libcurl itself */
|
/* ================================================================ */
|
||||||
/* #undef BUILDING_LIBCURL */
|
/* Hand crafted config file for Symbian */
|
||||||
|
/* ================================================================ */
|
||||||
|
|
||||||
/* Location of default ca bundle */
|
/* Location of default ca bundle */
|
||||||
/* #define CURL_CA_BUNDLE "/etc/pki/tls/certs/ca-bundle.crt"*/
|
/* #define CURL_CA_BUNDLE "/etc/pki/tls/certs/ca-bundle.crt"*/
|
||||||
@@ -63,18 +65,12 @@
|
|||||||
/* to disable verbose strings */
|
/* to disable verbose strings */
|
||||||
/* #define CURL_DISABLE_VERBOSE_STRINGS 1*/
|
/* #define CURL_DISABLE_VERBOSE_STRINGS 1*/
|
||||||
|
|
||||||
/* to make a symbol visible */
|
/* Definition to make a library symbol externally visible. */
|
||||||
/*#define CURL_EXTERN_SYMBOL __declspec(dllexport)*/
|
/* #undef CURL_EXTERN_SYMBOL */
|
||||||
|
|
||||||
/* to enable hidden symbols */
|
|
||||||
/*#define CURL_HIDDEN_SYMBOLS 1*/
|
|
||||||
|
|
||||||
/* Use Windows LDAP implementation */
|
/* Use Windows LDAP implementation */
|
||||||
/* #undef CURL_LDAP_WIN */
|
/* #undef CURL_LDAP_WIN */
|
||||||
|
|
||||||
/* when not building a shared library */
|
|
||||||
/* #undef CURL_STATICLIB */
|
|
||||||
|
|
||||||
/* your Entropy Gathering Daemon socket pathname */
|
/* your Entropy Gathering Daemon socket pathname */
|
||||||
/* #undef EGD_SOCKET */
|
/* #undef EGD_SOCKET */
|
||||||
|
|
||||||
@@ -400,9 +396,6 @@
|
|||||||
/* Define to 1 if you have the `pipe' function. */
|
/* Define to 1 if you have the `pipe' function. */
|
||||||
#define HAVE_PIPE 1
|
#define HAVE_PIPE 1
|
||||||
|
|
||||||
/* if you have the function PK11_CreateGenericObject */
|
|
||||||
/* #undef HAVE_PK11_CREATEGENERICOBJECT */
|
|
||||||
|
|
||||||
/* Define to 1 if you have the `poll' function. */
|
/* Define to 1 if you have the `poll' function. */
|
||||||
/*#define HAVE_POLL 1*/
|
/*#define HAVE_POLL 1*/
|
||||||
|
|
||||||
@@ -646,9 +639,6 @@
|
|||||||
/* Define to 1 if you have the <x509.h> header file. */
|
/* Define to 1 if you have the <x509.h> header file. */
|
||||||
/* #undef HAVE_X509_H */
|
/* #undef HAVE_X509_H */
|
||||||
|
|
||||||
/* Define to 1 if you are building a native Windows target. */
|
|
||||||
/* #undef NATIVE_WINDOWS */
|
|
||||||
|
|
||||||
/* Define to 1 if you need the lber.h header file even with ldap.h */
|
/* Define to 1 if you need the lber.h header file even with ldap.h */
|
||||||
/* #undef NEED_LBER_H */
|
/* #undef NEED_LBER_H */
|
||||||
|
|
||||||
@@ -830,3 +820,5 @@
|
|||||||
/* if OpenSSL is in use */
|
/* if OpenSSL is in use */
|
||||||
#define USE_OPENSSL
|
#define USE_OPENSSL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif /* HEADER_CURL_CONFIG_SYMBIAN_H */
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __LIBCONFIGTPF_H
|
#ifndef HEADER_CURL_CONFIG_TPF_H
|
||||||
#define __LIBCONFIGTPF_H
|
#define HEADER_CURL_CONFIG_TPF_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -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
|
||||||
@@ -23,7 +23,7 @@
|
|||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/* ================================================================ */
|
/* ================================================================ */
|
||||||
/* lib/config-tpf.h - Hand crafted config file for TPF */
|
/* Hand crafted config file for TPF */
|
||||||
/* ================================================================ */
|
/* ================================================================ */
|
||||||
|
|
||||||
/* ---------------------------------------------------------------- */
|
/* ---------------------------------------------------------------- */
|
||||||
@@ -32,9 +32,6 @@
|
|||||||
|
|
||||||
/* NOTE: Refer also to the .mak file for some of the flags below */
|
/* NOTE: Refer also to the .mak file for some of the flags below */
|
||||||
|
|
||||||
/* when building libcurl itself */
|
|
||||||
/* #undef BUILDING_LIBCURL */
|
|
||||||
|
|
||||||
/* to disable cookies support */
|
/* to disable cookies support */
|
||||||
/* #undef CURL_DISABLE_COOKIES */
|
/* #undef CURL_DISABLE_COOKIES */
|
||||||
|
|
||||||
@@ -65,9 +62,6 @@
|
|||||||
/* to disable verbose strings */
|
/* to disable verbose strings */
|
||||||
/* #undef CURL_DISABLE_VERBOSE_STRINGS */
|
/* #undef CURL_DISABLE_VERBOSE_STRINGS */
|
||||||
|
|
||||||
/* when not building a shared library */
|
|
||||||
/* #undef CURL_STATICLIB */
|
|
||||||
|
|
||||||
/* lber dynamic library file */
|
/* lber dynamic library file */
|
||||||
/* #undef DL_LBER_FILE */
|
/* #undef DL_LBER_FILE */
|
||||||
|
|
||||||
@@ -779,4 +773,4 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif /* __LIBCONFIGTPF_H */
|
#endif /* HEADER_CURL_CONFIG_TPF_H */
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __LIB_CONFIG_VXWORKS_H
|
#ifndef HEADER_CURL_CONFIG_VXWORKS_H
|
||||||
#define __LIB_CONFIG_VXWORKS_H
|
#define HEADER_CURL_CONFIG_VXWORKS_H
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
* Project ___| | | | _ \| |
|
* Project ___| | | | _ \| |
|
||||||
@@ -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
|
||||||
@@ -23,12 +23,9 @@
|
|||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
|
||||||
/* =============================================================== */
|
/* =============================================================== */
|
||||||
/* lib/config-vxworks.h - Hand crafted config file for VxWorks */
|
/* Hand crafted config file for VxWorks */
|
||||||
/* =============================================================== */
|
/* =============================================================== */
|
||||||
|
|
||||||
/* when building libcurl itself */
|
|
||||||
/* #undef BUILDING_LIBCURL */
|
|
||||||
|
|
||||||
/* Location of default ca bundle */
|
/* Location of default ca bundle */
|
||||||
/* #undef CURL_CA_BUNDLE */
|
/* #undef CURL_CA_BUNDLE */
|
||||||
|
|
||||||
@@ -74,18 +71,12 @@
|
|||||||
/* to disable verbose strings */
|
/* to disable verbose strings */
|
||||||
/* #undef CURL_DISABLE_VERBOSE_STRINGS */
|
/* #undef CURL_DISABLE_VERBOSE_STRINGS */
|
||||||
|
|
||||||
/* to make a symbol visible */
|
/* Definition to make a library symbol externally visible. */
|
||||||
/* #undef CURL_EXTERN_SYMBOL */
|
/* #undef CURL_EXTERN_SYMBOL */
|
||||||
|
|
||||||
/* to enable hidden symbols */
|
|
||||||
/* #undef CURL_HIDDEN_SYMBOLS */
|
|
||||||
|
|
||||||
/* Use Windows LDAP implementation */
|
/* Use Windows LDAP implementation */
|
||||||
/* #undef CURL_LDAP_WIN */
|
/* #undef CURL_LDAP_WIN */
|
||||||
|
|
||||||
/* when not building a shared library */
|
|
||||||
/* #undef CURL_STATICLIB */
|
|
||||||
|
|
||||||
/* your Entropy Gathering Daemon socket pathname */
|
/* your Entropy Gathering Daemon socket pathname */
|
||||||
/* #undef EGD_SOCKET */
|
/* #undef EGD_SOCKET */
|
||||||
|
|
||||||
@@ -469,9 +460,6 @@
|
|||||||
/* Define to 1 if you have the `pipe' function. */
|
/* Define to 1 if you have the `pipe' function. */
|
||||||
#define HAVE_PIPE 1
|
#define HAVE_PIPE 1
|
||||||
|
|
||||||
/* if you have the function PK11_CreateGenericObject */
|
|
||||||
/* #undef HAVE_PK11_CREATEGENERICOBJECT */
|
|
||||||
|
|
||||||
/* Define to 1 if you have a working poll function. */
|
/* Define to 1 if you have a working poll function. */
|
||||||
/* #undef HAVE_POLL */
|
/* #undef HAVE_POLL */
|
||||||
|
|
||||||
@@ -745,9 +733,6 @@
|
|||||||
/* if you have the zlib.h header file */
|
/* if you have the zlib.h header file */
|
||||||
#define HAVE_ZLIB_H 1
|
#define HAVE_ZLIB_H 1
|
||||||
|
|
||||||
/* Define to 1 if you are building a native Windows target. */
|
|
||||||
/* #undef NATIVE_WINDOWS */
|
|
||||||
|
|
||||||
/* Define to 1 if you need the lber.h header file even with ldap.h */
|
/* Define to 1 if you need the lber.h header file even with ldap.h */
|
||||||
/* #undef NEED_LBER_H */
|
/* #undef NEED_LBER_H */
|
||||||
|
|
||||||
@@ -952,4 +937,4 @@
|
|||||||
/* the signed version of size_t */
|
/* the signed version of size_t */
|
||||||
/* #undef ssize_t */
|
/* #undef ssize_t */
|
||||||
|
|
||||||
#endif /* __LIB_CONFIG_VXWORKS_H */
|
#endif /* HEADER_CURL_CONFIG_VXWORKS_H */
|
||||||
|
223
lib/connect.c
223
lib/connect.c
@@ -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,20 +89,37 @@
|
|||||||
#undef SO_NOSIGPIPE
|
#undef SO_NOSIGPIPE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct Curl_sockaddr_ex {
|
|
||||||
int family;
|
|
||||||
int socktype;
|
|
||||||
int protocol;
|
|
||||||
unsigned int addrlen;
|
|
||||||
union {
|
|
||||||
struct sockaddr addr;
|
|
||||||
struct Curl_sockaddr_storage buff;
|
|
||||||
} _sa_ex_u;
|
|
||||||
};
|
|
||||||
#define sa_addr _sa_ex_u.addr
|
|
||||||
|
|
||||||
static bool verifyconnect(curl_socket_t sockfd, int *error);
|
static bool verifyconnect(curl_socket_t sockfd, int *error);
|
||||||
|
|
||||||
|
static void
|
||||||
|
tcpkeepalive(struct SessionHandle *data,
|
||||||
|
curl_socket_t sockfd)
|
||||||
|
{
|
||||||
|
int optval = data->set.tcp_keepalive?1:0;
|
||||||
|
|
||||||
|
/* only set IDLE and INTVL if setting KEEPALIVE is successful */
|
||||||
|
if(setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE,
|
||||||
|
(void *)&optval, sizeof(optval)) < 0) {
|
||||||
|
infof(data, "Failed to set SO_KEEPALIVE on fd %d\n", sockfd);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
#ifdef TCP_KEEPIDLE
|
||||||
|
optval = curlx_sltosi(data->set.tcp_keepidle);
|
||||||
|
if(setsockopt(sockfd, IPPROTO_TCP, TCP_KEEPIDLE,
|
||||||
|
(void *)&optval, sizeof(optval)) < 0) {
|
||||||
|
infof(data, "Failed to set TCP_KEEPIDLE on fd %d\n", sockfd);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef TCP_KEEPINTVL
|
||||||
|
optval = curlx_sltosi(data->set.tcp_keepintvl);
|
||||||
|
if(setsockopt(sockfd, IPPROTO_TCP, TCP_KEEPINTVL,
|
||||||
|
(void *)&optval, sizeof(optval)) < 0) {
|
||||||
|
infof(data, "Failed to set TCP_KEEPINTVL on fd %d\n", sockfd);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
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 */
|
||||||
@@ -252,6 +269,10 @@ static CURLcode bindlocal(struct connectdata *conn,
|
|||||||
int error;
|
int error;
|
||||||
char myhost[256] = "";
|
char myhost[256] = "";
|
||||||
int done = 0; /* -1 for error, 1 for address found */
|
int done = 0; /* -1 for error, 1 for address found */
|
||||||
|
bool is_interface = FALSE;
|
||||||
|
bool is_host = FALSE;
|
||||||
|
static const char *if_prefix = "if!";
|
||||||
|
static const char *host_prefix = "host!";
|
||||||
|
|
||||||
/*************************************************************
|
/*************************************************************
|
||||||
* Select device to bind socket to
|
* Select device to bind socket to
|
||||||
@@ -263,9 +284,20 @@ static CURLcode bindlocal(struct connectdata *conn,
|
|||||||
memset(&sa, 0, sizeof(struct Curl_sockaddr_storage));
|
memset(&sa, 0, sizeof(struct Curl_sockaddr_storage));
|
||||||
|
|
||||||
if(dev && (strlen(dev)<255) ) {
|
if(dev && (strlen(dev)<255) ) {
|
||||||
|
if(strncmp(if_prefix, dev, strlen(if_prefix)) == 0) {
|
||||||
|
dev += strlen(if_prefix);
|
||||||
|
is_interface = TRUE;
|
||||||
|
}
|
||||||
|
else if(strncmp(host_prefix, dev, strlen(host_prefix)) == 0) {
|
||||||
|
dev += strlen(host_prefix);
|
||||||
|
is_host = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
/* interface */
|
/* interface */
|
||||||
if(Curl_if2ip(af, dev, myhost, sizeof(myhost))) {
|
if(!is_host && (is_interface || Curl_if_is_interface_name(dev))) {
|
||||||
|
if(Curl_if2ip(af, dev, myhost, sizeof(myhost)) == NULL)
|
||||||
|
return CURLE_INTERFACE_FAILED;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We now have the numerical IP address in the 'myhost' buffer
|
* We now have the numerical IP address in the 'myhost' buffer
|
||||||
*/
|
*/
|
||||||
@@ -729,6 +761,8 @@ CURLcode Curl_is_connected(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
next:
|
next:
|
||||||
|
|
||||||
|
conn->timeoutms_per_addr = conn->ip_addr->ai_next == NULL ?
|
||||||
|
allow : allow / 2;
|
||||||
code = trynextip(conn, sockindex, connected);
|
code = trynextip(conn, sockindex, connected);
|
||||||
|
|
||||||
if(code) {
|
if(code) {
|
||||||
@@ -841,57 +875,17 @@ singleipconnect(struct connectdata *conn,
|
|||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
curl_socket_t sockfd;
|
curl_socket_t sockfd;
|
||||||
CURLcode res = CURLE_OK;
|
CURLcode res = CURLE_OK;
|
||||||
#if defined(ENABLE_IPV6) && defined(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID)
|
|
||||||
struct sockaddr_in6 * const sa6 = (void *)&addr.sa_addr;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
*sockp = CURL_SOCKET_BAD;
|
*sockp = CURL_SOCKET_BAD;
|
||||||
|
|
||||||
/*
|
|
||||||
* The Curl_sockaddr_ex structure is basically libcurl's external API
|
|
||||||
* curl_sockaddr structure with enough space available to directly hold
|
|
||||||
* any protocol-specific address structures. The variable declared here
|
|
||||||
* will be used to pass / receive data to/from the fopensocket callback
|
|
||||||
* if this has been set, before that, it is initialized from parameters.
|
|
||||||
*/
|
|
||||||
|
|
||||||
addr.family = ai->ai_family;
|
|
||||||
addr.socktype = conn->socktype;
|
|
||||||
addr.protocol = conn->socktype==SOCK_DGRAM?IPPROTO_UDP:ai->ai_protocol;
|
|
||||||
addr.addrlen = ai->ai_addrlen;
|
|
||||||
|
|
||||||
if(addr.addrlen > sizeof(struct Curl_sockaddr_storage))
|
|
||||||
addr.addrlen = sizeof(struct Curl_sockaddr_storage);
|
|
||||||
memcpy(&addr.sa_addr, ai->ai_addr, addr.addrlen);
|
|
||||||
|
|
||||||
*connected = FALSE; /* default is not connected */
|
*connected = FALSE; /* default is not connected */
|
||||||
|
|
||||||
if(data->set.fopensocket)
|
res = Curl_socket(conn, ai, &addr, &sockfd);
|
||||||
/*
|
if(res)
|
||||||
* If the opensocket callback is set, all the destination address
|
/* Failed to create the socket, but still return OK since we signal the
|
||||||
* information is passed to the callback. Depending on this information the
|
lack of socket as well. This allows the parent function to keep looping
|
||||||
* callback may opt to abort the connection, this is indicated returning
|
over alternative addresses/socket families etc. */
|
||||||
* CURL_SOCKET_BAD; otherwise it will return a not-connected socket. When
|
|
||||||
* the callback returns a valid socket the destination address information
|
|
||||||
* might have been changed and this 'new' address will actually be used
|
|
||||||
* here to connect.
|
|
||||||
*/
|
|
||||||
sockfd = data->set.fopensocket(data->set.opensocket_client,
|
|
||||||
CURLSOCKTYPE_IPCXN,
|
|
||||||
(struct curl_sockaddr *)&addr);
|
|
||||||
else
|
|
||||||
/* opensocket callback not set, so simply create the socket now */
|
|
||||||
sockfd = socket(addr.family, addr.socktype, addr.protocol);
|
|
||||||
|
|
||||||
if(sockfd == CURL_SOCKET_BAD)
|
|
||||||
/* no socket, no connection */
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
|
|
||||||
#if defined(ENABLE_IPV6) && defined(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID)
|
|
||||||
if(conn->scope && (addr.family == AF_INET6))
|
|
||||||
sa6->sin6_scope_id = conn->scope;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* store remote address and port used in this connection attempt */
|
/* store remote address and port used in this connection attempt */
|
||||||
if(!getaddressinfo((struct sockaddr*)&addr.sa_addr,
|
if(!getaddressinfo((struct sockaddr*)&addr.sa_addr,
|
||||||
conn->primary_ip, &conn->primary_port)) {
|
conn->primary_ip, &conn->primary_port)) {
|
||||||
@@ -903,7 +897,7 @@ singleipconnect(struct connectdata *conn,
|
|||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
memcpy(conn->ip_addr_str, conn->primary_ip, MAX_IPADR_LEN);
|
memcpy(conn->ip_addr_str, conn->primary_ip, MAX_IPADR_LEN);
|
||||||
infof(data, " Trying %s... ", conn->ip_addr_str);
|
infof(data, " Trying %s...\n", conn->ip_addr_str);
|
||||||
|
|
||||||
Curl_persistconninfo(conn);
|
Curl_persistconninfo(conn);
|
||||||
|
|
||||||
@@ -914,6 +908,9 @@ singleipconnect(struct connectdata *conn,
|
|||||||
|
|
||||||
Curl_sndbufset(sockfd);
|
Curl_sndbufset(sockfd);
|
||||||
|
|
||||||
|
if(data->set.tcp_keepalive)
|
||||||
|
tcpkeepalive(data, sockfd);
|
||||||
|
|
||||||
if(data->set.fsockopt) {
|
if(data->set.fsockopt) {
|
||||||
/* activate callback for setting socket options */
|
/* activate callback for setting socket options */
|
||||||
error = data->set.fsockopt(data->set.sockopt_client,
|
error = data->set.fsockopt(data->set.sockopt_client,
|
||||||
@@ -1029,7 +1026,6 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
{
|
{
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
curl_socket_t sockfd = CURL_SOCKET_BAD;
|
curl_socket_t sockfd = CURL_SOCKET_BAD;
|
||||||
int aliasindex;
|
|
||||||
Curl_addrinfo *ai;
|
Curl_addrinfo *ai;
|
||||||
Curl_addrinfo *curr_addr;
|
Curl_addrinfo *curr_addr;
|
||||||
|
|
||||||
@@ -1053,9 +1049,7 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
return CURLE_OPERATION_TIMEDOUT;
|
return CURLE_OPERATION_TIMEDOUT;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Max time for each address */
|
|
||||||
conn->num_addr = Curl_num_addresses(remotehost->addr);
|
conn->num_addr = Curl_num_addresses(remotehost->addr);
|
||||||
conn->timeoutms_per_addr = timeout_ms / conn->num_addr;
|
|
||||||
|
|
||||||
ai = remotehost->addr;
|
ai = remotehost->addr;
|
||||||
|
|
||||||
@@ -1066,16 +1060,18 @@ CURLcode Curl_connecthost(struct connectdata *conn, /* context */
|
|||||||
/*
|
/*
|
||||||
* Connecting with a Curl_addrinfo chain
|
* Connecting with a Curl_addrinfo chain
|
||||||
*/
|
*/
|
||||||
for(curr_addr = ai, aliasindex=0; curr_addr;
|
for(curr_addr = ai; curr_addr; curr_addr = curr_addr->ai_next) {
|
||||||
curr_addr = curr_addr->ai_next, aliasindex++) {
|
CURLcode res;
|
||||||
|
|
||||||
|
/* Max time for the next address */
|
||||||
|
conn->timeoutms_per_addr = curr_addr->ai_next == NULL ?
|
||||||
|
timeout_ms : timeout_ms / 2;
|
||||||
|
|
||||||
/* start connecting to the IP curr_addr points to */
|
/* start connecting to the IP curr_addr points to */
|
||||||
CURLcode res =
|
res = singleipconnect(conn, curr_addr,
|
||||||
singleipconnect(conn, curr_addr,
|
/* don't hang when doing multi */
|
||||||
/* don't hang when doing multi */
|
(data->state.used_interface == Curl_if_multi)?0:
|
||||||
(data->state.used_interface == Curl_if_multi)?0:
|
conn->timeoutms_per_addr, &sockfd, connected);
|
||||||
conn->timeoutms_per_addr, &sockfd, connected);
|
|
||||||
|
|
||||||
if(res)
|
if(res)
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
@@ -1165,8 +1161,85 @@ curl_socket_t Curl_getconnectinfo(struct SessionHandle *data,
|
|||||||
int Curl_closesocket(struct connectdata *conn,
|
int Curl_closesocket(struct connectdata *conn,
|
||||||
curl_socket_t sock)
|
curl_socket_t sock)
|
||||||
{
|
{
|
||||||
if(conn && conn->fclosesocket)
|
if(conn && conn->fclosesocket) {
|
||||||
return conn->fclosesocket(conn->closesocket_client, sock);
|
if((sock == conn->sock[SECONDARYSOCKET]) &&
|
||||||
else
|
conn->sock_accepted[SECONDARYSOCKET])
|
||||||
return sclose(sock);
|
/* if this socket matches the second socket, and that was created with
|
||||||
|
accept, then we MUST NOT call the callback but clear the accepted
|
||||||
|
status */
|
||||||
|
conn->sock_accepted[SECONDARYSOCKET] = FALSE;
|
||||||
|
else
|
||||||
|
return conn->fclosesocket(conn->closesocket_client, sock);
|
||||||
|
}
|
||||||
|
return sclose(sock);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a socket based on info from 'conn' and 'ai'.
|
||||||
|
*
|
||||||
|
* 'addr' should be a pointer to the correct struct to get data back, or NULL.
|
||||||
|
* 'sockfd' must be a pointer to a socket descriptor.
|
||||||
|
*
|
||||||
|
* If the open socket callback is set, used that!
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
CURLcode Curl_socket(struct connectdata *conn,
|
||||||
|
const Curl_addrinfo *ai,
|
||||||
|
struct Curl_sockaddr_ex *addr,
|
||||||
|
curl_socket_t *sockfd)
|
||||||
|
{
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
struct Curl_sockaddr_ex dummy;
|
||||||
|
|
||||||
|
if(!addr)
|
||||||
|
/* if the caller doesn't want info back, use a local temp copy */
|
||||||
|
addr = &dummy;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The Curl_sockaddr_ex structure is basically libcurl's external API
|
||||||
|
* curl_sockaddr structure with enough space available to directly hold
|
||||||
|
* any protocol-specific address structures. The variable declared here
|
||||||
|
* will be used to pass / receive data to/from the fopensocket callback
|
||||||
|
* if this has been set, before that, it is initialized from parameters.
|
||||||
|
*/
|
||||||
|
|
||||||
|
addr->family = ai->ai_family;
|
||||||
|
addr->socktype = conn->socktype;
|
||||||
|
addr->protocol = conn->socktype==SOCK_DGRAM?IPPROTO_UDP:ai->ai_protocol;
|
||||||
|
addr->addrlen = ai->ai_addrlen;
|
||||||
|
|
||||||
|
if(addr->addrlen > sizeof(struct Curl_sockaddr_storage))
|
||||||
|
addr->addrlen = sizeof(struct Curl_sockaddr_storage);
|
||||||
|
memcpy(&addr->sa_addr, ai->ai_addr, addr->addrlen);
|
||||||
|
|
||||||
|
if(data->set.fopensocket)
|
||||||
|
/*
|
||||||
|
* If the opensocket callback is set, all the destination address
|
||||||
|
* information is passed to the callback. Depending on this information the
|
||||||
|
* callback may opt to abort the connection, this is indicated returning
|
||||||
|
* CURL_SOCKET_BAD; otherwise it will return a not-connected socket. When
|
||||||
|
* the callback returns a valid socket the destination address information
|
||||||
|
* might have been changed and this 'new' address will actually be used
|
||||||
|
* here to connect.
|
||||||
|
*/
|
||||||
|
*sockfd = data->set.fopensocket(data->set.opensocket_client,
|
||||||
|
CURLSOCKTYPE_IPCXN,
|
||||||
|
(struct curl_sockaddr *)addr);
|
||||||
|
else
|
||||||
|
/* opensocket callback not set, so simply create the socket now */
|
||||||
|
*sockfd = socket(addr->family, addr->socktype, addr->protocol);
|
||||||
|
|
||||||
|
if(*sockfd == CURL_SOCKET_BAD)
|
||||||
|
/* no socket, no connection */
|
||||||
|
return CURLE_COULDNT_CONNECT;
|
||||||
|
|
||||||
|
#if defined(ENABLE_IPV6) && defined(HAVE_SOCKADDR_IN6_SIN6_SCOPE_ID)
|
||||||
|
if(conn->scope && (addr->family == AF_INET6)) {
|
||||||
|
struct sockaddr_in6 * const sa6 = (void *)&addr->sa_addr;
|
||||||
|
sa6->sin6_scope_id = conn->scope;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@@ -24,6 +24,7 @@
|
|||||||
#include "setup.h"
|
#include "setup.h"
|
||||||
|
|
||||||
#include "nonblock.h" /* for curlx_nonblock(), formerly Curl_nonblock() */
|
#include "nonblock.h" /* for curlx_nonblock(), formerly Curl_nonblock() */
|
||||||
|
#include "sockaddr.h"
|
||||||
|
|
||||||
CURLcode Curl_is_connected(struct connectdata *conn,
|
CURLcode Curl_is_connected(struct connectdata *conn,
|
||||||
int sockindex,
|
int sockindex,
|
||||||
@@ -72,4 +73,35 @@ void Curl_updateconninfo(struct connectdata *conn, curl_socket_t sockfd);
|
|||||||
void Curl_persistconninfo(struct connectdata *conn);
|
void Curl_persistconninfo(struct connectdata *conn);
|
||||||
int Curl_closesocket(struct connectdata *conn, curl_socket_t sock);
|
int Curl_closesocket(struct connectdata *conn, curl_socket_t sock);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The Curl_sockaddr_ex structure is basically libcurl's external API
|
||||||
|
* curl_sockaddr structure with enough space available to directly hold any
|
||||||
|
* protocol-specific address structures. The variable declared here will be
|
||||||
|
* used to pass / receive data to/from the fopensocket callback if this has
|
||||||
|
* been set, before that, it is initialized from parameters.
|
||||||
|
*/
|
||||||
|
struct Curl_sockaddr_ex {
|
||||||
|
int family;
|
||||||
|
int socktype;
|
||||||
|
int protocol;
|
||||||
|
unsigned int addrlen;
|
||||||
|
union {
|
||||||
|
struct sockaddr addr;
|
||||||
|
struct Curl_sockaddr_storage buff;
|
||||||
|
} _sa_ex_u;
|
||||||
|
};
|
||||||
|
#define sa_addr _sa_ex_u.addr
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Create a socket based on info from 'conn' and 'ai'.
|
||||||
|
*
|
||||||
|
* Fill in 'addr' and 'sockfd' accordingly if OK is returned. If the open
|
||||||
|
* socket callback is set, used that!
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
CURLcode Curl_socket(struct connectdata *conn,
|
||||||
|
const Curl_addrinfo *ai,
|
||||||
|
struct Curl_sockaddr_ex *addr,
|
||||||
|
curl_socket_t *sockfd);
|
||||||
|
|
||||||
#endif /* HEADER_CURL_CONNECT_H */
|
#endif /* HEADER_CURL_CONNECT_H */
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
/* lib/curl_config.h.in. Generated from configure.ac by autoheader. */
|
/* lib/curl_config.h.in. Generated somehow by cmake. */
|
||||||
|
|
||||||
/* when building libcurl itself */
|
/* when building libcurl itself */
|
||||||
#cmakedefine BUILDING_LIBCURL ${BUILDING_LIBCURL}
|
#cmakedefine BUILDING_LIBCURL ${BUILDING_LIBCURL}
|
||||||
@@ -52,9 +52,6 @@
|
|||||||
#define CURL_EXTERN_SYMBOL
|
#define CURL_EXTERN_SYMBOL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* to enable hidden symbols */
|
|
||||||
#cmakedefine CURL_HIDDEN_SYMBOLS ${CURL_HIDDEN_SYMBOLS}
|
|
||||||
|
|
||||||
/* Use Windows LDAP implementation */
|
/* Use Windows LDAP implementation */
|
||||||
#cmakedefine CURL_LDAP_WIN ${CURL_LDAP_WIN}
|
#cmakedefine CURL_LDAP_WIN ${CURL_LDAP_WIN}
|
||||||
|
|
||||||
@@ -444,9 +441,6 @@
|
|||||||
/* Define to 1 if you have the `pipe' function. */
|
/* Define to 1 if you have the `pipe' function. */
|
||||||
#cmakedefine HAVE_PIPE ${HAVE_PIPE}
|
#cmakedefine HAVE_PIPE ${HAVE_PIPE}
|
||||||
|
|
||||||
/* if you have the function PK11_CreateGenericObject */
|
|
||||||
#cmakedefine HAVE_PK11_CREATEGENERICOBJECT ${HAVE_PK11_CREATEGENERICOBJECT}
|
|
||||||
|
|
||||||
/* Define to 1 if you have a working poll function. */
|
/* Define to 1 if you have a working poll function. */
|
||||||
#cmakedefine HAVE_POLL ${HAVE_POLL}
|
#cmakedefine HAVE_POLL ${HAVE_POLL}
|
||||||
|
|
||||||
@@ -724,9 +718,6 @@
|
|||||||
*/
|
*/
|
||||||
#cmakedefine LT_OBJDIR ${LT_OBJDIR}
|
#cmakedefine LT_OBJDIR ${LT_OBJDIR}
|
||||||
|
|
||||||
/* Define to 1 if you are building a native Windows target. */
|
|
||||||
#cmakedefine NATIVE_WINDOWS ${NATIVE_WINDOWS}
|
|
||||||
|
|
||||||
/* If you lack a fine basename() prototype */
|
/* If you lack a fine basename() prototype */
|
||||||
#cmakedefine NEED_BASENAME_PROTO ${NEED_BASENAME_PROTO}
|
#cmakedefine NEED_BASENAME_PROTO ${NEED_BASENAME_PROTO}
|
||||||
|
|
||||||
|
@@ -25,10 +25,39 @@
|
|||||||
#ifndef CURL_DISABLE_CRYPTO_AUTH
|
#ifndef CURL_DISABLE_CRYPTO_AUTH
|
||||||
#include "curl_hmac.h"
|
#include "curl_hmac.h"
|
||||||
|
|
||||||
|
#define MD5_DIGEST_LEN 16
|
||||||
|
|
||||||
|
typedef void (* Curl_MD5_init_func)(void *context);
|
||||||
|
typedef void (* Curl_MD5_update_func)(void *context,
|
||||||
|
const unsigned char *data,
|
||||||
|
unsigned int len);
|
||||||
|
typedef void (* Curl_MD5_final_func)(unsigned char *result, void *context);
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
Curl_MD5_init_func md5_init_func; /* Initialize context procedure */
|
||||||
|
Curl_MD5_update_func md5_update_func; /* Update context with data */
|
||||||
|
Curl_MD5_final_func md5_final_func; /* Get final result procedure */
|
||||||
|
unsigned int md5_ctxtsize; /* Context structure size */
|
||||||
|
unsigned int md5_resultlen; /* Result length (bytes) */
|
||||||
|
} MD5_params;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
const MD5_params *md5_hash; /* Hash function definition */
|
||||||
|
void *md5_hashctx; /* Hash function context */
|
||||||
|
} MD5_context;
|
||||||
|
|
||||||
|
extern const MD5_params Curl_DIGEST_MD5[1];
|
||||||
extern const HMAC_params Curl_HMAC_MD5[1];
|
extern const HMAC_params Curl_HMAC_MD5[1];
|
||||||
|
|
||||||
void Curl_md5it(unsigned char *output,
|
void Curl_md5it(unsigned char *output,
|
||||||
const unsigned char *input);
|
const unsigned char *input);
|
||||||
|
|
||||||
|
MD5_context * Curl_MD5_init(const MD5_params *md5params);
|
||||||
|
int Curl_MD5_update(MD5_context *context,
|
||||||
|
const unsigned char *data,
|
||||||
|
unsigned int len);
|
||||||
|
int Curl_MD5_final(MD5_context *context, unsigned char *result);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* HEADER_CURL_MD5_H */
|
#endif /* HEADER_CURL_MD5_H */
|
||||||
|
@@ -63,6 +63,11 @@
|
|||||||
# define DESKEY(x) &x
|
# define DESKEY(x) &x
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
|
||||||
|
# include <nettle/des.h>
|
||||||
|
# include <nettle/md4.h>
|
||||||
|
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
|
|
||||||
# include <gcrypt.h>
|
# include <gcrypt.h>
|
||||||
@@ -133,7 +138,17 @@ static void extend_key_56_to_64(const unsigned char *key_56, char *key)
|
|||||||
key[7] = (unsigned char) ((key_56[6] << 1) & 0xFF);
|
key[7] = (unsigned char) ((key_56[6] << 1) & 0xFF);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(USE_GNUTLS)
|
#if defined(USE_GNUTLS_NETTLE)
|
||||||
|
|
||||||
|
static void setup_des_key(const unsigned char *key_56,
|
||||||
|
struct des_ctx *des)
|
||||||
|
{
|
||||||
|
char key[8];
|
||||||
|
extend_key_56_to_64(key_56, key);
|
||||||
|
des_set_key(des, (const uint8_t*)key);
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(USE_GNUTLS)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Turns a 56 bit key into the 64 bit, odd parity key and sets the key.
|
* Turns a 56 bit key into the 64 bit, odd parity key and sets the key.
|
||||||
@@ -233,6 +248,14 @@ void Curl_ntlm_core_lm_resp(const unsigned char *keys,
|
|||||||
setup_des_key(keys + 14, DESKEY(ks));
|
setup_des_key(keys + 14, DESKEY(ks));
|
||||||
DES_ecb_encrypt((DES_cblock*) plaintext, (DES_cblock*) (results + 16),
|
DES_ecb_encrypt((DES_cblock*) plaintext, (DES_cblock*) (results + 16),
|
||||||
DESKEY(ks), DES_ENCRYPT);
|
DESKEY(ks), DES_ENCRYPT);
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
struct des_ctx des;
|
||||||
|
setup_des_key(keys, &des);
|
||||||
|
des_encrypt(&des, 8, results, plaintext);
|
||||||
|
setup_des_key(keys + 7, &des);
|
||||||
|
des_encrypt(&des, 8, results + 8, plaintext);
|
||||||
|
setup_des_key(keys + 14, &des);
|
||||||
|
des_encrypt(&des, 8, results + 16, plaintext);
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
gcry_cipher_hd_t des;
|
gcry_cipher_hd_t des;
|
||||||
|
|
||||||
@@ -295,6 +318,12 @@ void Curl_ntlm_core_mk_lm_hash(struct SessionHandle *data,
|
|||||||
setup_des_key(pw + 7, DESKEY(ks));
|
setup_des_key(pw + 7, DESKEY(ks));
|
||||||
DES_ecb_encrypt((DES_cblock *)magic, (DES_cblock *)(lmbuffer + 8),
|
DES_ecb_encrypt((DES_cblock *)magic, (DES_cblock *)(lmbuffer + 8),
|
||||||
DESKEY(ks), DES_ENCRYPT);
|
DESKEY(ks), DES_ENCRYPT);
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
struct des_ctx des;
|
||||||
|
setup_des_key(pw, &des);
|
||||||
|
des_encrypt(&des, 8, lmbuffer, magic);
|
||||||
|
setup_des_key(pw + 7, &des);
|
||||||
|
des_encrypt(&des, 8, lmbuffer + 8, magic);
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
gcry_cipher_hd_t des;
|
gcry_cipher_hd_t des;
|
||||||
|
|
||||||
@@ -357,6 +386,11 @@ CURLcode Curl_ntlm_core_mk_nt_hash(struct SessionHandle *data,
|
|||||||
MD4_Init(&MD4pw);
|
MD4_Init(&MD4pw);
|
||||||
MD4_Update(&MD4pw, pw, 2 * len);
|
MD4_Update(&MD4pw, pw, 2 * len);
|
||||||
MD4_Final(ntbuffer, &MD4pw);
|
MD4_Final(ntbuffer, &MD4pw);
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
struct md4_ctx MD4pw;
|
||||||
|
md4_init(&MD4pw);
|
||||||
|
md4_update(&MD4pw, (unsigned int)(2 * len), pw);
|
||||||
|
md4_digest(&MD4pw, MD4_DIGEST_SIZE, ntbuffer);
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
gcry_md_hd_t MD4pw;
|
gcry_md_hd_t MD4pw;
|
||||||
gcry_md_open(&MD4pw, GCRY_MD_MD4, 0);
|
gcry_md_open(&MD4pw, GCRY_MD_MD4, 0);
|
||||||
|
@@ -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
|
||||||
@@ -54,6 +54,13 @@
|
|||||||
# endif
|
# endif
|
||||||
# include "ssluse.h"
|
# include "ssluse.h"
|
||||||
|
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
|
||||||
|
# include <nettle/md5.h>
|
||||||
|
# include <gnutls/gnutls.h>
|
||||||
|
# include <gnutls/crypto.h>
|
||||||
|
# define MD5_DIGEST_LENGTH 16
|
||||||
|
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
|
|
||||||
# include <gcrypt.h>
|
# include <gcrypt.h>
|
||||||
@@ -688,7 +695,7 @@ CURLcode Curl_ntlm_create_type3_message(struct SessionHandle *data,
|
|||||||
/* Get the machine's un-qualified host name as NTLM doesn't like the fully
|
/* Get the machine's un-qualified host name as NTLM doesn't like the fully
|
||||||
qualified domain name */
|
qualified domain name */
|
||||||
if(Curl_gethostname(host, sizeof(host))) {
|
if(Curl_gethostname(host, sizeof(host))) {
|
||||||
infof(data, "gethostname() failed, continuing without!");
|
infof(data, "gethostname() failed, continuing without!\n");
|
||||||
hostlen = 0;
|
hostlen = 0;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@@ -714,6 +721,9 @@ CURLcode Curl_ntlm_create_type3_message(struct SessionHandle *data,
|
|||||||
MD5_CTX MD5pw;
|
MD5_CTX MD5pw;
|
||||||
Curl_ossl_seed(data); /* Initiate the seed if not already done */
|
Curl_ossl_seed(data); /* Initiate the seed if not already done */
|
||||||
RAND_bytes(entropy, 8);
|
RAND_bytes(entropy, 8);
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
struct md5_ctx MD5pw;
|
||||||
|
gnutls_rnd(GNUTLS_RND_RANDOM, entropy, 8);
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
gcry_md_hd_t MD5pw;
|
gcry_md_hd_t MD5pw;
|
||||||
Curl_gtls_seed(data); /* Initiate the seed if not already done */
|
Curl_gtls_seed(data); /* Initiate the seed if not already done */
|
||||||
@@ -739,6 +749,10 @@ CURLcode Curl_ntlm_create_type3_message(struct SessionHandle *data,
|
|||||||
MD5_Init(&MD5pw);
|
MD5_Init(&MD5pw);
|
||||||
MD5_Update(&MD5pw, tmp, 16);
|
MD5_Update(&MD5pw, tmp, 16);
|
||||||
MD5_Final(md5sum, &MD5pw);
|
MD5_Final(md5sum, &MD5pw);
|
||||||
|
#elif defined(USE_GNUTLS_NETTLE)
|
||||||
|
md5_init(&MD5pw);
|
||||||
|
md5_update(&MD5pw, 16, tmp);
|
||||||
|
md5_digest(&MD5pw, 16, md5sum);
|
||||||
#elif defined(USE_GNUTLS)
|
#elif defined(USE_GNUTLS)
|
||||||
gcry_md_open(&MD5pw, GCRY_MD_MD5, 0);
|
gcry_md_open(&MD5pw, GCRY_MD_MD5, 0);
|
||||||
gcry_md_write(MD5pw, tmp, MD5_DIGEST_LENGTH);
|
gcry_md_write(MD5pw, tmp, MD5_DIGEST_LENGTH);
|
||||||
|
@@ -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
|
||||||
@@ -258,7 +258,7 @@ cyassl_connect_step2(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
conssl->connecting_state = ssl_connect_3;
|
conssl->connecting_state = ssl_connect_3;
|
||||||
infof(data, "SSL connected");
|
infof(data, "SSL connected\n");
|
||||||
|
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -404,9 +404,10 @@ size_t Curl_cyassl_version(char *buffer, size_t size)
|
|||||||
|
|
||||||
int Curl_cyassl_init(void)
|
int Curl_cyassl_init(void)
|
||||||
{
|
{
|
||||||
InitCyaSSL();
|
if(CyaSSL_Init() == 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
return 1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@@ -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
|
||||||
@@ -98,7 +98,7 @@ const struct Curl_handler Curl_handler_dict = {
|
|||||||
ZERO_NULL, /* readwrite */
|
ZERO_NULL, /* readwrite */
|
||||||
PORT_DICT, /* defport */
|
PORT_DICT, /* defport */
|
||||||
CURLPROTO_DICT, /* protocol */
|
CURLPROTO_DICT, /* protocol */
|
||||||
PROTOPT_NONE /* flags */
|
PROTOPT_NONE | PROTOPT_NOURLQUERY /* flags */
|
||||||
};
|
};
|
||||||
|
|
||||||
static char *unescape_word(struct SessionHandle *data, const char *inputbuff)
|
static char *unescape_word(struct SessionHandle *data, const char *inputbuff)
|
||||||
@@ -178,7 +178,7 @@ static CURLcode dict_do(struct connectdata *conn, bool *done)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if((word == NULL) || (*word == (char)0)) {
|
if((word == NULL) || (*word == (char)0)) {
|
||||||
infof(data, "lookup word is missing");
|
infof(data, "lookup word is missing\n");
|
||||||
word=(char *)"default";
|
word=(char *)"default";
|
||||||
}
|
}
|
||||||
if((database == NULL) || (*database == (char)0)) {
|
if((database == NULL) || (*database == (char)0)) {
|
||||||
@@ -232,7 +232,7 @@ static CURLcode dict_do(struct connectdata *conn, bool *done)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if((word == NULL) || (*word == (char)0)) {
|
if((word == NULL) || (*word == (char)0)) {
|
||||||
infof(data, "lookup word is missing");
|
infof(data, "lookup word is missing\n");
|
||||||
word=(char *)"default";
|
word=(char *)"default";
|
||||||
}
|
}
|
||||||
if((database == NULL) || (*database == (char)0)) {
|
if((database == NULL) || (*database == (char)0)) {
|
||||||
|
11
lib/easy.c
11
lib/easy.c
@@ -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
|
||||||
@@ -66,6 +66,7 @@
|
|||||||
#include "curl_ntlm.h"
|
#include "curl_ntlm.h"
|
||||||
#include "connect.h" /* for Curl_getconnectinfo */
|
#include "connect.h" /* for Curl_getconnectinfo */
|
||||||
#include "slist.h"
|
#include "slist.h"
|
||||||
|
#include "amigaos.h"
|
||||||
#include "curl_rand.h"
|
#include "curl_rand.h"
|
||||||
#include "non-ascii.h"
|
#include "non-ascii.h"
|
||||||
#include "warnless.h"
|
#include "warnless.h"
|
||||||
@@ -238,8 +239,8 @@ CURLcode curl_global_init(long flags)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __AMIGA__
|
#ifdef __AMIGA__
|
||||||
if(!amiga_init()) {
|
if(!Curl_amiga_init()) {
|
||||||
DEBUGF(fprintf(stderr, "Error: amiga_init failed\n"));
|
DEBUGF(fprintf(stderr, "Error: Curl_amiga_init failed\n"));
|
||||||
return CURLE_FAILED_INIT;
|
return CURLE_FAILED_INIT;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@@ -328,9 +329,7 @@ void curl_global_cleanup(void)
|
|||||||
if(init_flags & CURL_GLOBAL_WIN32)
|
if(init_flags & CURL_GLOBAL_WIN32)
|
||||||
win32_cleanup();
|
win32_cleanup();
|
||||||
|
|
||||||
#ifdef __AMIGA__
|
Curl_amiga_cleanup();
|
||||||
amiga_cleanup();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(USE_LIBSSH2) && defined(HAVE_LIBSSH2_EXIT)
|
#if defined(USE_LIBSSH2) && defined(HAVE_LIBSSH2_EXIT)
|
||||||
(void)libssh2_exit();
|
(void)libssh2_exit();
|
||||||
|
63
lib/escape.c
63
lib/escape.c
@@ -31,6 +31,7 @@
|
|||||||
#include "urldata.h"
|
#include "urldata.h"
|
||||||
#include "warnless.h"
|
#include "warnless.h"
|
||||||
#include "non-ascii.h"
|
#include "non-ascii.h"
|
||||||
|
#include "escape.h"
|
||||||
|
|
||||||
#define _MPRINTF_REPLACE /* use our functions only */
|
#define _MPRINTF_REPLACE /* use our functions only */
|
||||||
#include <curl/mprintf.h>
|
#include <curl/mprintf.h>
|
||||||
@@ -84,7 +85,7 @@ char *curl_easy_escape(CURL *handle, const char *string, int inlength)
|
|||||||
char *testing_ptr = NULL;
|
char *testing_ptr = NULL;
|
||||||
unsigned char in; /* we need to treat the characters unsigned */
|
unsigned char in; /* we need to treat the characters unsigned */
|
||||||
size_t newlen = alloc;
|
size_t newlen = alloc;
|
||||||
int strindex=0;
|
size_t strindex=0;
|
||||||
size_t length;
|
size_t length;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
@@ -132,23 +133,29 @@ char *curl_easy_escape(CURL *handle, const char *string, int inlength)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Unescapes the given URL escaped string of given length. Returns a
|
* Curl_urldecode() URL decodes the given string.
|
||||||
* pointer to a malloced string with length given in *olen.
|
*
|
||||||
* If length == 0, the length is assumed to be strlen(string).
|
* Optionally detects control characters (byte codes lower than 32) in the
|
||||||
* If olen == NULL, no output length is stored.
|
* data and rejects such data.
|
||||||
|
*
|
||||||
|
* Returns a pointer to a malloced string in *ostring with length given in
|
||||||
|
* *olen. If length == 0, the length is assumed to be strlen(string).
|
||||||
|
*
|
||||||
*/
|
*/
|
||||||
char *curl_easy_unescape(CURL *handle, const char *string, int length,
|
CURLcode Curl_urldecode(struct SessionHandle *data,
|
||||||
int *olen)
|
const char *string, size_t length,
|
||||||
|
char **ostring, size_t *olen,
|
||||||
|
bool reject_ctrl)
|
||||||
{
|
{
|
||||||
int alloc = (length?length:(int)strlen(string))+1;
|
size_t alloc = (length?length:strlen(string))+1;
|
||||||
char *ns = malloc(alloc);
|
char *ns = malloc(alloc);
|
||||||
unsigned char in;
|
unsigned char in;
|
||||||
int strindex=0;
|
size_t strindex=0;
|
||||||
unsigned long hex;
|
unsigned long hex;
|
||||||
CURLcode res;
|
CURLcode res;
|
||||||
|
|
||||||
if(!ns)
|
if(!ns)
|
||||||
return NULL;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
while(--alloc > 0) {
|
while(--alloc > 0) {
|
||||||
in = *string;
|
in = *string;
|
||||||
@@ -164,16 +171,20 @@ char *curl_easy_unescape(CURL *handle, const char *string, int length,
|
|||||||
|
|
||||||
in = curlx_ultouc(hex); /* this long is never bigger than 255 anyway */
|
in = curlx_ultouc(hex); /* this long is never bigger than 255 anyway */
|
||||||
|
|
||||||
res = Curl_convert_from_network(handle, &in, 1);
|
res = Curl_convert_from_network(data, &in, 1);
|
||||||
if(res) {
|
if(res) {
|
||||||
/* Curl_convert_from_network calls failf if unsuccessful */
|
/* Curl_convert_from_network calls failf if unsuccessful */
|
||||||
free(ns);
|
free(ns);
|
||||||
return NULL;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
string+=2;
|
string+=2;
|
||||||
alloc-=2;
|
alloc-=2;
|
||||||
}
|
}
|
||||||
|
if(reject_ctrl && (in < 0x20)) {
|
||||||
|
free(ns);
|
||||||
|
return CURLE_URL_MALFORMAT;
|
||||||
|
}
|
||||||
|
|
||||||
ns[strindex++] = in;
|
ns[strindex++] = in;
|
||||||
string++;
|
string++;
|
||||||
@@ -183,7 +194,33 @@ char *curl_easy_unescape(CURL *handle, const char *string, int length,
|
|||||||
if(olen)
|
if(olen)
|
||||||
/* store output size */
|
/* store output size */
|
||||||
*olen = strindex;
|
*olen = strindex;
|
||||||
return ns;
|
|
||||||
|
if(ostring)
|
||||||
|
/* store output string */
|
||||||
|
*ostring = ns;
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Unescapes the given URL escaped string of given length. Returns a
|
||||||
|
* pointer to a malloced string with length given in *olen.
|
||||||
|
* If length == 0, the length is assumed to be strlen(string).
|
||||||
|
* If olen == NULL, no output length is stored.
|
||||||
|
*/
|
||||||
|
char *curl_easy_unescape(CURL *handle, const char *string, int length,
|
||||||
|
int *olen)
|
||||||
|
{
|
||||||
|
char *str = NULL;
|
||||||
|
size_t inputlen = length;
|
||||||
|
size_t outputlen;
|
||||||
|
CURLcode res = Curl_urldecode(handle, string, inputlen, &str, &outputlen,
|
||||||
|
FALSE);
|
||||||
|
if(res)
|
||||||
|
return NULL;
|
||||||
|
if(olen)
|
||||||
|
*olen = curlx_uztosi(outputlen);
|
||||||
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* For operating systems/environments that use different malloc/free
|
/* For operating systems/environments that use different malloc/free
|
||||||
|
10
lib/escape.h
10
lib/escape.h
@@ -1,5 +1,5 @@
|
|||||||
#ifndef __ESCAPE_H
|
#ifndef HEADER_CURL_ESCAPE_H
|
||||||
#define __ESCAPE_H
|
#define HEADER_CURL_ESCAPE_H
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
* _ _ ____ _
|
* _ _ ____ _
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
* | (__| |_| | _ <| |___
|
* | (__| |_| | _ <| |___
|
||||||
* \___|\___/|_| \_\_____|
|
* \___|\___/|_| \_\_____|
|
||||||
*
|
*
|
||||||
* Copyright (C) 1998 - 2006, Daniel Stenberg, <daniel@haxx.se>, et al.
|
* Copyright (C) 1998 - 2011, 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
|
||||||
@@ -25,5 +25,9 @@
|
|||||||
/* Escape and unescape URL encoding in strings. The functions return a new
|
/* Escape and unescape URL encoding in strings. The functions return a new
|
||||||
* allocated string or NULL if an error occurred. */
|
* allocated string or NULL if an error occurred. */
|
||||||
|
|
||||||
|
CURLcode Curl_urldecode(struct SessionHandle *data,
|
||||||
|
const char *string, size_t length,
|
||||||
|
char **ostring, size_t *olen,
|
||||||
|
bool reject_crlf);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -119,7 +119,7 @@ const struct Curl_handler Curl_handler_file = {
|
|||||||
ZERO_NULL, /* readwrite */
|
ZERO_NULL, /* readwrite */
|
||||||
0, /* defport */
|
0, /* defport */
|
||||||
CURLPROTO_FILE, /* protocol */
|
CURLPROTO_FILE, /* protocol */
|
||||||
PROTOPT_NONETWORK /* flags */
|
PROTOPT_NONETWORK | PROTOPT_NOURLQUERY /* flags */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
176
lib/formdata.c
176
lib/formdata.c
@@ -156,8 +156,6 @@ static FormInfo * AddFormInfo(char *value,
|
|||||||
/* then move the original 'more' to point to ourselves */
|
/* then move the original 'more' to point to ourselves */
|
||||||
parent_form_info->more = form_info;
|
parent_form_info->more = form_info;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
return form_info;
|
return form_info;
|
||||||
}
|
}
|
||||||
@@ -458,9 +456,21 @@ CURLFORMcode FormAdd(struct curl_httppost **httppost,
|
|||||||
if(current_form->value) {
|
if(current_form->value) {
|
||||||
if(current_form->flags & HTTPPOST_FILENAME) {
|
if(current_form->flags & HTTPPOST_FILENAME) {
|
||||||
if(filename) {
|
if(filename) {
|
||||||
if((current_form = AddFormInfo(strdup(filename),
|
char *fname = strdup(filename);
|
||||||
NULL, current_form)) == NULL)
|
if(!fname)
|
||||||
return_value = CURL_FORMADD_MEMORY;
|
return_value = CURL_FORMADD_MEMORY;
|
||||||
|
else {
|
||||||
|
form = AddFormInfo(fname, NULL, current_form);
|
||||||
|
if(!form) {
|
||||||
|
Curl_safefree(fname);
|
||||||
|
return_value = CURL_FORMADD_MEMORY;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
form->value_alloc = TRUE;
|
||||||
|
current_form = form;
|
||||||
|
form = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return_value = CURL_FORMADD_NULL;
|
return_value = CURL_FORMADD_NULL;
|
||||||
@@ -535,10 +545,21 @@ CURLFORMcode FormAdd(struct curl_httppost **httppost,
|
|||||||
if(current_form->contenttype) {
|
if(current_form->contenttype) {
|
||||||
if(current_form->flags & HTTPPOST_FILENAME) {
|
if(current_form->flags & HTTPPOST_FILENAME) {
|
||||||
if(contenttype) {
|
if(contenttype) {
|
||||||
if((current_form = AddFormInfo(NULL,
|
char *type = strdup(contenttype);
|
||||||
strdup(contenttype),
|
if(!type)
|
||||||
current_form)) == NULL)
|
|
||||||
return_value = CURL_FORMADD_MEMORY;
|
return_value = CURL_FORMADD_MEMORY;
|
||||||
|
else {
|
||||||
|
form = AddFormInfo(NULL, type, current_form);
|
||||||
|
if(!form) {
|
||||||
|
Curl_safefree(type);
|
||||||
|
return_value = CURL_FORMADD_MEMORY;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
form->contenttype_alloc = TRUE;
|
||||||
|
current_form = form;
|
||||||
|
form = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return_value = CURL_FORMADD_NULL;
|
return_value = CURL_FORMADD_NULL;
|
||||||
@@ -596,6 +617,30 @@ CURLFORMcode FormAdd(struct curl_httppost **httppost,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(CURL_FORMADD_OK != return_value) {
|
||||||
|
/* On error, free allocated fields for all nodes of the FormInfo linked
|
||||||
|
list without deallocating nodes. List nodes are deallocated later on */
|
||||||
|
FormInfo *ptr;
|
||||||
|
for(ptr = first_form; ptr != NULL; ptr = ptr->more) {
|
||||||
|
if(ptr->name_alloc) {
|
||||||
|
Curl_safefree(ptr->name);
|
||||||
|
ptr->name_alloc = FALSE;
|
||||||
|
}
|
||||||
|
if(ptr->value_alloc) {
|
||||||
|
Curl_safefree(ptr->value);
|
||||||
|
ptr->value_alloc = FALSE;
|
||||||
|
}
|
||||||
|
if(ptr->contenttype_alloc) {
|
||||||
|
Curl_safefree(ptr->contenttype);
|
||||||
|
ptr->contenttype_alloc = FALSE;
|
||||||
|
}
|
||||||
|
if(ptr->showfilename_alloc) {
|
||||||
|
Curl_safefree(ptr->showfilename);
|
||||||
|
ptr->showfilename_alloc = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if(CURL_FORMADD_OK == return_value) {
|
if(CURL_FORMADD_OK == return_value) {
|
||||||
/* go through the list, check for completeness and if everything is
|
/* go through the list, check for completeness and if everything is
|
||||||
* alright add the HttpPost item otherwise set return_value accordingly */
|
* alright add the HttpPost item otherwise set return_value accordingly */
|
||||||
@@ -675,32 +720,39 @@ CURLFORMcode FormAdd(struct curl_httppost **httppost,
|
|||||||
prevtype = form->contenttype;
|
prevtype = form->contenttype;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
if(CURL_FORMADD_OK != return_value) {
|
||||||
|
/* On error, free allocated fields for nodes of the FormInfo linked
|
||||||
if(return_value) {
|
list which are not already owned by the httppost linked list
|
||||||
/* we return on error, free possibly allocated fields */
|
without deallocating nodes. List nodes are deallocated later on */
|
||||||
if(!form)
|
FormInfo *ptr;
|
||||||
form = current_form;
|
for(ptr = form; ptr != NULL; ptr = ptr->more) {
|
||||||
if(form) {
|
if(ptr->name_alloc) {
|
||||||
if(form->name_alloc)
|
Curl_safefree(ptr->name);
|
||||||
free(form->name);
|
ptr->name_alloc = FALSE;
|
||||||
if(form->value_alloc)
|
}
|
||||||
free(form->value);
|
if(ptr->value_alloc) {
|
||||||
if(form->contenttype_alloc)
|
Curl_safefree(ptr->value);
|
||||||
free(form->contenttype);
|
ptr->value_alloc = FALSE;
|
||||||
if(form->showfilename_alloc)
|
}
|
||||||
free(form->showfilename);
|
if(ptr->contenttype_alloc) {
|
||||||
|
Curl_safefree(ptr->contenttype);
|
||||||
|
ptr->contenttype_alloc = FALSE;
|
||||||
|
}
|
||||||
|
if(ptr->showfilename_alloc) {
|
||||||
|
Curl_safefree(ptr->showfilename);
|
||||||
|
ptr->showfilename_alloc = FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* always delete the allocated memory before returning */
|
/* Always deallocate FormInfo linked list nodes without touching node
|
||||||
form = first_form;
|
fields given that these have either been deallocated or are owned
|
||||||
while(form != NULL) {
|
now by the httppost linked list */
|
||||||
FormInfo *delete_form;
|
while(first_form) {
|
||||||
|
FormInfo *ptr = first_form->more;
|
||||||
delete_form = form;
|
Curl_safefree(first_form);
|
||||||
form = form->more;
|
first_form = ptr;
|
||||||
free (delete_form);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return return_value;
|
return return_value;
|
||||||
@@ -996,12 +1048,12 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
struct curl_httppost *file;
|
struct curl_httppost *file;
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
|
|
||||||
curl_off_t size=0; /* support potentially ENORMOUS formposts */
|
curl_off_t size = 0; /* support potentially ENORMOUS formposts */
|
||||||
char *boundary;
|
char *boundary;
|
||||||
char *fileboundary=NULL;
|
char *fileboundary = NULL;
|
||||||
struct curl_slist* curList;
|
struct curl_slist* curList;
|
||||||
|
|
||||||
*finalform=NULL; /* default form is empty */
|
*finalform = NULL; /* default form is empty */
|
||||||
|
|
||||||
if(!post)
|
if(!post)
|
||||||
return result; /* no input => no output! */
|
return result; /* no input => no output! */
|
||||||
@@ -1018,7 +1070,7 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
boundary);
|
boundary);
|
||||||
|
|
||||||
if(result) {
|
if(result) {
|
||||||
free(boundary);
|
Curl_safefree(boundary);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
/* we DO NOT include that line in the total size of the POST, since it'll be
|
/* we DO NOT include that line in the total size of the POST, since it'll be
|
||||||
@@ -1061,7 +1113,12 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
/* If used, this is a link to more file names, we must then do
|
/* If used, this is a link to more file names, we must then do
|
||||||
the magic to include several files with the same field name */
|
the magic to include several files with the same field name */
|
||||||
|
|
||||||
|
Curl_safefree(fileboundary);
|
||||||
fileboundary = Curl_FormBoundary();
|
fileboundary = Curl_FormBoundary();
|
||||||
|
if(!fileboundary) {
|
||||||
|
result = CURLE_OUT_OF_MEMORY;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
result = AddFormDataf(&form, &size,
|
result = AddFormDataf(&form, &size,
|
||||||
"\r\nContent-Type: multipart/mixed,"
|
"\r\nContent-Type: multipart/mixed,"
|
||||||
@@ -1081,13 +1138,12 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
|
|
||||||
if(post->more) {
|
if(post->more) {
|
||||||
/* if multiple-file */
|
/* if multiple-file */
|
||||||
char *filebasename= NULL;
|
char *filebasename = NULL;
|
||||||
if(!file->showfilename) {
|
if(!file->showfilename) {
|
||||||
filebasename = strippath(file->contents);
|
filebasename = strippath(file->contents);
|
||||||
if(!filebasename) {
|
if(!filebasename) {
|
||||||
Curl_formclean(&firstform);
|
result = CURLE_OUT_OF_MEMORY;
|
||||||
free(boundary);
|
break;
|
||||||
return CURLE_OUT_OF_MEMORY;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1097,8 +1153,7 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
fileboundary,
|
fileboundary,
|
||||||
(file->showfilename?file->showfilename:
|
(file->showfilename?file->showfilename:
|
||||||
filebasename));
|
filebasename));
|
||||||
if(filebasename)
|
Curl_safefree(filebasename);
|
||||||
free(filebasename);
|
|
||||||
if(result)
|
if(result)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@@ -1115,8 +1170,7 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
"; filename=\"%s\"",
|
"; filename=\"%s\"",
|
||||||
(post->showfilename?post->showfilename:
|
(post->showfilename?post->showfilename:
|
||||||
filebasename));
|
filebasename));
|
||||||
if(filebasename)
|
Curl_safefree(filebasename);
|
||||||
free(filebasename);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(result)
|
if(result)
|
||||||
@@ -1140,11 +1194,8 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
break;
|
break;
|
||||||
curList = curList->next;
|
curList = curList->next;
|
||||||
}
|
}
|
||||||
if(result) {
|
if(result)
|
||||||
Curl_formclean(&firstform);
|
break;
|
||||||
free(boundary);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
result = AddFormDataf(&form, &size, "\r\n\r\n");
|
result = AddFormDataf(&form, &size, "\r\n\r\n");
|
||||||
if(result)
|
if(result)
|
||||||
@@ -1166,7 +1217,7 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
|
|
||||||
if(fileread) {
|
if(fileread) {
|
||||||
if(fileread != stdin) {
|
if(fileread != stdin) {
|
||||||
/* close the file again */
|
/* close the file */
|
||||||
fclose(fileread);
|
fclose(fileread);
|
||||||
/* add the file name only - for later reading from this */
|
/* add the file name only - for later reading from this */
|
||||||
result = AddFormData(&form, FORM_FILE, file->contents, 0, &size);
|
result = AddFormData(&form, FORM_FILE, file->contents, 0, &size);
|
||||||
@@ -1210,11 +1261,8 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
file = file->more;
|
file = file->more;
|
||||||
} while(file && !result); /* for each specified file for this field */
|
} while(file && !result); /* for each specified file for this field */
|
||||||
|
|
||||||
if(result) {
|
if(result)
|
||||||
Curl_formclean(&firstform);
|
break;
|
||||||
free(boundary);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(post->more) {
|
if(post->more) {
|
||||||
/* this was a multiple-file inclusion, make a termination file
|
/* this was a multiple-file inclusion, make a termination file
|
||||||
@@ -1222,33 +1270,31 @@ CURLcode Curl_getformdata(struct SessionHandle *data,
|
|||||||
result = AddFormDataf(&form, &size,
|
result = AddFormDataf(&form, &size,
|
||||||
"\r\n--%s--",
|
"\r\n--%s--",
|
||||||
fileboundary);
|
fileboundary);
|
||||||
free(fileboundary);
|
|
||||||
if(result)
|
if(result)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
} while((post = post->next) != NULL); /* for each field */
|
} while((post = post->next) != NULL); /* for each field */
|
||||||
if(result) {
|
|
||||||
Curl_formclean(&firstform);
|
|
||||||
free(boundary);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* end-boundary for everything */
|
/* end-boundary for everything */
|
||||||
result = AddFormDataf(&form, &size,
|
if(CURLE_OK == result)
|
||||||
"\r\n--%s--\r\n",
|
result = AddFormDataf(&form, &size,
|
||||||
boundary);
|
"\r\n--%s--\r\n",
|
||||||
|
boundary);
|
||||||
|
|
||||||
if(result) {
|
if(result) {
|
||||||
Curl_formclean(&firstform);
|
Curl_formclean(&firstform);
|
||||||
free(boundary);
|
Curl_safefree(fileboundary);
|
||||||
|
Curl_safefree(boundary);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
*sizep = size;
|
*sizep = size;
|
||||||
|
|
||||||
free(boundary);
|
Curl_safefree(fileboundary);
|
||||||
|
Curl_safefree(boundary);
|
||||||
|
|
||||||
*finalform=firstform;
|
*finalform = firstform;
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
532
lib/ftp.c
532
lib/ftp.c
@@ -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
|
||||||
@@ -108,6 +108,8 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Local API functions */
|
/* Local API functions */
|
||||||
|
static void state(struct connectdata *conn,
|
||||||
|
ftpstate newstate);
|
||||||
static CURLcode ftp_sendquote(struct connectdata *conn,
|
static CURLcode ftp_sendquote(struct connectdata *conn,
|
||||||
struct curl_slist *quote);
|
struct curl_slist *quote);
|
||||||
static CURLcode ftp_quit(struct connectdata *conn);
|
static CURLcode ftp_quit(struct connectdata *conn);
|
||||||
@@ -132,7 +134,7 @@ static CURLcode ftp_done(struct connectdata *conn,
|
|||||||
CURLcode, bool premature);
|
CURLcode, bool premature);
|
||||||
static CURLcode ftp_connect(struct connectdata *conn, bool *done);
|
static CURLcode ftp_connect(struct connectdata *conn, bool *done);
|
||||||
static CURLcode ftp_disconnect(struct connectdata *conn, bool dead_connection);
|
static CURLcode ftp_disconnect(struct connectdata *conn, bool dead_connection);
|
||||||
static CURLcode ftp_nextconnect(struct connectdata *conn);
|
static CURLcode ftp_do_more(struct connectdata *conn, bool *completed);
|
||||||
static CURLcode ftp_multi_statemach(struct connectdata *conn, bool *done);
|
static CURLcode ftp_multi_statemach(struct connectdata *conn, bool *done);
|
||||||
static int ftp_getsock(struct connectdata *conn, curl_socket_t *socks,
|
static int ftp_getsock(struct connectdata *conn, curl_socket_t *socks,
|
||||||
int numsocks);
|
int numsocks);
|
||||||
@@ -150,6 +152,11 @@ static void wc_data_dtor(void *ptr);
|
|||||||
static CURLcode ftp_state_post_retr_size(struct connectdata *conn,
|
static CURLcode ftp_state_post_retr_size(struct connectdata *conn,
|
||||||
curl_off_t filesize);
|
curl_off_t filesize);
|
||||||
|
|
||||||
|
static CURLcode ftp_readresp(curl_socket_t sockfd,
|
||||||
|
struct pingpong *pp,
|
||||||
|
int *ftpcode,
|
||||||
|
size_t *size);
|
||||||
|
|
||||||
/* easy-to-use macro: */
|
/* easy-to-use macro: */
|
||||||
#define FTPSENDF(x,y,z) if((result = Curl_ftpsendf(x,y,z)) != CURLE_OK) \
|
#define FTPSENDF(x,y,z) if((result = Curl_ftpsendf(x,y,z)) != CURLE_OK) \
|
||||||
return result
|
return result
|
||||||
@@ -166,7 +173,7 @@ const struct Curl_handler Curl_handler_ftp = {
|
|||||||
ftp_setup_connection, /* setup_connection */
|
ftp_setup_connection, /* setup_connection */
|
||||||
ftp_do, /* do_it */
|
ftp_do, /* do_it */
|
||||||
ftp_done, /* done */
|
ftp_done, /* done */
|
||||||
ftp_nextconnect, /* do_more */
|
ftp_do_more, /* do_more */
|
||||||
ftp_connect, /* connect_it */
|
ftp_connect, /* connect_it */
|
||||||
ftp_multi_statemach, /* connecting */
|
ftp_multi_statemach, /* connecting */
|
||||||
ftp_doing, /* doing */
|
ftp_doing, /* doing */
|
||||||
@@ -178,7 +185,8 @@ const struct Curl_handler Curl_handler_ftp = {
|
|||||||
ZERO_NULL, /* readwrite */
|
ZERO_NULL, /* readwrite */
|
||||||
PORT_FTP, /* defport */
|
PORT_FTP, /* defport */
|
||||||
CURLPROTO_FTP, /* protocol */
|
CURLPROTO_FTP, /* protocol */
|
||||||
PROTOPT_DUAL | PROTOPT_CLOSEACTION | PROTOPT_NEEDSPWD /* flags */
|
PROTOPT_DUAL | PROTOPT_CLOSEACTION | PROTOPT_NEEDSPWD
|
||||||
|
| PROTOPT_NOURLQUERY /* flags */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -192,7 +200,7 @@ const struct Curl_handler Curl_handler_ftps = {
|
|||||||
ftp_setup_connection, /* setup_connection */
|
ftp_setup_connection, /* setup_connection */
|
||||||
ftp_do, /* do_it */
|
ftp_do, /* do_it */
|
||||||
ftp_done, /* done */
|
ftp_done, /* done */
|
||||||
ftp_nextconnect, /* do_more */
|
ftp_do_more, /* do_more */
|
||||||
ftp_connect, /* connect_it */
|
ftp_connect, /* connect_it */
|
||||||
ftp_multi_statemach, /* connecting */
|
ftp_multi_statemach, /* connecting */
|
||||||
ftp_doing, /* doing */
|
ftp_doing, /* doing */
|
||||||
@@ -205,7 +213,7 @@ const struct Curl_handler Curl_handler_ftps = {
|
|||||||
PORT_FTPS, /* defport */
|
PORT_FTPS, /* defport */
|
||||||
CURLPROTO_FTP | CURLPROTO_FTPS, /* protocol */
|
CURLPROTO_FTP | CURLPROTO_FTPS, /* protocol */
|
||||||
PROTOPT_SSL | PROTOPT_DUAL | PROTOPT_CLOSEACTION |
|
PROTOPT_SSL | PROTOPT_DUAL | PROTOPT_CLOSEACTION |
|
||||||
PROTOPT_NEEDSPWD /* flags */
|
PROTOPT_NEEDSPWD | PROTOPT_NOURLQUERY /* flags */
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -309,19 +317,16 @@ static bool isBadFtpString(const char *string)
|
|||||||
|
|
||||||
/***********************************************************************
|
/***********************************************************************
|
||||||
*
|
*
|
||||||
* AllowServerConnect()
|
* AcceptServerConnect()
|
||||||
*
|
*
|
||||||
* When we've issue the PORT command, we have told the server to connect
|
* After connection request is received from the server this function is
|
||||||
* to us. This function will sit and wait here until the server has
|
* called to accept the connection and close the listening socket
|
||||||
* connected.
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static CURLcode AllowServerConnect(struct connectdata *conn)
|
static CURLcode AcceptServerConnect(struct connectdata *conn)
|
||||||
{
|
{
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
curl_socket_t sock = conn->sock[SECONDARYSOCKET];
|
curl_socket_t sock = conn->sock[SECONDARYSOCKET];
|
||||||
long timeout_ms;
|
|
||||||
long interval_ms;
|
|
||||||
curl_socket_t s = CURL_SOCKET_BAD;
|
curl_socket_t s = CURL_SOCKET_BAD;
|
||||||
#ifdef ENABLE_IPV6
|
#ifdef ENABLE_IPV6
|
||||||
struct Curl_sockaddr_storage add;
|
struct Curl_sockaddr_storage add;
|
||||||
@@ -330,47 +335,258 @@ static CURLcode AllowServerConnect(struct connectdata *conn)
|
|||||||
#endif
|
#endif
|
||||||
curl_socklen_t size = (curl_socklen_t) sizeof(add);
|
curl_socklen_t size = (curl_socklen_t) sizeof(add);
|
||||||
|
|
||||||
for(;;) {
|
if(0 == getsockname(sock, (struct sockaddr *) &add, &size)) {
|
||||||
timeout_ms = Curl_timeleft(data, NULL, TRUE);
|
size = sizeof(add);
|
||||||
|
|
||||||
if(timeout_ms < 0) {
|
s=accept(sock, (struct sockaddr *) &add, &size);
|
||||||
/* if a timeout was already reached, bail out */
|
}
|
||||||
failf(data, "Timeout while waiting for server connect");
|
Curl_closesocket(conn, sock); /* close the first socket */
|
||||||
return CURLE_OPERATION_TIMEDOUT;
|
|
||||||
|
if(CURL_SOCKET_BAD == s) {
|
||||||
|
failf(data, "Error accept()ing server connect");
|
||||||
|
return CURLE_FTP_PORT_FAILED;
|
||||||
|
}
|
||||||
|
infof(data, "Connection accepted from server\n");
|
||||||
|
|
||||||
|
conn->sock[SECONDARYSOCKET] = s;
|
||||||
|
curlx_nonblock(s, TRUE); /* enable non-blocking */
|
||||||
|
conn->sock_accepted[SECONDARYSOCKET] = TRUE;
|
||||||
|
return CURLE_OK;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ftp_timeleft_accept() returns the amount of milliseconds left allowed for
|
||||||
|
* waiting server to connect. If the value is negative, the timeout time has
|
||||||
|
* already elapsed.
|
||||||
|
*
|
||||||
|
* The start time is stored in progress.t_acceptdata - as set with
|
||||||
|
* Curl_pgrsTime(..., TIMER_STARTACCEPT);
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static long ftp_timeleft_accept(struct SessionHandle *data)
|
||||||
|
{
|
||||||
|
long timeout_ms = DEFAULT_ACCEPT_TIMEOUT;
|
||||||
|
long other;
|
||||||
|
struct timeval now;
|
||||||
|
|
||||||
|
if(data->set.accepttimeout > 0)
|
||||||
|
timeout_ms = data->set.accepttimeout;
|
||||||
|
|
||||||
|
now = Curl_tvnow();
|
||||||
|
|
||||||
|
/* check if the generic timeout possibly is set shorter */
|
||||||
|
other = Curl_timeleft(data, &now, FALSE);
|
||||||
|
if(other && (other < timeout_ms))
|
||||||
|
/* note that this also works fine for when other happens to be negative
|
||||||
|
due to it already having elapsed */
|
||||||
|
timeout_ms = other;
|
||||||
|
else {
|
||||||
|
/* subtract elapsed time */
|
||||||
|
timeout_ms -= Curl_tvdiff(now, data->progress.t_acceptdata);
|
||||||
|
if(!timeout_ms)
|
||||||
|
/* avoid returning 0 as that means no timeout! */
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return timeout_ms;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/***********************************************************************
|
||||||
|
*
|
||||||
|
* ReceivedServerConnect()
|
||||||
|
*
|
||||||
|
* After allowing server to connect to us from data port, this function
|
||||||
|
* checks both data connection for connection establishment and ctrl
|
||||||
|
* connection for a negative response regarding a failure in connecting
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static CURLcode ReceivedServerConnect(struct connectdata* conn, bool* received)
|
||||||
|
{
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
curl_socket_t ctrl_sock = conn->sock[FIRSTSOCKET];
|
||||||
|
curl_socket_t data_sock = conn->sock[SECONDARYSOCKET];
|
||||||
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
|
struct pingpong *pp = &ftpc->pp;
|
||||||
|
int result;
|
||||||
|
long timeout_ms;
|
||||||
|
ssize_t nread;
|
||||||
|
int ftpcode;
|
||||||
|
|
||||||
|
*received = FALSE;
|
||||||
|
|
||||||
|
timeout_ms = ftp_timeleft_accept(data);
|
||||||
|
infof(data, "Checking for server connect\n");
|
||||||
|
if(timeout_ms < 0) {
|
||||||
|
/* if a timeout was already reached, bail out */
|
||||||
|
failf(data, "Accept timeout occurred while waiting server connect");
|
||||||
|
return CURLE_FTP_ACCEPT_TIMEOUT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* First check whether there is a cached response from server */
|
||||||
|
if(pp->cache_size && pp->cache && pp->cache[0] > '3') {
|
||||||
|
/* Data connection could not be established, let's return */
|
||||||
|
infof(data, "There is negative response in cache while serv connect\n");
|
||||||
|
Curl_GetFTPResponse(&nread, conn, &ftpcode);
|
||||||
|
return CURLE_FTP_ACCEPT_FAILED;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = Curl_socket_check(ctrl_sock, data_sock, CURL_SOCKET_BAD, 0);
|
||||||
|
|
||||||
|
/* see if the connection request is already here */
|
||||||
|
switch (result) {
|
||||||
|
case -1: /* error */
|
||||||
|
/* let's die here */
|
||||||
|
failf(data, "Error while waiting for server connect");
|
||||||
|
return CURLE_FTP_ACCEPT_FAILED;
|
||||||
|
case 0: /* Server connect is not received yet */
|
||||||
|
break; /* loop */
|
||||||
|
default:
|
||||||
|
|
||||||
|
if(result & CURL_CSELECT_IN2) {
|
||||||
|
infof(data, "Ready to accept data connection from server\n");
|
||||||
|
*received = TRUE;
|
||||||
|
}
|
||||||
|
else if(result & CURL_CSELECT_IN) {
|
||||||
|
infof(data, "Ctrl conn has data while waiting for data conn\n");
|
||||||
|
Curl_GetFTPResponse(&nread, conn, &ftpcode);
|
||||||
|
|
||||||
|
if(ftpcode/100 > 3)
|
||||||
|
return CURLE_FTP_ACCEPT_FAILED;
|
||||||
|
|
||||||
|
return CURLE_FTP_WEIRD_SERVER_REPLY;
|
||||||
}
|
}
|
||||||
|
|
||||||
interval_ms = 1000; /* use 1 second timeout intervals */
|
break;
|
||||||
if(timeout_ms < interval_ms)
|
} /* switch() */
|
||||||
interval_ms = timeout_ms;
|
|
||||||
|
|
||||||
switch (Curl_socket_ready(sock, CURL_SOCKET_BAD, interval_ms)) {
|
return CURLE_OK;
|
||||||
case -1: /* error */
|
}
|
||||||
/* let's die here */
|
|
||||||
failf(data, "Error while waiting for server connect");
|
|
||||||
return CURLE_FTP_PORT_FAILED;
|
|
||||||
case 0: /* timeout */
|
|
||||||
break; /* loop */
|
|
||||||
default:
|
|
||||||
/* we have received data here */
|
|
||||||
if(0 == getsockname(sock, (struct sockaddr *) &add, &size)) {
|
|
||||||
size = sizeof(add);
|
|
||||||
|
|
||||||
s=accept(sock, (struct sockaddr *) &add, &size);
|
|
||||||
}
|
|
||||||
Curl_closesocket(conn, sock); /* close the first socket */
|
|
||||||
|
|
||||||
if(CURL_SOCKET_BAD == s) {
|
/***********************************************************************
|
||||||
failf(data, "Error accept()ing server connect");
|
*
|
||||||
return CURLE_FTP_PORT_FAILED;
|
* InitiateTransfer()
|
||||||
}
|
*
|
||||||
infof(data, "Connection accepted from server\n");
|
* After connection from server is accepted this function is called to
|
||||||
|
* setup transfer parameters and initiate the data transfer.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static CURLcode InitiateTransfer(struct connectdata *conn)
|
||||||
|
{
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
struct FTP *ftp = data->state.proto.ftp;
|
||||||
|
CURLcode result = CURLE_OK;
|
||||||
|
|
||||||
conn->sock[SECONDARYSOCKET] = s;
|
if(conn->ssl[SECONDARYSOCKET].use) {
|
||||||
curlx_nonblock(s, TRUE); /* enable non-blocking */
|
/* since we only have a plaintext TCP connection here, we must now
|
||||||
return CURLE_OK;
|
* do the TLS stuff */
|
||||||
} /* switch() */
|
infof(data, "Doing the SSL/TLS handshake on the data stream\n");
|
||||||
|
result = Curl_ssl_connect(conn, SECONDARYSOCKET);
|
||||||
|
if(result)
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
/* never reaches this point */
|
|
||||||
|
if(conn->proto.ftpc.state_saved == FTP_STOR) {
|
||||||
|
*(ftp->bytecountp)=0;
|
||||||
|
|
||||||
|
/* When we know we're uploading a specified file, we can get the file
|
||||||
|
size prior to the actual upload. */
|
||||||
|
|
||||||
|
Curl_pgrsSetUploadSize(data, data->set.infilesize);
|
||||||
|
|
||||||
|
/* set the SO_SNDBUF for the secondary socket for those who need it */
|
||||||
|
Curl_sndbufset(conn->sock[SECONDARYSOCKET]);
|
||||||
|
|
||||||
|
Curl_setup_transfer(conn, -1, -1, FALSE, NULL, /* no download */
|
||||||
|
SECONDARYSOCKET, ftp->bytecountp);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* FTP download: */
|
||||||
|
Curl_setup_transfer(conn, SECONDARYSOCKET,
|
||||||
|
conn->proto.ftpc.retr_size_saved, FALSE,
|
||||||
|
ftp->bytecountp, -1, NULL); /* no upload here */
|
||||||
|
}
|
||||||
|
|
||||||
|
conn->proto.ftpc.pp.pending_resp = TRUE; /* expect server response */
|
||||||
|
state(conn, FTP_STOP);
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
/***********************************************************************
|
||||||
|
*
|
||||||
|
* AllowServerConnect()
|
||||||
|
*
|
||||||
|
* When we've issue the PORT command, we have told the server to connect
|
||||||
|
* to us. This function
|
||||||
|
* - will sit and wait here until the server has connected for easy interface
|
||||||
|
* - will check whether data connection is established if so it is accepted
|
||||||
|
* for multi interface
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
static CURLcode AllowServerConnect(struct connectdata *conn, bool *connected)
|
||||||
|
{
|
||||||
|
struct SessionHandle *data = conn->data;
|
||||||
|
long timeout_ms;
|
||||||
|
long interval_ms;
|
||||||
|
CURLcode ret = CURLE_OK;
|
||||||
|
|
||||||
|
*connected = FALSE;
|
||||||
|
infof(data, "Preparing for accepting server on data port\n");
|
||||||
|
|
||||||
|
/* Save the time we start accepting server connect */
|
||||||
|
Curl_pgrsTime(data, TIMER_STARTACCEPT);
|
||||||
|
|
||||||
|
for(;;) {
|
||||||
|
timeout_ms = ftp_timeleft_accept(data);
|
||||||
|
if(timeout_ms < 0) {
|
||||||
|
/* if a timeout was already reached, bail out */
|
||||||
|
failf(data, "Accept timeout occurred while waiting server connect");
|
||||||
|
return CURLE_FTP_ACCEPT_TIMEOUT;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* see if the connection request is already here */
|
||||||
|
ret = ReceivedServerConnect(conn, connected);
|
||||||
|
if(ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
if(*connected) {
|
||||||
|
ret = AcceptServerConnect(conn);
|
||||||
|
if(ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
ret = InitiateTransfer(conn);
|
||||||
|
if(ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
break; /* connection is accepted, break the loop */
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(data->state.used_interface == Curl_if_easy) {
|
||||||
|
interval_ms = 1000;
|
||||||
|
if(timeout_ms < interval_ms)
|
||||||
|
interval_ms = timeout_ms;
|
||||||
|
|
||||||
|
/* sleep for 1 second and then continue */
|
||||||
|
Curl_socket_ready(CURL_SOCKET_BAD, CURL_SOCKET_BAD, interval_ms);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
/* Add timeout to multi handle and break out of the loop */
|
||||||
|
if(ret == CURLE_OK && *connected == FALSE) {
|
||||||
|
if(data->set.accepttimeout > 0)
|
||||||
|
Curl_expire(data, data->set.accepttimeout);
|
||||||
|
else
|
||||||
|
Curl_expire(data, DEFAULT_ACCEPT_TIMEOUT);
|
||||||
|
}
|
||||||
|
|
||||||
|
break; /* connection was not accepted immediately */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* macro to check for a three-digit ftp status code at the start of the
|
/* macro to check for a three-digit ftp status code at the start of the
|
||||||
@@ -666,6 +882,10 @@ static int ftp_domore_getsock(struct connectdata *conn, curl_socket_t *socks,
|
|||||||
}
|
}
|
||||||
|
|
||||||
socks[0] = conn->sock[SECONDARYSOCKET];
|
socks[0] = conn->sock[SECONDARYSOCKET];
|
||||||
|
if(ftpc->wait_data_conn) {
|
||||||
|
socks[1] = conn->sock[FIRSTSOCKET];
|
||||||
|
return GETSOCK_READSOCK(0) | GETSOCK_READSOCK(1);
|
||||||
|
}
|
||||||
|
|
||||||
return GETSOCK_READSOCK(0);
|
return GETSOCK_READSOCK(0);
|
||||||
}
|
}
|
||||||
@@ -900,14 +1120,8 @@ static CURLcode ftp_state_use_port(struct connectdata *conn,
|
|||||||
portsock = CURL_SOCKET_BAD;
|
portsock = CURL_SOCKET_BAD;
|
||||||
error = 0;
|
error = 0;
|
||||||
for(ai = res; ai; ai = ai->ai_next) {
|
for(ai = res; ai; ai = ai->ai_next) {
|
||||||
/*
|
result = Curl_socket(conn, ai, NULL, &portsock);
|
||||||
* Workaround for AIX5 getaddrinfo() problem (it doesn't set ai_socktype):
|
if(result) {
|
||||||
*/
|
|
||||||
if(ai->ai_socktype == 0)
|
|
||||||
ai->ai_socktype = conn->socktype;
|
|
||||||
|
|
||||||
portsock = socket(ai->ai_family, ai->ai_socktype, ai->ai_protocol);
|
|
||||||
if(portsock == CURL_SOCKET_BAD) {
|
|
||||||
error = SOCKERRNO;
|
error = SOCKERRNO;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@@ -939,7 +1153,7 @@ static CURLcode ftp_state_use_port(struct connectdata *conn,
|
|||||||
* the control connection instead and restart the port loop
|
* the control connection instead and restart the port loop
|
||||||
*/
|
*/
|
||||||
|
|
||||||
infof(data, "bind(port=%hu) on non-local address failed: %s", port,
|
infof(data, "bind(port=%hu) on non-local address failed: %s\n", port,
|
||||||
Curl_strerror(conn, error) );
|
Curl_strerror(conn, error) );
|
||||||
|
|
||||||
sslen = sizeof(ss);
|
sslen = sizeof(ss);
|
||||||
@@ -2157,11 +2371,10 @@ static CURLcode ftp_state_rest_resp(struct connectdata *conn,
|
|||||||
}
|
}
|
||||||
|
|
||||||
static CURLcode ftp_state_stor_resp(struct connectdata *conn,
|
static CURLcode ftp_state_stor_resp(struct connectdata *conn,
|
||||||
int ftpcode)
|
int ftpcode, ftpstate instate)
|
||||||
{
|
{
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
struct SessionHandle *data = conn->data;
|
struct SessionHandle *data = conn->data;
|
||||||
struct FTP *ftp = data->state.proto.ftp;
|
|
||||||
|
|
||||||
if(ftpcode>=400) {
|
if(ftpcode>=400) {
|
||||||
failf(data, "Failed FTP upload: %0d", ftpcode);
|
failf(data, "Failed FTP upload: %0d", ftpcode);
|
||||||
@@ -2169,41 +2382,29 @@ static CURLcode ftp_state_stor_resp(struct connectdata *conn,
|
|||||||
return CURLE_UPLOAD_FAILED;
|
return CURLE_UPLOAD_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
conn->proto.ftpc.state_saved = instate;
|
||||||
|
|
||||||
|
/* PORT means we are now awaiting the server to connect to us. */
|
||||||
if(data->set.ftp_use_port) {
|
if(data->set.ftp_use_port) {
|
||||||
/* BLOCKING */
|
bool connected;
|
||||||
/* PORT means we are now awaiting the server to connect to us. */
|
|
||||||
result = AllowServerConnect(conn);
|
result = AllowServerConnect(conn, &connected);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
|
|
||||||
|
if(!connected) {
|
||||||
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
|
infof(data, "Data conn was not available immediately\n");
|
||||||
|
/* as there's not necessarily an immediate action on the control
|
||||||
|
connection now, we halt the state machine */
|
||||||
|
state(conn, FTP_STOP);
|
||||||
|
ftpc->wait_data_conn = TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
if(conn->ssl[SECONDARYSOCKET].use) {
|
return InitiateTransfer(conn);
|
||||||
/* since we only have a plaintext TCP connection here, we must now
|
|
||||||
do the TLS stuff */
|
|
||||||
infof(data, "Doing the SSL/TLS handshake on the data stream\n");
|
|
||||||
/* BLOCKING */
|
|
||||||
result = Curl_ssl_connect(conn, SECONDARYSOCKET);
|
|
||||||
if(result)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
*(ftp->bytecountp)=0;
|
|
||||||
|
|
||||||
/* When we know we're uploading a specified file, we can get the file
|
|
||||||
size prior to the actual upload. */
|
|
||||||
|
|
||||||
Curl_pgrsSetUploadSize(data, data->set.infilesize);
|
|
||||||
|
|
||||||
/* set the SO_SNDBUF for the secondary socket for those who need it */
|
|
||||||
Curl_sndbufset(conn->sock[SECONDARYSOCKET]);
|
|
||||||
|
|
||||||
Curl_setup_transfer(conn, -1, -1, FALSE, NULL, /* no download */
|
|
||||||
SECONDARYSOCKET, ftp->bytecountp);
|
|
||||||
state(conn, FTP_STOP);
|
|
||||||
|
|
||||||
conn->proto.ftpc.pp.pending_resp = TRUE; /* expect a server response */
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* for LIST and RETR responses */
|
/* for LIST and RETR responses */
|
||||||
@@ -2284,22 +2485,6 @@ static CURLcode ftp_state_get_resp(struct connectdata *conn,
|
|||||||
else if(ftp->downloadsize > -1)
|
else if(ftp->downloadsize > -1)
|
||||||
size = ftp->downloadsize;
|
size = ftp->downloadsize;
|
||||||
|
|
||||||
if(data->set.ftp_use_port) {
|
|
||||||
/* BLOCKING */
|
|
||||||
result = AllowServerConnect(conn);
|
|
||||||
if(result)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(conn->ssl[SECONDARYSOCKET].use) {
|
|
||||||
/* since we only have a plaintext TCP connection here, we must now
|
|
||||||
do the TLS stuff */
|
|
||||||
infof(data, "Doing the SSL/TLS handshake on the data stream\n");
|
|
||||||
result = Curl_ssl_connect(conn, SECONDARYSOCKET);
|
|
||||||
if(result)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(size > data->req.maxdownload && data->req.maxdownload > 0)
|
if(size > data->req.maxdownload && data->req.maxdownload > 0)
|
||||||
size = data->req.size = data->req.maxdownload;
|
size = data->req.size = data->req.maxdownload;
|
||||||
else if((instate != FTP_LIST) && (data->set.prefer_ascii))
|
else if((instate != FTP_LIST) && (data->set.prefer_ascii))
|
||||||
@@ -2311,11 +2496,25 @@ static CURLcode ftp_state_get_resp(struct connectdata *conn,
|
|||||||
infof(data, "Getting file with size: %" FORMAT_OFF_T "\n", size);
|
infof(data, "Getting file with size: %" FORMAT_OFF_T "\n", size);
|
||||||
|
|
||||||
/* FTP download: */
|
/* FTP download: */
|
||||||
Curl_setup_transfer(conn, SECONDARYSOCKET, size, FALSE,
|
conn->proto.ftpc.state_saved = instate;
|
||||||
ftp->bytecountp, -1, NULL); /* no upload here */
|
conn->proto.ftpc.retr_size_saved = size;
|
||||||
|
|
||||||
conn->proto.ftpc.pp.pending_resp = TRUE; /* expect server response */
|
if(data->set.ftp_use_port) {
|
||||||
state(conn, FTP_STOP);
|
bool connected;
|
||||||
|
|
||||||
|
result = AllowServerConnect(conn, &connected);
|
||||||
|
if(result)
|
||||||
|
return result;
|
||||||
|
|
||||||
|
if(!connected) {
|
||||||
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
|
infof(data, "Data conn was not available immediately\n");
|
||||||
|
state(conn, FTP_STOP);
|
||||||
|
ftpc->wait_data_conn = TRUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return InitiateTransfer(conn);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if((instate == FTP_LIST) && (ftpcode == 450)) {
|
if((instate == FTP_LIST) && (ftpcode == 450)) {
|
||||||
@@ -2463,7 +2662,6 @@ static CURLcode ftp_statemach_act(struct connectdata *conn)
|
|||||||
if(pp->sendleft)
|
if(pp->sendleft)
|
||||||
return Curl_pp_flushsend(pp);
|
return Curl_pp_flushsend(pp);
|
||||||
|
|
||||||
/* we read a piece of response */
|
|
||||||
result = ftp_readresp(sock, pp, &ftpcode, &nread);
|
result = ftp_readresp(sock, pp, &ftpcode, &nread);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
@@ -2869,7 +3067,7 @@ static CURLcode ftp_statemach_act(struct connectdata *conn)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case FTP_STOR:
|
case FTP_STOR:
|
||||||
result = ftp_state_stor_resp(conn, ftpcode);
|
result = ftp_state_stor_resp(conn, ftpcode, ftpc->state);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case FTP_QUIT:
|
case FTP_QUIT:
|
||||||
@@ -2999,33 +3197,6 @@ static CURLcode ftp_connect(struct connectdata *conn,
|
|||||||
pp->endofresp = ftp_endofresp;
|
pp->endofresp = ftp_endofresp;
|
||||||
pp->conn = conn;
|
pp->conn = conn;
|
||||||
|
|
||||||
if(conn->bits.tunnel_proxy && conn->bits.httpproxy) {
|
|
||||||
/* for FTP over HTTP proxy */
|
|
||||||
struct HTTP http_proxy;
|
|
||||||
struct FTP *ftp_save;
|
|
||||||
|
|
||||||
/* BLOCKING */
|
|
||||||
/* We want "seamless" FTP operations through HTTP proxy tunnel */
|
|
||||||
|
|
||||||
/* Curl_proxyCONNECT is based on a pointer to a struct HTTP at the member
|
|
||||||
* conn->proto.http; we want FTP through HTTP and we have to change the
|
|
||||||
* member temporarily for connecting to the HTTP proxy. After
|
|
||||||
* Curl_proxyCONNECT we have to set back the member to the original struct
|
|
||||||
* FTP pointer
|
|
||||||
*/
|
|
||||||
ftp_save = data->state.proto.ftp;
|
|
||||||
memset(&http_proxy, 0, sizeof(http_proxy));
|
|
||||||
data->state.proto.http = &http_proxy;
|
|
||||||
|
|
||||||
result = Curl_proxyCONNECT(conn, FIRSTSOCKET,
|
|
||||||
conn->host.name, conn->remote_port);
|
|
||||||
|
|
||||||
data->state.proto.ftp = ftp_save;
|
|
||||||
|
|
||||||
if(CURLE_OK != result)
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(conn->handler->flags & PROTOPT_SSL) {
|
if(conn->handler->flags & PROTOPT_SSL) {
|
||||||
/* BLOCKING */
|
/* BLOCKING */
|
||||||
result = Curl_ssl_connect(conn, FIRSTSOCKET);
|
result = Curl_ssl_connect(conn, FIRSTSOCKET);
|
||||||
@@ -3085,8 +3256,11 @@ static CURLcode ftp_done(struct connectdata *conn, CURLcode status,
|
|||||||
case CURLE_BAD_DOWNLOAD_RESUME:
|
case CURLE_BAD_DOWNLOAD_RESUME:
|
||||||
case CURLE_FTP_WEIRD_PASV_REPLY:
|
case CURLE_FTP_WEIRD_PASV_REPLY:
|
||||||
case CURLE_FTP_PORT_FAILED:
|
case CURLE_FTP_PORT_FAILED:
|
||||||
|
case CURLE_FTP_ACCEPT_FAILED:
|
||||||
|
case CURLE_FTP_ACCEPT_TIMEOUT:
|
||||||
case CURLE_FTP_COULDNT_SET_TYPE:
|
case CURLE_FTP_COULDNT_SET_TYPE:
|
||||||
case CURLE_FTP_COULDNT_RETR_FILE:
|
case CURLE_FTP_COULDNT_RETR_FILE:
|
||||||
|
case CURLE_PARTIAL_FILE:
|
||||||
case CURLE_UPLOAD_FAILED:
|
case CURLE_UPLOAD_FAILED:
|
||||||
case CURLE_REMOTE_ACCESS_DENIED:
|
case CURLE_REMOTE_ACCESS_DENIED:
|
||||||
case CURLE_FILESIZE_EXCEEDED:
|
case CURLE_FILESIZE_EXCEEDED:
|
||||||
@@ -3457,28 +3631,54 @@ static CURLcode ftp_range(struct connectdata *conn)
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ftp_nextconnect()
|
* ftp_do_more()
|
||||||
*
|
*
|
||||||
* This function shall be called when the second FTP (data) connection is
|
* This function shall be called when the second FTP (data) connection is
|
||||||
* connected.
|
* connected.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static CURLcode ftp_nextconnect(struct connectdata *conn)
|
static CURLcode ftp_do_more(struct connectdata *conn, bool *complete)
|
||||||
{
|
{
|
||||||
struct SessionHandle *data=conn->data;
|
struct SessionHandle *data=conn->data;
|
||||||
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
CURLcode result = CURLE_OK;
|
CURLcode result = CURLE_OK;
|
||||||
|
bool connected = FALSE;
|
||||||
|
|
||||||
/* the ftp struct is inited in ftp_connect() */
|
/* the ftp struct is inited in ftp_connect() */
|
||||||
struct FTP *ftp = data->state.proto.ftp;
|
struct FTP *ftp = data->state.proto.ftp;
|
||||||
|
|
||||||
DEBUGF(infof(data, "DO-MORE phase starts\n"));
|
/* if the second connection isn't done yet, wait for it */
|
||||||
|
if(!conn->bits.tcpconnect[SECONDARYSOCKET]) {
|
||||||
|
result = Curl_is_connected(conn, SECONDARYSOCKET, &connected);
|
||||||
|
|
||||||
|
/* Ready to do more? */
|
||||||
|
if(connected) {
|
||||||
|
DEBUGF(infof(data, "DO-MORE connected phase starts\n"));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
if(ftp->transfer <= FTPTRANSFER_INFO) {
|
if(ftp->transfer <= FTPTRANSFER_INFO) {
|
||||||
/* a transfer is about to take place, or if not a file name was given
|
/* a transfer is about to take place, or if not a file name was given
|
||||||
so we'll do a SIZE on it later and then we need the right TYPE first */
|
so we'll do a SIZE on it later and then we need the right TYPE first */
|
||||||
|
|
||||||
if(data->set.upload) {
|
if(ftpc->wait_data_conn == TRUE) {
|
||||||
|
bool serv_conned;
|
||||||
|
|
||||||
|
result = ReceivedServerConnect(conn, &serv_conned);
|
||||||
|
if(result)
|
||||||
|
return result; /* Failed to accept data connection */
|
||||||
|
|
||||||
|
if(serv_conned) {
|
||||||
|
/* It looks data connection is established */
|
||||||
|
result = AcceptServerConnect(conn);
|
||||||
|
ftpc->wait_data_conn = FALSE;
|
||||||
|
if(result == CURLE_OK)
|
||||||
|
result = InitiateTransfer(conn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(data->set.upload) {
|
||||||
result = ftp_nb_type(conn, data->set.prefer_ascii, FTP_STOR_TYPE);
|
result = ftp_nb_type(conn, data->set.prefer_ascii, FTP_STOR_TYPE);
|
||||||
if(result)
|
if(result)
|
||||||
return result;
|
return result;
|
||||||
@@ -3517,8 +3717,11 @@ static CURLcode ftp_nextconnect(struct connectdata *conn)
|
|||||||
too! */
|
too! */
|
||||||
Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
|
Curl_setup_transfer(conn, -1, -1, FALSE, NULL, -1, NULL);
|
||||||
|
|
||||||
/* end of transfer */
|
if(!ftpc->wait_data_conn) {
|
||||||
DEBUGF(infof(data, "DO-MORE phase ends with %d\n", (int)result));
|
/* no waiting for the data connection so this is now complete */
|
||||||
|
*complete = TRUE;
|
||||||
|
DEBUGF(infof(data, "DO-MORE phase ends with %d\n", (int)result));
|
||||||
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -3621,15 +3824,17 @@ static CURLcode init_wc_data(struct connectdata *conn)
|
|||||||
resources for wildcard transfer */
|
resources for wildcard transfer */
|
||||||
|
|
||||||
/* allocate ftp protocol specific temporary wildcard data */
|
/* allocate ftp protocol specific temporary wildcard data */
|
||||||
ftp_tmp = malloc(sizeof(struct ftp_wc_tmpdata));
|
ftp_tmp = calloc(1, sizeof(struct ftp_wc_tmpdata));
|
||||||
if(!ftp_tmp) {
|
if(!ftp_tmp) {
|
||||||
|
Curl_safefree(wildcard->pattern);
|
||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* INITIALIZE parselist structure */
|
/* INITIALIZE parselist structure */
|
||||||
ftp_tmp->parser = Curl_ftp_parselist_data_alloc();
|
ftp_tmp->parser = Curl_ftp_parselist_data_alloc();
|
||||||
if(!ftp_tmp->parser) {
|
if(!ftp_tmp->parser) {
|
||||||
free(ftp_tmp);
|
Curl_safefree(wildcard->pattern);
|
||||||
|
Curl_safefree(ftp_tmp);
|
||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3643,9 +3848,22 @@ static CURLcode init_wc_data(struct connectdata *conn)
|
|||||||
/* try to parse ftp url */
|
/* try to parse ftp url */
|
||||||
ret = ftp_parse_url_path(conn);
|
ret = ftp_parse_url_path(conn);
|
||||||
if(ret) {
|
if(ret) {
|
||||||
|
Curl_safefree(wildcard->pattern);
|
||||||
|
wildcard->tmp_dtor(wildcard->tmp);
|
||||||
|
wildcard->tmp_dtor = ZERO_NULL;
|
||||||
|
wildcard->tmp = NULL;
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wildcard->path = strdup(conn->data->state.path);
|
||||||
|
if(!wildcard->path) {
|
||||||
|
Curl_safefree(wildcard->pattern);
|
||||||
|
wildcard->tmp_dtor(wildcard->tmp);
|
||||||
|
wildcard->tmp_dtor = ZERO_NULL;
|
||||||
|
wildcard->tmp = NULL;
|
||||||
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
}
|
||||||
|
|
||||||
/* backup old write_function */
|
/* backup old write_function */
|
||||||
ftp_tmp->backup.write_function = conn->data->set.fwrite_func;
|
ftp_tmp->backup.write_function = conn->data->set.fwrite_func;
|
||||||
/* parsing write function */
|
/* parsing write function */
|
||||||
@@ -3655,11 +3873,6 @@ static CURLcode init_wc_data(struct connectdata *conn)
|
|||||||
/* let the writefunc callback know what curl pointer is working with */
|
/* let the writefunc callback know what curl pointer is working with */
|
||||||
conn->data->set.out = conn;
|
conn->data->set.out = conn;
|
||||||
|
|
||||||
wildcard->path = strdup(conn->data->state.path);
|
|
||||||
if(!wildcard->path) {
|
|
||||||
return CURLE_OUT_OF_MEMORY;
|
|
||||||
}
|
|
||||||
|
|
||||||
infof(conn->data, "Wildcard - Parsing started\n");
|
infof(conn->data, "Wildcard - Parsing started\n");
|
||||||
return CURLE_OK;
|
return CURLE_OK;
|
||||||
}
|
}
|
||||||
@@ -3686,6 +3899,8 @@ static CURLcode wc_statemach(struct connectdata *conn)
|
|||||||
struct ftp_wc_tmpdata *ftp_tmp = wildcard->tmp;
|
struct ftp_wc_tmpdata *ftp_tmp = wildcard->tmp;
|
||||||
conn->data->set.fwrite_func = ftp_tmp->backup.write_function;
|
conn->data->set.fwrite_func = ftp_tmp->backup.write_function;
|
||||||
conn->data->set.out = ftp_tmp->backup.file_descriptor;
|
conn->data->set.out = ftp_tmp->backup.file_descriptor;
|
||||||
|
ftp_tmp->backup.write_function = ZERO_NULL;
|
||||||
|
ftp_tmp->backup.file_descriptor = NULL;
|
||||||
wildcard->state = CURLWC_DOWNLOADING;
|
wildcard->state = CURLWC_DOWNLOADING;
|
||||||
|
|
||||||
if(Curl_ftp_parselist_geterror(ftp_tmp->parser)) {
|
if(Curl_ftp_parselist_geterror(ftp_tmp->parser)) {
|
||||||
@@ -3798,8 +4013,10 @@ static CURLcode wc_statemach(struct connectdata *conn)
|
|||||||
static CURLcode ftp_do(struct connectdata *conn, bool *done)
|
static CURLcode ftp_do(struct connectdata *conn, bool *done)
|
||||||
{
|
{
|
||||||
CURLcode retcode = CURLE_OK;
|
CURLcode retcode = CURLE_OK;
|
||||||
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
|
|
||||||
*done = FALSE; /* default to false */
|
*done = FALSE; /* default to false */
|
||||||
|
ftpc->wait_data_conn = FALSE; /* default to no such wait */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Since connections can be re-used between SessionHandles, this might be a
|
Since connections can be re-used between SessionHandles, this might be a
|
||||||
@@ -4039,7 +4256,8 @@ CURLcode ftp_parse_url_path(struct connectdata *conn)
|
|||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
|
|
||||||
ftpc->dirs[0] = curl_easy_unescape(conn->data, slash_pos ? cur_pos : "/",
|
ftpc->dirs[0] = curl_easy_unescape(conn->data, slash_pos ? cur_pos : "/",
|
||||||
slash_pos?(int)(slash_pos-cur_pos):1,
|
slash_pos ?
|
||||||
|
curlx_sztosi(slash_pos-cur_pos) : 1,
|
||||||
NULL);
|
NULL);
|
||||||
if(!ftpc->dirs[0]) {
|
if(!ftpc->dirs[0]) {
|
||||||
freedirs(ftpc);
|
freedirs(ftpc);
|
||||||
@@ -4078,7 +4296,7 @@ CURLcode ftp_parse_url_path(struct connectdata *conn)
|
|||||||
/* we skip empty path components, like "x//y" since the FTP command
|
/* we skip empty path components, like "x//y" since the FTP command
|
||||||
CWD requires a parameter and a non-existent parameter a) doesn't
|
CWD requires a parameter and a non-existent parameter a) doesn't
|
||||||
work on many servers and b) has no effect on the others. */
|
work on many servers and b) has no effect on the others. */
|
||||||
int len = (int)(slash_pos - cur_pos + absolute_dir);
|
int len = curlx_sztosi(slash_pos - cur_pos + absolute_dir);
|
||||||
ftpc->dirs[ftpc->dirdepth] =
|
ftpc->dirs[ftpc->dirdepth] =
|
||||||
curl_easy_unescape(conn->data, cur_pos - absolute_dir, len, NULL);
|
curl_easy_unescape(conn->data, cur_pos - absolute_dir, len, NULL);
|
||||||
if(!ftpc->dirs[ftpc->dirdepth]) { /* run out of memory ... */
|
if(!ftpc->dirs[ftpc->dirdepth]) { /* run out of memory ... */
|
||||||
@@ -4149,8 +4367,8 @@ CURLcode ftp_parse_url_path(struct connectdata *conn)
|
|||||||
return CURLE_OUT_OF_MEMORY;
|
return CURLE_OUT_OF_MEMORY;
|
||||||
}
|
}
|
||||||
|
|
||||||
dlen -= ftpc->file?(int)strlen(ftpc->file):0;
|
dlen -= ftpc->file?curlx_uztosi(strlen(ftpc->file)):0;
|
||||||
if((dlen == (int)strlen(ftpc->prevpath)) &&
|
if((dlen == curlx_uztosi(strlen(ftpc->prevpath))) &&
|
||||||
strnequal(path, ftpc->prevpath, dlen)) {
|
strnequal(path, ftpc->prevpath, dlen)) {
|
||||||
infof(data, "Request has same path as previous transfer\n");
|
infof(data, "Request has same path as previous transfer\n");
|
||||||
ftpc->cwddone = TRUE;
|
ftpc->cwddone = TRUE;
|
||||||
@@ -4169,8 +4387,10 @@ static CURLcode ftp_dophase_done(struct connectdata *conn,
|
|||||||
struct FTP *ftp = conn->data->state.proto.ftp;
|
struct FTP *ftp = conn->data->state.proto.ftp;
|
||||||
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
struct ftp_conn *ftpc = &conn->proto.ftpc;
|
||||||
|
|
||||||
if(connected)
|
if(connected) {
|
||||||
result = ftp_nextconnect(conn);
|
bool completed;
|
||||||
|
result = ftp_do_more(conn, &completed);
|
||||||
|
}
|
||||||
|
|
||||||
if(result && (conn->sock[SECONDARYSOCKET] != CURL_SOCKET_BAD)) {
|
if(result && (conn->sock[SECONDARYSOCKET] != CURL_SOCKET_BAD)) {
|
||||||
/* Failure detected, close the second socket if it was created already */
|
/* Failure detected, close the second socket if it was created already */
|
||||||
|
@@ -139,6 +139,7 @@ struct ftp_conn {
|
|||||||
already has been done */
|
already has been done */
|
||||||
bool cwdfail; /* set TRUE if a CWD command fails, as then we must prevent
|
bool cwdfail; /* set TRUE if a CWD command fails, as then we must prevent
|
||||||
caching the current directory */
|
caching the current directory */
|
||||||
|
bool wait_data_conn; /* this is set TRUE if data connection is waited */
|
||||||
char *prevpath; /* conn->path from the previous transfer */
|
char *prevpath; /* conn->path from the previous transfer */
|
||||||
char transfertype; /* set by ftp_transfertype for use by Curl_client_write()a
|
char transfertype; /* set by ftp_transfertype for use by Curl_client_write()a
|
||||||
and others (A/I or zero) */
|
and others (A/I or zero) */
|
||||||
@@ -146,10 +147,15 @@ struct ftp_conn {
|
|||||||
int count2; /* general purpose counter for the state machine */
|
int count2; /* general purpose counter for the state machine */
|
||||||
int count3; /* general purpose counter for the state machine */
|
int count3; /* general purpose counter for the state machine */
|
||||||
ftpstate state; /* always use ftp.c:state() to change state! */
|
ftpstate state; /* always use ftp.c:state() to change state! */
|
||||||
|
ftpstate state_saved; /* transfer type saved to be reloaded after
|
||||||
|
data connection is established */
|
||||||
|
curl_off_t retr_size_saved; /* Size of retrieved file saved */
|
||||||
char * server_os; /* The target server operating system. */
|
char * server_os; /* The target server operating system. */
|
||||||
curl_off_t known_filesize; /* file size is different from -1, if wildcard
|
curl_off_t known_filesize; /* file size is different from -1, if wildcard
|
||||||
LIST parsing was done and wc_statemach set
|
LIST parsing was done and wc_statemach set
|
||||||
it */
|
it */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define DEFAULT_ACCEPT_TIMEOUT 60000 /* milliseconds == one minute */
|
||||||
|
|
||||||
#endif /* HEADER_CURL_FTP_H */
|
#endif /* HEADER_CURL_FTP_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
|
||||||
@@ -46,6 +46,7 @@ CURLcode Curl_initinfo(struct SessionHandle *data)
|
|||||||
|
|
||||||
pro->t_nslookup = 0;
|
pro->t_nslookup = 0;
|
||||||
pro->t_connect = 0;
|
pro->t_connect = 0;
|
||||||
|
pro->t_appconnect = 0;
|
||||||
pro->t_pretransfer = 0;
|
pro->t_pretransfer = 0;
|
||||||
pro->t_starttransfer = 0;
|
pro->t_starttransfer = 0;
|
||||||
pro->timespent = 0;
|
pro->timespent = 0;
|
||||||
@@ -86,6 +87,11 @@ CURLcode Curl_getinfo(struct SessionHandle *data, CURLINFO info, ...)
|
|||||||
struct curl_slist * to_slist;
|
struct curl_slist * to_slist;
|
||||||
} ptr;
|
} ptr;
|
||||||
|
|
||||||
|
union {
|
||||||
|
unsigned long *to_ulong;
|
||||||
|
long *to_long;
|
||||||
|
} lptr;
|
||||||
|
|
||||||
if(!data)
|
if(!data)
|
||||||
return CURLE_BAD_FUNCTION_ARGUMENT;
|
return CURLE_BAD_FUNCTION_ARGUMENT;
|
||||||
|
|
||||||
@@ -190,10 +196,12 @@ CURLcode Curl_getinfo(struct SessionHandle *data, CURLINFO info, ...)
|
|||||||
*param_charp = (char *) data->set.private_data;
|
*param_charp = (char *) data->set.private_data;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_HTTPAUTH_AVAIL:
|
case CURLINFO_HTTPAUTH_AVAIL:
|
||||||
*param_longp = data->info.httpauthavail;
|
lptr.to_long = param_longp;
|
||||||
|
*lptr.to_ulong = data->info.httpauthavail;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_PROXYAUTH_AVAIL:
|
case CURLINFO_PROXYAUTH_AVAIL:
|
||||||
*param_longp = data->info.proxyauthavail;
|
lptr.to_long = param_longp;
|
||||||
|
*lptr.to_ulong = data->info.proxyauthavail;
|
||||||
break;
|
break;
|
||||||
case CURLINFO_OS_ERRNO:
|
case CURLINFO_OS_ERRNO:
|
||||||
*param_longp = data->state.os_errno;
|
*param_longp = data->state.os_errno;
|
||||||
|
29
lib/gtls.c
29
lib/gtls.c
@@ -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
|
||||||
@@ -34,7 +34,9 @@
|
|||||||
|
|
||||||
#include <gnutls/gnutls.h>
|
#include <gnutls/gnutls.h>
|
||||||
#include <gnutls/x509.h>
|
#include <gnutls/x509.h>
|
||||||
|
#ifndef USE_GNUTLS_NETTLE
|
||||||
#include <gcrypt.h>
|
#include <gcrypt.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_SYS_SOCKET_H
|
#ifdef HAVE_SYS_SOCKET_H
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
@@ -85,8 +87,7 @@ static bool gtls_inited = FALSE;
|
|||||||
# define USE_GNUTLS_PRIORITY_SET_DIRECT 1
|
# define USE_GNUTLS_PRIORITY_SET_DIRECT 1
|
||||||
# endif
|
# endif
|
||||||
# if (GNUTLS_VERSION_NUMBER >= 0x020c03)
|
# if (GNUTLS_VERSION_NUMBER >= 0x020c03)
|
||||||
# undef gnutls_transport_set_global_errno
|
# define GNUTLS_MAPS_WINSOCK_ERRORS 1
|
||||||
# define gnutls_transport_set_global_errno(A) SET_ERRNO((A))
|
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@@ -107,9 +108,13 @@ static bool gtls_inited = FALSE;
|
|||||||
* resort global errno variable using gnutls_transport_set_global_errno,
|
* resort global errno variable using gnutls_transport_set_global_errno,
|
||||||
* with a transport agnostic error value. This implies that some winsock
|
* with a transport agnostic error value. This implies that some winsock
|
||||||
* error translation must take place in these callbacks.
|
* error translation must take place in these callbacks.
|
||||||
|
*
|
||||||
|
* Paragraph above applies to GNU TLS versions older than 2.12.3, since
|
||||||
|
* this version GNU TLS does its own internal winsock error translation
|
||||||
|
* using system_errno() function.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef USE_WINSOCK
|
#if defined(USE_WINSOCK) && !defined(GNUTLS_MAPS_WINSOCK_ERRORS)
|
||||||
# define gtls_EINTR 4
|
# define gtls_EINTR 4
|
||||||
# define gtls_EIO 5
|
# define gtls_EIO 5
|
||||||
# define gtls_EAGAIN 11
|
# define gtls_EAGAIN 11
|
||||||
@@ -130,7 +135,7 @@ static int gtls_mapped_sockerrno(void)
|
|||||||
static ssize_t Curl_gtls_push(void *s, const void *buf, size_t len)
|
static ssize_t Curl_gtls_push(void *s, const void *buf, size_t len)
|
||||||
{
|
{
|
||||||
ssize_t ret = swrite(GNUTLS_POINTER_TO_INT_CAST(s), buf, len);
|
ssize_t ret = swrite(GNUTLS_POINTER_TO_INT_CAST(s), buf, len);
|
||||||
#ifdef USE_WINSOCK
|
#if defined(USE_WINSOCK) && !defined(GNUTLS_MAPS_WINSOCK_ERRORS)
|
||||||
if(ret < 0)
|
if(ret < 0)
|
||||||
gnutls_transport_set_global_errno(gtls_mapped_sockerrno());
|
gnutls_transport_set_global_errno(gtls_mapped_sockerrno());
|
||||||
#endif
|
#endif
|
||||||
@@ -140,7 +145,7 @@ static ssize_t Curl_gtls_push(void *s, const void *buf, size_t len)
|
|||||||
static ssize_t Curl_gtls_pull(void *s, void *buf, size_t len)
|
static ssize_t Curl_gtls_pull(void *s, void *buf, size_t len)
|
||||||
{
|
{
|
||||||
ssize_t ret = sread(GNUTLS_POINTER_TO_INT_CAST(s), buf, len);
|
ssize_t ret = sread(GNUTLS_POINTER_TO_INT_CAST(s), buf, len);
|
||||||
#ifdef USE_WINSOCK
|
#if defined(USE_WINSOCK) && !defined(GNUTLS_MAPS_WINSOCK_ERRORS)
|
||||||
if(ret < 0)
|
if(ret < 0)
|
||||||
gnutls_transport_set_global_errno(gtls_mapped_sockerrno());
|
gnutls_transport_set_global_errno(gtls_mapped_sockerrno());
|
||||||
#endif
|
#endif
|
||||||
@@ -198,7 +203,7 @@ static void showtime(struct SessionHandle *data,
|
|||||||
tm->tm_hour,
|
tm->tm_hour,
|
||||||
tm->tm_min,
|
tm->tm_min,
|
||||||
tm->tm_sec);
|
tm->tm_sec);
|
||||||
infof(data, "%s", data->state.buffer);
|
infof(data, "%s\n", data->state.buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
static gnutls_datum load_file (const char *file)
|
static gnutls_datum load_file (const char *file)
|
||||||
@@ -448,7 +453,13 @@ gtls_connect_step1(struct connectdata *conn,
|
|||||||
rc = gnutls_protocol_set_priority(session, protocol_priority);
|
rc = gnutls_protocol_set_priority(session, protocol_priority);
|
||||||
#else
|
#else
|
||||||
const char *err;
|
const char *err;
|
||||||
rc = gnutls_priority_set_direct(session, "-VERS-TLS-ALL:+VERS-SSL3.0",
|
/* the combination of the cipher ARCFOUR with SSL 3.0 and TLS 1.0 is not
|
||||||
|
vulnerable to attacks such as the BEAST, why this code now explicitly
|
||||||
|
asks for that
|
||||||
|
*/
|
||||||
|
rc = gnutls_priority_set_direct(session,
|
||||||
|
"NORMAL:-VERS-TLS-ALL:+VERS-SSL3.0:"
|
||||||
|
"-CIPHER-ALL:+ARCFOUR-128",
|
||||||
&err);
|
&err);
|
||||||
#endif
|
#endif
|
||||||
if(rc != GNUTLS_E_SUCCESS)
|
if(rc != GNUTLS_E_SUCCESS)
|
||||||
@@ -1032,7 +1043,9 @@ int Curl_gtls_seed(struct SessionHandle *data)
|
|||||||
static bool ssl_seeded = FALSE;
|
static bool ssl_seeded = FALSE;
|
||||||
|
|
||||||
/* Quickly add a bit of entropy */
|
/* Quickly add a bit of entropy */
|
||||||
|
#ifndef USE_GNUTLS_NETTLE
|
||||||
gcry_fast_random_poll();
|
gcry_fast_random_poll();
|
||||||
|
#endif
|
||||||
|
|
||||||
if(!ssl_seeded || data->set.str[STRING_SSL_RANDOM_FILE] ||
|
if(!ssl_seeded || data->set.str[STRING_SSL_RANDOM_FILE] ||
|
||||||
data->set.str[STRING_SSL_EGDSOCKET]) {
|
data->set.str[STRING_SSL_EGDSOCKET]) {
|
||||||
|
@@ -264,6 +264,9 @@ Curl_hash_clean_with_criterium(struct curl_hash *h, void *user,
|
|||||||
struct curl_llist *list;
|
struct curl_llist *list;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
if(!h)
|
||||||
|
return;
|
||||||
|
|
||||||
for(i = 0; i < h->slots; ++i) {
|
for(i = 0; i < h->slots; ++i) {
|
||||||
list = h->table[i];
|
list = h->table[i];
|
||||||
le = list->head; /* get first list entry */
|
le = list->head; /* get first list entry */
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user