/* * Copyright (C) 2011 Igalia S.L. * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public License * along with this library; see the file COPYING.LIB. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, * Boston, MA 02110-1301, USA. */ #include "config.h" #include "WebKitURIResponse.h" #include "WebKitPrivate.h" #include "WebKitURIResponsePrivate.h" #include #include using namespace WebKit; using namespace WebCore; /** * SECTION: WebKitURIResponse * @Short_description: Represents a URI response * @Title: WebKitURIResponse * * A #WebKitURIResponse contains information such as the URI, the * status code, the content length, the mime type, the HTTP status or * the suggested filename. * */ enum { PROP_0, PROP_URI, PROP_STATUS_CODE, PROP_CONTENT_LENGTH, PROP_MIME_TYPE, PROP_SUGGESTED_FILENAME }; struct _WebKitURIResponsePrivate { ResourceResponse resourceResponse; CString uri; CString mimeType; CString suggestedFilename; }; WEBKIT_DEFINE_TYPE(WebKitURIResponse, webkit_uri_response, G_TYPE_OBJECT) static void webkitURIResponseGetProperty(GObject* object, guint propId, GValue* value, GParamSpec* paramSpec) { WebKitURIResponse* response = WEBKIT_URI_RESPONSE(object); switch (propId) { case PROP_URI: g_value_set_string(value, webkit_uri_response_get_uri(response)); break; case PROP_STATUS_CODE: g_value_set_uint(value, webkit_uri_response_get_status_code(response)); break; case PROP_CONTENT_LENGTH: g_value_set_uint64(value, webkit_uri_response_get_content_length(response)); break; case PROP_MIME_TYPE: g_value_set_string(value, webkit_uri_response_get_mime_type(response)); break; case PROP_SUGGESTED_FILENAME: g_value_set_string(value, webkit_uri_response_get_suggested_filename(response)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID(object, propId, paramSpec); } } static void webkit_uri_response_class_init(WebKitURIResponseClass* responseClass) { GObjectClass* objectClass = G_OBJECT_CLASS(responseClass); objectClass->get_property = webkitURIResponseGetProperty; /** * WebKitURIResponse:uri: * * The URI for which the response was made. */ g_object_class_install_property(objectClass, PROP_URI, g_param_spec_string("uri", _("URI"), _("The URI for which the response was made."), 0, WEBKIT_PARAM_READABLE)); /** * WebKitURIResponse:status-code: * * The status code of the response as returned by the server. */ g_object_class_install_property(objectClass, PROP_STATUS_CODE, g_param_spec_uint("status-code", _("Status Code"), _("The status code of the response as returned by the server."), 0, G_MAXUINT, SOUP_STATUS_NONE, WEBKIT_PARAM_READABLE)); /** * WebKitURIResponse:content-length: * * The expected content length of the response. */ g_object_class_install_property(objectClass, PROP_CONTENT_LENGTH, g_param_spec_uint64("content-length", _("Content Length"), _("The expected content length of the response."), 0, G_MAXUINT64, 0, WEBKIT_PARAM_READABLE)); /** * WebKitURIResponse:mime-type: * * The MIME type of the response. */ g_object_class_install_property(objectClass, PROP_MIME_TYPE, g_param_spec_string("mime-type", _("MIME Type"), _("The MIME type of the response"), 0, WEBKIT_PARAM_READABLE)); /** * WebKitURIResponse:suggested-filename: * * The suggested filename for the URI response. */ g_object_class_install_property(objectClass, PROP_SUGGESTED_FILENAME, g_param_spec_string("suggested-filename", _("Suggested Filename"), _("The suggested filename for the URI response"), 0, WEBKIT_PARAM_READABLE)); } /** * webkit_uri_response_get_uri: * @response: a #WebKitURIResponse * * Returns: the uri of the #WebKitURIResponse */ const gchar* webkit_uri_response_get_uri(WebKitURIResponse* response) { g_return_val_if_fail(WEBKIT_IS_URI_RESPONSE(response), 0); response->priv->uri = response->priv->resourceResponse.url().string().utf8(); return response->priv->uri.data(); } /** * webkit_uri_response_get_status_code: * @response: a #WebKitURIResponse * * Get the status code of the #WebKitURIResponse as returned by * the server. It will normally be a #SoupKnownStatusCode, for * example %SOUP_STATUS_OK, though the server can respond with any * unsigned integer. * * Returns: the status code of @response */ guint webkit_uri_response_get_status_code(WebKitURIResponse* response) { g_return_val_if_fail(WEBKIT_IS_URI_RESPONSE(response), SOUP_STATUS_NONE); return response->priv->resourceResponse.httpStatusCode(); } /** * webkit_uri_response_get_content_length: * @response: a #WebKitURIResponse * * Get the expected content length of the #WebKitURIResponse. It can * be 0 if the server provided an incorrect or missing Content-Length. * * Returns: the expected content length of @response. */ guint64 webkit_uri_response_get_content_length(WebKitURIResponse* response) { g_return_val_if_fail(WEBKIT_IS_URI_RESPONSE(response), 0); return response->priv->resourceResponse.expectedContentLength(); } /** * webkit_uri_response_get_mime_type: * @response: a #WebKitURIResponse * * Returns: the MIME type of the #WebKitURIResponse */ const gchar* webkit_uri_response_get_mime_type(WebKitURIResponse* response) { g_return_val_if_fail(WEBKIT_IS_URI_RESPONSE(response), 0); response->priv->mimeType = response->priv->resourceResponse.mimeType().utf8(); return response->priv->mimeType.data(); } /** * webkit_uri_response_get_suggested_filename: * @response: a #WebKitURIResponse * * Get the suggested filename for @response, as specified by * the 'Content-Disposition' HTTP header, or %NULL if it's not * present. * * Returns: (transfer none): the suggested filename or %NULL if * the 'Content-Disposition' HTTP header is not present. */ const gchar* webkit_uri_response_get_suggested_filename(WebKitURIResponse* response) { g_return_val_if_fail(WEBKIT_IS_URI_RESPONSE(response), 0); if (response->priv->resourceResponse.suggestedFilename().isEmpty()) return 0; response->priv->suggestedFilename = response->priv->resourceResponse.suggestedFilename().utf8(); return response->priv->suggestedFilename.data(); } WebKitURIResponse* webkitURIResponseCreateForResourceResponse(const WebCore::ResourceResponse& resourceResponse) { WebKitURIResponse* uriResponse = WEBKIT_URI_RESPONSE(g_object_new(WEBKIT_TYPE_URI_RESPONSE, NULL)); uriResponse->priv->resourceResponse = resourceResponse; return uriResponse; } const WebCore::ResourceResponse& webkitURIResponseGetResourceResponse(WebKitURIResponse* uriResponse) { return uriResponse->priv->resourceResponse; }