blob: cdc3741b50456800bf074a3f622293ba201f94a2 [file] [log] [blame]
[email protected]c11e6592014-06-27 17:07:341// Copyright 2014 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef EXTENSIONS_RENDERER_SCRIPT_INJECTOR_H_
6#define EXTENSIONS_RENDERER_SCRIPT_INJECTOR_H_
7
dchengf6f80662016-04-20 20:26:048#include <memory>
[email protected]c11e6592014-06-27 17:07:349#include <vector>
10
[email protected]23a85362014-07-07 23:26:1911#include "extensions/common/permissions/permissions_data.h"
[email protected]c11e6592014-06-27 17:07:3412#include "extensions/common/user_script.h"
13#include "third_party/WebKit/public/web/WebScriptSource.h"
14
15class GURL;
hanxia5c856cf2015-02-13 20:51:5816class InjectionHost;
[email protected]c11e6592014-06-27 17:07:3417
18namespace blink {
rdevlin.cronin3e11c9862015-06-04 19:54:2519class WebLocalFrame;
[email protected]c11e6592014-06-27 17:07:3420}
21
22namespace extensions {
[email protected]c11e6592014-06-27 17:07:3423struct ScriptsRunInfo;
24
25// The pseudo-delegate class for a ScriptInjection that provides all necessary
26// information about how to inject the script, including what code to inject,
27// when (run location), and where (world), but without any injection logic.
28class ScriptInjector {
29 public:
30 // The possible reasons for not injecting the script.
31 enum InjectFailureReason {
32 EXTENSION_REMOVED, // The extension was removed before injection.
33 NOT_ALLOWED, // The script is not allowed to inject.
34 WONT_INJECT // The injection won't inject because the user rejected
35 // (or just did not accept) the injection.
36 };
37
[email protected]c11e6592014-06-27 17:07:3438 virtual ~ScriptInjector() {}
39
[email protected]23a85362014-07-07 23:26:1940 // Returns the script type of this particular injection.
41 virtual UserScript::InjectionType script_type() const = 0;
42
[email protected]c11e6592014-06-27 17:07:3443 // Returns true if the script should execute in the main world.
44 virtual bool ShouldExecuteInMainWorld() const = 0;
45
46 // Returns true if the script is running inside a user gesture.
47 virtual bool IsUserGesture() const = 0;
48
thakis1eeacc842015-03-26 07:30:5249 // Returns true if the script expects results.
[email protected]c11e6592014-06-27 17:07:3450 virtual bool ExpectsResults() const = 0;
51
52 // Returns true if the script should inject JS source at the given
53 // |run_location|.
catmullingsd4faad4f2016-09-08 19:55:3054 virtual bool ShouldInjectJs(
55 UserScript::RunLocation run_location,
56 const std::set<std::string>& executing_scripts) const = 0;
[email protected]c11e6592014-06-27 17:07:3457
58 // Returns true if the script should inject CSS at the given |run_location|.
catmullingsd4faad4f2016-09-08 19:55:3059 virtual bool ShouldInjectCss(
60 UserScript::RunLocation run_location,
61 const std::set<std::string>& injected_stylesheets) const = 0;
[email protected]c11e6592014-06-27 17:07:3462
63 // Returns true if the script should execute on the given |frame|.
[email protected]23a85362014-07-07 23:26:1964 virtual PermissionsData::AccessType CanExecuteOnFrame(
hanxia5c856cf2015-02-13 20:51:5865 const InjectionHost* injection_host,
rdevlin.cronin3e11c9862015-06-04 19:54:2566 blink::WebLocalFrame* web_frame,
rdevlin.croninf994d1e2015-06-03 22:28:1967 int tab_id) const = 0;
[email protected]c11e6592014-06-27 17:07:3468
69 // Returns the javascript sources to inject at the given |run_location|.
70 // Only called if ShouldInjectJs() is true.
71 virtual std::vector<blink::WebScriptSource> GetJsSources(
catmullingsd4faad4f2016-09-08 19:55:3072 UserScript::RunLocation run_location,
73 std::set<std::string>* executing_scripts,
74 size_t* num_injected_js_scripts) const = 0;
[email protected]c11e6592014-06-27 17:07:3475
76 // Returns the css to inject at the given |run_location|.
77 // Only called if ShouldInjectCss() is true.
lazyboy49cc0b3a2016-08-18 21:55:1278 virtual std::vector<blink::WebString> GetCssSources(
catmullingsd4faad4f2016-09-08 19:55:3079 UserScript::RunLocation run_location,
80 std::set<std::string>* injected_stylesheets,
81 size_t* num_injected_stylesheets) const = 0;
kozyatinskiyc8bc9a582015-03-06 09:33:4182
[email protected]c11e6592014-06-27 17:07:3483 // Notifies the script that injection has completed, with a possibly-populated
84 // list of results (depending on whether or not ExpectsResults() was true).
rdevlin.cronind533be962015-10-02 17:01:1885 // |render_frame| contains the render frame, or null if the frame was
86 // invalidated.
[email protected]c11e6592014-06-27 17:07:3487 virtual void OnInjectionComplete(
dchengf6f80662016-04-20 20:26:0488 std::unique_ptr<base::Value> execution_result,
rdevlin.cronind533be962015-10-02 17:01:1889 UserScript::RunLocation run_location,
90 content::RenderFrame* render_frame) = 0;
[email protected]c11e6592014-06-27 17:07:3491
92 // Notifies the script that injection will never occur.
rdevlin.cronind533be962015-10-02 17:01:1893 // |render_frame| contains the render frame, or null if the frame was
94 // invalidated.
95 virtual void OnWillNotInject(InjectFailureReason reason,
96 content::RenderFrame* render_frame) = 0;
[email protected]c11e6592014-06-27 17:07:3497};
98
99} // namespace extensions
100
101#endif // EXTENSIONS_RENDERER_SCRIPT_INJECTOR_H_