2 * Copyright (C) 2007, 2008 Holger Hans Peter Freyther
3 * Copyright (C) 2009 Gustavo Noronha Silva
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
15 * You should have received a copy of the GNU Library General Public License
16 * along with this library; see the file COPYING.LIB. If not, write to
17 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
18 * Boston, MA 02110-1301, USA.
22 #include "webkitnetworkrequest.h"
25 #include "ResourceRequest.h"
26 #include "webkitglobalsprivate.h"
27 #include <glib/gi18n-lib.h>
28 #include <wtf/text/CString.h>
31 * SECTION:webkitnetworkrequest
32 * @short_description: The target of a navigation request
33 * @see_also: #WebKitWebView::navigation-policy-decision-requested
35 * This class represents the network related aspects of a navigation
36 * request. It is used whenever WebKit wants to provide information
37 * about a request that will be sent, or has been sent. Inside it you
38 * can find the URI of the request, and, for valid URIs, a
39 * #SoupMessage object, which provides access to further information
44 G_DEFINE_TYPE(WebKitNetworkRequest, webkit_network_request, G_TYPE_OBJECT);
46 struct _WebKitNetworkRequestPrivate {
58 static void webkit_network_request_dispose(GObject* object)
60 WebKitNetworkRequest* request = WEBKIT_NETWORK_REQUEST(object);
61 WebKitNetworkRequestPrivate* priv = request->priv;
64 g_object_unref(priv->message);
68 G_OBJECT_CLASS(webkit_network_request_parent_class)->dispose(object);
71 static void webkit_network_request_finalize(GObject* object)
73 WebKitNetworkRequest* request = WEBKIT_NETWORK_REQUEST(object);
74 WebKitNetworkRequestPrivate* priv = request->priv;
78 G_OBJECT_CLASS(webkit_network_request_parent_class)->finalize(object);
81 static void webkit_network_request_get_property(GObject* object, guint propertyID, GValue* value, GParamSpec* pspec)
83 WebKitNetworkRequest* request = WEBKIT_NETWORK_REQUEST(object);
87 g_value_set_string(value, webkit_network_request_get_uri(request));
90 g_value_set_object(value, webkit_network_request_get_message(request));
93 G_OBJECT_WARN_INVALID_PROPERTY_ID(object, propertyID, pspec);
97 static void webkit_network_request_set_property(GObject* object, guint propertyID, const GValue* value, GParamSpec* pspec)
99 WebKitNetworkRequest* request = WEBKIT_NETWORK_REQUEST(object);
100 WebKitNetworkRequestPrivate* priv = request->priv;
104 webkit_network_request_set_uri(request, g_value_get_string(value));
107 priv->message = SOUP_MESSAGE(g_value_dup_object(value));
110 G_OBJECT_WARN_INVALID_PROPERTY_ID(object, propertyID, pspec);
114 static void webkit_network_request_class_init(WebKitNetworkRequestClass* requestClass)
116 GObjectClass* objectClass = G_OBJECT_CLASS(requestClass);
118 objectClass->dispose = webkit_network_request_dispose;
119 objectClass->finalize = webkit_network_request_finalize;
120 objectClass->get_property = webkit_network_request_get_property;
121 objectClass->set_property = webkit_network_request_set_property;
126 * WebKitNetworkRequest:uri:
128 * The URI to which the request will be made.
132 g_object_class_install_property(objectClass, PROP_URI,
133 g_param_spec_string("uri",
135 _("The URI to which the request will be made."),
137 (GParamFlags)(WEBKIT_PARAM_READWRITE)));
140 * WebKitNetworkRequest:message:
142 * The #SoupMessage that backs the request.
146 g_object_class_install_property(objectClass, PROP_MESSAGE,
147 g_param_spec_object("message",
149 _("The SoupMessage that backs the request."),
151 (GParamFlags)(WEBKIT_PARAM_READWRITE|G_PARAM_CONSTRUCT_ONLY)));
153 g_type_class_add_private(requestClass, sizeof(WebKitNetworkRequestPrivate));
156 static void webkit_network_request_init(WebKitNetworkRequest* request)
158 WebKitNetworkRequestPrivate* priv = G_TYPE_INSTANCE_GET_PRIVATE(request, WEBKIT_TYPE_NETWORK_REQUEST, WebKitNetworkRequestPrivate);
159 request->priv = priv;
163 * webkit_network_request_new:
166 * Creates a new #WebKitNetworkRequest initialized with an URI.
168 * Returns: a new #WebKitNetworkRequest, or %NULL if the URI is
171 WebKitNetworkRequest* webkit_network_request_new(const gchar* uri)
173 g_return_val_if_fail(uri, NULL);
175 return WEBKIT_NETWORK_REQUEST(g_object_new(WEBKIT_TYPE_NETWORK_REQUEST, "uri", uri, NULL));
179 * webkit_network_request_set_uri:
180 * @request: a #WebKitNetworkRequest
183 * Sets the URI held and used by the given request. When the request
184 * has an associated #SoupMessage, its URI will also be set by this
188 void webkit_network_request_set_uri(WebKitNetworkRequest* request, const gchar* uri)
190 g_return_if_fail(WEBKIT_IS_NETWORK_REQUEST(request));
191 g_return_if_fail(uri);
193 WebKitNetworkRequestPrivate* priv = request->priv;
197 priv->uri = g_strdup(uri);
202 SoupURI* soupURI = soup_uri_new(uri);
203 g_return_if_fail(soupURI);
205 soup_message_set_uri(priv->message, soupURI);
206 soup_uri_free(soupURI);
210 * webkit_network_request_get_uri:
211 * @request: a #WebKitNetworkRequest
213 * Returns: the uri of the #WebKitNetworkRequest
217 const gchar* webkit_network_request_get_uri(WebKitNetworkRequest* request)
219 g_return_val_if_fail(WEBKIT_IS_NETWORK_REQUEST(request), NULL);
221 WebKitNetworkRequestPrivate* priv = request->priv;
226 SoupURI* soupURI = soup_message_get_uri(priv->message);
227 priv->uri = soup_uri_to_string(soupURI, FALSE);
232 * webkit_network_request_get_message:
233 * @request: a #WebKitNetworkRequest
235 * Obtains the #SoupMessage held and used by the given request. Notice
236 * that modification of the SoupMessage of a request by signal
237 * handlers is only supported (as in, will only affect what is
238 * actually sent to the server) where explicitly documented.
240 * Returns: (transfer none): the #SoupMessage
243 SoupMessage* webkit_network_request_get_message(WebKitNetworkRequest* request)
245 g_return_val_if_fail(WEBKIT_IS_NETWORK_REQUEST(request), NULL);
247 WebKitNetworkRequestPrivate* priv = request->priv;
249 return priv->message;
254 WebKitNetworkRequest* kitNew(const WebCore::ResourceRequest& resourceRequest)
256 GRefPtr<SoupMessage> soupMessage(adoptGRef(resourceRequest.toSoupMessage()));
258 return WEBKIT_NETWORK_REQUEST(g_object_new(WEBKIT_TYPE_NETWORK_REQUEST, "message", soupMessage.get(), NULL));
260 return WEBKIT_NETWORK_REQUEST(g_object_new(WEBKIT_TYPE_NETWORK_REQUEST, "uri", resourceRequest.url().string().utf8().data(), NULL));
263 WebCore::ResourceRequest core(WebKitNetworkRequest* request)
265 SoupMessage* soupMessage = webkit_network_request_get_message(request);
267 return WebCore::ResourceRequest(soupMessage);
269 WebCore::KURL url = WebCore::KURL(WebCore::KURL(), String::fromUTF8(webkit_network_request_get_uri(request)));
270 return WebCore::ResourceRequest(url);