diff options
author | Christian Persch <chpe@cvs.gnome.org> | 2005-01-12 03:15:27 +0800 |
---|---|---|
committer | Christian Persch <chpe@src.gnome.org> | 2005-01-12 03:15:27 +0800 |
commit | 4f4141d49c35db2106fc8b84f08a03a4e416dc20 (patch) | |
tree | 889188d66ca9d0c93440fc954cef5ce609266031 /embed/mozilla/EphyContentPolicy.cpp | |
parent | fa0d7a25b665db353b859e3785271d02dfb2be36 (diff) | |
download | gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar.gz gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar.bz2 gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar.lz gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar.xz gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.tar.zst gsoc2013-epiphany-4f4141d49c35db2106fc8b84f08a03a4e416dc20.zip |
Add "check-content" signal.
2005-01-11 Christian Persch <chpe@cvs.gnome.org>
* embed/ephy-embed-single.c: (ephy_embed_single_iface_init):
* embed/ephy-embed-single.h:
Add "check-content" signal.
* embed/mozilla/EphyContentPolicy.cpp:
* embed/mozilla/EphyContentPolicy.h:
Emit from here.
* lib/ephy-marshal.list:
New marshal.
Diffstat (limited to 'embed/mozilla/EphyContentPolicy.cpp')
-rw-r--r-- | embed/mozilla/EphyContentPolicy.cpp | 125 |
1 files changed, 90 insertions, 35 deletions
diff --git a/embed/mozilla/EphyContentPolicy.cpp b/embed/mozilla/EphyContentPolicy.cpp index 5eb2e5404..98f5f3afd 100644 --- a/embed/mozilla/EphyContentPolicy.cpp +++ b/embed/mozilla/EphyContentPolicy.cpp @@ -25,6 +25,8 @@ #include "EphyContentPolicy.h" +#include "ephy-embed-shell.h" +#include "ephy-embed-single.h" #include "eel-gconf-extensions.h" #include "ephy-debug.h" @@ -49,6 +51,8 @@ EphyContentPolicy::EphyContentPolicy() mSafeProtocols = g_slist_prepend (mSafeProtocols, g_strdup ("https")); mSafeProtocols = g_slist_prepend (mSafeProtocols, g_strdup ("http")); + mEmbedSingle = ephy_embed_shell_get_embed_single (embed_shell); + g_return_if_fail (mEmbedSingle); } EphyContentPolicy::~EphyContentPolicy() @@ -69,33 +73,46 @@ EphyContentPolicy::ShouldLoad(PRUint32 aContentType, nsISupports *aExtra, PRInt16 *aDecision) { - if (!mLocked) - { - *aDecision = nsIContentPolicy::ACCEPT; - return NS_OK; - } + NS_ENSURE_ARG (aContentLocation); - NS_ENSURE_TRUE (aContentLocation, NS_ERROR_FAILURE); + nsEmbedCString contentScheme; + aContentLocation->GetScheme (contentScheme); - nsEmbedCString scheme; - aContentLocation->GetScheme (scheme); + nsEmbedCString contentSpec; + aContentLocation->GetSpec (contentSpec); - nsEmbedCString spec; - aContentLocation->GetSpec (spec); + /* first general lockdown check */ + if (mLocked && + !g_slist_find_custom (mSafeProtocols, contentScheme.get(), (GCompareFunc) strcmp) && + strcmp (contentSpec.get(), "about:blank") != 0) + { + *aDecision = nsIContentPolicy::REJECT_REQUEST; + return NS_OK; + } - LOG ("ShouldLoad type=%d location=%s (scheme %s)", aContentType, spec.get(), scheme.get()) + nsEmbedCString requestingSpec; + if (aRequestingLocation) + { + aRequestingLocation->GetSpec (requestingSpec); + } - *aDecision = nsIContentPolicy::REJECT_REQUEST; + gboolean result = FALSE; + g_signal_emit_by_name (mEmbedSingle, "check-content", + (EphyContentCheckType) aContentType, + contentSpec.get(), + requestingSpec.get(), + nsEmbedCString(aMimeTypeGuess).get(), + &result); - /* Allow the load if the protocol is in safe list, or it's about:blank */ - if (g_slist_find_custom (mSafeProtocols, scheme.get(), (GCompareFunc) strcmp) - || strcmp (spec.get(), "about:blank") == 0) + if (result) + { + *aDecision = nsIContentPolicy::REJECT_REQUEST; + } + else { *aDecision = nsIContentPolicy::ACCEPT; } - LOG ("Decision: %sallowing load", *aDecision >= 0 ? "" : "DIS") - return NS_OK; } @@ -115,33 +132,71 @@ EphyContentPolicy::ShouldProcess(PRUint32 aContentType, #else /* boolean shouldLoad (in PRInt32 contentType, in nsIURI contentLocation, in nsISupports ctxt, in nsIDOMWindow window); */ -NS_IMETHODIMP EphyContentPolicy::ShouldLoad(PRInt32 contentType, - nsIURI *contentLocation, - nsISupports *ctxt, - nsIDOMWindow *window, +NS_IMETHODIMP EphyContentPolicy::ShouldLoad(PRInt32 aContentType, + nsIURI *aContentLocation, + nsISupports *aContext, + nsIDOMWindow *aWindow, PRBool *_retval) { - if (!mLocked) - { - *_retval = PR_TRUE; - return NS_OK; - } + NS_ENSURE_ARG (aContentLocation); - nsEmbedCString scheme; - contentLocation->GetScheme (scheme); + nsEmbedCString contentScheme; + aContentLocation->GetScheme (contentScheme); - nsEmbedCString spec; - contentLocation->GetSpec (spec); + nsEmbedCString contentSpec; + aContentLocation->GetSpec (contentSpec); - *_retval = PR_FALSE; + /* first general lockdown check */ + if (mLocked && + !g_slist_find_custom (mSafeProtocols, contentScheme.get(), (GCompareFunc) strcmp) && + strcmp (contentSpec.get(), "about:blank") != 0) + { + *_retval = PR_FALSE; + return NS_OK; + } - /* Allow the load if the protocol is in safe list, or it's about:blank */ - if (g_slist_find_custom (mSafeProtocols, scheme.get(), (GCompareFunc) strcmp) - || strcmp (spec.get(), "about:blank") == 0) + /* translate to variant-2 types */ + EphyContentCheckType type; + switch (aContentType) { - *_retval = PR_TRUE; + case nsIContentPolicy::SCRIPT: + type = EPHY_CONTENT_CHECK_TYPE_SCRIPT; + break; + case nsIContentPolicy::IMAGE: + type = EPHY_CONTENT_CHECK_TYPE_IMAGE; + break; + case nsIContentPolicy::STYLESHEET: + type = EPHY_CONTENT_CHECK_TYPE_STYLESHEET; + break; + case nsIContentPolicy::OBJECT: + type = EPHY_CONTENT_CHECK_TYPE_OBJECT; + break; + case nsIContentPolicy::SUBDOCUMENT: + type = EPHY_CONTENT_CHECK_TYPE_SUBDOCUMENT; + break; + case nsIContentPolicy::CONTROL_TAG: + type = EPHY_CONTENT_CHECK_TYPE_REFRESH; + break; + case nsIContentPolicy::DOCUMENT: + type = EPHY_CONTENT_CHECK_TYPE_DOCUMENT; + break; + case nsIContentPolicy::OTHER: + case nsIContentPolicy::RAW_URL: + default: + type = EPHY_CONTENT_CHECK_TYPE_OTHER; + break; } + gboolean result = FALSE; + g_signal_emit_by_name (mEmbedSingle, "check-content", + type, + contentSpec.get(), + "", + "", + &result); + + *_retval = !result; + return NS_OK; } |