OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 // Implements the Chrome Extensions WebNavigation API. | 5 // Implements the Chrome Extensions WebNavigation API. |
6 | 6 |
7 #include "chrome/browser/extensions/extension_webnavigation_api.h" | 7 #include "chrome/browser/extensions/extension_webnavigation_api.h" |
8 | 8 |
9 #include "base/json/json_writer.h" | 9 #include "base/json/json_writer.h" |
10 #include "base/time.h" | 10 #include "base/time.h" |
11 #include "base/values.h" | 11 #include "base/values.h" |
12 #include "chrome/browser/extensions/extension_message_service.h" | 12 #include "chrome/browser/extensions/extension_message_service.h" |
13 #include "chrome/browser/extensions/extension_tabs_module.h" | 13 #include "chrome/browser/extensions/extension_tabs_module.h" |
14 #include "chrome/browser/extensions/extension_webnavigation_api_constants.h" | 14 #include "chrome/browser/extensions/extension_webnavigation_api_constants.h" |
15 #include "chrome/browser/profile.h" | 15 #include "chrome/browser/profile.h" |
16 #include "chrome/browser/tab_contents/navigation_entry.h" | 16 #include "chrome/browser/tab_contents/navigation_controller.h" |
| 17 #include "chrome/browser/tab_contents/provisional_load_details.h" |
17 #include "chrome/common/notification_type.h" | 18 #include "chrome/common/notification_type.h" |
18 #include "chrome/common/notification_service.h" | 19 #include "chrome/common/notification_service.h" |
| 20 #include "net/base/net_errors.h" |
19 | 21 |
20 namespace keys = extension_webnavigation_api_constants; | 22 namespace keys = extension_webnavigation_api_constants; |
21 | 23 |
22 // static | 24 // static |
23 ExtensionWebNavigationEventRouter* | 25 ExtensionWebNavigationEventRouter* |
24 ExtensionWebNavigationEventRouter::GetInstance() { | 26 ExtensionWebNavigationEventRouter::GetInstance() { |
25 return Singleton<ExtensionWebNavigationEventRouter>::get(); | 27 return Singleton<ExtensionWebNavigationEventRouter>::get(); |
26 } | 28 } |
27 | 29 |
28 void ExtensionWebNavigationEventRouter::Init() { | 30 void ExtensionWebNavigationEventRouter::Init() { |
29 if (registrar_.IsEmpty()) { | 31 if (registrar_.IsEmpty()) { |
30 registrar_.Add(this, | 32 registrar_.Add(this, |
31 NotificationType::NAV_ENTRY_COMMITTED, | 33 NotificationType::FRAME_PROVISIONAL_LOAD_START, |
| 34 NotificationService::AllSources()); |
| 35 registrar_.Add(this, |
| 36 NotificationType::FRAME_PROVISIONAL_LOAD_COMMITTED, |
| 37 NotificationService::AllSources()); |
| 38 registrar_.Add(this, |
| 39 NotificationType::FAIL_PROVISIONAL_LOAD_WITH_ERROR, |
32 NotificationService::AllSources()); | 40 NotificationService::AllSources()); |
33 } | 41 } |
34 } | 42 } |
35 | 43 |
36 void ExtensionWebNavigationEventRouter::Observe( | 44 void ExtensionWebNavigationEventRouter::Observe( |
37 NotificationType type, | 45 NotificationType type, |
38 const NotificationSource& source, | 46 const NotificationSource& source, |
39 const NotificationDetails& details) { | 47 const NotificationDetails& details) { |
40 switch (type.value) { | 48 switch (type.value) { |
41 case NotificationType::NAV_ENTRY_COMMITTED: | 49 case NotificationType::FRAME_PROVISIONAL_LOAD_START: |
42 NavEntryCommitted( | 50 FrameProvisionalLoadStart( |
43 Source<NavigationController>(source).ptr(), | 51 Source<NavigationController>(source).ptr(), |
44 Details<NavigationController::LoadCommittedDetails>(details).ptr()); | 52 Details<ProvisionalLoadDetails>(details).ptr()); |
| 53 break; |
| 54 case NotificationType::FRAME_PROVISIONAL_LOAD_COMMITTED: |
| 55 FrameProvisionalLoadCommitted( |
| 56 Source<NavigationController>(source).ptr(), |
| 57 Details<ProvisionalLoadDetails>(details).ptr()); |
| 58 break; |
| 59 case NotificationType::FAIL_PROVISIONAL_LOAD_WITH_ERROR: |
| 60 FailProvisionalLoadWithError( |
| 61 Source<NavigationController>(source).ptr(), |
| 62 Details<ProvisionalLoadDetails>(details).ptr()); |
45 break; | 63 break; |
46 | 64 |
47 default: | 65 default: |
48 NOTREACHED(); | 66 NOTREACHED(); |
49 } | 67 } |
50 } | 68 } |
51 | 69 void ExtensionWebNavigationEventRouter::FrameProvisionalLoadStart( |
52 void ExtensionWebNavigationEventRouter::NavEntryCommitted( | |
53 NavigationController* controller, | 70 NavigationController* controller, |
54 NavigationController::LoadCommittedDetails* details) { | 71 ProvisionalLoadDetails* details) { |
55 ListValue args; | 72 ListValue args; |
56 DictionaryValue* dict = new DictionaryValue(); | 73 DictionaryValue* dict = new DictionaryValue(); |
57 dict->SetInteger(keys::kTabIdKey, | 74 dict->SetInteger(keys::kTabIdKey, |
58 ExtensionTabUtil::GetTabId(controller->tab_contents())); | 75 ExtensionTabUtil::GetTabId(controller->tab_contents())); |
59 dict->SetString(keys::kUrlKey, | 76 dict->SetString(keys::kUrlKey, |
60 details->entry->url().spec()); | 77 details->url().spec()); |
61 dict->SetInteger(keys::kFrameIdKey, | 78 dict->SetInteger(keys::kFrameIdKey, 0); |
62 details->is_main_frame ? 0 : details->entry->page_id()); | 79 dict->SetInteger(keys::kRequestIdKey, 0); |
63 dict->SetString(keys::kTransitionTypeKey, | 80 dict->SetReal(keys::kTimeStampKey, |
64 PageTransition::CoreTransitionString( | 81 static_cast<double>( |
65 details->entry->transition_type())); | 82 (base::Time::Now() - base::Time::UnixEpoch()).InMilliseconds())); |
66 dict->SetString(keys::kTransitionQualifiersKey, | |
67 PageTransition::QualifierString( | |
68 details->entry->transition_type())); | |
69 dict->SetReal(keys::kTimeStampKey, base::Time::Now().ToDoubleT()); | |
70 args.Append(dict); | 83 args.Append(dict); |
71 | 84 |
72 std::string json_args; | 85 std::string json_args; |
| 86 base::JSONWriter::Write(&args, false, &json_args); |
| 87 DispatchEvent(controller->profile(), keys::kOnBeforeNavigate, json_args); |
| 88 } |
| 89 |
| 90 void ExtensionWebNavigationEventRouter::FrameProvisionalLoadCommitted( |
| 91 NavigationController* controller, |
| 92 ProvisionalLoadDetails* details) { |
| 93 ListValue args; |
| 94 DictionaryValue* dict = new DictionaryValue(); |
| 95 dict->SetInteger(keys::kTabIdKey, |
| 96 ExtensionTabUtil::GetTabId(controller->tab_contents())); |
| 97 dict->SetString(keys::kUrlKey, |
| 98 details->url().spec()); |
| 99 dict->SetInteger(keys::kFrameIdKey, 0); |
| 100 dict->SetString(keys::kTransitionTypeKey, |
| 101 PageTransition::CoreTransitionString( |
| 102 details->transition_type())); |
| 103 dict->SetString(keys::kTransitionQualifiersKey, |
| 104 PageTransition::QualifierString( |
| 105 details->transition_type())); |
| 106 dict->SetReal(keys::kTimeStampKey, |
| 107 static_cast<double>( |
| 108 (base::Time::Now() - base::Time::UnixEpoch()).InMilliseconds())); |
| 109 args.Append(dict); |
| 110 |
| 111 std::string json_args; |
73 base::JSONWriter::Write(&args, false, &json_args); | 112 base::JSONWriter::Write(&args, false, &json_args); |
74 DispatchEvent(controller->profile(), keys::kOnCommitted, json_args); | 113 DispatchEvent(controller->profile(), keys::kOnCommitted, json_args); |
75 } | 114 } |
76 | 115 |
| 116 void ExtensionWebNavigationEventRouter::FailProvisionalLoadWithError( |
| 117 NavigationController* controller, |
| 118 ProvisionalLoadDetails* details) { |
| 119 ListValue args; |
| 120 DictionaryValue* dict = new DictionaryValue(); |
| 121 dict->SetInteger(keys::kTabIdKey, |
| 122 ExtensionTabUtil::GetTabId(controller->tab_contents())); |
| 123 dict->SetString(keys::kUrlKey, |
| 124 details->url().spec()); |
| 125 dict->SetInteger(keys::kFrameIdKey, 0); |
| 126 dict->SetString(keys::kErrorKey, |
| 127 std::string(net::ErrorToString(details->error_code()))); |
| 128 dict->SetReal(keys::kTimeStampKey, |
| 129 static_cast<double>( |
| 130 (base::Time::Now() - base::Time::UnixEpoch()).InMilliseconds())); |
| 131 args.Append(dict); |
| 132 |
| 133 std::string json_args; |
| 134 base::JSONWriter::Write(&args, false, &json_args); |
| 135 DispatchEvent(controller->profile(), keys::kOnErrorOccurred, json_args); |
| 136 } |
| 137 |
77 void ExtensionWebNavigationEventRouter::DispatchEvent( | 138 void ExtensionWebNavigationEventRouter::DispatchEvent( |
78 Profile* profile, | 139 Profile* profile, |
79 const char* event_name, | 140 const char* event_name, |
80 const std::string& json_args) { | 141 const std::string& json_args) { |
81 if (profile && profile->GetExtensionMessageService()) { | 142 if (profile && profile->GetExtensionMessageService()) { |
82 profile->GetExtensionMessageService()->DispatchEventToRenderers( | 143 profile->GetExtensionMessageService()->DispatchEventToRenderers( |
83 event_name, json_args, profile, GURL()); | 144 event_name, json_args, profile, GURL()); |
84 } | 145 } |
85 } | 146 } |
OLD | NEW |