blob: 891e0ac982cd65414fb9802129887eb3b35a2468 [file] [log] [blame]
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -04001// Copyright (C) 2016 The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Jorge Lucangeli Obesf3f824e2016-12-15 12:13:38 -050015#ifndef _INIT_CAPABILITIES_H
16#define _INIT_CAPABILITIES_H
17
Luis Hector Chavez519e5f02017-06-29 09:50:30 -070018#include <sys/capability.h>
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -040019
20#include <bitset>
21#include <string>
Luis Hector Chavez519e5f02017-06-29 09:50:30 -070022#include <type_traits>
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -040023
Tom Cherryde6bd502018-02-13 16:50:08 -080024#if !defined(__ANDROID__)
25#ifndef CAP_BLOCK_SUSPEND
26#define CAP_BLOCK_SUSPEND 36
27#endif
28#ifndef CAP_AUDIT_READ
29#define CAP_AUDIT_READ 37
30#endif
31#undef CAP_LAST_CAP
32#define CAP_LAST_CAP CAP_AUDIT_READ
33#endif
34
Tom Cherry81f5d3e2017-06-22 12:53:17 -070035namespace android {
36namespace init {
37
Luis Hector Chavez519e5f02017-06-29 09:50:30 -070038struct CapDeleter {
39 void operator()(cap_t caps) const { cap_free(caps); }
40};
41
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -040042using CapSet = std::bitset<CAP_LAST_CAP + 1>;
Luis Hector Chavez519e5f02017-06-29 09:50:30 -070043using ScopedCaps = std::unique_ptr<std::remove_pointer<cap_t>::type, CapDeleter>;
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -040044
45int LookupCap(const std::string& cap_name);
Jorge Lucangeli Obesf3f824e2016-12-15 12:13:38 -050046bool CapAmbientSupported();
47unsigned int GetLastValidCap();
Jorge Lucangeli Obes24b29132016-10-27 10:33:03 -040048bool SetCapsForExec(const CapSet& to_keep);
Luis Hector Chavez94fb5b02017-11-16 15:52:00 -080049bool DropInheritableCaps();
Jorge Lucangeli Obesf3f824e2016-12-15 12:13:38 -050050
Tom Cherry81f5d3e2017-06-22 12:53:17 -070051} // namespace init
52} // namespace android
53
Jorge Lucangeli Obesf3f824e2016-12-15 12:13:38 -050054#endif // _INIT_CAPABILITIES_H