// Copyright 2020 Google LLC // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef SANDBOX_H_ #define SANDBOX_H_ #include #include // For mmap arguments #include #include #include "curl_sapi.sapi.h" // NOLINT(build/include) #include "sandboxed_api/sandbox2/util/bpf_helper.h" namespace curl { class CurlSapiSandbox : public curl::CurlSandbox { protected: std::unique_ptr ModifyPolicy( sandbox2::PolicyBuilder*) override { // Return a new policy return sandbox2::PolicyBuilder() .AllowDynamicStartup() .AllowExit() .AllowFork() .AllowFutexOp(FUTEX_WAIT_PRIVATE) .AllowFutexOp(FUTEX_WAKE_PRIVATE) .AllowFutexOp(FUTEX_REQUEUE_PRIVATE) .AllowMmap() .AllowOpen() .AllowSafeFcntl() .AllowWrite() .AllowAccess() .AllowSyscalls({ __NR_accept, __NR_bind, __NR_connect, __NR_getpeername, __NR_getsockname, __NR_getsockopt, __NR_ioctl, __NR_listen, __NR_madvise, __NR_poll, __NR_recvfrom, __NR_recvmsg, __NR_rt_sigaction, __NR_sendmmsg, __NR_sendto, __NR_setsockopt, __NR_socket, __NR_sysinfo, }) .AddDirectory("/lib") .AllowUnrestrictedNetworking() .BuildOrDie(); } }; } // namespace curl #endif // SANDBOX_H_