Elly Jones | a44d22d | 2012-01-05 18:05:56 -0500 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
Alex Vakulenko | 262be3f | 2014-07-30 15:25:50 -0700 | [diff] [blame] | 5 | #include "debugd/src/subprocess_tool.h" |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 6 | |
Ben Chan | 8e9f6d0 | 2017-09-26 23:04:21 -0700 | [diff] [blame] | 7 | #include <memory> |
Mike Frysinger | 56379d7 | 2019-02-19 16:03:03 -0500 | [diff] [blame] | 8 | #include <string> |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 9 | #include <utility> |
Mike Frysinger | 56379d7 | 2019-02-19 16:03:03 -0500 | [diff] [blame] | 10 | #include <vector> |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 11 | |
Mike Frysinger | f9da3d3 | 2017-09-19 23:41:27 -0400 | [diff] [blame] | 12 | #include <base/stl_util.h> |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 13 | |
Eric Caruso | cc7106c | 2017-04-27 14:22:42 -0700 | [diff] [blame] | 14 | #include "debugd/src/error_utils.h" |
| 15 | |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 16 | namespace debugd { |
| 17 | |
Ben Chan | a0011d8 | 2014-05-13 00:19:29 -0700 | [diff] [blame] | 18 | namespace { |
| 19 | |
| 20 | const char kErrorNoSuchProcess[] = "org.chromium.debugd.error.NoSuchProcess"; |
| 21 | |
| 22 | } // namespace |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 23 | |
Mike Frysinger | 56379d7 | 2019-02-19 16:03:03 -0500 | [diff] [blame] | 24 | ProcessWithId* SubprocessTool::CreateProcess( |
| 25 | bool sandboxed, |
| 26 | bool access_root_mount_ns, |
| 27 | const std::vector<std::string>& minijail_extra_args) { |
Ben Chan | 8e9f6d0 | 2017-09-26 23:04:21 -0700 | [diff] [blame] | 28 | auto process = std::make_unique<ProcessWithId>(); |
Jorge Lucangeli Obes | 623f8ca | 2014-09-18 10:50:06 -0700 | [diff] [blame] | 29 | if (!sandboxed) |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 30 | process->DisableSandbox(); |
| 31 | |
Jorge Lucangeli Obes | 623f8ca | 2014-09-18 10:50:06 -0700 | [diff] [blame] | 32 | if (access_root_mount_ns) |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 33 | process->AllowAccessRootMountNamespace(); |
| 34 | |
Mike Frysinger | 56379d7 | 2019-02-19 16:03:03 -0500 | [diff] [blame] | 35 | if (!process->Init(minijail_extra_args)) |
Ben Chan | 64d19b2 | 2017-02-06 14:03:47 -0800 | [diff] [blame] | 36 | return nullptr; |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 37 | |
| 38 | ProcessWithId* process_ptr = process.get(); |
Mike Frysinger | f9da3d3 | 2017-09-19 23:41:27 -0400 | [diff] [blame] | 39 | if (RecordProcess(std::move(process))) |
| 40 | return process_ptr; |
| 41 | |
| 42 | return nullptr; |
| 43 | } |
| 44 | |
Mike Frysinger | 56379d7 | 2019-02-19 16:03:03 -0500 | [diff] [blame] | 45 | ProcessWithId* SubprocessTool::CreateProcess(bool sandboxed, |
| 46 | bool access_root_mount_ns) { |
| 47 | return CreateProcess(sandboxed, access_root_mount_ns, {}); |
| 48 | } |
| 49 | |
Mike Frysinger | f9da3d3 | 2017-09-19 23:41:27 -0400 | [diff] [blame] | 50 | bool SubprocessTool::RecordProcess(std::unique_ptr<ProcessWithId> process) { |
Eric Caruso | 1b640da | 2018-05-11 15:09:51 -0700 | [diff] [blame] | 51 | if (base::ContainsKey(processes_, process->id())) |
Mike Frysinger | f9da3d3 | 2017-09-19 23:41:27 -0400 | [diff] [blame] | 52 | return false; |
| 53 | |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 54 | processes_[process->id()] = std::move(process); |
Mike Frysinger | f9da3d3 | 2017-09-19 23:41:27 -0400 | [diff] [blame] | 55 | return true; |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 56 | } |
| 57 | |
Eric Caruso | cc7106c | 2017-04-27 14:22:42 -0700 | [diff] [blame] | 58 | bool SubprocessTool::Stop(const std::string& handle, brillo::ErrorPtr* error) { |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 59 | if (processes_.count(handle) != 1) { |
Eric Caruso | cc7106c | 2017-04-27 14:22:42 -0700 | [diff] [blame] | 60 | DEBUGD_ADD_ERROR(error, kErrorNoSuchProcess, handle.c_str()); |
Eric Caruso | 8fe49c7 | 2017-04-25 10:43:59 -0700 | [diff] [blame] | 61 | return false; |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 62 | } |
Ben Chan | 2314289 | 2017-02-15 12:34:13 -0800 | [diff] [blame] | 63 | ProcessWithId* process_ptr = processes_[handle].get(); |
| 64 | process_ptr->KillProcessGroup(); |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 65 | processes_.erase(handle); |
Eric Caruso | 8fe49c7 | 2017-04-25 10:43:59 -0700 | [diff] [blame] | 66 | return true; |
Elly Jones | 0c016cc | 2011-12-19 16:19:22 -0500 | [diff] [blame] | 67 | } |
| 68 | |
Ben Chan | a0011d8 | 2014-05-13 00:19:29 -0700 | [diff] [blame] | 69 | } // namespace debugd |