// Copyright (c) 2011 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_SYSTEM_SYSLOGS_PROVIDER_H_
#define CHROME_BROWSER_CHROMEOS_SYSTEM_SYSLOGS_PROVIDER_H_
#include <map>
#include <string>
#include "base/callback.h"
#include "chrome/common/cancelable_task_tracker.h"
namespace chromeos {
namespace system {
// Maximum number of bytes in system info log chunk to be still included
// in product specific data.
extern const size_t kFeedbackMaxLength;
// Maximum number of lines in system info log chunk to be still included
// in product specific data.
extern const size_t kFeedbackMaxLineCount;
typedef std::map<std::string, std::string> LogDictionaryType;
// This interface provides access to Chrome OS syslogs.
class SyslogsProvider {
public:
static SyslogsProvider* GetInstance();
// The callback type used with RequestSyslogs().
typedef base::Callback<void(LogDictionaryType*,
std::string*)> ReadCompleteCallback;
// Used to specify the syslogs context with RequestSyslogs().
enum SyslogsContext {
SYSLOGS_FEEDBACK,
SYSLOGS_SYSINFO,
SYSLOGS_NETWORK,
SYSLOGS_DEFAULT
};
// Request system logs. Read happens on the FILE thread and callback is
// called on the thread this is called from. Logs are owned by callback
// function (use delete when done with them).
// Call CancelableTaskTracker::TryCancel() with the returned task ID to cancel
// task and callback.
virtual CancelableTaskTracker::TaskId RequestSyslogs(
bool compress_logs,
SyslogsContext context,
const ReadCompleteCallback& callback,
CancelableTaskTracker* tracker) = 0;
protected:
virtual ~SyslogsProvider() {}
};
} // namespace system
} // namespace chromeos
#endif // CHROME_BROWSER_CHROMEOS_SYSTEM_SYSLOGS_PROVIDER_H_