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 "chromecast/crash/android/cast_crash_reporter_client_android.h" | 5 #include "chromecast/crash/android/cast_crash_reporter_client_android.h" |
| 6 | 6 |
| 7 #include "base/base_paths.h" | 7 #include "base/base_paths.h" |
| 8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
| 9 #include "base/files/file_util.h" | 9 #include "base/files/file_util.h" |
| 10 #include "base/path_service.h" | 10 #include "base/path_service.h" |
| 11 #include "chromecast/android/chromecast_config_android.h" | 11 #include "chromecast/android/chromecast_config_android.h" |
| 12 #include "chromecast/base/version.h" | 12 #include "chromecast/base/version.h" |
| 13 #include "chromecast/common/global_descriptors.h" | 13 #include "chromecast/common/global_descriptors.h" |
| 14 #include "chromecast/crash/cast_crash_keys.h" | 14 #include "chromecast/crash/cast_crash_keys.h" |
| 15 #include "content/public/common/content_switches.h" | 15 #include "content/public/common/content_switches.h" |
| 16 | 16 |
| 17 namespace chromecast { | 17 namespace chromecast { |
| 18 | 18 |
| 19 CastCrashReporterClientAndroid::CastCrashReporterClientAndroid() { | 19 CastCrashReporterClientAndroid::CastCrashReporterClientAndroid(bool privileged) |
| 20 : privileged_(privileged) { | |
|
lcwu1
2015/06/12 01:42:01
I feel like it is not very clear what 'privileged_
| |
| 20 } | 21 } |
| 21 | 22 |
| 22 CastCrashReporterClientAndroid::~CastCrashReporterClientAndroid() { | 23 CastCrashReporterClientAndroid::~CastCrashReporterClientAndroid() { |
| 23 } | 24 } |
| 24 | 25 |
| 25 void CastCrashReporterClientAndroid::GetProductNameAndVersion( | 26 void CastCrashReporterClientAndroid::GetProductNameAndVersion( |
| 26 const char** product_name, | 27 const char** product_name, |
| 27 const char** version) { | 28 const char** version) { |
| 28 *product_name = "media_shell"; | 29 *product_name = "media_shell"; |
| 29 *version = PRODUCT_VERSION | 30 *version = PRODUCT_VERSION |
| 30 #if CAST_IS_DEBUG_BUILD() | 31 #if CAST_IS_DEBUG_BUILD() |
| 31 ".debug" | 32 ".debug" |
| 32 #endif | 33 #endif |
| 33 "." CAST_BUILD_REVISION; | 34 "." CAST_BUILD_REVISION; |
| 34 } | 35 } |
| 35 | 36 |
| 36 base::FilePath CastCrashReporterClientAndroid::GetReporterLogFilename() { | 37 base::FilePath CastCrashReporterClientAndroid::GetReporterLogFilename() { |
| 37 return base::FilePath(FILE_PATH_LITERAL("uploads.log")); | 38 return base::FilePath(FILE_PATH_LITERAL("uploads.log")); |
| 38 } | 39 } |
| 39 | 40 |
| 40 bool CastCrashReporterClientAndroid::GetCrashDumpLocation( | 41 bool CastCrashReporterClientAndroid::GetCrashDumpLocation( |
| 41 base::FilePath* crash_dir) { | 42 base::FilePath* crash_dir) { |
| 42 base::FilePath crash_dir_local; | 43 base::FilePath crash_dir_local; |
| 43 if (!PathService::Get(base::DIR_ANDROID_APP_DATA, &crash_dir_local)) { | 44 if (!PathService::Get(base::DIR_ANDROID_APP_DATA, &crash_dir_local)) { |
| 44 return false; | 45 return false; |
| 45 } | 46 } |
| 46 crash_dir_local = crash_dir_local.Append("crashes"); | 47 crash_dir_local = crash_dir_local.Append("crashes"); |
| 47 | 48 |
| 48 if (!base::DirectoryExists(crash_dir_local)) { | 49 // Only try to create the directory in a privileged process. For other |
| 49 if (!base::CreateDirectory(crash_dir_local)) { | 50 // processes, assume the directory exists. |
|
halliwell
2015/06/10 21:23:16
Do we need to make that assumption? Wouldn't it b
gunsch
2015/06/10 21:30:16
Renderer process is not allowed to check if file e
gunsch
2015/06/12 20:07:52
I was hoping to abstract over the "process type" c
| |
| 50 return false; | 51 if (privileged_) { |
| 52 if (!base::DirectoryExists(crash_dir_local)) { | |
| 53 if (!base::CreateDirectory(crash_dir_local)) { | |
| 54 return false; | |
| 55 } | |
| 51 } | 56 } |
| 52 } | 57 } |
| 53 | 58 |
| 54 // Provide value to crash_dir once directory is known to be a valid path. | 59 // Provide value to crash_dir once directory is known to be a valid path. |
| 55 *crash_dir = crash_dir_local; | 60 *crash_dir = crash_dir_local; |
| 56 return true; | 61 return true; |
| 57 } | 62 } |
| 58 | 63 |
| 59 size_t CastCrashReporterClientAndroid::RegisterCrashKeys() { | 64 size_t CastCrashReporterClientAndroid::RegisterCrashKeys() { |
| 60 return crash_keys::RegisterCastCrashKeys(); | 65 return crash_keys::RegisterCastCrashKeys(); |
| 61 } | 66 } |
| 62 | 67 |
| 63 bool CastCrashReporterClientAndroid::GetCollectStatsConsent() { | 68 bool CastCrashReporterClientAndroid::GetCollectStatsConsent() { |
| 64 return android::ChromecastConfigAndroid::GetInstance()->CanSendUsageStats(); | 69 return android::ChromecastConfigAndroid::GetInstance()->CanSendUsageStats(); |
| 65 } | 70 } |
| 66 | 71 |
| 67 int CastCrashReporterClientAndroid::GetAndroidMinidumpDescriptor() { | 72 int CastCrashReporterClientAndroid::GetAndroidMinidumpDescriptor() { |
| 68 return kAndroidMinidumpDescriptor; | 73 return kAndroidMinidumpDescriptor; |
| 69 } | 74 } |
| 70 | 75 |
| 71 bool CastCrashReporterClientAndroid::EnableBreakpadForProcess( | 76 bool CastCrashReporterClientAndroid::EnableBreakpadForProcess( |
| 72 const std::string& process_type) { | 77 const std::string& process_type) { |
| 73 return process_type == switches::kRendererProcess || | 78 return process_type == switches::kRendererProcess || |
| 74 process_type == switches::kGpuProcess; | 79 process_type == switches::kGpuProcess; |
| 75 } | 80 } |
| 76 | 81 |
| 77 } // namespace chromecast | 82 } // namespace chromecast |
| OLD | NEW |