Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/renderer/pepper/pepper_uma_host.h" | 5 #include "chrome/renderer/pepper/pepper_uma_host.h" |
| 6 | 6 |
| 7 #include "base/metrics/histogram.h" | 7 #include "base/metrics/histogram.h" |
| 8 #include "base/sha1.h" | 8 #include "base/sha1.h" |
| 9 #include "base/strings/string_number_conversions.h" | 9 #include "base/strings/string_number_conversions.h" |
| 10 #include "chrome/common/chrome_switches.h" | 10 #include "chrome/common/chrome_switches.h" |
| 11 #include "chrome/renderer/chrome_content_renderer_client.h" | 11 #include "chrome/renderer/chrome_content_renderer_client.h" |
| 12 #include "content/public/renderer/renderer_ppapi_host.h" | 12 #include "content/public/renderer/renderer_ppapi_host.h" |
| 13 #include "extensions/common/constants.h" | 13 #include "extensions/common/constants.h" |
| 14 #include "extensions/common/extension.h" | 14 #include "extensions/common/extension.h" |
| 15 #include "ppapi/c/pp_errors.h" | 15 #include "ppapi/c/pp_errors.h" |
| 16 #include "ppapi/host/dispatch_host_message.h" | 16 #include "ppapi/host/dispatch_host_message.h" |
| 17 #include "ppapi/host/host_message_context.h" | 17 #include "ppapi/host/host_message_context.h" |
| 18 #include "ppapi/host/ppapi_host.h" | 18 #include "ppapi/host/ppapi_host.h" |
| 19 #include "ppapi/proxy/ppapi_messages.h" | 19 #include "ppapi/proxy/ppapi_messages.h" |
| 20 | 20 |
| 21 namespace { | 21 namespace { |
| 22 | 22 |
| 23 const char* kPredefinedAllowedUMAOrigins[] = { | 23 const char* kPredefinedAllowedUMAOrigins[] = { |
| 24 "6EAED1924DB611B6EEF2A664BD077BE7EAD33B8F", // see crbug.com/317833 | 24 "6EAED1924DB611B6EEF2A664BD077BE7EAD33B8F", // see crbug.com/317833 |
| 25 "4EB74897CB187C7633357C2FE832E0AD6A44883A" // see crbug.com/317833 | 25 "4EB74897CB187C7633357C2FE832E0AD6A44883A" // see crbug.com/317833 |
| 26 }; | 26 }; |
| 27 | 27 |
| 28 const char* kWhitelistedHistogramHashes[] = { | 28 // The first 12 characters must match one of the prefixes below. |
| 29 "F131550DAB7A7C6E6633EF81FB5998CC0482AC63", // see crbug.com/317833 | 29 const int kWhitelistedHistogramPrefixLength = 12; |
|
Ilya Sherman
2014/03/06 00:34:14
Hmm, maybe scan up to the first dot instead?
elijahtaylor1
2014/03/06 00:46:27
Great suggestion. Done.
| |
| 30 "13955AB4DAD798384DFB4304734FCF2A95F353CC", // see crbug.com/317833 | 30 |
| 31 "404E800582901F1B937B8E287235FC603A5DEDFB" // see crbug.com/317833 | 31 const char* kWhitelistedHistogramPrefixes[] = { |
|
Ilya Sherman
2014/03/06 00:34:14
nit: "const char* const"
elijahtaylor1
2014/03/06 00:46:27
Done.
| |
| 32 "CD190EA2B764EDF0BB97552A638D32072F3CFD41", // see crbug.com/317833 | |
|
Ilya Sherman
2014/03/06 00:34:14
nit: Links should start with "http://". Also, thi
elijahtaylor1
2014/03/06 00:46:27
Fixed "http://"
Yeah, I agree that could be frust
| |
| 32 }; | 33 }; |
| 33 | 34 |
| 34 std::string HashHistogram(const std::string& histogram) { | 35 |
| 35 const std::string id_hash = base::SHA1HashString(histogram); | 36 std::string HashPrefix(const std::string& histogram) { |
| 37 const std::string id_hash = base::SHA1HashString( | |
| 38 histogram.substr(0, kWhitelistedHistogramPrefixLength)); | |
| 36 DCHECK_EQ(id_hash.length(), base::kSHA1Length); | 39 DCHECK_EQ(id_hash.length(), base::kSHA1Length); |
| 37 return base::HexEncode(id_hash.c_str(), id_hash.length()); | 40 return base::HexEncode(id_hash.c_str(), id_hash.length()); |
| 38 } | 41 } |
| 39 | 42 |
| 40 } // namespace | 43 } // namespace |
| 41 | 44 |
| 42 PepperUMAHost::PepperUMAHost( | 45 PepperUMAHost::PepperUMAHost( |
| 43 content::RendererPpapiHost* host, | 46 content::RendererPpapiHost* host, |
| 44 PP_Instance instance, | 47 PP_Instance instance, |
| 45 PP_Resource resource) | 48 PP_Resource resource) |
| 46 : ResourceHost(host->GetPpapiHost(), instance, resource), | 49 : ResourceHost(host->GetPpapiHost(), instance, resource), |
| 47 document_url_(host->GetDocumentURL(instance)), | 50 document_url_(host->GetDocumentURL(instance)), |
| 48 is_plugin_in_process_(host->IsRunningInProcess()) { | 51 is_plugin_in_process_(host->IsRunningInProcess()) { |
| 49 for (size_t i = 0; i < arraysize(kPredefinedAllowedUMAOrigins); ++i) | 52 for (size_t i = 0; i < arraysize(kPredefinedAllowedUMAOrigins); ++i) |
| 50 allowed_origins_.insert(kPredefinedAllowedUMAOrigins[i]); | 53 allowed_origins_.insert(kPredefinedAllowedUMAOrigins[i]); |
| 51 for (size_t i = 0; i < arraysize(kWhitelistedHistogramHashes); ++i) | 54 for (size_t i = 0; i < arraysize(kWhitelistedHistogramPrefixes); ++i) |
| 52 allowed_histograms_.insert(kWhitelistedHistogramHashes[i]); | 55 allowed_histogram_prefixes_.insert(kWhitelistedHistogramPrefixes[i]); |
| 53 } | 56 } |
| 54 | 57 |
| 55 PepperUMAHost::~PepperUMAHost() { | 58 PepperUMAHost::~PepperUMAHost() { |
| 56 } | 59 } |
| 57 | 60 |
| 58 int32_t PepperUMAHost::OnResourceMessageReceived( | 61 int32_t PepperUMAHost::OnResourceMessageReceived( |
| 59 const IPC::Message& msg, | 62 const IPC::Message& msg, |
| 60 ppapi::host::HostMessageContext* context) { | 63 ppapi::host::HostMessageContext* context) { |
| 61 IPC_BEGIN_MESSAGE_MAP(PepperUMAHost, msg) | 64 IPC_BEGIN_MESSAGE_MAP(PepperUMAHost, msg) |
| 62 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramCustomTimes, | 65 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramCustomTimes, |
| 63 OnHistogramCustomTimes); | 66 OnHistogramCustomTimes); |
| 64 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramCustomCounts, | 67 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramCustomCounts, |
| 65 OnHistogramCustomCounts); | 68 OnHistogramCustomCounts); |
| 66 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramEnumeration, | 69 PPAPI_DISPATCH_HOST_RESOURCE_CALL(PpapiHostMsg_UMA_HistogramEnumeration, |
| 67 OnHistogramEnumeration); | 70 OnHistogramEnumeration); |
| 68 IPC_END_MESSAGE_MAP() | 71 IPC_END_MESSAGE_MAP() |
| 69 return PP_ERROR_FAILED; | 72 return PP_ERROR_FAILED; |
| 70 } | 73 } |
| 71 | 74 |
| 72 bool PepperUMAHost::IsHistogramAllowed(const std::string& histogram) { | 75 bool PepperUMAHost::IsHistogramAllowed(const std::string& histogram) { |
| 73 if (is_plugin_in_process_ && histogram.find("NaCl.") == 0) { | 76 if (is_plugin_in_process_ && histogram.find("NaCl.") == 0) { |
| 74 return true; | 77 return true; |
| 75 } | 78 } |
| 76 | 79 |
| 77 bool is_whitelisted = | 80 bool is_whitelisted = |
| 78 ChromeContentRendererClient::IsExtensionOrSharedModuleWhitelisted( | 81 ChromeContentRendererClient::IsExtensionOrSharedModuleWhitelisted( |
| 79 document_url_, allowed_origins_); | 82 document_url_, allowed_origins_); |
| 80 if (is_whitelisted && | 83 if (is_whitelisted && |
| 81 allowed_histograms_.find(HashHistogram(histogram)) != | 84 allowed_histogram_prefixes_.find(HashPrefix(histogram)) != |
| 82 allowed_histograms_.end()) { | 85 allowed_histogram_prefixes_.end()) { |
| 83 return true; | 86 return true; |
| 84 } | 87 } |
| 85 | 88 |
| 86 LOG(ERROR) << "Host or histogram name is not allowed to use the UMA API."; | 89 LOG(ERROR) << "Host or histogram name is not allowed to use the UMA API."; |
| 87 return false; | 90 return false; |
| 88 } | 91 } |
| 89 | 92 |
| 90 #define RETURN_IF_BAD_ARGS(_min, _max, _buckets) \ | 93 #define RETURN_IF_BAD_ARGS(_min, _max, _buckets) \ |
| 91 do { \ | 94 do { \ |
| 92 if (_min >= _max || _buckets <= 1) \ | 95 if (_min >= _max || _buckets <= 1) \ |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 153 base::LinearHistogram::FactoryGet( | 156 base::LinearHistogram::FactoryGet( |
| 154 name, | 157 name, |
| 155 1, | 158 1, |
| 156 boundary_value, | 159 boundary_value, |
| 157 boundary_value + 1, | 160 boundary_value + 1, |
| 158 base::HistogramBase::kUmaTargetedHistogramFlag); | 161 base::HistogramBase::kUmaTargetedHistogramFlag); |
| 159 counter->Add(sample); | 162 counter->Add(sample); |
| 160 return PP_OK; | 163 return PP_OK; |
| 161 } | 164 } |
| 162 | 165 |
| OLD | NEW |