blob: 77ecc5216014d9326fc15eafed759aa7310b0af4 [file] [log] [blame]
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_NETWORK_TIME_TIME_TRACKER_TIME_TRACKER_H_
#define COMPONENTS_NETWORK_TIME_TIME_TRACKER_TIME_TRACKER_H_
#include "base/time/time.h"
namespace network_time {
// A class that's created with a known good time, and provides an estimate of
// the current time by adding the system clock seconds that have elapsed since
// it was created.
class TimeTracker {
public:
struct TimeTrackerState {
base::Time system_time;
base::TimeTicks system_ticks;
base::Time known_time;
base::TimeDelta uncertainty;
};
TimeTracker(const base::Time& system_time,
const base::TimeTicks& system_ticks,
const base::Time& time,
const base::TimeDelta& uncertainty);
~TimeTracker() = default;
// Returns true if the time is available, false otherwise (e.g. if sync was
// lost). Sets |estimated_ time| to an estimate of the true time. If
// |uncertainty| is non-NULL, it will be set to an estimate of the error
// range. |system_time| and |system_ticks| should come from the same clocks
// used to retrieve the system time on creation.
bool GetTime(const base::Time& system_time,
const base::TimeTicks& system_ticks,
base::Time* time,
base::TimeDelta* uncertainty) const;
TimeTrackerState GetStateAtCreation() const { return state_; }
private:
TimeTrackerState state_;
};
} // namespace network_time
#endif // COMPONENTS_NETWORK_TIME_TIME_TRACKER_TIME_TRACKER_H_