// Copyright 2022 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CONTENT_BROWSER_NETWORK_SANDBOX_H_ #define CONTENT_BROWSER_NETWORK_SANDBOX_H_ #include "base/functional/callback.h" #include "services/network/public/mojom/network_context.mojom.h" // As of 2022-03 there is no plan to sandbox the network service in any special // way on Android. #if BUILDFLAG(IS_ANDROID) #error "Sandboxing disk access to a subdirectory is not implemented on Android" #endif namespace content { enum class SandboxGrantResult; // Attempts to grant the sandbox access to the file data specified in the // `params`. This function will also perform a migration of existing data from // `unsandboxed_data_path` to `data_directory` as necessary. // // Various failures can occur during this process, and those are represented by // the SandboxGrantResult. These values are described in more detail above. The // `result_callback` is posted back to the caller's task runner. As arguments it // receives the original `params` and the SandboxGrantResult. void GrantSandboxAccessOnThreadPool( network::mojom::NetworkContextParamsPtr params, base::OnceCallback<void(network::mojom::NetworkContextParamsPtr, SandboxGrantResult)> result_callback); } // namespace content #endif // CONTENT_BROWSER_NETWORK_SANDBOX_H_