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 #ifndef EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ | 5 #ifndef EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ |
6 #define EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ | 6 #define EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/macros.h" | 9 #include "base/macros.h" |
| 10 #include "base/memory/scoped_ptr.h" |
10 #include "extensions/common/user_script.h" | 11 #include "extensions/common/user_script.h" |
11 #include "extensions/renderer/injection_host.h" | 12 #include "extensions/renderer/injection_host.h" |
12 #include "extensions/renderer/script_injector.h" | 13 #include "extensions/renderer/script_injector.h" |
13 | 14 |
14 struct HostID; | 15 struct HostID; |
15 | 16 |
16 namespace blink { | 17 namespace blink { |
17 class WebLocalFrame; | 18 class WebLocalFrame; |
| 19 template<typename T> class WebVector; |
| 20 } |
| 21 |
| 22 namespace v8 { |
| 23 class Value; |
| 24 template <class T> class Local; |
18 } | 25 } |
19 | 26 |
20 namespace extensions { | 27 namespace extensions { |
| 28 class ScriptInjectionManager; |
21 struct ScriptsRunInfo; | 29 struct ScriptsRunInfo; |
22 | 30 |
23 // A script wrapper which is aware of whether or not it is allowed to execute, | 31 // A script wrapper which is aware of whether or not it is allowed to execute, |
24 // and contains the implementation to do so. | 32 // and contains the implementation to do so. |
25 class ScriptInjection { | 33 class ScriptInjection { |
26 public: | 34 public: |
| 35 enum InjectionResult { |
| 36 INJECTION_FINISHED, |
| 37 INJECTION_BLOCKED, |
| 38 INJECTION_WAITING |
| 39 }; |
| 40 |
27 // Return the id of the injection host associated with the given world. | 41 // Return the id of the injection host associated with the given world. |
28 static std::string GetHostIdForIsolatedWorld(int world_id); | 42 static std::string GetHostIdForIsolatedWorld(int world_id); |
29 | 43 |
30 // Remove the isolated world associated with the given injection host. | 44 // Remove the isolated world associated with the given injection host. |
31 static void RemoveIsolatedWorld(const std::string& host_id); | 45 static void RemoveIsolatedWorld(const std::string& host_id); |
32 | 46 |
33 ScriptInjection(scoped_ptr<ScriptInjector> injector, | 47 ScriptInjection(scoped_ptr<ScriptInjector> injector, |
34 blink::WebLocalFrame* web_frame, | 48 blink::WebLocalFrame* web_frame, |
35 scoped_ptr<const InjectionHost> injection_host, | 49 scoped_ptr<const InjectionHost> injection_host, |
36 UserScript::RunLocation run_location, | 50 UserScript::RunLocation run_location, |
37 int tab_id); | 51 int tab_id); |
38 ~ScriptInjection(); | 52 ~ScriptInjection(); |
39 | 53 |
40 // Try to inject the script at the |current_location|. This returns true if | 54 // Try to inject the script at the |current_location|. This returns |
41 // the script has either injected or will never inject (i.e., if the object | 55 // INJECTION_FINISHED if injection has injected or will never inject, returns |
42 // is done), and false if injection is delayed (either for permission purposes | 56 // INJECTION_BLOCKED if injection is running asynchronously and has not |
43 // or because |current_location| is not the designated |run_location_|). | 57 // finished yet, returns INJECTION_WAITING if injections is delayed (either |
44 bool TryToInject(UserScript::RunLocation current_location, | 58 // for permission purposes or because |current_location| is not the designated |
45 ScriptsRunInfo* scripts_run_info); | 59 // |run_location_|). |
| 60 InjectionResult TryToInject(UserScript::RunLocation current_location, |
| 61 ScriptsRunInfo* scripts_run_info, |
| 62 ScriptInjectionManager* manager); |
46 | 63 |
47 // Called when permission for the given injection has been granted. | 64 // Called when permission for the given injection has been granted. |
48 // Returns true if the injection ran. | 65 // Returns INJECTION_FINISHED if injection has injected or will never inject, |
49 bool OnPermissionGranted(ScriptsRunInfo* scripts_run_info); | 66 // returns INJECTION_BLOCKED if injection is ran asynchronously. |
| 67 InjectionResult OnPermissionGranted(ScriptsRunInfo* scripts_run_info); |
50 | 68 |
51 // Resets the pointer of the injection host when the host is gone. | 69 // Resets the pointer of the injection host when the host is gone. |
52 void OnHostRemoved(); | 70 void OnHostRemoved(); |
53 | 71 |
| 72 // Called when JS injection for the given frame has been completed. |
| 73 void OnJsInjectionCompleted( |
| 74 blink::WebLocalFrame* frame, |
| 75 const blink::WebVector<v8::Local<v8::Value> >& results); |
| 76 |
54 // Accessors. | 77 // Accessors. |
55 blink::WebLocalFrame* web_frame() const { return web_frame_; } | 78 blink::WebLocalFrame* web_frame() const { return web_frame_; } |
56 const HostID& host_id() const { return injection_host_->id(); } | 79 const HostID& host_id() const { return injection_host_->id(); } |
57 int64 request_id() const { return request_id_; } | 80 int64 request_id() const { return request_id_; } |
58 | 81 |
59 private: | 82 private: |
60 // Sends a message to the browser, either that the script injection would | 83 // Sends a message to the browser, either that the script injection would |
61 // like to inject, or to notify the browser that it is currently injecting. | 84 // like to inject, or to notify the browser that it is currently injecting. |
62 void SendInjectionMessage(bool request_permission); | 85 void SendInjectionMessage(bool request_permission); |
63 | 86 |
64 // Injects the script, optionally populating |scripts_run_info|. | 87 // Injects the script. Returns INJECTION_FINISHED if injection has finished, |
65 void Inject(ScriptsRunInfo* scripts_run_info); | 88 // otherwise INJECTION_BLOCKED. |
| 89 InjectionResult Inject(ScriptsRunInfo* scripts_run_info); |
66 | 90 |
67 // Inject any JS scripts into the |frame|, optionally populating | 91 // Inject any JS scripts into the |frame|. |
68 // |execution_results|. | 92 void InjectJs(blink::WebLocalFrame* frame); |
69 void InjectJs(blink::WebLocalFrame* frame, | 93 |
70 base::ListValue* execution_results); | 94 // Checks if all scripts have been injected and finished. |
| 95 void TryToFinish(); |
71 | 96 |
72 // Inject any CSS source into the |frame|. | 97 // Inject any CSS source into the |frame|. |
73 void InjectCss(blink::WebLocalFrame* frame); | 98 void InjectCss(blink::WebLocalFrame* frame); |
74 | 99 |
75 // Notify that we will not inject, and mark it as acknowledged. | 100 // Notify that we will not inject, and mark it as acknowledged. |
76 void NotifyWillNotInject(ScriptInjector::InjectFailureReason reason); | 101 void NotifyWillNotInject(ScriptInjector::InjectFailureReason reason); |
77 | 102 |
78 // The injector for this injection. | 103 // The injector for this injection. |
79 scoped_ptr<ScriptInjector> injector_; | 104 scoped_ptr<ScriptInjector> injector_; |
80 | 105 |
(...skipping 10 matching lines...) Expand all Loading... |
91 int tab_id_; | 116 int tab_id_; |
92 | 117 |
93 // This injection's request id. This will be -1 unless the injection is | 118 // This injection's request id. This will be -1 unless the injection is |
94 // currently waiting on permission. | 119 // currently waiting on permission. |
95 int64 request_id_; | 120 int64 request_id_; |
96 | 121 |
97 // Whether or not the injection is complete, either via injecting the script | 122 // Whether or not the injection is complete, either via injecting the script |
98 // or because it will never complete. | 123 // or because it will never complete. |
99 bool complete_; | 124 bool complete_; |
100 | 125 |
| 126 // Number of frames in which the injection is running. |
| 127 int running_frames_; |
| 128 |
| 129 // Results storage. |
| 130 scoped_ptr<base::ListValue> execution_results_; |
| 131 |
| 132 // Flag is true when injections for each frame started. |
| 133 bool all_injections_started_; |
| 134 |
| 135 // ScriptInjectionManager::OnInjectionFinished will be called after injection |
| 136 // finished. |
| 137 ScriptInjectionManager* script_injection_manager_; |
| 138 |
101 DISALLOW_COPY_AND_ASSIGN(ScriptInjection); | 139 DISALLOW_COPY_AND_ASSIGN(ScriptInjection); |
102 }; | 140 }; |
103 | 141 |
104 } // namespace extensions | 142 } // namespace extensions |
105 | 143 |
106 #endif // EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ | 144 #endif // EXTENSIONS_RENDERER_SCRIPT_INJECTION_H_ |
OLD | NEW |