Chromium Code Reviews| Index: chrome/browser/chromeos/policy/system_log_uploader.h |
| diff --git a/chrome/browser/chromeos/policy/system_log_uploader.h b/chrome/browser/chromeos/policy/system_log_uploader.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..e1d1d68f84a07cb6e659f2811dc7732f27b62285 |
| --- /dev/null |
| +++ b/chrome/browser/chromeos/policy/system_log_uploader.h |
| @@ -0,0 +1,73 @@ |
| +// Copyright (c) 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CHROME_BROWSER_CHROMEOS_POLICY_SYSTEM_LOG_UPLOADER_H_ |
| +#define CHROME_BROWSER_CHROMEOS_POLICY_SYSTEM_LOG_UPLOADER_H_ |
| + |
| +#include "base/macros.h" |
| +#include "base/memory/ref_counted.h" |
| +#include "base/memory/ref_counted_memory.h" |
| +#include "base/memory/scoped_ptr.h" |
| +#include "base/memory/weak_ptr.h" |
| +#include "base/time/time.h" |
| +#include "chrome/browser/chromeos/policy/system_log_upload_job.h" |
| + |
| +namespace base { |
| +class SequencedTaskRunner; |
| +} |
| + |
| +namespace policy { |
| + |
| +// Class responsible for periodically uploading system logs. |
| +class SystemLogUploader { |
| + public: |
| + // Constructor. |
| + SystemLogUploader(const scoped_refptr<base::SequencedTaskRunner>& task_runner, |
| + scoped_ptr<SystemLogUploadJob> upload_job); |
|
Andrew T Wilson (Slow)
2015/06/29 15:06:09
I don't like having a persistent upload_job that y
Polina Bondarenko
2015/07/02 15:28:04
Done.
|
| + |
| + // Destructor. |
|
Andrew T Wilson (Slow)
2015/06/29 15:06:09
Remove this comment (and the one above) - no need
Polina Bondarenko
2015/07/02 15:28:04
Done.
|
| + ~SystemLogUploader(); |
| + |
| + // Returns the time of the last successful upload, or Time(0) if no upload |
| + // has ever happened. |
| + base::Time last_upload() const { return last_upload_; } |
| + |
| + private: |
| + // Handles success and failure results of upload. |
| + void OnSuccess(); |
| + void OnFailure(); |
| + |
| + // Start upload system logs, run upload job. |
| + void StartLogUpload(); |
| + |
| + // Helper method that figures out when the next system log upload should |
| + // be scheduled. |
| + void ScheduleNextSystemLogUpload(base::TimeDelta frequency); |
| + |
| + // Indicates whether the last log upload was successful or not the first |
| + // failed. Because if log upload is failed, only one retry log upload should |
|
Andrew T Wilson (Slow)
2015/06/29 15:06:09
This comment is a bit unclear. Maybe this flag sho
Polina Bondarenko
2015/07/02 15:28:04
Done.
|
| + // be done. |
| + bool last_success_; |
| + |
| + // How long to wait between system log uploads. |
| + base::TimeDelta upload_frequency_; |
| + |
| + // The time the last upload was performed. |
|
Andrew T Wilson (Slow)
2015/06/29 15:06:09
nit: "last successful upload"? Or just last upload
Polina Bondarenko
2015/07/02 15:28:04
Done. Renamed to last_upload_attempt_.
|
| + base::Time last_upload_; |
| + |
| + // TaskRunner used for scheduling upload tasks. |
| + const scoped_refptr<base::SequencedTaskRunner> task_runner_; |
| + |
| + // System log upload job. |
|
Andrew T Wilson (Slow)
2015/06/29 15:06:09
Delete this comment or make it useful. Maybe talk
Polina Bondarenko
2015/07/02 15:28:04
Done.
|
| + scoped_ptr<SystemLogUploadJob> upload_job_; |
| + |
| + // Note: This should remain the last member so it'll be destroyed and |
| + // invalidate the weak pointers before any other members are destroyed. |
| + base::WeakPtrFactory<SystemLogUploader> weak_factory_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(SystemLogUploader); |
| +}; |
| + |
| +} // namespace policy |
| +#endif // CHROME_BROWSER_CHROMEOS_POLICY_SYSTEM_LOG_UPLOADER_H_ |