blob: 4b9eb76cea0c1bfb816f2f69ac25091f1dfbd7d2 [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 CHROME_BROWSER_DATA_SAVER_DATA_SAVER_H_
#define CHROME_BROWSER_DATA_SAVER_DATA_SAVER_H_
#include "content/public/browser/browser_context.h"
namespace data_saver {
// Overrides the data saver setting when testing.
void OverrideIsDataSaverEnabledForTesting(bool flag);
// Resets the override flag.
void ResetIsDataSaverEnabledForTesting();
// Fetch and cache the Android Data Saver saver setting.
void FetchDataSaverOSSettingAsynchronously();
// Returns true if the Android Data Saver option is enabled. On non-Android
// OSes, this always return false. Note that the result returned by this
// function may be stale. Making OS calls to get the state of the Data Saver
// setting can be slow. For this reason, we make the OS calls happen in a
// background thread and store the result in a global variable. Calling
// IsDataSaverEnabled immediately returns the last cached value and fires of OS
// calls in a background thread. If there is no cached value, this function may
// lookup the setting synchronously, depending on the state of the
// DataSaverSettingBlockWhenUninitialized Finch feature.
bool IsDataSaverEnabled(content::BrowserContext* browser_context);
} // namespace data_saver
#endif // CHROME_BROWSER_DATA_SAVER_DATA_SAVER_H_