// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_PUBLIC_BROWSER_RESOURCE_REQUEST_DETAILS_H_
#define CONTENT_PUBLIC_BROWSER_RESOURCE_REQUEST_DETAILS_H_
#include <string>
#include "net/base/host_port_pair.h"
#include "net/cert/cert_status_flags.h"
#include "net/url_request/url_request_status.h"
#include "url/gurl.h"
#include "webkit/common/resource_type.h"
namespace net {
class URLRequest;
}
namespace content {
// The ResourceRequestDetails object contains additional details about a
// resource request notification. It copies many of the publicly accessible
// member variables of net::URLRequest, but exists on the UI thread.
struct ResourceRequestDetails {
ResourceRequestDetails(const net::URLRequest* request, int cert_id);
virtual ~ResourceRequestDetails();
GURL url;
GURL original_url;
std::string method;
std::string referrer;
bool has_upload;
int load_flags;
int origin_child_id;
net::URLRequestStatus status;
int ssl_cert_id;
net::CertStatus ssl_cert_status;
ResourceType::Type resource_type;
net::HostPortPair socket_address;
int render_frame_id;
// HTTP response code. See HttpResponseHeaders::response_code().
// -1 if there are no response headers yet.
int http_response_code;
};
// Details about a redirection of a resource request.
struct ResourceRedirectDetails : public ResourceRequestDetails {
ResourceRedirectDetails(const net::URLRequest* request,
int cert_id,
const GURL& new_url);
virtual ~ResourceRedirectDetails();
// The URL to which we are being redirected.
GURL new_url;
};
} // namespace content
#endif // CONTENT_PUBLIC_BROWSER_RESOURCE_REQUEST_DETAILS_H_