Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/plugins/plugin_uma.h" | 5 #include "chrome/renderer/plugins/plugin_uma.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <cstring> | 8 #include <cstring> |
| 9 | 9 |
| 10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
| 11 #include "base/string_util.h" | 11 #include "base/string_util.h" |
| 12 | 12 |
| 13 namespace { | 13 namespace { |
| 14 | 14 |
| 15 // String we will use to convert mime tyoe to plugin type. | 15 // String we will use to convert mime tyoe to plugin type. |
| 16 const char kWindowsMediaPlayerType[] = "application/x-mplayer2"; | 16 const char kWindowsMediaPlayerType[] = "application/x-mplayer2"; |
| 17 const char kSilverlightTypePrefix[] = "application/x-silverlight"; | 17 const char kSilverlightTypePrefix[] = "application/x-silverlight"; |
| 18 const char kRealPlayerTypePrefix[] = "audio/x-pn-realaudio"; | 18 const char kRealPlayerTypePrefix[] = "audio/x-pn-realaudio"; |
| 19 const char kJavaTypeSubstring[] = "application/x-java-applet"; | 19 const char kJavaTypeSubstring[] = "application/x-java-applet"; |
| 20 const char kQuickTimeType[] = "video/quicktime"; | 20 const char kQuickTimeType[] = "video/quicktime"; |
| 21 const char kShockwaveFlashType[] = "application/x-shockwave-flash"; | |
| 22 const char kWidevineCDMType[] = "application/x-ppapi-widevine-cdm"; | |
| 21 | 23 |
| 22 // Arrays containing file extensions connected with specific plugins. | 24 // Arrays containing file extensions connected with specific plugins. |
| 23 // The arrays must be sorted because binary search is used on them. | 25 // The arrays must be sorted because binary search is used on them. |
| 24 const char* kWindowsMediaPlayerExtensions[] = { | 26 const char* kWindowsMediaPlayerExtensions[] = { |
| 25 ".asx" | 27 ".asx" |
| 26 }; | 28 }; |
| 27 | 29 |
| 28 const char* kRealPlayerExtensions[] = { | 30 const char* kRealPlayerExtensions[] = { |
| 29 ".ra", | 31 ".ra", |
| 30 ".ram", | 32 ".ram", |
| (...skipping 16 matching lines...) Expand all Loading... | |
| 47 | 49 |
| 48 class UMASenderImpl : public MissingPluginReporter::UMASender { | 50 class UMASenderImpl : public MissingPluginReporter::UMASender { |
| 49 virtual void SendPluginUMA(MissingPluginReporter::PluginType plugin_type) | 51 virtual void SendPluginUMA(MissingPluginReporter::PluginType plugin_type) |
| 50 OVERRIDE; | 52 OVERRIDE; |
| 51 }; | 53 }; |
| 52 | 54 |
| 53 void UMASenderImpl::SendPluginUMA( | 55 void UMASenderImpl::SendPluginUMA( |
| 54 MissingPluginReporter::PluginType plugin_type) { | 56 MissingPluginReporter::PluginType plugin_type) { |
| 55 UMA_HISTOGRAM_ENUMERATION("Plugin.MissingPlugins", | 57 UMA_HISTOGRAM_ENUMERATION("Plugin.MissingPlugins", |
| 56 plugin_type, | 58 plugin_type, |
| 57 MissingPluginReporter::OTHER); | 59 MissingPluginReporter::OTHER); |
|
ddorwin
2013/04/04 20:08:26
You need to use your new PLUGIN_TYPE_MAX here, rig
xhwang
2013/04/05 00:58:18
Done.
| |
| 58 } | 60 } |
| 59 | 61 |
| 60 // static. | 62 // static. |
| 61 MissingPluginReporter* MissingPluginReporter::GetInstance() { | 63 MissingPluginReporter* MissingPluginReporter::GetInstance() { |
| 62 return Singleton<MissingPluginReporter>::get(); | 64 return Singleton<MissingPluginReporter>::get(); |
| 63 } | 65 } |
| 64 | 66 |
| 65 void MissingPluginReporter::ReportPluginMissing( | 67 void MissingPluginReporter::ReportPluginMissing( |
| 66 std::string plugin_mime_type, const GURL& plugin_src) { | 68 std::string plugin_mime_type, const GURL& plugin_src) { |
| 67 PluginType plugin_type; | 69 PluginType plugin_type; |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 108 size_t last_dot = extension_file_path.find_last_of('.'); | 110 size_t last_dot = extension_file_path.find_last_of('.'); |
| 109 if (last_dot != std::string::npos) { | 111 if (last_dot != std::string::npos) { |
| 110 *extension = extension_file_path.substr(last_dot); | 112 *extension = extension_file_path.substr(last_dot); |
| 111 } else { | 113 } else { |
| 112 extension->clear(); | 114 extension->clear(); |
| 113 } | 115 } |
| 114 | 116 |
| 115 StringToLowerASCII(extension); | 117 StringToLowerASCII(extension); |
| 116 } | 118 } |
| 117 | 119 |
| 118 MissingPluginReporter::PluginType MissingPluginReporter::SrcToPluginType( | 120 MissingPluginReporter::PluginType MissingPluginReporter::SrcToPluginType( |
|
xhwang
2013/04/03 23:36:55
For flash, do we also want to get plugin type from
xhwang
2013/04/03 23:38:09
+ilja
yzshen1
2013/04/04 17:38:11
I think we could add the extensions for Flash here
ddorwin
2013/04/04 19:52:24
SGTM. Also, should we differentiate "OTHER" mime t
ddorwin
2013/04/04 20:08:26
Even better, (since the meaning of OTHER is/would
xhwang
2013/04/05 00:58:18
Done. Do we want to add more, e.g. fla et al?
xhwang
2013/04/05 00:58:18
Done. Use 240/241 in case we want to add more unsu
ddorwin
2013/04/05 04:21:37
I coud be wrong, but it looks like we only support
xhwang
2013/04/05 05:05:21
Done.
| |
| 119 const GURL& src) { | 121 const GURL& src) { |
| 120 std::string file_extension; | 122 std::string file_extension; |
| 121 ExtractFileExtension(src, &file_extension); | 123 ExtractFileExtension(src, &file_extension); |
| 122 if (CStringArrayContainsCString(kWindowsMediaPlayerExtensions, | 124 if (CStringArrayContainsCString(kWindowsMediaPlayerExtensions, |
| 123 arraysize(kWindowsMediaPlayerExtensions), | 125 arraysize(kWindowsMediaPlayerExtensions), |
| 124 file_extension.c_str())) { | 126 file_extension.c_str())) { |
| 125 return WINDOWS_MEDIA_PLAYER; | 127 return WINDOWS_MEDIA_PLAYER; |
| 126 } | 128 } |
| 127 | 129 |
| 128 if (CStringArrayContainsCString(kQuickTimeExtensions, | 130 if (CStringArrayContainsCString(kQuickTimeExtensions, |
| (...skipping 23 matching lines...) Expand all Loading... | |
| 152 prefix_length = strlen(kRealPlayerTypePrefix); | 154 prefix_length = strlen(kRealPlayerTypePrefix); |
| 153 if (strncmp(mime_type.c_str(), kRealPlayerTypePrefix, prefix_length) == 0) | 155 if (strncmp(mime_type.c_str(), kRealPlayerTypePrefix, prefix_length) == 0) |
| 154 return REALPLAYER; | 156 return REALPLAYER; |
| 155 | 157 |
| 156 if (strstr(mime_type.c_str(), kJavaTypeSubstring)) | 158 if (strstr(mime_type.c_str(), kJavaTypeSubstring)) |
| 157 return JAVA; | 159 return JAVA; |
| 158 | 160 |
| 159 if (strcmp(mime_type.c_str(), kQuickTimeType) == 0) | 161 if (strcmp(mime_type.c_str(), kQuickTimeType) == 0) |
| 160 return QUICKTIME; | 162 return QUICKTIME; |
| 161 | 163 |
| 164 if (strcmp(mime_type.c_str(), kShockwaveFlashType) == 0) | |
| 165 return SHOCKWAVE_FLASH; | |
| 166 | |
| 167 if (strcmp(mime_type.c_str(), kWidevineCDMType) == 0) | |
| 168 return WIDEVINE_CDM; | |
| 169 | |
| 162 return OTHER; | 170 return OTHER; |
| 163 } | 171 } |
| 164 | |
| OLD | NEW |