summaryrefslogtreecommitdiff
path: root/src/lib/exchange_api_curl_defaults.c
blob: 45aa36b9f91c3b78b6b6eb29fb8c05af4ce8bb06 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
/*
  This file is part of TALER
  Copyright (C) 2014-2018 GNUnet e.V.

  TALER is free software; you can redistribute it and/or modify it under the
  terms of the GNU General Public License as published by the Free Software
  Foundation; either version 3, or (at your option) any later version.

  TALER is distributed in the hope that it will be useful, but WITHOUT ANY
  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
  A PARTICULAR PURPOSE.  See the GNU General Public License for more details.

  You should have received a copy of the GNU General Public License along with
  TALER; see the file COPYING.  If not, see
  <http://www.gnu.org/licenses/>
*/
/**
 * @file lib/exchange_api_curl_defaults.c
 * @brief curl easy handle defaults
 * @author Florian Dold
 */

#include "exchange_api_curl_defaults.h"


/**
 * Get a curl handle with the right defaults
 * for the exchange lib.  In the future, we might manage a pool of connections here.
 *
 * @param url URL to query
 */
CURL *
TEL_curl_easy_get (const char *url)
{
  CURL *eh;

  eh = curl_easy_init ();

  GNUNET_assert (CURLE_OK ==
                 curl_easy_setopt (eh,
                                   CURLOPT_URL,
                                   url));
  GNUNET_assert (CURLE_OK ==
                 curl_easy_setopt (eh,
                                   CURLOPT_ENCODING,
                                   "deflate"));
#ifdef CURLOPT_TCP_FASTOPEN
  GNUNET_assert (CURLE_OK ==
                 curl_easy_setopt (eh,
                                   CURLOPT_TCP_FASTOPEN,
                                   1L));
#endif
  {
    /* Unfortunately libcurl needs chunk to be alive until after
    curl_easy_perform.  To avoid manual cleanup, we keep
    one static list here.  */
    static struct curl_slist *chunk = NULL;
    if (NULL == chunk)
    {
      /* With POST requests, we do not want to wait for the
      "100 Continue" response, as our request bodies are usually
      small and directy sending them saves us a round trip.

      Clearing the expect header like this disables libcurl's
      default processing of the header.

      Disabling this header is safe for other HTTP methods, thus
      we don't distinguish further before setting it.  */
      chunk = curl_slist_append (chunk, "Expect:");
    }
    GNUNET_assert (CURLE_OK == curl_easy_setopt (eh, CURLOPT_HTTPHEADER, chunk));
  }

  return eh;
}