12a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved.
22a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be
32a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)// found in the LICENSE file.
42a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
52a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "chrome/browser/chromeos/system_logs/dbus_log_source.h"
62a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
72a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "content/public/browser/browser_thread.h"
82a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "dbus/dbus_statistics.h"
92a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
102a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)const char kDBusLogEntryShort[] = "dbus_summary";
112a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)const char kDBusLogEntryLong[] = "dbus_details";
122a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
135d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)namespace system_logs {
142a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
152a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DBusLogSource::Fetch(const SysLogsSourceCallback& callback) {
162a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
172a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  DCHECK(!callback.is_null());
182a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
192a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  SystemLogsResponse response;
202a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  response[kDBusLogEntryShort] = dbus::statistics::GetAsString(
212a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)      dbus::statistics::SHOW_INTERFACE,
222a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)      dbus::statistics::FORMAT_ALL);
232a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  response[kDBusLogEntryLong] = dbus::statistics::GetAsString(
242a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)      dbus::statistics::SHOW_METHOD,
252a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)      dbus::statistics::FORMAT_TOTALS);
262a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)  callback.Run(&response);
272a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)}
282a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)
295d1f7b1de12d16ceb2c938c56701a3e8bfa558f7Torne (Richard Coles)}  // namespace system_logs
30