| // Copyright 2013 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 CHROME_BROWSER_DOWNLOAD_DOWNLOAD_STATS_H_ |
| #define CHROME_BROWSER_DOWNLOAD_DOWNLOAD_STATS_H_ |
| |
| #include "content/public/browser/download_danger_type.h" |
| |
| // Record the total number of items and the number of in-progress items showing |
| // in the shelf when it closes. Set |autoclose| to true when the shelf is |
| // closing itself, false when the user explicitly closed it. |
| void RecordDownloadShelfClose(int size, int in_progress, bool autoclose); |
| |
| // Used for counting UMA stats. Similar to content's |
| // download_stats::DownloadCountTypes but from the chrome layer. |
| enum ChromeDownloadCountTypes { |
| // Stale enum values left around os that values passed to UMA don't |
| // change. |
| CHROME_DOWNLOAD_COUNT_UNUSED_0 = 0, |
| CHROME_DOWNLOAD_COUNT_UNUSED_1, |
| CHROME_DOWNLOAD_COUNT_UNUSED_2, |
| CHROME_DOWNLOAD_COUNT_UNUSED_3, |
| |
| // A download *would* have been initiated, but it was blocked |
| // by the DownloadThrottlingResourceHandler. |
| CHROME_DOWNLOAD_COUNT_BLOCKED_BY_THROTTLING, |
| |
| CHROME_DOWNLOAD_COUNT_TYPES_LAST_ENTRY |
| }; |
| |
| // Used for counting UMA stats. Similar to content's |
| // download_stats::DownloadInitiattionSources but from the chrome layer. |
| enum ChromeDownloadSource { |
| // The download was initiated by navigating to a URL (e.g. by user click). |
| DOWNLOAD_INITIATED_BY_NAVIGATION = 0, |
| |
| // The download was initiated by invoking a context menu within a page. |
| DOWNLOAD_INITIATED_BY_CONTEXT_MENU, |
| |
| // The download was initiated by the WebStore installer. |
| DOWNLOAD_INITIATED_BY_WEBSTORE_INSTALLER, |
| |
| // The download was initiated by the ImageBurner (cros). |
| DOWNLOAD_INITIATED_BY_IMAGE_BURNER, |
| |
| // The download was initiated by the plugin installer. |
| DOWNLOAD_INITIATED_BY_PLUGIN_INSTALLER, |
| |
| // The download was initiated by the PDF plugin.. |
| DOWNLOAD_INITIATED_BY_PDF_SAVE, |
| |
| // The download was initiated by chrome.downloads.download(). |
| DOWNLOAD_INITIATED_BY_EXTENSION, |
| |
| CHROME_DOWNLOAD_SOURCE_LAST_ENTRY, |
| }; |
| |
| // How a download was opened. Note that a download could be opened multiple |
| // times. |
| enum ChromeDownloadOpenMethod { |
| // The download was opened using the platform handler. There was no special |
| // handling for this download. |
| DOWNLOAD_OPEN_METHOD_DEFAULT_PLATFORM = 0, |
| |
| // The download was opened using the browser bypassing the system handler. |
| DOWNLOAD_OPEN_METHOD_DEFAULT_BROWSER, |
| |
| // The user chose to open the download using the system handler even though |
| // the preferred method was to open the download using the browser. |
| DOWNLOAD_OPEN_METHOD_USER_PLATFORM, |
| |
| DOWNLOAD_OPEN_METHOD_LAST_ENTRY |
| }; |
| |
| // Increment one of the above counts. |
| void RecordDownloadCount(ChromeDownloadCountTypes type); |
| |
| // Record initiation of a download from a specific source. |
| void RecordDownloadSource(ChromeDownloadSource source); |
| |
| // Record that a download warning was shown. |
| void RecordDangerousDownloadWarningShown( |
| content::DownloadDangerType danger_type); |
| |
| // Record that the user opened the confirmation dialog for a dangerous download. |
| void RecordOpenedDangerousConfirmDialog( |
| content::DownloadDangerType danger_type); |
| |
| // Record how a download was opened. |
| void RecordDownloadOpenMethod(ChromeDownloadOpenMethod open_method); |
| |
| #endif // CHROME_BROWSER_DOWNLOAD_DOWNLOAD_STATS_H_ |