xref: /aosp_15_r20/external/curl/docs/libcurl/opts/CURLOPT_TIMECONDITION.md (revision 6236dae45794135f37c4eb022389c904c8b0090d)
1*6236dae4SAndroid Build Coastguard Worker---
2*6236dae4SAndroid Build Coastguard Workerc: Copyright (C) Daniel Stenberg, <[email protected]>, et al.
3*6236dae4SAndroid Build Coastguard WorkerSPDX-License-Identifier: curl
4*6236dae4SAndroid Build Coastguard WorkerTitle: CURLOPT_TIMECONDITION
5*6236dae4SAndroid Build Coastguard WorkerSection: 3
6*6236dae4SAndroid Build Coastguard WorkerSource: libcurl
7*6236dae4SAndroid Build Coastguard WorkerSee-also:
8*6236dae4SAndroid Build Coastguard Worker  - CURLINFO_FILETIME (3)
9*6236dae4SAndroid Build Coastguard Worker  - CURLOPT_TIMEVALUE (3)
10*6236dae4SAndroid Build Coastguard WorkerProtocol:
11*6236dae4SAndroid Build Coastguard Worker  - HTTP
12*6236dae4SAndroid Build Coastguard WorkerAdded-in: 7.1
13*6236dae4SAndroid Build Coastguard Worker---
14*6236dae4SAndroid Build Coastguard Worker
15*6236dae4SAndroid Build Coastguard Worker# NAME
16*6236dae4SAndroid Build Coastguard Worker
17*6236dae4SAndroid Build Coastguard WorkerCURLOPT_TIMECONDITION - select condition for a time request
18*6236dae4SAndroid Build Coastguard Worker
19*6236dae4SAndroid Build Coastguard Worker# SYNOPSIS
20*6236dae4SAndroid Build Coastguard Worker
21*6236dae4SAndroid Build Coastguard Worker~~~c
22*6236dae4SAndroid Build Coastguard Worker#include <curl/curl.h>
23*6236dae4SAndroid Build Coastguard Worker
24*6236dae4SAndroid Build Coastguard WorkerCURLcode curl_easy_setopt(CURL *handle, CURLOPT_TIMECONDITION, long cond);
25*6236dae4SAndroid Build Coastguard Worker~~~
26*6236dae4SAndroid Build Coastguard Worker
27*6236dae4SAndroid Build Coastguard Worker# DESCRIPTION
28*6236dae4SAndroid Build Coastguard Worker
29*6236dae4SAndroid Build Coastguard WorkerPass a long as parameter. This defines how the CURLOPT_TIMEVALUE(3) time
30*6236dae4SAndroid Build Coastguard Workervalue is treated. You can set this parameter to *CURL_TIMECOND_IFMODSINCE*
31*6236dae4SAndroid Build Coastguard Workeror *CURL_TIMECOND_IFUNMODSINCE*.
32*6236dae4SAndroid Build Coastguard Worker
33*6236dae4SAndroid Build Coastguard WorkerThe last modification time of a file is not always known and in such instances
34*6236dae4SAndroid Build Coastguard Workerthis feature has no effect even if the given time condition would not have
35*6236dae4SAndroid Build Coastguard Workerbeen met. curl_easy_getinfo(3) with the *CURLINFO_CONDITION_UNMET*
36*6236dae4SAndroid Build Coastguard Workeroption can be used after a transfer to learn if a zero-byte successful
37*6236dae4SAndroid Build Coastguard Worker"transfer" was due to this condition not matching.
38*6236dae4SAndroid Build Coastguard Worker
39*6236dae4SAndroid Build Coastguard Worker# DEFAULT
40*6236dae4SAndroid Build Coastguard Worker
41*6236dae4SAndroid Build Coastguard WorkerCURL_TIMECOND_NONE (0)
42*6236dae4SAndroid Build Coastguard Worker
43*6236dae4SAndroid Build Coastguard Worker# %PROTOCOLS%
44*6236dae4SAndroid Build Coastguard Worker
45*6236dae4SAndroid Build Coastguard Worker# EXAMPLE
46*6236dae4SAndroid Build Coastguard Worker
47*6236dae4SAndroid Build Coastguard Worker~~~c
48*6236dae4SAndroid Build Coastguard Workerint main(void)
49*6236dae4SAndroid Build Coastguard Worker{
50*6236dae4SAndroid Build Coastguard Worker  CURL *curl = curl_easy_init();
51*6236dae4SAndroid Build Coastguard Worker  if(curl) {
52*6236dae4SAndroid Build Coastguard Worker    curl_easy_setopt(curl, CURLOPT_URL, "https://example.com");
53*6236dae4SAndroid Build Coastguard Worker
54*6236dae4SAndroid Build Coastguard Worker    /* January 1, 2020 is 1577833200 */
55*6236dae4SAndroid Build Coastguard Worker    curl_easy_setopt(curl, CURLOPT_TIMEVALUE, 1577833200L);
56*6236dae4SAndroid Build Coastguard Worker
57*6236dae4SAndroid Build Coastguard Worker    /* If-Modified-Since the above time stamp */
58*6236dae4SAndroid Build Coastguard Worker    curl_easy_setopt(curl, CURLOPT_TIMECONDITION,
59*6236dae4SAndroid Build Coastguard Worker                     (long)CURL_TIMECOND_IFMODSINCE);
60*6236dae4SAndroid Build Coastguard Worker
61*6236dae4SAndroid Build Coastguard Worker    /* Perform the request */
62*6236dae4SAndroid Build Coastguard Worker    curl_easy_perform(curl);
63*6236dae4SAndroid Build Coastguard Worker  }
64*6236dae4SAndroid Build Coastguard Worker}
65*6236dae4SAndroid Build Coastguard Worker~~~
66*6236dae4SAndroid Build Coastguard Worker
67*6236dae4SAndroid Build Coastguard Worker# %AVAILABILITY%
68*6236dae4SAndroid Build Coastguard Worker
69*6236dae4SAndroid Build Coastguard Worker# RETURN VALUE
70*6236dae4SAndroid Build Coastguard Worker
71*6236dae4SAndroid Build Coastguard WorkerReturns CURLE_OK
72