static void uriSchemeRequestCallback(WebKitURISchemeRequest* request, gpointer userData) { URISchemeTest* test = static_cast<URISchemeTest*>(userData); test->m_uriSchemeRequest = request; test->assertObjectIsDeletedWhenTestFinishes(G_OBJECT(request)); g_assert(webkit_uri_scheme_request_get_web_view(request) == test->m_webView); const char* scheme = webkit_uri_scheme_request_get_scheme(request); g_assert(scheme); g_assert(test->m_handlersMap.contains(String::fromUTF8(scheme))); const URISchemeHandler& handler = test->m_handlersMap.get(String::fromUTF8(scheme)); GRefPtr<GInputStream> inputStream = adoptGRef(g_memory_input_stream_new()); test->assertObjectIsDeletedWhenTestFinishes(G_OBJECT(inputStream.get())); const gchar* requestPath = webkit_uri_scheme_request_get_path(request); if (!g_strcmp0(scheme, "error")) { if (!g_strcmp0(requestPath, "before-response")) { GUniquePtr<GError> error(g_error_new_literal(g_quark_from_string(errorDomain), errorCode, beforeReceiveResponseErrorMessage)); // We call finish() and then finish_error() to make sure that not even // the didReceiveResponse message is processed at the time of failing. webkit_uri_scheme_request_finish(request, G_INPUT_STREAM(inputStream.get()), handler.replyLength, handler.mimeType.data()); webkit_uri_scheme_request_finish_error(request, error.get()); } else if (!g_strcmp0(requestPath, "after-first-chunk")) { g_memory_input_stream_add_data(G_MEMORY_INPUT_STREAM(inputStream.get()), handler.reply.data(), handler.reply.length(), 0); webkit_uri_scheme_request_finish(request, inputStream.get(), handler.replyLength, handler.mimeType.data()); // We need to wait until we reach the load-committed state before calling webkit_uri_scheme_request_finish_error(), // so we rely on the test using finishOnCommittedAndWaitUntilLoadFinished() to actually call it from loadCommitted(). } else { GUniquePtr<GError> error(g_error_new_literal(g_quark_from_string(errorDomain), errorCode, genericErrorMessage)); webkit_uri_scheme_request_finish_error(request, error.get()); } return; } if (!g_strcmp0(scheme, "echo")) { char* replyHTML = g_strdup_printf(handler.reply.data(), requestPath); g_memory_input_stream_add_data(G_MEMORY_INPUT_STREAM(inputStream.get()), replyHTML, strlen(replyHTML), g_free); } else if (!g_strcmp0(scheme, "closed")) g_input_stream_close(inputStream.get(), 0, 0); else if (!handler.reply.isNull()) g_memory_input_stream_add_data(G_MEMORY_INPUT_STREAM(inputStream.get()), handler.reply.data(), handler.reply.length(), 0); webkit_uri_scheme_request_finish(request, inputStream.get(), handler.replyLength, handler.mimeType.data()); }
static void aboutURISchemeRequestCallback(WebKitURISchemeRequest *request, gpointer userData) { GInputStream *stream; gsize streamLength; const gchar *path; gchar *contents; GError *error; path = webkit_uri_scheme_request_get_path(request); if (!g_strcmp0(path, "minibrowser")) { contents = g_strdup_printf("<html><body><h1>WebKitGTK+ MiniBrowser</h1><p>The WebKit2 test browser of the GTK+ port.</p><p>WebKit version: %d.%d.%d</p></body></html>", webkit_get_major_version(), webkit_get_minor_version(), webkit_get_micro_version()); streamLength = strlen(contents); stream = g_memory_input_stream_new_from_data(contents, streamLength, g_free); webkit_uri_scheme_request_finish(request, stream, streamLength, "text/html"); g_object_unref(stream); } else { error = g_error_new(MINI_BROWSER_ERROR, MINI_BROWSER_ERROR_INVALID_ABOUT_PATH, "Invalid about:%s page.", path); webkit_uri_scheme_request_finish_error(request, error); g_error_free(error); } }
static void uriSchemeRequestCallback(WebKitURISchemeRequest* request, gpointer userData) { URISchemeTest* test = static_cast<URISchemeTest*>(userData); test->m_uriSchemeRequest = request; test->assertObjectIsDeletedWhenTestFinishes(G_OBJECT(request)); g_assert(webkit_uri_scheme_request_get_web_view(request) == test->m_webView); GRefPtr<GInputStream> inputStream = adoptGRef(g_memory_input_stream_new()); test->assertObjectIsDeletedWhenTestFinishes(G_OBJECT(inputStream.get())); const char* scheme = webkit_uri_scheme_request_get_scheme(request); g_assert(scheme); g_assert(test->m_handlersMap.contains(String::fromUTF8(scheme))); if (!g_strcmp0(scheme, "error")) { GUniquePtr<GError> error(g_error_new_literal(g_quark_from_string(errorDomain), errorCode, errorMessage)); webkit_uri_scheme_request_finish_error(request, error.get()); return; } const URISchemeHandler& handler = test->m_handlersMap.get(String::fromUTF8(scheme)); if (!g_strcmp0(scheme, "echo")) { char* replyHTML = g_strdup_printf(handler.reply.data(), webkit_uri_scheme_request_get_path(request)); g_memory_input_stream_add_data(G_MEMORY_INPUT_STREAM(inputStream.get()), replyHTML, strlen(replyHTML), g_free); } else if (!g_strcmp0(scheme, "closed")) g_input_stream_close(inputStream.get(), 0, 0); else if (!handler.reply.isNull()) g_memory_input_stream_add_data(G_MEMORY_INPUT_STREAM(inputStream.get()), handler.reply.data(), handler.reply.length(), 0); webkit_uri_scheme_request_finish(request, inputStream.get(), handler.replyLength, handler.mimeType.data()); }
static void ephy_resource_request_cb (WebKitURISchemeRequest *request) { const char *path; GInputStream *stream; gsize size; GError *error = NULL; path = webkit_uri_scheme_request_get_path (request); if (!g_resources_get_info (path, 0, &size, NULL, &error)) { webkit_uri_scheme_request_finish_error (request, error); g_error_free (error); return; } stream = g_resources_open_stream (path, 0, &error); if (stream) { webkit_uri_scheme_request_finish (request, stream, size, NULL); g_object_unref (stream); } else { webkit_uri_scheme_request_finish_error (request, error); g_error_free (error); } }