diff options
author | Carlos Garcia Campos <cgarcia@igalia.com> | 2012-06-07 00:03:57 +0800 |
---|---|---|
committer | Carlos Garcia Campos <carlosgc@gnome.org> | 2012-06-26 20:39:38 +0800 |
commit | bab68f12adaed81397aa34cbfe760eafc51c993f (patch) | |
tree | 86e7210793633258a239d4f6596ea658246ec72f /embed | |
parent | 990ee247b9613724f764b1bca2ff721e5688fcd8 (diff) | |
download | gsoc2013-epiphany-bab68f12adaed81397aa34cbfe760eafc51c993f.tar.gz gsoc2013-epiphany-bab68f12adaed81397aa34cbfe760eafc51c993f.tar.zst gsoc2013-epiphany-bab68f12adaed81397aa34cbfe760eafc51c993f.zip |
Port geolocation permission request to WebKit2
https://bugzilla.gnome.org/show_bug.cgi?id=678614
Diffstat (limited to 'embed')
-rw-r--r-- | embed/ephy-web-view.c | 47 |
1 files changed, 40 insertions, 7 deletions
diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c index cfc185a52..48ed732f8 100644 --- a/embed/ephy-web-view.c +++ b/embed/ephy-web-view.c @@ -1847,7 +1847,25 @@ mime_type_policy_decision_requested_cb (WebKitWebView *web_view, #endif #ifdef HAVE_WEBKIT2 -/* TODO: Geolocation */ +static void +decide_on_geolocation_policy_request (GtkWidget *info_bar, + int response, + WebKitPermissionRequest *request) +{ + gtk_widget_destroy (info_bar); + + switch (response) { + case GTK_RESPONSE_YES: + webkit_permission_request_allow (request); + break; + default: + webkit_permission_request_deny (request); + break; + } + + gtk_widget_destroy (info_bar); + g_object_unref (request); +} #else static void decide_on_geolocation_policy_request (GtkWidget *info_bar, @@ -1866,12 +1884,19 @@ decide_on_geolocation_policy_request (GtkWidget *info_bar, webkit_geolocation_policy_deny (decision); g_object_unref (decision); } +#endif +#ifdef HAVE_WEBKIT2 +static gboolean +permission_request_cb (WebKitWebView *web_view, + WebKitPermissionRequest *decision) +#else static gboolean geolocation_policy_decision_requested_cb (WebKitWebView *web_view, WebKitWebFrame *web_frame, WebKitGeolocationPolicyDecision *decision, gpointer data) +#endif { GtkWidget *info_bar; GtkWidget *action_area; @@ -1882,6 +1907,11 @@ geolocation_policy_decision_requested_cb (WebKitWebView *web_view, char *message; char *host; +#ifdef HAVE_WEBKIT2 + if (!WEBKIT_IS_GEOLOCATION_PERMISSION_REQUEST (decision)) + return FALSE; +#endif + info_bar = gtk_info_bar_new (); /* Buttons */ @@ -1903,7 +1933,11 @@ geolocation_policy_decision_requested_cb (WebKitWebView *web_view, G_CALLBACK (send_yes_response_cb), info_bar); /* Label */ +#ifdef HAVE_WEBKIT2 + host = ephy_string_get_host_name (webkit_web_view_get_uri (web_view)); +#else host = ephy_string_get_host_name (webkit_web_frame_get_uri (web_frame)); +#endif message = g_markup_printf_escaped (_("The page at <b>%s</b> wants to know your location."), host); g_free (host); @@ -1918,19 +1952,16 @@ geolocation_policy_decision_requested_cb (WebKitWebView *web_view, gtk_widget_show_all (info_bar); + /* Ref the decision, to keep it alive while we decide */ g_signal_connect (info_bar, "response", G_CALLBACK (decide_on_geolocation_policy_request), - decision); + g_object_ref (decision)); ephy_embed_add_top_widget (EPHY_GET_EMBED_FROM_EPHY_WEB_VIEW (web_view), info_bar, TRUE); - /* Ref the decision, to keep it alive while we decide */ - g_object_ref (decision); - return TRUE; } -#endif #ifdef HAVE_WEBKIT2 /* TODO: DOM Bindings */ @@ -2662,7 +2693,9 @@ ephy_web_view_init (EphyWebView *web_view) #endif #ifdef HAVE_WEBKIT2 - /* TODO: Geolocation */ + g_signal_connect (web_view, "permission-request", + G_CALLBACK (permission_request_cb), + NULL); #else g_signal_connect (web_view, "geolocation-policy-decision-requested", G_CALLBACK (geolocation_policy_decision_requested_cb), |