[libsoup] Revert "cookie-jar: use base domain to decide if cookie is third party"
- From: Claudio Saavedra <csaavedra src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libsoup] Revert "cookie-jar: use base domain to decide if cookie is third party"
- Date: Mon, 5 Mar 2018 17:31:36 +0000 (UTC)
commit 15abc70541531f916e4cf19010ffef5fc656005e
Author: Claudio Saavedra <csaavedra igalia com>
Date: Mon Mar 5 19:24:11 2018 +0200
Revert "cookie-jar: use base domain to decide if cookie is third party"
This reverts commit 20a8463ae65369ac17f8bca7749be188a275a99f.
libsoup/soup-cookie-jar.c | 26 ++---------------------
tests/cookies-test.c | 48 ---------------------------------------------
2 files changed, 3 insertions(+), 71 deletions(-)
---
diff --git a/libsoup/soup-cookie-jar.c b/libsoup/soup-cookie-jar.c
index 0068874..41b614a 100644
--- a/libsoup/soup-cookie-jar.c
+++ b/libsoup/soup-cookie-jar.c
@@ -12,7 +12,6 @@
#include <string.h>
#include "soup-cookie-jar.h"
-#include "soup-misc-private.h"
#include "soup.h"
/**
@@ -510,26 +509,6 @@ soup_cookie_jar_add_cookie (SoupCookieJar *jar, SoupCookie *cookie)
soup_cookie_jar_changed (jar, NULL, cookie);
}
-static gboolean
-incoming_cookie_is_third_party (SoupCookie *cookie, SoupURI *first_party)
-{
- const char *cookie_base_domain;
- const char *first_party_base_domain;
-
- if (first_party == NULL || first_party->host == NULL)
- return TRUE;
-
- cookie_base_domain = soup_tld_get_base_domain (cookie->domain, NULL);
- if (cookie_base_domain == NULL)
- cookie_base_domain = cookie->domain;
-
- first_party_base_domain = soup_tld_get_base_domain (first_party->host, NULL);
- if (first_party_base_domain == NULL)
- first_party_base_domain = first_party->host;
-
- return !soup_host_matches_host (cookie_base_domain, first_party_base_domain);
-}
-
/**
* soup_cookie_jar_add_cookie_with_first_party:
* @jar: a #SoupCookieJar
@@ -563,7 +542,7 @@ soup_cookie_jar_add_cookie_with_first_party (SoupCookieJar *jar, SoupURI *first_
}
if (priv->accept_policy == SOUP_COOKIE_JAR_ACCEPT_ALWAYS ||
- !incoming_cookie_is_third_party (cookie, first_party)) {
+ soup_cookie_domain_matches (cookie, first_party->host)) {
/* will steal or free soup_cookie */
soup_cookie_jar_add_cookie (jar, cookie);
} else {
@@ -665,7 +644,8 @@ process_set_cookie_header (SoupMessage *msg, gpointer user_data)
SoupURI *first_party = soup_message_get_first_party (msg);
if ((priv->accept_policy == SOUP_COOKIE_JAR_ACCEPT_NO_THIRD_PARTY &&
- !incoming_cookie_is_third_party (nc->data, first_party)) ||
+ first_party != NULL && first_party->host &&
+ soup_cookie_domain_matches (nc->data, first_party->host)) ||
priv->accept_policy == SOUP_COOKIE_JAR_ACCEPT_ALWAYS)
soup_cookie_jar_add_cookie (jar, nc->data);
else
diff --git a/tests/cookies-test.c b/tests/cookies-test.c
index e029397..479bcfe 100644
--- a/tests/cookies-test.c
+++ b/tests/cookies-test.c
@@ -94,53 +94,6 @@ do_cookies_accept_policy_test (void)
soup_test_session_abort_unref (session);
}
-static void
-do_cookies_subdomain_policy_test (void)
-{
- SoupCookieJar *jar;
- GSList *cookies;
- SoupURI *uri1;
- SoupURI *uri2;
-
- g_test_bug ("792130");
-
- /* Only the base domain should be considered when deciding
- * whether a cookie is a third-party cookie.
- */
- uri1 = soup_uri_new ("https://www.gnome.org");
- uri2 = soup_uri_new ("https://foundation.gnome.org");
-
- /* We can't check subdomains with a test server running on
- * localhost, so we'll just check the cookie jar API itself.
- */
-
- /* Cookie should be accepted. One cookie in the jar. */
- jar = soup_cookie_jar_new ();
- soup_cookie_jar_set_accept_policy (jar, SOUP_COOKIE_JAR_ACCEPT_NO_THIRD_PARTY);
- soup_cookie_jar_set_cookie_with_first_party (jar, uri1, uri2, "1=foo");
- cookies = soup_cookie_jar_all_cookies (jar);
- g_assert_cmpint (g_slist_length (cookies), ==, 1);
- g_slist_free_full (cookies, (GDestroyNotify)soup_cookie_free);
-
- /* Cookie should be accepted. Two cookies in the jar. */
- soup_cookie_jar_set_cookie_with_first_party (jar, uri2, uri1, "2=foo");
- cookies = soup_cookie_jar_all_cookies (jar);
- g_assert_cmpint (g_slist_length (cookies), ==, 2);
- g_slist_free_full (cookies, (GDestroyNotify)soup_cookie_free);
-
- /* Third-party cookie should be rejected, so there are still
- * only two cookies in the jar.
- */
- soup_cookie_jar_set_cookie_with_first_party (jar, third_party_uri, uri1, "3=foo");
- cookies = soup_cookie_jar_all_cookies (jar);
- g_assert_cmpint (g_slist_length (cookies), ==, 2);
- g_slist_free_full (cookies, (GDestroyNotify)soup_cookie_free);
-
- soup_uri_free (uri1);
- soup_uri_free (uri2);
- g_object_unref (jar);
-}
-
/* FIXME: moar tests! */
static void
do_cookies_parsing_test (void)
@@ -229,7 +182,6 @@ main (int argc, char **argv)
soup_uri_set_port (third_party_uri, server_uri->port);
g_test_add_func ("/cookies/accept-policy", do_cookies_accept_policy_test);
- g_test_add_func ("/cookies/accept-policy-subdomains", do_cookies_subdomain_policy_test);
g_test_add_func ("/cookies/parsing", do_cookies_parsing_test);
ret = g_test_run ();
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]