blob: a3f19d4e8f81e7fedba30778022ce5d0f12e9a24 [file] [log] [blame]
// 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_