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

Unified Diff: content/browser/histogram_internals_url_loader.cc

Issue 2874623002: Implement chrome://histograms with network service. (Closed)
Patch Set: add comment Created 3 years, 7 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
Index: content/browser/histogram_internals_url_loader.cc
diff --git a/content/browser/histogram_internals_url_loader.cc b/content/browser/histogram_internals_url_loader.cc
new file mode 100644
index 0000000000000000000000000000000000000000..67b37b3c4a535306325065685e0b8bf597a11f27
--- /dev/null
+++ b/content/browser/histogram_internals_url_loader.cc
@@ -0,0 +1,49 @@
+// Copyright 2017 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.
+
+#include "content/browser/histogram_internals_url_loader.h"
+
+#include "base/metrics/histogram_macros.h"
+#include "base/metrics/statistics_recorder.h"
+#include "content/browser/histogram_internals_request_job.h"
+#include "mojo/common/data_pipe_utils.h"
+
+namespace content {
+
+void StartHistogramInternalsURLLoader(const ResourceRequest& request,
+ mojom::URLLoaderClientPtr client) {
+ scoped_refptr<net::HttpResponseHeaders> headers(
+ new net::HttpResponseHeaders("HTTP/1.1 200 OK"));
+ ResourceResponseHead resource_response;
+ resource_response.headers = headers;
+ resource_response.mime_type = "text/html";
+ client->OnReceiveResponse(resource_response, base::nullopt, nullptr);
+
+ base::StatisticsRecorder::ImportProvidedHistograms();
+ std::string data = HistogramInternalsRequestJob::GenerateHTML(request.url);
+
+ MojoCreateDataPipeOptions options;
+ options.struct_size = sizeof(MojoCreateDataPipeOptions);
+ options.flags = MOJO_CREATE_DATA_PIPE_OPTIONS_FLAG_NONE;
+ options.element_num_bytes = 1;
+ options.capacity_num_bytes = data.size();
+ mojo::DataPipe data_pipe(options);
+
+ DCHECK(data_pipe.producer_handle.is_valid());
+ DCHECK(data_pipe.consumer_handle.is_valid());
+
+ CHECK(mojo::common::BlockingCopyFromString(data, data_pipe.producer_handle));
+
+ client->OnStartLoadingResponseBody(std::move(data_pipe.consumer_handle));
+
+ ResourceRequestCompletionStatus request_complete_data;
+ request_complete_data.error_code = net::OK;
+ request_complete_data.exists_in_cache = false;
+ request_complete_data.completion_time = base::TimeTicks::Now();
+ request_complete_data.encoded_data_length = data.size();
+ request_complete_data.encoded_body_length = data.size();
+ client->OnComplete(request_complete_data);
+}
+
+} // namespace content
« no previous file with comments | « content/browser/histogram_internals_url_loader.h ('k') | content/browser/webui/web_ui_url_loader_factory.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698