examples: fix deps - rebuild on library changes
[ocurl.git] / curl.mli
blob9b704f2eba7c3adc58d717a96314b0d3ffcf1379
1 (*
2 * curl.mli
4 * Copyright (c) 2003-2008, Lars Nilsson, <lars@quantumchamaeleon.com>
5 * Copyright (c) 2009, ygrek, <ygrek@autistici.org>
6 *)
8 (** libcurl wrapper *)
10 (** {2 Types} *)
12 type t
14 type curlCode =
15 | CURLE_OK
16 | CURLE_UNSUPPORTED_PROTOCOL
17 | CURLE_FAILED_INIT
18 | CURLE_URL_MALFORMAT
19 | CURLE_URL_MALFORMAT_USER
20 | CURLE_COULDNT_RESOLVE_PROXY
21 | CURLE_COULDNT_RESOLVE_HOST
22 | CURLE_COULDNT_CONNECT
23 | CURLE_FTP_WEIRD_SERVER_REPLY
24 | CURLE_FTP_ACCESS_DENIED
25 | CURLE_FTP_USER_PASSWORD_INCORRECT
26 | CURLE_FTP_WEIRD_PASS_REPLY
27 | CURLE_FTP_WEIRD_USER_REPLY
28 | CURLE_FTP_WEIRD_PASV_REPLY
29 | CURLE_FTP_WEIRD_227_FORMAT
30 | CURLE_FTP_CANT_GET_HOST
31 | CURLE_FTP_CANT_RECONNECT
32 | CURLE_FTP_COULDNT_SET_BINARY
33 | CURLE_PARTIAL_FILE
34 | CURLE_FTP_COULDNT_RETR_FILE
35 | CURLE_FTP_WRITE_ERROR
36 | CURLE_FTP_QUOTE_ERROR
37 | CURLE_HTTP_NOT_FOUND
38 | CURLE_WRITE_ERROR
39 | CURLE_MALFORMAT_USER
40 | CURLE_FTP_COULDNT_STOR_FILE
41 | CURLE_READ_ERROR
42 | CURLE_OUT_OF_MEMORY
43 | CURLE_OPERATION_TIMEOUTED
44 | CURLE_FTP_COULDNT_SET_ASCII
45 | CURLE_FTP_PORT_FAILED
46 | CURLE_FTP_COULDNT_USE_REST
47 | CURLE_FTP_COULDNT_GET_SIZE
48 | CURLE_HTTP_RANGE_ERROR
49 | CURLE_HTTP_POST_ERROR
50 | CURLE_SSL_CONNECT_ERROR
51 | CURLE_FTP_BAD_DOWNLOAD_RESUME
52 | CURLE_FILE_COULDNT_READ_FILE
53 | CURLE_LDAP_CANNOT_BIND
54 | CURLE_LDAP_SEARCH_FAILED
55 | CURLE_LIBRARY_NOT_FOUND
56 | CURLE_FUNCTION_NOT_FOUND
57 | CURLE_ABORTED_BY_CALLBACK
58 | CURLE_BAD_FUNCTION_ARGUMENT
59 | CURLE_BAD_CALLING_ORDER
60 | CURLE_HTTP_PORT_FAILED
61 | CURLE_BAD_PASSWORD_ENTERED
62 | CURLE_TOO_MANY_REDIRECTS
63 | CURLE_UNKNOWN_TELNET_OPTION
64 | CURLE_TELNET_OPTION_SYNTAX
65 | CURLE_OBSOLETE
66 | CURLE_SSL_PEER_CERTIFICATE
67 | CURLE_GOT_NOTHING
68 | CURLE_SSL_ENGINE_NOTFOUND
69 | CURLE_SSL_ENGINE_SETFAILED
70 | CURLE_SEND_ERROR
71 | CURLE_RECV_ERROR
72 | CURLE_SHARE_IN_USE
73 | CURLE_SSL_CERTPROBLEM
74 | CURLE_SSL_CIPHER
75 | CURLE_SSL_CACERT
76 | CURLE_BAD_CONTENT_ENCODING
77 | CURLE_LDAP_INVALID_URL
78 | CURLE_FILESIZE_EXCEEDED
79 | CURLE_USE_SSL_FAILED
80 | CURLE_SEND_FAIL_REWIND
81 | CURLE_SSL_ENGINE_INITFAILED
82 | CURLE_LOGIN_DENIED
83 | CURLE_TFTP_NOTFOUND
84 | CURLE_TFTP_PERM
85 | CURLE_REMOTE_DISK_FULL
86 | CURLE_TFTP_ILLEGAL
87 | CURLE_TFTP_UNKNOWNID
88 | CURLE_REMOTE_FILE_EXISTS
89 | CURLE_TFTP_NOSUCHUSER
90 | CURLE_CONV_FAILED
91 | CURLE_CONV_REQD
92 | CURLE_SSL_CACERT_BADFILE
93 | CURLE_REMOTE_FILE_NOT_FOUND
94 | CURLE_SSH
95 | CURLE_SSL_SHUTDOWN_FAILED
96 | CURLE_AGAIN
98 exception CurlException of (curlCode * int * string)
100 type curlNETRCOption =
101 | CURL_NETRC_OPTIONAL
102 | CURL_NETRC_IGNORED
103 | CURL_NETRC_REQUIRED
105 type curlEncoding =
106 | CURL_ENCODING_NONE (* identity *)
107 | CURL_ENCODING_DEFLATE (* deflate *)
108 | CURL_ENCODING_GZIP (* gzip *)
109 | CURL_ENCODING_ANY (* all supported encodings *)
111 type curlContentType =
112 | DEFAULT
113 | CONTENTTYPE of string
115 type curlHTTPPost =
116 | CURLFORM_CONTENT of string * string * curlContentType
117 | CURLFORM_FILECONTENT of string * string * curlContentType
118 | CURLFORM_FILE of string * string * curlContentType
119 | CURLFORM_BUFFER of string * string * string * curlContentType
122 type curlHTTPPost =
123 | CURLFORM_COPYNAME of string
124 | CURLFORM_PTRNAME of string
125 | CURLFORM_NAMELENGTH of int
126 | CURLFORM_COPYCONTENTS of string
127 | CURLFORM_PTRCONTENTS of string
128 | CURLFORM_FILE of string
129 | CURLFORM_FILECONTENT of string
130 | CURLFORM_CONTENTSLENGTH of int
131 | CURLFORM_CONTENTTYPE of string
134 type curlTimeCondition =
135 | TIMECOND_NONE (** since 0.6.1 *)
136 | TIMECOND_IFMODSINCE
137 | TIMECOND_IFUNMODSINCE
138 | TIMECOND_LASTMOD (** since 0.6.1 *)
140 type curlKRB4Level =
141 | KRB4_NONE
142 | KRB4_CLEAR
143 | KRB4_SAFE
144 | KRB4_CONFIDENTIAL
145 | KRB4_PRIVATE
147 type curlClosePolicy =
148 | CLOSEPOLICY_OLDEST
149 | CLOSEPOLICY_LEAST_RECENTLY_USED
151 type curlSSLVerifyHost =
152 | SSLVERIFYHOST_NONE (** connection succeeds regardless of the names in the certificate *)
153 | SSLVERIFYHOST_EXISTENCE (** deprecated, equivalent to SSLVERIFYHOST_HOSTNAME *)
154 | SSLVERIFYHOST_HOSTNAME (** certificate must indicate the matching hostname, or the connection fails *)
156 type curlHTTPVersion =
157 | HTTP_VERSION_NONE
158 | HTTP_VERSION_1_0
159 | HTTP_VERSION_1_1
161 type curlDebugType =
162 | DEBUGTYPE_TEXT
163 | DEBUGTYPE_HEADER_IN
164 | DEBUGTYPE_HEADER_OUT
165 | DEBUGTYPE_DATA_IN
166 | DEBUGTYPE_DATA_OUT
167 | DEBUGTYPE_END
169 type curlAuth =
170 | CURLAUTH_BASIC
171 | CURLAUTH_DIGEST
172 | CURLAUTH_GSSNEGOTIATE
173 | CURLAUTH_NTLM
174 | CURLAUTH_ANY
175 | CURLAUTH_ANYSAFE
177 type curlIPResolve =
178 | IPRESOLVE_WHATEVER
179 | IPRESOLVE_V4
180 | IPRESOLVE_V6
182 type curlFTPSSL =
183 | FTPSSL_NONE
184 | FTPSSL_TRY
185 | FTPSSL_CONTROL
186 | FTPSSL_ALL
188 type curlFTPSSLAuth =
189 | FTPAUTH_DEFAULT
190 | FTPAUTH_SSL
191 | FTPAUTH_TLS
193 type curlIOCmd =
194 | IOCMD_NOP
195 | IOCMD_RESTARTREAD
197 type curlIOErr =
198 | IOE_OK
199 | IOE_UNKNOWNCMD
200 | IOE_FAILRESTART
202 type curlSeekResult =
203 | SEEKFUNC_OK
204 | SEEKFUNC_FAIL
205 | SEEKFUNC_CANTSEEK
207 type curlFTPMethod =
208 | FTPMETHOD_DEFAULT
209 | FTPMETHOD_MULTICWD
210 | FTPMETHOD_NOCWD
211 | FTPMETHOD_SINGLECWD
213 type curlSSHAuthTypes =
214 | SSHAUTH_ANY
215 | SSHAUTH_PUBLICKEY
216 | SSHAUTH_PASSWORD
217 | SSHAUTH_HOST
218 | SSHAUTH_KEYBOARD
220 type curlFTPSSLCCC =
221 | FTPSSL_CCC_NONE
222 | FTPSSL_CCC_PASSIVE
223 | FTPSSL_CCC_ACTIVE
225 type curlSeek =
226 | SEEK_SET
227 | SEEK_CUR
228 | SEEK_END
230 type curlProxyType =
231 | CURLPROXY_HTTP
232 | CURLPROXY_HTTP_1_0 (** since libcurl 7.19.4 *)
233 | CURLPROXY_SOCKS4 (** since libcurl 7.15.2 *)
234 | CURLPROXY_SOCKS5
235 | CURLPROXY_SOCKS4A (** since libcurl 7.18.0 *)
236 | CURLPROXY_SOCKS5_HOSTNAME (** since libcurl 7.18.0 *)
238 (** Protocols to enable (via CURLOPT_PROTOCOLS and CURLOPT_REDIR_PROTOCOLS) *)
239 type curlProto =
240 | CURLPROTO_ALL (** enable everything *)
241 | CURLPROTO_HTTP
242 | CURLPROTO_HTTPS
243 | CURLPROTO_FTP
244 | CURLPROTO_FTPS
245 | CURLPROTO_SCP
246 | CURLPROTO_SFTP
247 | CURLPROTO_TELNET
248 | CURLPROTO_LDAP
249 | CURLPROTO_LDAPS
250 | CURLPROTO_DICT
251 | CURLPROTO_FILE
252 | CURLPROTO_TFTP
253 | CURLPROTO_IMAP
254 | CURLPROTO_IMAPS
255 | CURLPROTO_POP3
256 | CURLPROTO_POP3S
257 | CURLPROTO_SMTP
258 | CURLPROTO_SMTPS
259 | CURLPROTO_RTSP
260 | CURLPROTO_RTMP
261 | CURLPROTO_RTMPT
262 | CURLPROTO_RTMPE
263 | CURLPROTO_RTMPTE
264 | CURLPROTO_RTMPS
265 | CURLPROTO_RTMPTS
266 | CURLPROTO_GOPHER
268 type curlOption =
269 | CURLOPT_WRITEFUNCTION of (string -> int)
270 | CURLOPT_READFUNCTION of (int -> string)
271 | CURLOPT_INFILESIZE of int
272 | CURLOPT_URL of string
273 | CURLOPT_PROXY of string
274 | CURLOPT_PROXYPORT of int
275 | CURLOPT_HTTPPROXYTUNNEL of bool
276 | CURLOPT_VERBOSE of bool
277 | CURLOPT_HEADER of bool
278 | CURLOPT_NOPROGRESS of bool
279 | CURLOPT_NOSIGNAL of bool
280 | CURLOPT_NOBODY of bool
281 | CURLOPT_FAILONERROR of bool
282 | CURLOPT_UPLOAD of bool
283 | CURLOPT_POST of bool
284 | CURLOPT_FTPLISTONLY of bool
285 | CURLOPT_FTPAPPEND of bool
286 | CURLOPT_NETRC of curlNETRCOption
287 | CURLOPT_ENCODING of curlEncoding
288 | CURLOPT_FOLLOWLOCATION of bool
289 | CURLOPT_TRANSFERTEXT of bool
290 | CURLOPT_PUT of bool
291 | CURLOPT_USERPWD of string
292 | CURLOPT_PROXYUSERPWD of string
293 | CURLOPT_RANGE of string
294 | CURLOPT_ERRORBUFFER of string ref
295 | CURLOPT_TIMEOUT of int
296 | CURLOPT_POSTFIELDS of string
297 | CURLOPT_POSTFIELDSIZE of int
298 | CURLOPT_REFERER of string
299 | CURLOPT_USERAGENT of string
300 | CURLOPT_FTPPORT of string
301 | CURLOPT_LOWSPEEDLIMIT of int
302 | CURLOPT_LOWSPEEDTIME of int
303 | CURLOPT_RESUMEFROM of int
304 | CURLOPT_COOKIE of string
305 | CURLOPT_HTTPHEADER of string list
306 | CURLOPT_HTTPPOST of curlHTTPPost list
307 | CURLOPT_SSLCERT of string
308 | CURLOPT_SSLCERTTYPE of string
309 | CURLOPT_SSLCERTPASSWD of string
310 | CURLOPT_SSLKEY of string
311 | CURLOPT_SSLKEYTYPE of string
312 | CURLOPT_SSLKEYPASSWD of string
313 | CURLOPT_SSLENGINE of string
314 | CURLOPT_SSLENGINEDEFAULT of bool
315 | CURLOPT_CRLF of bool
316 | CURLOPT_QUOTE of string list
317 | CURLOPT_POSTQUOTE of string list
318 | CURLOPT_HEADERFUNCTION of (string -> int)
319 | CURLOPT_COOKIEFILE of string
320 | CURLOPT_SSLVERSION of int
321 | CURLOPT_TIMECONDITION of curlTimeCondition
322 | CURLOPT_TIMEVALUE of int32
323 | CURLOPT_CUSTOMREQUEST of string
324 | CURLOPT_STDERR (* UNIMPLEMENTED *)
325 | CURLOPT_INTERFACE of string
326 | CURLOPT_KRB4LEVEL of curlKRB4Level
327 | CURLOPT_PROGRESSFUNCTION of (float -> float -> float -> float -> bool)
328 | CURLOPT_SSLVERIFYPEER of bool
329 | CURLOPT_CAINFO of string
330 | CURLOPT_CAPATH of string
331 | CURLOPT_FILETIME of bool
332 | CURLOPT_MAXREDIRS of int
333 | CURLOPT_MAXCONNECTS of int
334 | CURLOPT_CLOSEPOLICY of curlClosePolicy
335 | CURLOPT_FRESHCONNECT of bool
336 | CURLOPT_FORBIDREUSE of bool
337 | CURLOPT_RANDOMFILE of string
338 | CURLOPT_EGDSOCKET of string
339 | CURLOPT_CONNECTTIMEOUT of int
340 | CURLOPT_HTTPGET of bool
341 | CURLOPT_SSLVERIFYHOST of curlSSLVerifyHost
342 | CURLOPT_COOKIEJAR of string
343 | CURLOPT_SSLCIPHERLIST of string
344 | CURLOPT_HTTPVERSION of curlHTTPVersion
345 | CURLOPT_FTPUSEEPSV of bool
346 | CURLOPT_DNSCACHETIMEOUT of int
347 | CURLOPT_DNSUSEGLOBALCACHE of bool
348 | CURLOPT_DEBUGFUNCTION of (t -> curlDebugType -> string -> unit)
349 | CURLOPT_PRIVATE of string
350 | CURLOPT_HTTP200ALIASES of string list
351 | CURLOPT_UNRESTRICTEDAUTH of bool
352 | CURLOPT_FTPUSEEPRT of bool
353 | CURLOPT_HTTPAUTH of curlAuth list
354 | CURLOPT_FTPCREATEMISSINGDIRS of bool
355 | CURLOPT_PROXYAUTH of curlAuth list
356 | CURLOPT_FTPRESPONSETIMEOUT of int
357 | CURLOPT_IPRESOLVE of curlIPResolve
358 | CURLOPT_MAXFILESIZE of int32
359 | CURLOPT_INFILESIZELARGE of int64
360 | CURLOPT_RESUMEFROMLARGE of int64
361 | CURLOPT_MAXFILESIZELARGE of int64
362 | CURLOPT_NETRCFILE of string
363 | CURLOPT_FTPSSL of curlFTPSSL
364 | CURLOPT_POSTFIELDSIZELARGE of int64
365 | CURLOPT_TCPNODELAY of bool
366 | CURLOPT_FTPSSLAUTH of curlFTPSSLAuth
367 | CURLOPT_IOCTLFUNCTION of (t -> curlIOCmd -> curlIOErr)
368 | CURLOPT_FTPACCOUNT of string
369 | CURLOPT_COOKIELIST of string
370 | CURLOPT_IGNORECONTENTLENGTH of bool
371 | CURLOPT_FTPSKIPPASVIP of bool
372 | CURLOPT_FTPFILEMETHOD of curlFTPMethod
373 | CURLOPT_LOCALPORT of int
374 | CURLOPT_LOCALPORTRANGE of int
375 | CURLOPT_CONNECTONLY of bool
376 | CURLOPT_MAXSENDSPEEDLARGE of int64
377 | CURLOPT_MAXRECVSPEEDLARGE of int64
378 | CURLOPT_FTPALTERNATIVETOUSER of string
379 | CURLOPT_SSLSESSIONIDCACHE of bool
380 | CURLOPT_SSHAUTHTYPES of curlSSHAuthTypes list
381 | CURLOPT_SSHPUBLICKEYFILE of string
382 | CURLOPT_SSHPRIVATEKEYFILE of string
383 | CURLOPT_FTPSSLCCC of curlFTPSSLCCC
384 | CURLOPT_TIMEOUTMS of int
385 | CURLOPT_CONNECTTIMEOUTMS of int
386 | CURLOPT_HTTPTRANSFERDECODING of bool
387 | CURLOPT_HTTPCONTENTDECODING of bool
388 | CURLOPT_NEWFILEPERMS of int
389 | CURLOPT_NEWDIRECTORYPERMS of int
390 | CURLOPT_POST301 of bool
391 | CURLOPT_SSHHOSTPUBLICKEYMD5 of string
392 | CURLOPT_COPYPOSTFIELDS of string
393 | CURLOPT_PROXYTRANSFERMODE of bool
394 | CURLOPT_SEEKFUNCTION of (int64 -> curlSeek -> curlSeekResult)
395 | CURLOPT_AUTOREFERER of bool
396 | CURLOPT_OPENSOCKETFUNCTION of (Unix.file_descr -> unit)
397 | CURLOPT_PROXYTYPE of curlProxyType
398 | CURLOPT_PROTOCOLS of curlProto list
399 | CURLOPT_REDIR_PROTOCOLS of curlProto list
400 | CURLOPT_RESOLVE of string list
401 | CURLOPT_DNS_SERVERS of string
403 type initOption =
404 | CURLINIT_GLOBALALL
405 | CURLINIT_GLOBALSSL
406 | CURLINIT_GLOBALWIN32
407 | CURLINIT_GLOBALNOTHING
409 type curlInfo =
410 | CURLINFO_EFFECTIVE_URL
411 | CURLINFO_HTTP_CODE
412 | CURLINFO_RESPONSE_CODE
413 | CURLINFO_TOTAL_TIME
414 | CURLINFO_NAMELOOKUP_TIME
415 | CURLINFO_CONNECT_TIME
416 | CURLINFO_PRETRANSFER_TIME
417 | CURLINFO_SIZE_UPLOAD
418 | CURLINFO_SIZE_DOWNLOAD
419 | CURLINFO_SPEED_DOWNLOAD
420 | CURLINFO_SPEED_UPLOAD
421 | CURLINFO_HEADER_SIZE
422 | CURLINFO_REQUEST_SIZE
423 | CURLINFO_SSL_VERIFYRESULT
424 | CURLINFO_FILETIME
425 | CURLINFO_CONTENT_LENGTH_DOWNLOAD
426 | CURLINFO_CONTENT_LENGTH_UPLOAD
427 | CURLINFO_STARTTRANSFER_TIME
428 | CURLINFO_CONTENT_TYPE
429 | CURLINFO_REDIRECT_TIME
430 | CURLINFO_REDIRECT_COUNT
431 | CURLINFO_PRIVATE
432 | CURLINFO_HTTP_CONNECTCODE
433 | CURLINFO_HTTPAUTH_AVAIL
434 | CURLINFO_PROXYAUTH_AVAIL
435 | CURLINFO_OS_ERRNO
436 | CURLINFO_NUM_CONNECTS
437 | CURLINFO_SSL_ENGINES
438 | CURLINFO_COOKIELIST
439 | CURLINFO_LASTSOCKET
440 | CURLINFO_FTP_ENTRY_PATH
441 | CURLINFO_REDIRECT_URL
442 | CURLINFO_PRIMARY_IP
443 | CURLINFO_LOCAL_IP
444 | CURLINFO_LOCAL_PORT
445 | CURLINFO_CONDITION_UNMET
447 type curlInfoResult =
448 | CURLINFO_String of string
449 | CURLINFO_Long of int
450 | CURLINFO_Double of float
451 | CURLINFO_StringList of string list
453 type version_info = {
454 version : string;
455 number : int * int * int;
456 host : string;
457 features : string list;
458 ssl_version : string option;
459 libz_version : string option;
460 protocols : string list;
461 ares : string; (** starting from this field are optional features - may be empty/zero *)
462 ares_num : int;
463 libidn : string;
464 iconv_ver_num : int;
465 libssh_version : string;
468 type pauseOption = PAUSE_SEND | PAUSE_RECV | PAUSE_ALL
470 (** {2 curl_easy API} *)
472 val global_init : initOption -> unit
473 val global_cleanup : unit -> unit
474 val init : unit -> t
475 val reset : t -> unit
476 (** Reset [t] to the default state *)
477 val duphandle : t -> t
478 val setopt : t -> curlOption -> unit
479 val perform : t -> unit
480 val cleanup : t -> unit
481 val getinfo : t -> curlInfo -> curlInfoResult
482 val escape : string -> string
483 val unescape : string -> string
484 val getdate : string -> float -> float
485 val version : unit -> string
486 val strerror : curlCode -> string
487 val errno : curlCode -> int
488 val version_info : unit -> version_info
489 val pause : t -> pauseOption list -> unit
491 (** {2 Set transfer options}
493 All callback functions shouldn't raise exceptions.
494 Any exception raised in callback function will be silently caught and discared,
495 and transfer will be aborted. *)
497 val set_writefunction : t -> (string -> int) -> unit
498 val set_readfunction : t -> (int -> string) -> unit
499 (** [readfunction n] should return string of length at most [n], otherwise
500 transfer will be aborted (as if with exception) *)
501 val set_infilesize : t -> int -> unit
502 val set_url : t -> string -> unit
503 val set_proxy : t -> string -> unit
504 val set_proxyport : t -> int -> unit
505 val set_httpproxytunnel : t -> bool -> unit
506 val set_verbose : t -> bool -> unit
507 val set_header : t -> bool -> unit
508 val set_noprogress : t -> bool -> unit
509 val set_nosignal : t -> bool -> unit
510 val set_nobody : t -> bool -> unit
511 val set_failonerror : t -> bool -> unit
512 val set_upload : t -> bool -> unit
513 val set_post : t -> bool -> unit
514 val set_ftplistonly : t -> bool -> unit
515 val set_ftpappend : t -> bool -> unit
516 val set_netrc : t -> curlNETRCOption -> unit
517 val set_encoding : t -> curlEncoding -> unit
518 val set_followlocation : t -> bool -> unit
519 val set_transfertext : t -> bool -> unit
520 val set_put : t -> bool -> unit
521 val set_userpwd : t -> string -> unit
522 val set_proxyuserpwd : t -> string -> unit
523 val set_range : t -> string -> unit
524 val set_errorbuffer : t -> string ref -> unit
525 val set_timeout : t -> int -> unit
526 val set_postfields : t -> string -> unit
527 val set_postfieldsize : t -> int -> unit
528 val set_referer : t -> string -> unit
529 val set_useragent : t -> string -> unit
530 val set_ftpport : t -> string -> unit
531 val set_lowspeedlimit : t -> int -> unit
532 val set_lowspeedtime : t -> int -> unit
533 val set_resumefrom : t -> int -> unit
534 val set_cookie : t -> string -> unit
535 val set_httpheader : t -> string list -> unit
536 val set_httppost : t -> curlHTTPPost list -> unit
537 val set_sslcert : t -> string -> unit
538 val set_sslcerttype : t -> string -> unit
539 val set_sslcertpasswd : t -> string -> unit
540 val set_sslkey : t -> string -> unit
541 val set_sslkeytype : t -> string -> unit
542 val set_sslkeypasswd : t -> string -> unit
543 val set_sslengine : t -> string -> unit
544 val set_sslenginedefault : t -> bool -> unit
545 val set_crlf : t -> bool -> unit
546 val set_quote : t -> string list -> unit
547 val set_postquote : t -> string list -> unit
548 val set_headerfunction: t -> (string -> int) -> unit
549 val set_cookiefile : t -> string -> unit
550 val set_sslversion : t -> int -> unit
551 val set_timecondition : t -> curlTimeCondition -> unit
552 val set_timevalue : t -> int32 -> unit
553 val set_customrequest : t -> string -> unit
554 val set_interface : t -> string -> unit
555 val set_krb4level : t -> curlKRB4Level -> unit
556 val set_progressfunction : t -> (float -> float -> float -> float -> bool) -> unit
557 val set_sslverifypeer : t -> bool -> unit
558 val set_cainfo : t -> string -> unit
559 val set_capath : t -> string -> unit
560 val set_filetime : t -> bool -> unit
561 val set_maxredirs : t -> int -> unit
562 val set_maxconnects : t -> int -> unit
563 val set_closepolicy : t -> curlClosePolicy -> unit
564 val set_freshconnect : t -> bool -> unit
565 val set_forbidreuse : t -> bool -> unit
566 val set_randomfile : t -> string -> unit
567 val set_egdsocket : t -> string -> unit
568 val set_connecttimeout : t -> int -> unit
569 val set_httpget : t -> bool -> unit
570 val set_sslverifyhost : t -> curlSSLVerifyHost -> unit
571 val set_cookiejar : t -> string -> unit
572 val set_sslcipherlist : t -> string -> unit
573 val set_httpversion : t -> curlHTTPVersion -> unit
574 val set_ftpuseepsv : t -> bool -> unit
575 val set_dnscachetimeout : t -> int -> unit
576 val set_dnsuseglobalcache : t -> bool -> unit
577 val set_debugfunction : t -> (t -> curlDebugType -> string -> unit) -> unit
578 val set_private : t -> string -> unit
579 val set_http200aliases : t -> string list -> unit
580 val set_unrestrictedauth : t -> bool -> unit
581 val set_ftpuseeprt : t -> bool -> unit
582 val set_httpauth : t -> curlAuth list -> unit
583 val set_ftpcreatemissingdirs : t -> bool -> unit
584 val set_proxyauth : t -> curlAuth list -> unit
585 val set_ftpresponsetimeout : t -> int -> unit
586 val set_ipresolve : t -> curlIPResolve -> unit
587 val set_maxfilesize : t -> int32 -> unit
588 val set_infilesizelarge : t -> int64 -> unit
589 val set_resumefromlarge : t -> int64 -> unit
590 val set_maxfilesizelarge : t -> int64 -> unit
591 val set_netrcfile : t -> string -> unit
592 val set_ftpssl : t -> curlFTPSSL -> unit
593 val set_postfieldsizelarge : t -> int64 -> unit
594 val set_tcpnodelay : t -> bool -> unit
595 val set_ftpsslauth : t -> curlFTPSSLAuth -> unit
596 val set_ioctlfunction : t -> (t -> curlIOCmd -> curlIOErr) -> unit
597 val set_ftpaccount : t -> string -> unit
598 val set_cookielist : t -> string -> unit
599 val set_ignorecontentlength : t -> bool -> unit
600 val set_ftpskippasvip : t -> bool -> unit
601 val set_ftpfilemethod : t -> curlFTPMethod -> unit
602 val set_localport : t -> int -> unit
603 val set_localportrange : t -> int -> unit
604 val set_connectonly : t -> bool -> unit
605 val set_maxsendspeedlarge : t -> int64 -> unit
606 val set_maxrecvspeedlarge : t -> int64 -> unit
607 val set_ftpalternativetouser : t -> string -> unit
608 val set_sslsessionidcache : t -> bool -> unit
609 val set_sshauthtypes : t -> curlSSHAuthTypes list -> unit
610 val set_sshpublickeyfile : t -> string -> unit
611 val set_sshprivatekeyfile : t -> string -> unit
612 val set_ftpsslccc : t -> curlFTPSSLCCC -> unit
613 val set_timeoutms : t -> int -> unit
614 val set_connecttimeoutms : t -> int -> unit
615 val set_httptransferdecoding : t -> bool -> unit
616 val set_httpcontentdecoding : t -> bool -> unit
617 val set_newfileperms : t -> int -> unit
618 val set_newdirectoryperms : t -> int -> unit
619 val set_post301 : t -> bool -> unit
620 val set_sshhostpublickeymd5 : t -> string -> unit
621 val set_copypostfields : t -> string -> unit
622 val set_proxytransfermode : t -> bool -> unit
623 val set_seekfunction : t -> (int64 -> curlSeek -> curlSeekResult) -> unit
624 val set_autoreferer : t -> bool -> unit
625 val set_opensocketfunction : t -> (Unix.file_descr -> unit) -> unit
626 val set_proxytype : t -> curlProxyType -> unit
627 val set_protocols : t -> curlProto list -> unit
628 val set_redirprotocols : t -> curlProto list -> unit
630 (** [set_resolve t add del] adjusts builtin dns mapping
632 @param add is the (host,port,address) list to add to dns mapping
633 @param del is the (host,port) list to remove from mapping
635 val set_resolve : t -> (string * int * string) list -> (string * int) list -> unit
636 val set_dns_servers : t -> string list -> unit
638 (** {2 Get transfer properties} *)
640 val get_effectiveurl : t -> string
641 val get_redirecturl : t -> string
642 val get_httpcode : t -> int
643 val get_responsecode : t -> int
644 val get_totaltime : t -> float
645 val get_namelookuptime : t -> float
646 val get_connecttime : t -> float
647 val get_pretransfertime : t -> float
648 val get_sizeupload : t -> float
649 val get_sizedownload : t -> float
650 val get_speeddownload : t -> float
651 val get_speedupload : t -> float
652 val get_headersize : t -> int
653 val get_requestsize : t -> int
654 val get_sslverifyresult : t -> int
655 val get_filetime : t -> float
656 val get_contentlengthdownload : t -> float
657 val get_contentlengthupload : t -> float
658 val get_starttransfertime : t -> float
659 val get_contenttype : t -> string
660 val get_redirecttime : t -> float
661 val get_redirectcount : t -> int
662 val get_private : t -> string
663 val get_httpconnectcode : t -> int
664 val get_httpauthavail : t -> curlAuth list
665 val get_proxyauthavail : t -> curlAuth list
666 val get_oserrno : t -> int
667 val get_numconnects : t -> int
668 val get_sslengines : t -> string list
669 val get_cookielist : t -> string list
670 val get_lastsocket : t -> int
671 val get_ftpentrypath : t -> string
672 val get_primaryip : t -> string
673 val get_localip : t -> string
674 (** @since 0.5.5 (libcurl 7.21.0) *)
675 val get_localport : t -> int
676 (** @since 0.5.5 (libcurl 7.21.0) *)
677 val get_conditionunmet : t -> bool
678 (** @since 0.6.1 (libcurl 7.19.4) *)
680 (** {2 Object interface} *)
682 class handle :
683 object ('a)
684 val conn : t
685 method handle : t
686 method cleanup : unit
687 method duphandle : 'a
688 method perform : unit
690 method set_writefunction : (string -> int) -> unit
691 method set_readfunction : (int -> string) -> unit
692 method set_infilesize : int -> unit
693 method set_url : string -> unit
694 method set_proxy : string -> unit
695 method set_proxyport : int -> unit
696 method set_httpproxytunnel : bool -> unit
697 method set_verbose : bool -> unit
698 method set_header : bool -> unit
699 method set_noprogress : bool -> unit
700 method set_nosignal : bool -> unit
701 method set_nobody : bool -> unit
702 method set_failonerror : bool -> unit
703 method set_upload : bool -> unit
704 method set_post : bool -> unit
705 method set_ftplistonly : bool -> unit
706 method set_ftpappend : bool -> unit
707 method set_netrc : curlNETRCOption -> unit
708 method set_encoding : curlEncoding -> unit
709 method set_followlocation : bool -> unit
710 method set_transfertext : bool -> unit
711 method set_put : bool -> unit
712 method set_userpwd : string -> unit
713 method set_proxyuserpwd : string -> unit
714 method set_range : string -> unit
715 method set_errorbuffer : string ref -> unit
716 method set_timeout : int -> unit
717 method set_postfields : string -> unit
718 method set_postfieldsize : int -> unit
719 method set_referer : string -> unit
720 method set_useragent : string -> unit
721 method set_ftpport : string -> unit
722 method set_lowspeedlimit : int -> unit
723 method set_lowspeedtime : int -> unit
724 method set_resumefrom : int -> unit
725 method set_cookie : string -> unit
726 method set_httpheader : string list -> unit
727 method set_httppost : curlHTTPPost list -> unit
728 method set_sslcert : string -> unit
729 method set_sslcerttype : string -> unit
730 method set_sslcertpasswd : string -> unit
731 method set_sslkey : string -> unit
732 method set_sslkeytype : string -> unit
733 method set_sslkeypasswd : string -> unit
734 method set_sslengine : string -> unit
735 method set_sslenginedefault : bool -> unit
736 method set_crlf : bool -> unit
737 method set_quote : string list -> unit
738 method set_postquote : string list -> unit
739 method set_headerfunction: (string -> int) -> unit
740 method set_cookiefile : string -> unit
741 method set_sslversion : int -> unit
742 method set_timecondition : curlTimeCondition -> unit
743 method set_timevalue : int32 -> unit
744 method set_customrequest : string -> unit
745 method set_interface : string -> unit
746 method set_krb4level : curlKRB4Level -> unit
747 method set_progressfunction :
748 (float -> float -> float -> float -> bool) -> unit
749 method set_sslverifypeer : bool -> unit
750 method set_cainfo : string -> unit
751 method set_capath : string -> unit
752 method set_filetime : bool -> unit
753 method set_maxredirs : int -> unit
754 method set_maxconnects : int -> unit
755 method set_closepolicy : curlClosePolicy -> unit
756 method set_freshconnect : bool -> unit
757 method set_forbidreuse : bool -> unit
758 method set_randomfile : string -> unit
759 method set_egdsocket : string -> unit
760 method set_connecttimeout : int -> unit
761 method set_httpget : bool -> unit
762 method set_sslverifyhost : curlSSLVerifyHost -> unit
763 method set_cookiejar : string -> unit
764 method set_sslcipherlist : string -> unit
765 method set_httpversion : curlHTTPVersion -> unit
766 method set_ftpuseepsv : bool -> unit
767 method set_dnscachetimeout : int -> unit
768 method set_dnsuseglobalcache : bool -> unit
769 method set_debugfunction : (t -> curlDebugType -> string -> unit) -> unit
770 method set_private : string -> unit
771 method set_http200aliases : string list -> unit
772 method set_unrestrictedauth : bool -> unit
773 method set_ftpuseeprt : bool -> unit
774 method set_httpauth : curlAuth list -> unit
775 method set_ftpcreatemissingdirs : bool -> unit
776 method set_proxyauth : curlAuth list -> unit
777 method set_ftpresponsetimeout : int -> unit
778 method set_ipresolve : curlIPResolve -> unit
779 method set_maxfilesize : int32 -> unit
780 method set_infilesizelarge : int64 -> unit
781 method set_resumefromlarge : int64 -> unit
782 method set_maxfilesizelarge : int64 -> unit
783 method set_netrcfile : string -> unit
784 method set_ftpssl : curlFTPSSL -> unit
785 method set_postfieldsizelarge : int64 -> unit
786 method set_tcpnodelay : bool -> unit
787 method set_ftpsslauth : curlFTPSSLAuth -> unit
788 method set_ioctlfunction : (t -> curlIOCmd -> curlIOErr) -> unit
789 method set_ftpaccount : string -> unit
790 method set_cookielist : string -> unit
791 method set_ignorecontentlength : bool -> unit
792 method set_ftpskippasvip : bool -> unit
793 method set_ftpfilemethod : curlFTPMethod -> unit
794 method set_localport : int -> unit
795 method set_localportrange : int -> unit
796 method set_connectonly : bool -> unit
797 method set_maxsendspeedlarge : int64 -> unit
798 method set_maxrecvspeedlarge : int64 -> unit
799 method set_ftpalternativetouser : string -> unit
800 method set_sslsessionidcache : bool -> unit
801 method set_sshauthtypes : curlSSHAuthTypes list -> unit
802 method set_sshpublickeyfile : string -> unit
803 method set_sshprivatekeyfile : string -> unit
804 method set_ftpsslccc : curlFTPSSLCCC -> unit
805 method set_timeoutms : int -> unit
806 method set_connecttimeoutms : int -> unit
807 method set_httptransferdecoding : bool -> unit
808 method set_httpcontentdecoding : bool -> unit
809 method set_newfileperms : int -> unit
810 method set_newdirectoryperms : int -> unit
811 method set_post301 : bool -> unit
812 method set_sshhostpublickeymd5 : string -> unit
813 method set_copypostfields : string -> unit
814 method set_proxytransfermode : bool -> unit
815 method set_seekfunction : (int64 -> curlSeek -> curlSeekResult) -> unit
816 method set_autoreferer : bool -> unit
817 method set_opensocketfunction : (Unix.file_descr -> unit) -> unit
818 method set_proxytype : curlProxyType -> unit
819 method set_resolve : (string * int * string) list -> (string * int) list -> unit
820 method set_dns_servers : string list -> unit
822 method get_effectiveurl : string
823 method get_redirecturl : string
824 method get_httpcode : int
825 method get_responsecode : int
826 method get_totaltime : float
827 method get_namelookuptime : float
828 method get_connecttime : float
829 method get_pretransfertime : float
830 method get_sizeupload : float
831 method get_sizedownload : float
832 method get_speeddownload : float
833 method get_speedupload : float
834 method get_headersize : int
835 method get_requestsize : int
836 method get_sslverifyresult : int
837 method get_filetime : float
838 method get_contentlengthdownload : float
839 method get_contentlengthupload : float
840 method get_starttransfertime : float
841 method get_contenttype : string
842 method get_redirecttime : float
843 method get_redirectcount : int
844 method get_private : string
845 method get_httpconnectcode : int
846 method get_httpauthavail : curlAuth list
847 method get_proxyauthavail : curlAuth list
848 method get_oserrno : int
849 method get_numconnects : int
850 method get_sslengines : string list
851 method get_cookielist : string list
852 method get_lastsocket : int
853 method get_ftpentrypath : string
854 method get_primaryip : string
855 method get_localip : string
856 method get_localport : int
857 method get_conditionunmet : bool
860 (** {2 curl_multi API} *)
862 (** Curl multi stack. Functions may raise [Failure] on critical errors *)
863 module Multi : sig
865 (** type of Curl multi stack *)
866 type mt
868 (** exception raised on internal errors *)
869 exception Error of string
871 (** create new multi stack *)
872 val create : unit -> mt
874 (** add handle to multi stack *)
875 val add : mt -> t -> unit
877 (** remove handle from multi stack (effectively halting the transfer) *)
878 val remove : mt -> t -> unit
880 (** perform pending data transfers (if any) on all handles currently in multi stack
881 @return the number of handles that still transfer data *)
882 val perform : mt -> int
884 (** wait till there are some active data transfers on multi stack
885 @return whether [perform] should be called *)
886 val wait : mt -> bool
888 (** remove finished handle from the multi stack if any. The returned handle may be reused *)
889 val remove_finished : mt -> (t * curlCode) option
891 (** destroy multi handle (all transfers are stopped, but individual {!type: Curl.t} handles can be reused) *)
892 val cleanup : mt -> unit
894 (** events that should be reported for the socket *)
895 type poll =
896 | POLL_NONE (** none *)
897 | POLL_IN (** available for reading *)
898 | POLL_OUT (** available for writing *)
899 | POLL_INOUT (** both *)
900 | POLL_REMOVE (** socket not needed anymore *)
902 (** socket status *)
903 type fd_status =
904 | EV_AUTO (** determine socket status automatically (with extra system call) *)
905 | EV_IN (** socket has incoming data *)
906 | EV_OUT (** socket is available for writing *)
907 | EV_INOUT (** both *)
909 (** set the function to receive notifications on what socket events
910 are currently interesting for libcurl on the specified socket handle *)
911 val set_socket_function : mt -> (Unix.file_descr -> poll -> unit) -> unit
913 (** set the function to receive notification when libcurl internal timeout changes,
914 timeout value is in milliseconds
916 NB {!action_timeout} should be called when timeout occurs *)
917 val set_timer_function : mt -> (int -> unit) -> unit
919 (** perform pending data transfers (if any) on all handles currently in multi stack
920 (not recommended, {!action} should be used instead)
921 @return the number of handles that still transfer data
922 @raise Error on errors
924 val action_all : mt -> int
926 (** inform libcurl that timeout occured
927 @raise Error on errors
929 val action_timeout : mt -> unit
931 (** [action mt fd status] informs libcurl about event on the specified socket.
932 [status] specifies socket status. Perform pending data transfers.
933 @return the number of handles still active
934 @raise Error on errors
936 val action : mt -> Unix.file_descr -> fd_status -> int
938 (** [timeout mt] polls multi handle for timeout (not recommended, use {!set_timer_function} instead).
939 @return maximum allowed number of milliseconds to wait before calling libcurl to perform actions
940 @raise Error on errors
942 external timeout : mt -> int = "caml_curl_multi_timeout"