aboutsummaryrefslogtreecommitdiffstats
path: root/embed/ephy-request-about.c
diff options
context:
space:
mode:
authorCarlos Garcia Campos <cgarcia@igalia.com>2012-06-22 17:17:20 +0800
committerCarlos Garcia Campos <carlosgc@gnome.org>2012-06-26 20:30:23 +0800
commit63ff2e3dc786c97d74c7c2e6ee96a26f826abca8 (patch)
treebe23fe0c6e12c42f3436874fefaec9d6189206ee /embed/ephy-request-about.c
parent213a7c80120f416b7082e54157904a638296c5cd (diff)
downloadgsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar.gz
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar.bz2
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar.lz
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar.xz
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.tar.zst
gsoc2013-epiphany-63ff2e3dc786c97d74c7c2e6ee96a26f826abca8.zip
embed: Move about handlers to a new file
Leaving in ephy-request-about only the code specific to the soup feature implementation.
Diffstat (limited to 'embed/ephy-request-about.c')
-rw-r--r--embed/ephy-request-about.c160
1 files changed, 3 insertions, 157 deletions
diff --git a/embed/ephy-request-about.c b/embed/ephy-request-about.c
index cddb9d135..9a0bcafd5 100644
--- a/embed/ephy-request-about.c
+++ b/embed/ephy-request-about.c
@@ -23,45 +23,22 @@
#endif
#include "ephy-request-about.h"
-#include "ephy-file-helpers.h"
-#include "ephy-smaps.h"
-#include "ephy-web-app-utils.h"
+#include "ephy-about-handler.h"
#include <gio/gio.h>
#include <glib/gi18n.h>
#include <libsoup/soup-uri.h>
-#ifdef HAVE_WEBKIT2
-#include <webkit2/webkit2.h>
-#else
-#include <webkit/webkit.h>
-#endif
G_DEFINE_TYPE (EphyRequestAbout, ephy_request_about, SOUP_TYPE_REQUEST)
struct _EphyRequestAboutPrivate {
gssize content_length;
- gchar *css_style;
- EphySMaps *smaps;
};
static void
ephy_request_about_init (EphyRequestAbout *about)
{
about->priv = G_TYPE_INSTANCE_GET_PRIVATE (about, EPHY_TYPE_REQUEST_ABOUT, EphyRequestAboutPrivate);
- about->priv->content_length = 0;
- about->priv->css_style = NULL;
- about->priv->smaps = ephy_smaps_new ();
-}
-
-static void
-ephy_request_about_finalize (GObject *obj)
-{
- EphyRequestAboutPrivate *priv = EPHY_REQUEST_ABOUT (obj)->priv;
-
- g_object_unref (priv->smaps);
- g_free (priv->css_style);
-
- G_OBJECT_CLASS (ephy_request_about_parent_class)->finalize (obj);
}
static gboolean
@@ -72,18 +49,6 @@ ephy_request_about_check_uri (SoupRequest *request,
return uri->host == NULL;
}
-static void
-read_css_style (EphyRequestAbout *about)
-{
- GError *error = NULL;
- const gchar *file = ephy_file ("about.css");
-
- if (file && !g_file_get_contents (file, &about->priv->css_style, NULL, &error)) {
- g_debug ("%s", error->message);
- g_error_free (error);
- }
-}
-
static GInputStream *
ephy_request_about_send (SoupRequest *request,
GCancellable *cancellable,
@@ -91,126 +56,10 @@ ephy_request_about_send (SoupRequest *request,
{
EphyRequestAbout *about = EPHY_REQUEST_ABOUT (request);
SoupURI *uri = soup_request_get_uri (request);
- GString *data_str = g_string_new("<html>");
-
- if (!about->priv->css_style)
- read_css_style (about);
-
- if (!g_strcmp0 (uri->path, "plugins")) {
-#ifdef HAVE_WEBKIT2
- /* TODO: SoupRequest and Plugins */
-#else
- WebKitWebPluginDatabase* database = webkit_get_web_plugin_database ();
- GSList *plugin_list, *p;
-
- g_string_append_printf (data_str, "<head><title>%s</title>" \
- "<style type=\"text/css\">%s</style></head><body>",
- _("Installed plugins"),
- about->priv->css_style);
-
- g_string_append_printf (data_str, "<h1>%s</h1>", _("Installed plugins"));
- plugin_list = webkit_web_plugin_database_get_plugins (database);
-
- for (p = plugin_list; p; p = p->next) {
- WebKitWebPlugin *plugin = WEBKIT_WEB_PLUGIN (p->data);
- GSList *m, *mime_types;
-
- g_string_append_printf (data_str, "<h2>%s</h2>%s<br>%s: <b>%s</b>"\
- "<table id=\"plugin-table\">" \
- " <thead><tr><th>%s</th><th>%s</th><th>%s</th></tr></thead><tbody>",
- webkit_web_plugin_get_name (plugin),
- webkit_web_plugin_get_description (plugin),
- _("Enabled"), webkit_web_plugin_get_enabled (plugin) ? _("Yes") : _("No"),
- _("MIME type"), _("Description"), _("Suffixes"));
-
- mime_types = webkit_web_plugin_get_mimetypes (plugin);
+ GString *data_str = ephy_about_handler_handle (uri->path);
- for (m = mime_types; m; m = m->next) {
- WebKitWebPluginMIMEType *mime_type = (WebKitWebPluginMIMEType*) m->data;
- guint i;
-
- g_string_append_printf (data_str, "<tr><td>%s</td><td>%s</td><td>",
- mime_type->name, mime_type->description);
-
- for (i = 0; mime_type->extensions[i] != NULL; i++)
- g_string_append_printf (data_str, "%s%c", mime_type->extensions[i],
- mime_type->extensions[i + 1] ? ',' : ' ');
-
- g_string_append (data_str, "</td></tr>");
- }
-
- g_string_append (data_str, "</tbody></table>");
- }
-
- webkit_web_plugin_database_plugins_list_free (plugin_list);
-#endif
- g_string_append (data_str, "</body>");
- } else if (!g_strcmp0 (uri->path, "memory")) {
- char *memory = ephy_smaps_to_html (EPHY_REQUEST_ABOUT (request)->priv->smaps);
-
- if (memory) {
- g_string_append_printf (data_str, "<head><title>%s</title>" \
- "<style type=\"text/css\">%s</style></head><body>",
- _("Memory usage"),
- about->priv->css_style);
-
- g_string_append_printf (data_str, "<h1>%s</h1>", _("Memory usage"));
- g_string_append (data_str, memory);
- g_free (memory);
- }
-
- } else if (!g_strcmp0 (uri->path, "epiphany")) {
- g_string_append_printf (data_str, "<head><title>Epiphany</title>" \
- "<style type=\"text/css\">%s</style></head>" \
- "<body style=\"background: #3369FF; color: white; font-style: italic;\">",
- about->priv->css_style);
-
- g_string_append (data_str, "<div id=\"ephytext\">" \
- "Il semble que la perfection soit atteinte non quand il n'y a plus rien à" \
- " ajouter, mais quand il n'y a plus rien à retrancher." \
- "</div>" \
- "<div id=\"from\">" \
- "<!-- Terre des Hommes, III: L'Avion, p. 60 -->" \
- "Antoine de Saint-Exupéry" \
- "</div></body>");
- } else if (!g_strcmp0 (uri->path, "applications")) {
- GList *applications, *p;
-
- g_string_append_printf (data_str, "<head><title>%s</title>" \
- "<style type=\"text/css\">%s</style></head>" \
- "<body class=\"applications-body\"><h1>%s</h1>" \
- "<p>%s</p>",
- _("Applications"),
- about->priv->css_style,
- _("Applications"),
- _("List of installed web applications"));
-
-
- g_string_append (data_str, "<form><table>");
-
- applications = ephy_web_application_get_application_list ();
- for (p = applications; p; p = p->next) {
- char *icon_uri;
- EphyWebApplication *app = (EphyWebApplication*)p->data;
-
- icon_uri = ephy_file_create_data_uri_for_filename (app->icon_url, "image/png");
- g_string_append_printf (data_str, "<tbody><tr><td class=\"icon\"><img width=64 height=64 src=\"%s\">" \
- " </img></td><td class=\"data\"><div class=\"appname\">%s</div><div class=\"appurl\">%s</div></td><td class=\"input\"><input type=\"submit\" value=\"Delete\" id=\"%s\"></td><td class=\"date\">%s <br /> %s</td></tr>",
- icon_uri ? icon_uri : "",
- app->name, app->url, app->name,
- /* Note for translators: this refers to the installation date. */
- _("Installed on:"), app->install_date);
- g_free (icon_uri);
- }
-
- g_string_append (data_str, "</form></table></body>");
-
- ephy_web_application_free_application_list (applications);
- }
-
- g_string_append (data_str, "</html>");
about->priv->content_length = data_str->len;
- return g_memory_input_stream_new_from_data (g_string_free (data_str, false), about->priv->content_length, g_free);
+ return g_memory_input_stream_new_from_data (g_string_free (data_str, FALSE), about->priv->content_length, g_free);
}
static goffset
@@ -230,11 +79,8 @@ static const char *about_schemes[] = { EPHY_ABOUT_SCHEME, NULL };
static void
ephy_request_about_class_init (EphyRequestAboutClass *request_about_class)
{
- GObjectClass *gobject_class = G_OBJECT_CLASS (request_about_class);
SoupRequestClass *request_class = SOUP_REQUEST_CLASS (request_about_class);
- gobject_class->finalize = ephy_request_about_finalize;
-
request_class->schemes = about_schemes;
request_class->check_uri = ephy_request_about_check_uri;
request_class->send = ephy_request_about_send;