diff options
| -rw-r--r-- | src/exchange/taler-exchange-httpd_keys.c | 10 | ||||
| -rw-r--r-- | src/exchange/taler-exchange-httpd_wire.c | 11 | ||||
| -rw-r--r-- | src/mhd/mhd_legal.c | 13 | 
3 files changed, 33 insertions, 1 deletions
| diff --git a/src/exchange/taler-exchange-httpd_keys.c b/src/exchange/taler-exchange-httpd_keys.c index a8484909..dea29f7d 100644 --- a/src/exchange/taler-exchange-httpd_keys.c +++ b/src/exchange/taler-exchange-httpd_keys.c @@ -1703,6 +1703,16 @@ setup_general_response_headers (struct TEH_KeyStateHandle *ksh,        = GNUNET_TIME_timestamp_min (m,                                     ksh->signature_expires);    } +  /* Set cache control headers: our response varies depending on these headers */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (response, +                                         MHD_HTTP_HEADER_VARY, +                                         MHD_HTTP_HEADER_ACCEPT_ENCODING)); +  /* Information is always public, revalidate after 1 hour */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (response, +                                         MHD_HTTP_HEADER_CACHE_CONTROL, +                                         "public,max-age=3600"));    return GNUNET_OK;  } diff --git a/src/exchange/taler-exchange-httpd_wire.c b/src/exchange/taler-exchange-httpd_wire.c index e2baa1ce..aa187c1c 100644 --- a/src/exchange/taler-exchange-httpd_wire.c +++ b/src/exchange/taler-exchange-httpd_wire.c @@ -483,6 +483,17 @@ build_wire_state (void)                                             wsh->dat));    }    TALER_MHD_add_global_headers (wsh->wire_reply); +  /* Set cache control headers: our response varies depending on these headers */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (wsh->wire_reply, +                                         MHD_HTTP_HEADER_VARY, +                                         MHD_HTTP_HEADER_ACCEPT_ENCODING)); +  /* Information is always public, revalidate after 1 day */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (wsh->wire_reply, +                                         MHD_HTTP_HEADER_CACHE_CONTROL, +                                         "public,max-age=86400")); +    {      struct GNUNET_HashCode h;      char etag[sizeof (h) * 2]; diff --git a/src/mhd/mhd_legal.c b/src/mhd/mhd_legal.c index bd596862..5082c181 100644 --- a/src/mhd/mhd_legal.c +++ b/src/mhd/mhd_legal.c @@ -306,7 +306,18 @@ TALER_MHD_reply_legal (struct MHD_Connection *conn,                  MHD_add_response_header (resp,                                           MHD_HTTP_HEADER_EXPIRES,                                           dat)); - +  /* Set cache control headers: our response varies depending on these headers */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (resp, +                                         MHD_HTTP_HEADER_VARY, +                                         MHD_HTTP_HEADER_ACCEPT_LANGUAGE "," +                                         MHD_HTTP_HEADER_ACCEPT "," +                                         MHD_HTTP_HEADER_ACCEPT_ENCODING)); +  /* Information is always public, revalidate after 10 days */ +  GNUNET_break (MHD_YES == +                MHD_add_response_header (resp, +                                         MHD_HTTP_HEADER_CACHE_CONTROL, +                                         "public max-age=864000"));    if (NULL != legal)      GNUNET_break (MHD_YES ==                    MHD_add_response_header (resp, | 
