1 // Copyright (c) 2012 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 CHROME_BROWSER_EXTENSIONS_API_MESSAGING_NATIVE_PROCESS_LAUNCHER_H_ 6 #define CHROME_BROWSER_EXTENSIONS_API_MESSAGING_NATIVE_PROCESS_LAUNCHER_H_ 7 8 #include "base/callback_forward.h" 9 #include "base/files/file.h" 10 #include "base/memory/scoped_ptr.h" 11 #include "base/process/process.h" 12 #include "ui/gfx/native_widget_types.h" 13 14 class GURL; 15 16 namespace base { 17 class CommandLine; 18 class FilePath; 19 } 20 21 namespace extensions { 22 23 class NativeProcessLauncher { 24 public: 25 enum LaunchResult { 26 RESULT_SUCCESS, 27 RESULT_INVALID_NAME, 28 RESULT_NOT_FOUND, 29 RESULT_FORBIDDEN, 30 RESULT_FAILED_TO_START, 31 }; 32 33 // Callback that's called after the process has been launched. |result| is set 34 // to false in case of a failure. Handler must take ownership of the IO 35 // handles. 36 typedef base::Callback<void(LaunchResult result, 37 base::ProcessHandle process_handle, 38 base::File read_file, 39 base::File write_file)> LaunchedCallback; 40 41 static scoped_ptr<NativeProcessLauncher> CreateDefault( 42 bool allow_user_level_hosts, 43 gfx::NativeView native_view); 44 45 NativeProcessLauncher() {} 46 virtual ~NativeProcessLauncher() {} 47 48 // Finds native messaging host with the specified name and launches it 49 // asynchronously. Also checks that the specified |origin| is permitted to 50 // access the host. |callback| is called after the process has been started. 51 // If the launcher is destroyed before the callback is called then the call is 52 // canceled and the process is stopped if it has been started already (by 53 // closing IO pipes). 54 virtual void Launch(const GURL& origin, 55 const std::string& native_host_name, 56 LaunchedCallback callback) const = 0; 57 58 protected: 59 // The following two methods are platform specific and are implemented in 60 // platform-specific .cc files. 61 62 // Finds manifest file for the native messaging host |native_host_name|. 63 // |user_level| is set to true if the manifest is installed on user level. 64 // Returns an empty path if the host with the specified name cannot be found. 65 static base::FilePath FindManifest(const std::string& native_host_name, 66 bool allow_user_level_hosts, 67 std::string* error_message); 68 69 // Launches native messaging process. 70 static bool LaunchNativeProcess(const base::CommandLine& command_line, 71 base::ProcessHandle* process_handle, 72 base::File* read_file, 73 base::File* write_file); 74 75 private: 76 DISALLOW_COPY_AND_ASSIGN(NativeProcessLauncher); 77 }; 78 79 } // namespace extensions 80 81 #endif // CHROME_BROWSER_EXTENSIONS_API_MESSAGING_NATIVE_PROCESS_LAUNCHER_H_ 82