xref: /aosp_15_r20/platform_testing/utils/shell-as/execute.h (revision dd0948b35e70be4c0246aabd6c72554a5eb8b22a)
1*dd0948b3SAndroid Build Coastguard Worker /*
2*dd0948b3SAndroid Build Coastguard Worker  * Copyright (C) 2023 The Android Open Source Project
3*dd0948b3SAndroid Build Coastguard Worker  *
4*dd0948b3SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*dd0948b3SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*dd0948b3SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*dd0948b3SAndroid Build Coastguard Worker  *
8*dd0948b3SAndroid Build Coastguard Worker  *     http://www.apache.org/licenses/LICENSE-2.0
9*dd0948b3SAndroid Build Coastguard Worker  *
10*dd0948b3SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*dd0948b3SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*dd0948b3SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*dd0948b3SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*dd0948b3SAndroid Build Coastguard Worker  * limitations under the License.
15*dd0948b3SAndroid Build Coastguard Worker  */
16*dd0948b3SAndroid Build Coastguard Worker 
17*dd0948b3SAndroid Build Coastguard Worker #ifndef SHELL_AS_EXECUTE_H_
18*dd0948b3SAndroid Build Coastguard Worker #define SHELL_AS_EXECUTE_H_
19*dd0948b3SAndroid Build Coastguard Worker 
20*dd0948b3SAndroid Build Coastguard Worker #include "context.h"
21*dd0948b3SAndroid Build Coastguard Worker 
22*dd0948b3SAndroid Build Coastguard Worker namespace shell_as {
23*dd0948b3SAndroid Build Coastguard Worker 
24*dd0948b3SAndroid Build Coastguard Worker // Executes a command in the given security context.
25*dd0948b3SAndroid Build Coastguard Worker //
26*dd0948b3SAndroid Build Coastguard Worker // The executable_and_args parameter must contain at least two values. The first
27*dd0948b3SAndroid Build Coastguard Worker // value is the path to the executable to run and the last value must be null.
28*dd0948b3SAndroid Build Coastguard Worker // Additional arguments are passed to the executable as command line options.
29*dd0948b3SAndroid Build Coastguard Worker //
30*dd0948b3SAndroid Build Coastguard Worker // Returns true if the executable was run and false otherwise.
31*dd0948b3SAndroid Build Coastguard Worker bool ExecuteInContext(char* const executable_and_args[],
32*dd0948b3SAndroid Build Coastguard Worker                       const SecurityContext* context);
33*dd0948b3SAndroid Build Coastguard Worker }  // namespace shell_as
34*dd0948b3SAndroid Build Coastguard Worker 
35*dd0948b3SAndroid Build Coastguard Worker #endif  // SHELL_AS_EXECUTE_H_
36