| 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/browser/translate/chrome_translate_client.h" | 5 #include "chrome/browser/translate/chrome_translate_client.h" | 
| 6 | 6 | 
| 7 #include <memory> | 7 #include <memory> | 
| 8 #include <vector> | 8 #include <vector> | 
| 9 | 9 | 
| 10 #include "base/logging.h" | 10 #include "base/logging.h" | 
| (...skipping 25 matching lines...) Expand all  Loading... | 
| 36 #include "components/translate/core/browser/language_model.h" | 36 #include "components/translate/core/browser/language_model.h" | 
| 37 #include "components/translate/core/browser/language_state.h" | 37 #include "components/translate/core/browser/language_state.h" | 
| 38 #include "components/translate/core/browser/page_translated_details.h" | 38 #include "components/translate/core/browser/page_translated_details.h" | 
| 39 #include "components/translate/core/browser/translate_accept_languages.h" | 39 #include "components/translate/core/browser/translate_accept_languages.h" | 
| 40 #include "components/translate/core/browser/translate_download_manager.h" | 40 #include "components/translate/core/browser/translate_download_manager.h" | 
| 41 #include "components/translate/core/browser/translate_infobar_delegate.h" | 41 #include "components/translate/core/browser/translate_infobar_delegate.h" | 
| 42 #include "components/translate/core/browser/translate_manager.h" | 42 #include "components/translate/core/browser/translate_manager.h" | 
| 43 #include "components/translate/core/browser/translate_prefs.h" | 43 #include "components/translate/core/browser/translate_prefs.h" | 
| 44 #include "components/translate/core/common/language_detection_details.h" | 44 #include "components/translate/core/common/language_detection_details.h" | 
| 45 #include "components/translate/core/common/language_detection_logging_helper.h" | 45 #include "components/translate/core/common/language_detection_logging_helper.h" | 
|  | 46 #include "components/translate/core/common/translation_logging_helper.h" | 
| 46 #include "components/variations/service/variations_service.h" | 47 #include "components/variations/service/variations_service.h" | 
| 47 #include "content/public/browser/navigation_entry.h" | 48 #include "content/public/browser/navigation_entry.h" | 
| 48 #include "content/public/browser/notification_service.h" | 49 #include "content/public/browser/notification_service.h" | 
| 49 #include "content/public/browser/render_view_host.h" | 50 #include "content/public/browser/render_view_host.h" | 
| 50 #include "content/public/browser/web_contents.h" | 51 #include "content/public/browser/web_contents.h" | 
| 51 #include "url/gurl.h" | 52 #include "url/gurl.h" | 
| 52 | 53 | 
| 53 namespace { | 54 namespace { | 
|  | 55 using metrics::TranslateEventProto; | 
| 54 | 56 | 
| 55 metrics::TranslateEventProto::EventType BubbleResultToTranslateEvent( | 57 TranslateEventProto::EventType BubbleResultToTranslateEvent( | 
| 56     ShowTranslateBubbleResult result) { | 58     ShowTranslateBubbleResult result) { | 
| 57   switch (result) { | 59   switch (result) { | 
| 58     case ShowTranslateBubbleResult::BROWSER_WINDOW_NOT_VALID: | 60     case ShowTranslateBubbleResult::BROWSER_WINDOW_NOT_VALID: | 
| 59       return metrics::TranslateEventProto::BROWSER_WINDOW_IS_INVALID; | 61       return TranslateEventProto::BROWSER_WINDOW_IS_INVALID; | 
| 60     case ShowTranslateBubbleResult::BROWSER_WINDOW_MINIMIZED: | 62     case ShowTranslateBubbleResult::BROWSER_WINDOW_MINIMIZED: | 
| 61       return metrics::TranslateEventProto::BROWSER_WINDOW_IS_MINIMIZED; | 63       return TranslateEventProto::BROWSER_WINDOW_IS_MINIMIZED; | 
| 62     case ShowTranslateBubbleResult::BROWSER_WINDOW_NOT_ACTIVE: | 64     case ShowTranslateBubbleResult::BROWSER_WINDOW_NOT_ACTIVE: | 
| 63       return metrics::TranslateEventProto::BROWSER_WINDOW_NOT_ACTIVE; | 65       return TranslateEventProto::BROWSER_WINDOW_NOT_ACTIVE; | 
| 64     case ShowTranslateBubbleResult::WEB_CONTENTS_NOT_ACTIVE: | 66     case ShowTranslateBubbleResult::WEB_CONTENTS_NOT_ACTIVE: | 
| 65       return metrics::TranslateEventProto::WEB_CONTENTS_NOT_ACTIVE; | 67       return TranslateEventProto::WEB_CONTENTS_NOT_ACTIVE; | 
| 66     case ShowTranslateBubbleResult::EDITABLE_FIELD_IS_ACTIVE: | 68     case ShowTranslateBubbleResult::EDITABLE_FIELD_IS_ACTIVE: | 
| 67       return metrics::TranslateEventProto::EDITABLE_FIELD_IS_ACTIVE; | 69       return TranslateEventProto::EDITABLE_FIELD_IS_ACTIVE; | 
| 68     default: | 70     default: | 
| 69       NOTREACHED(); | 71       NOTREACHED(); | 
| 70       return metrics::TranslateEventProto::UNKNOWN; | 72       return metrics::TranslateEventProto::UNKNOWN; | 
| 71   } | 73   } | 
| 72 } | 74 } | 
| 73 | 75 | 
|  | 76 // ========== LOG LANGUAGE DETECTION EVENT ============== | 
|  | 77 | 
| 74 void LogLanguageDetectionEvent( | 78 void LogLanguageDetectionEvent( | 
| 75     const content::WebContents* const web_contents, | 79     const content::WebContents* const web_contents, | 
| 76     const translate::LanguageDetectionDetails& details) { | 80     const translate::LanguageDetectionDetails& details) { | 
| 77   auto* const profile = | 81   auto* const profile = | 
| 78       Profile::FromBrowserContext(web_contents->GetBrowserContext()); | 82       Profile::FromBrowserContext(web_contents->GetBrowserContext()); | 
| 79 | 83 | 
| 80   syncer::UserEventService* const user_event_service = | 84   syncer::UserEventService* const user_event_service = | 
| 81       browser_sync::UserEventServiceFactory::GetForProfile(profile); | 85       browser_sync::UserEventServiceFactory::GetForProfile(profile); | 
| 82 | 86 | 
| 83   const auto* const entry = | 87   const auto* const entry = | 
| 84       web_contents->GetController().GetLastCommittedEntry(); | 88       web_contents->GetController().GetLastCommittedEntry(); | 
| 85 | 89 | 
| 86   // If entry is null, we don't record the page. | 90   // If entry is null, we don't record the page. | 
| 87   // The navigation entry can be null in situations like download or initial | 91   // The navigation entry can be null in situations like download or initial | 
| 88   // blank page. | 92   // blank page. | 
| 89   if (entry != nullptr) { | 93   if (entry != nullptr) { | 
| 90     user_event_service->RecordUserEvent( | 94     user_event_service->RecordUserEvent( | 
| 91         translate::ConstructLanguageDetectionEvent(details)); | 95         translate::ConstructLanguageDetectionEvent(details)); | 
| 92   } | 96   } | 
| 93 } | 97 } | 
| 94 | 98 | 
|  | 99 // ========== LOG TRANSLATE EVENT ============== | 
|  | 100 | 
|  | 101 void LogTranslateEvent(const content::WebContents* const web_contents, | 
|  | 102                        const metrics::TranslateEventProto& translate_event) { | 
|  | 103   DCHECK(web_contents); | 
|  | 104   auto* const profile = | 
|  | 105       Profile::FromBrowserContext(web_contents->GetBrowserContext()); | 
|  | 106 | 
|  | 107   syncer::UserEventService* const user_event_service = | 
|  | 108       browser_sync::UserEventServiceFactory::GetForProfile(profile); | 
|  | 109 | 
|  | 110   const auto* const entry = | 
|  | 111       web_contents->GetController().GetLastCommittedEntry(); | 
|  | 112 | 
|  | 113   // If entry is null, we don't record the page. | 
|  | 114   // The navigation entry can be null in situations like download or initial | 
|  | 115   // blank page. | 
|  | 116   if (entry == nullptr) | 
|  | 117     return; | 
|  | 118 | 
|  | 119   auto specifics = base::MakeUnique<sync_pb::UserEventSpecifics>(); | 
|  | 120   // We only log the event we care about. | 
|  | 121   const bool needs_logging = translate::ConstructTranslateEvent( | 
|  | 122       entry->GetTimestamp().ToInternalValue(), translate_event, | 
|  | 123       specifics.get()); | 
|  | 124   if (needs_logging) { | 
|  | 125     user_event_service->RecordUserEvent(std::move(specifics)); | 
|  | 126   } | 
|  | 127 } | 
|  | 128 | 
| 95 }  // namespace | 129 }  // namespace | 
| 96 | 130 | 
| 97 DEFINE_WEB_CONTENTS_USER_DATA_KEY(ChromeTranslateClient); | 131 DEFINE_WEB_CONTENTS_USER_DATA_KEY(ChromeTranslateClient); | 
| 98 | 132 | 
| 99 ChromeTranslateClient::ChromeTranslateClient(content::WebContents* web_contents) | 133 ChromeTranslateClient::ChromeTranslateClient(content::WebContents* web_contents) | 
| 100     : content::WebContentsObserver(web_contents), | 134     : content::WebContentsObserver(web_contents), | 
| 101       translate_driver_(&web_contents->GetController()), | 135       translate_driver_(&web_contents->GetController()), | 
| 102       translate_manager_(new translate::TranslateManager( | 136       translate_manager_(new translate::TranslateManager( | 
| 103           this, | 137           this, | 
| 104           translate::TranslateRankerFactory::GetForBrowserContext( | 138           translate::TranslateRankerFactory::GetForBrowserContext( | 
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 189     if (!auto_translate_language.empty()) { | 223     if (!auto_translate_language.empty()) { | 
| 190       *target = auto_translate_language; | 224       *target = auto_translate_language; | 
| 191       return; | 225       return; | 
| 192     } | 226     } | 
| 193   } | 227   } | 
| 194 | 228 | 
| 195   *target = | 229   *target = | 
| 196       translate::TranslateManager::GetTargetLanguage(translate_prefs.get()); | 230       translate::TranslateManager::GetTargetLanguage(translate_prefs.get()); | 
| 197 } | 231 } | 
| 198 | 232 | 
|  | 233 void ChromeTranslateClient::RecordTranslateEvent( | 
|  | 234     const TranslateEventProto& translate_event) { | 
|  | 235   LogTranslateEvent(web_contents(), translate_event); | 
|  | 236 } | 
|  | 237 | 
| 199 // static | 238 // static | 
| 200 void ChromeTranslateClient::BindContentTranslateDriver( | 239 void ChromeTranslateClient::BindContentTranslateDriver( | 
| 201     content::RenderFrameHost* render_frame_host, | 240     content::RenderFrameHost* render_frame_host, | 
| 202     const service_manager::BindSourceInfo& source_info, | 241     const service_manager::BindSourceInfo& source_info, | 
| 203     translate::mojom::ContentTranslateDriverRequest request) { | 242     translate::mojom::ContentTranslateDriverRequest request) { | 
| 204   content::WebContents* web_contents = | 243   content::WebContents* web_contents = | 
| 205       content::WebContents::FromRenderFrameHost(render_frame_host); | 244       content::WebContents::FromRenderFrameHost(render_frame_host); | 
| 206   if (!web_contents) | 245   if (!web_contents) | 
| 207     return; | 246     return; | 
| 208 | 247 | 
| (...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 392       return ShowTranslateBubbleResult::SUCCESS; | 431       return ShowTranslateBubbleResult::SUCCESS; | 
| 393   } | 432   } | 
| 394 | 433 | 
| 395   return TranslateBubbleFactory::Show(browser->window(), web_contents(), step, | 434   return TranslateBubbleFactory::Show(browser->window(), web_contents(), step, | 
| 396                                       error_type); | 435                                       error_type); | 
| 397 #else | 436 #else | 
| 398   NOTREACHED(); | 437   NOTREACHED(); | 
| 399   return ShowTranslateBubbleResult::SUCCESS; | 438   return ShowTranslateBubbleResult::SUCCESS; | 
| 400 #endif | 439 #endif | 
| 401 } | 440 } | 
| OLD | NEW | 
|---|