Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2615)

Unified Diff: content/public/browser/resource_request_info.h

Issue 9580002: Add ResourceRequestInfo. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/public/browser/DEPS ('k') | content/public/browser/resource_request_info.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/public/browser/resource_request_info.h
===================================================================
--- content/public/browser/resource_request_info.h (revision 0)
+++ content/public/browser/resource_request_info.h (revision 0)
@@ -0,0 +1,101 @@
+// 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_INFO_H_
+#define CONTENT_PUBLIC_BROWSER_RESOURCE_REQUEST_INFO_H_
+
+#include "base/basictypes.h"
+#include "base/supports_user_data.h"
+#include "content/common/content_export.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebReferrerPolicy.h"
+#include "webkit/glue/resource_type.h"
+
+namespace net {
+class URLRequest;
+}
+
+namespace content {
+class ResourceContext;
+
+class ResourceRequestInfo : public base::SupportsUserData::Data {
jam 2012/03/05 07:16:17 nit: please add a little comment about what this c
+ public:
+ CONTENT_EXPORT static const ResourceRequestInfo* ForRequest(
+ const net::URLRequest* request);
+
+ CONTENT_EXPORT static ResourceRequestInfo* CreateForTesting(
+ ResourceContext* context);
+
+ ResourceContext* context() const { return context_; }
jam 2012/03/05 07:16:17 for the Content API, we have tried to be strict th
+
+ // The child process unique ID of the requestor.
+ int child_id() const { return child_id_; }
+
+ // The IPC route identifier for this request (this identifies the RenderView
+ // or like-thing in the renderer that the request gets routed to).
+ int route_id() const { return route_id_; }
+
+ // The pid of the originating process, if the request is sent on behalf of a
+ // another process. Otherwise it is 0.
+ int origin_pid() const { return origin_pid_; }
+
+ // Unique identifier (within the scope of the child process) for this request.
+ int request_id() const { return request_id_; }
+
+ // True if |frame_id_| represents a main frame in the RenderView.
+ bool is_main_frame() const { return is_main_frame_; }
+
+ // Frame ID that sent this resource request. -1 if unknown / invalid.
+ int64 frame_id() const { return frame_id_; }
+
+ // True if |parent_frame_id_| represents a main frame in the RenderView.
+ bool parent_is_main_frame() const { return parent_is_main_frame_; }
+
+ // Frame ID of parent frame of frame that sent this resource request.
+ // -1 if unknown / invalid.
+ int64 parent_frame_id() const { return parent_frame_id_; }
+
+ ResourceType::Type resource_type() const { return resource_type_; }
+
+ WebKit::WebReferrerPolicy referrer_policy() const { return referrer_policy_; }
+
+ // When there is upload data, this is the byte count of that data. When there
+ // is no upload, this will be 0.
+ uint64 upload_size() const { return upload_size_; }
+
+ // Returns false if there is not an associated render view.
+ virtual bool GetAssociatedRenderView(int* render_process_id,
+ int* render_view_id) const = 0;
+
+ protected:
+ ResourceRequestInfo(ResourceContext* context,
+ int child_id,
+ int route_id,
+ int origin_pid,
+ int request_id,
+ bool is_main_frame,
+ int64 frame_id,
+ bool parent_is_main_frame,
+ int64 parent_frame_id,
+ ResourceType::Type resource_type,
+ WebKit::WebReferrerPolicy referrer_policy,
+ uint64 upload_size);
+ virtual ~ResourceRequestInfo();
+
+ ResourceContext* context_;
+ int child_id_;
+ int route_id_;
+ int origin_pid_;
+ int request_id_;
+ int64 frame_id_;
+ int64 parent_frame_id_;
+ bool is_main_frame_;
+ bool parent_is_main_frame_;
+ ResourceType::Type resource_type_;
+ WebKit::WebReferrerPolicy referrer_policy_;
+ uint64 upload_size_;
+};
+
+} // namespace content
+
+#endif // CONTENT_PUBLIC_BROWSER_RESOURCE_REQUEST_INFO_H_
« no previous file with comments | « content/public/browser/DEPS ('k') | content/public/browser/resource_request_info.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698