• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2011 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 // Multiply-included message file, so no include guard.
6 
7 #include <string>
8 #include <vector>
9 
10 #include "base/basictypes.h"
11 #include "base/file_path.h"
12 #include "base/platform_file.h"
13 #include "base/values.h"
14 #include "chrome/common/extensions/update_manifest.h"
15 #include "content/common/common_param_traits.h"
16 #include "content/common/indexed_db_key.h"
17 #include "content/common/indexed_db_param_traits.h"
18 #include "content/common/serialized_script_value.h"
19 #include "ipc/ipc_message_macros.h"
20 #include "ipc/ipc_message_utils.h"
21 #include "printing/backend/print_backend.h"
22 #include "printing/page_range.h"
23 #include "third_party/skia/include/core/SkBitmap.h"
24 #include "ui/gfx/rect.h"
25 
26 #define IPC_MESSAGE_START UtilityMsgStart
27 
28 IPC_STRUCT_TRAITS_BEGIN(printing::PageRange)
29   IPC_STRUCT_TRAITS_MEMBER(from)
30   IPC_STRUCT_TRAITS_MEMBER(to)
31 IPC_STRUCT_TRAITS_END()
32 
33 IPC_STRUCT_TRAITS_BEGIN(printing::PrinterCapsAndDefaults)
34   IPC_STRUCT_TRAITS_MEMBER(printer_capabilities)
35   IPC_STRUCT_TRAITS_MEMBER(caps_mime_type)
36   IPC_STRUCT_TRAITS_MEMBER(printer_defaults)
37   IPC_STRUCT_TRAITS_MEMBER(defaults_mime_type)
38 IPC_STRUCT_TRAITS_END()
39 
40 IPC_STRUCT_TRAITS_BEGIN(UpdateManifest::Result)
41   IPC_STRUCT_TRAITS_MEMBER(extension_id)
42   IPC_STRUCT_TRAITS_MEMBER(version)
43   IPC_STRUCT_TRAITS_MEMBER(browser_min_version)
44   IPC_STRUCT_TRAITS_MEMBER(package_hash)
45   IPC_STRUCT_TRAITS_MEMBER(crx_url)
46 IPC_STRUCT_TRAITS_END()
47 
48 IPC_STRUCT_TRAITS_BEGIN(UpdateManifest::Results)
49   IPC_STRUCT_TRAITS_MEMBER(list)
50   IPC_STRUCT_TRAITS_MEMBER(daystart_elapsed_seconds)
51 IPC_STRUCT_TRAITS_END()
52 
53 //------------------------------------------------------------------------------
54 // Utility process messages:
55 // These are messages from the browser to the utility process.
56 // Tell the utility process to unpack the given extension file in its
57 // directory and verify that it is valid.
58 IPC_MESSAGE_CONTROL1(UtilityMsg_UnpackExtension,
59                      FilePath /* extension_filename */)
60 
61 // Tell the utility process to parse the given JSON data and verify its
62 // validity.
63 IPC_MESSAGE_CONTROL1(UtilityMsg_UnpackWebResource,
64                      std::string /* JSON data */)
65 
66 // Tell the utility process to parse the given xml document.
67 IPC_MESSAGE_CONTROL1(UtilityMsg_ParseUpdateManifest,
68                      std::string /* xml document contents */)
69 
70 // Tell the utility process to decode the given image data.
71 IPC_MESSAGE_CONTROL1(UtilityMsg_DecodeImage,
72                      std::vector<unsigned char>)  // encoded image contents
73 
74 // Tell the utility process to decode the given image data, which is base64
75 // encoded.
76 IPC_MESSAGE_CONTROL1(UtilityMsg_DecodeImageBase64,
77                      std::string)  // base64 encoded image contents
78 
79 // Tell the utility process to render the given PDF into a metafile.
80 IPC_MESSAGE_CONTROL5(UtilityMsg_RenderPDFPagesToMetafile,
81                      base::PlatformFile,       // PDF file
82                      FilePath,                 // Location for output metafile
83                      gfx::Rect,                // Render Area
84                      int,                      // DPI
85                      std::vector<printing::PageRange>)
86 
87 // Tell the utility process to extract the given IDBKeyPath from the
88 // SerializedScriptValue vector and reply with the corresponding IDBKeys.
89 IPC_MESSAGE_CONTROL3(UtilityMsg_IDBKeysFromValuesAndKeyPath,
90                      int,     // id
91                      std::vector<SerializedScriptValue>,
92                      string16)  // IDBKeyPath
93 
94 IPC_MESSAGE_CONTROL3(UtilityMsg_InjectIDBKey,
95                      IndexedDBKey /* key */,
96                      SerializedScriptValue /* value */,
97                      string16 /* key path*/)
98 
99 // Tell the utility process to parse a JSON string into a Value object.
100 IPC_MESSAGE_CONTROL1(UtilityMsg_ParseJSON,
101                      std::string /* JSON to parse */)
102 
103 // Tells the utility process that it's running in batch mode.
104 IPC_MESSAGE_CONTROL0(UtilityMsg_BatchMode_Started)
105 
106 // Tells the utility process that it can shutdown.
107 IPC_MESSAGE_CONTROL0(UtilityMsg_BatchMode_Finished)
108 
109 // Tells the utility process to get capabilities and defaults for the specified
110 // printer. Used on Windows to isolate the service process from printer driver
111 // crashes by executing this in a separate process. This does not run in a
112 // sandbox.
113 IPC_MESSAGE_CONTROL1(UtilityMsg_GetPrinterCapsAndDefaults,
114                      std::string /* printer name */)
115 
116 //------------------------------------------------------------------------------
117 // Utility process host messages:
118 // These are messages from the utility process to the browser.
119 // Reply when the utility process is done unpacking an extension.  |manifest|
120 // is the parsed manifest.json file.
121 // The unpacker should also have written out files containing the decoded
122 // images and message catalogs from the extension. See ExtensionUnpacker for
123 // details.
124 IPC_MESSAGE_CONTROL1(UtilityHostMsg_UnpackExtension_Succeeded,
125                      DictionaryValue /* manifest */)
126 
127 // Reply when the utility process has failed while unpacking an extension.
128 // |error_message| is a user-displayable explanation of what went wrong.
129 IPC_MESSAGE_CONTROL1(UtilityHostMsg_UnpackExtension_Failed,
130                      std::string /* error_message, if any */)
131 
132 // Reply when the utility process is done unpacking and parsing JSON data
133 // from a web resource.
134 IPC_MESSAGE_CONTROL1(UtilityHostMsg_UnpackWebResource_Succeeded,
135                      DictionaryValue /* json data */)
136 
137 // Reply when the utility process has failed while unpacking and parsing a
138 // web resource.  |error_message| is a user-readable explanation of what
139 // went wrong.
140 IPC_MESSAGE_CONTROL1(UtilityHostMsg_UnpackWebResource_Failed,
141                      std::string /* error_message, if any */)
142 
143 // Reply when the utility process has succeeded in parsing an update manifest
144 // xml document.
145 IPC_MESSAGE_CONTROL1(UtilityHostMsg_ParseUpdateManifest_Succeeded,
146                      UpdateManifest::Results /* updates */)
147 
148 // Reply when an error occured parsing the update manifest. |error_message|
149 // is a description of what went wrong suitable for logging.
150 IPC_MESSAGE_CONTROL1(UtilityHostMsg_ParseUpdateManifest_Failed,
151                      std::string /* error_message, if any */)
152 
153 // Reply when the utility process has succeeded in decoding the image.
154 IPC_MESSAGE_CONTROL1(UtilityHostMsg_DecodeImage_Succeeded,
155                      SkBitmap)  // decoded image
156 
157 // Reply when an error occured decoding the image.
158 IPC_MESSAGE_CONTROL0(UtilityHostMsg_DecodeImage_Failed)
159 
160 // Reply when the utility process has succeeded in rendering the PDF.
161 IPC_MESSAGE_CONTROL1(UtilityHostMsg_RenderPDFPagesToMetafile_Succeeded,
162                      int)       // Highest rendered page number
163 
164 // Reply when an error occured rendering the PDF.
165 IPC_MESSAGE_CONTROL0(UtilityHostMsg_RenderPDFPagesToMetafile_Failed)
166 
167 #if defined(OS_WIN)
168 // Request that the given font be loaded by the host so it's cached by the
169 // OS. Please see ChildProcessHost::PreCacheFont for details.
170 IPC_SYNC_MESSAGE_CONTROL1_0(UtilityHostMsg_PreCacheFont,
171                             LOGFONT /* font data */)
172 #endif  // defined(OS_WIN)
173 
174 // Reply when the utility process has succeeded in obtaining the value for
175 // IDBKeyPath.
176 IPC_MESSAGE_CONTROL2(UtilityHostMsg_IDBKeysFromValuesAndKeyPath_Succeeded,
177                      int /* id */,
178                      std::vector<IndexedDBKey> /* value */)
179 
180 // Reply when the utility process has failed in obtaining the value for
181 // IDBKeyPath.
182 IPC_MESSAGE_CONTROL1(UtilityHostMsg_IDBKeysFromValuesAndKeyPath_Failed,
183                      int /* id */)
184 
185 // Reply when the utility process has finished injecting an IDBKey into
186 // a SerializedScriptValue.
187 IPC_MESSAGE_CONTROL1(UtilityHostMsg_InjectIDBKey_Finished,
188                      SerializedScriptValue /* new value */)
189 
190 // Reply when the utility process successfully parsed a JSON string.
191 //
192 // WARNING: The result can be of any Value subclass type, but we can't easily
193 // pass indeterminate value types by const object reference with our IPC macros,
194 // so we put the result Value into a ListValue. Handlers should examine the
195 // first (and only) element of the ListValue for the actual result.
196 IPC_MESSAGE_CONTROL1(UtilityHostMsg_ParseJSON_Succeeded,
197                      ListValue)
198 
199 // Reply when the utility process failed in parsing a JSON string.
200 IPC_MESSAGE_CONTROL1(UtilityHostMsg_ParseJSON_Failed,
201                      std::string /* error message, if any*/)
202 
203 // Reply when the utility process has succeeded in obtaining the printer
204 // capabilities and defaults.
205 IPC_MESSAGE_CONTROL2(UtilityHostMsg_GetPrinterCapsAndDefaults_Succeeded,
206                      std::string /* printer name */,
207                      printing::PrinterCapsAndDefaults)
208 
209 // Reply when the utility process has failed to obtain the printer
210 // capabilities and defaults.
211 IPC_MESSAGE_CONTROL1(UtilityHostMsg_GetPrinterCapsAndDefaults_Failed,
212                      std::string /* printer name */)
213