1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
|
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_FRAME_CFPROXY_H_
#define CHROME_FRAME_CFPROXY_H_
#pragma once
#include <windows.h>
#include <map> // for proxy factory
#include <vector>
#include <string>
#include "base/synchronization/lock.h"
#include "base/time.h" // for base::TimeDelta
#include "base/file_path.h"
#include "chrome/common/automation_constants.h"
#include "content/common/page_zoom.h"
#include "ipc/ipc_channel.h"
class ChromeProxyDelegate;
class ChromeProxyFactory;
class GURL;
struct AttachExternalTabParams;
struct AutomationURLRequest;
struct ContextMenuModel;
struct ExternalTabSettings;
struct MiniContextMenuParams;
struct NavigationInfo;
struct ProxyParams;
namespace net {
class URLRequestStatus;
} // namespace net
// Some callers of synchronous messages wants a context to be passed back
// in order to identify the call they made. Presumably one can make
// multiple sync calls of same type (as async) and want to identify what
// is what.
struct SyncMessageContext {
virtual ~SyncMessageContext() {}
};
/*
[activex] UIDelegate (UI_THREAD)
[activedoc] <---------------+
|
| ChromeProxy (UI_THREAD)
+----------------+ --------------> +-------+
URL_FETCHER <---------|ExternalTabProxy| |CFProxy|
+----------------+ +-------+
|
^ |
| |
+-----------------------------+
ChromeProxyDelegate (IPC_THREAD)
*/
// ChromeProxy is an abstract class. Is forwards the commands to an
// instance of the running Chromium browser.
// A pointer to ChromeProxy instance is obtained through a
// ChromeProxyFactory object.
class ChromeProxy {
public:
// General
virtual void RemoveBrowsingData(int remove_mask) = 0; // async
virtual void SetProxyConfig(const std::string& json_encoded_settings) = 0;
// Tab management.
virtual void CreateTab(ChromeProxyDelegate* delegate,
const ExternalTabSettings& settings) = 0;
virtual void ConnectTab(ChromeProxyDelegate* delegate, HWND hwnd,
uint64 cookie) = 0;
virtual void BlockTab(uint64 cookie) = 0;
// Tab related.
virtual void Tab_PostMessage(int tab, const std::string& message,
const std::string& origin,
const std::string& target) = 0;
virtual void Tab_Reload(int tab) = 0;
virtual void Tab_Stop(int tab) = 0;
virtual void Tab_SaveAs(int tab) = 0;
virtual void Tab_Print(int tab) = 0;
virtual void Tab_Cut(int tab) = 0;
virtual void Tab_Copy(int tab) = 0;
virtual void Tab_Paste(int tab) = 0;
virtual void Tab_SelectAll(int tab) = 0;
virtual void Tab_Find(int tab, const string16& search_string,
FindInPageDirection forward, FindInPageCase match_case,
bool find_next) = 0;
virtual void Tab_MenuCommand(int tab, int selected_command) = 0;
// UI
virtual void Tab_Zoom(int tab, PageZoom::Function zoom_level) = 0;
virtual void Tab_FontSize(int tab, enum AutomationPageFontSize font_size) = 0;
virtual void Tab_SetInitialFocus(int tab,
bool reverse, bool restore_focus_to_view) = 0;
virtual void Tab_SetParentWindow(int tab) = 0;
virtual void Tab_Resize(int tab) = 0;
virtual void Tab_ProcessAccelerator(int tab, const MSG& msg) = 0;
// Misc.
virtual void Tab_OnHostMoved(int tab) = 0;
virtual void Tab_RunUnloadHandlers(int tab) = 0;
virtual void Tab_Navigate(int tab, const GURL& url, const GURL& referrer) = 0;
virtual void Tab_OverrideEncoding(int tab, const char* encoding) = 0;
protected:
// Accessible by ChromeProxyFactory
friend class ChromeProxyFactory;
virtual ~ChromeProxy() {}
virtual void Init(const ProxyParams& params) = 0;
virtual int AddDelegate(ChromeProxyDelegate* delegate) = 0;
virtual int RemoveDelegate(ChromeProxyDelegate* delegate) = 0;
};
// The object that uses ChromeProxy should implement ChromeProxyDelegate in
// order to get notified about important events/requests coming from the
// instance of Chromium.
// Allow only one delegate per tab, i.e. delegate can handle only a single tab.
// Note: all of the methods are invoked always in a background IPC thread.
class ChromeProxyDelegate : public IPC::Channel::Listener {
public:
enum DisconnectReason {
CHROME_EXE_LAUNCH_FAILED,
CHROME_EXE_LAUNCH_TIMEOUT,
CHANNEL_ERROR
};
virtual void Connected(ChromeProxy* proxy) = 0;
virtual void Disconnected() = 0;
virtual void PeerLost(ChromeProxy* proxy, DisconnectReason reason) = 0;
virtual int tab_handle() = 0; // to avoid reverse lookup :)
// Sync message responses.
virtual void Completed_CreateTab(bool success, HWND chrome_wnd,
HWND tab_window, int tab_handle, int session_id) = 0;
virtual void Completed_ConnectToTab(bool success, HWND chrome_window,
HWND tab_window, int tab_handle, int session_id) = 0;
virtual void Completed_Navigate(bool success,
enum AutomationMsg_NavigationResponseValues res) = 0;
protected:
~ChromeProxyDelegate() {}
};
// a way to obtain a ChromeProxy implementation
struct ProxyParams {
std::string profile;
std::wstring extra_params;
FilePath profile_path;
base::TimeDelta timeout;
};
class ChromeProxyFactory {
public:
ChromeProxyFactory();
~ChromeProxyFactory();
void GetProxy(ChromeProxyDelegate* delegate, const ProxyParams& params);
bool ReleaseProxy(ChromeProxyDelegate* delegate, const std::string& profile);
protected:
virtual ChromeProxy* CreateProxy();
typedef std::map<std::string, ChromeProxy*> ProxyMap;
ProxyMap proxies_;
base::Lock lock_;
};
#endif // CHROME_FRAME_CFPROXY_H_
|