blob: 58f0b2631fa13bf77874eaf68cbd19db3cd7670c [file] [log] [blame]
Christopher Wileya4915c42014-03-27 14:45:37 -07001// Copyright 2014 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Christopher Wileya4915c42014-03-27 14:45:37 -07005#include "buffet/dbus_utils.h"
6
Christopher Wiley90016242014-04-01 17:33:29 -07007#include <base/logging.h>
8#include <base/bind.h>
9
Christopher Wileya4915c42014-03-27 14:45:37 -070010namespace buffet {
11
12namespace dbus_utils {
13
Christopher Wiley90016242014-04-01 17:33:29 -070014namespace {
15
16// Passes |method_call| to |handler| and passes the response to
17// |response_sender|. If |handler| returns NULL, an empty response is created
18// and sent.
19void HandleSynchronousDBusMethodCall(
20 base::Callback<scoped_ptr<dbus::Response>(dbus::MethodCall*)> handler,
21 dbus::MethodCall* method_call,
22 dbus::ExportedObject::ResponseSender response_sender) {
23 auto response = handler.Run(method_call);
24 if (!response)
25 response = dbus::Response::FromMethodCall(method_call);
26
27 response_sender.Run(response.Pass());
28}
29
30} // namespace
31
Christopher Wileya4915c42014-03-27 14:45:37 -070032scoped_ptr<dbus::Response> GetBadArgsError(dbus::MethodCall* method_call,
33 const std::string& message) {
34 LOG(ERROR) << "Error while handling DBus call: " << message;
35 scoped_ptr<dbus::ErrorResponse> resp(dbus::ErrorResponse::FromMethodCall(
36 method_call, "org.freedesktop.DBus.Error.InvalidArgs", message));
37 return scoped_ptr<dbus::Response>(resp.release());
38}
39
Alex Vakulenkob3aac252014-05-07 17:35:24 -070040scoped_ptr<dbus::Response> GetDBusError(dbus::MethodCall* method_call,
Alex Vakulenkoaf23b322014-05-08 16:25:45 -070041 const Error* error) {
Alex Vakulenkob3aac252014-05-07 17:35:24 -070042 std::string message;
43 while (error) {
44 // Format error string as "domain/code:message".
45 if (!message.empty())
46 message += ';';
47 message += error->GetDomain() + '/' + error->GetCode() + ':' +
48 error->GetMessage();
49 error = error->GetInnerError();
50 }
51 scoped_ptr<dbus::ErrorResponse> resp(dbus::ErrorResponse::FromMethodCall(
52 method_call, "org.freedesktop.DBus.Error.Failed", message));
53 return scoped_ptr<dbus::Response>(resp.release());
54}
55
Christopher Wiley90016242014-04-01 17:33:29 -070056dbus::ExportedObject::MethodCallCallback GetExportableDBusMethod(
57 base::Callback<scoped_ptr<dbus::Response>(dbus::MethodCall*)> handler) {
58 return base::Bind(&HandleSynchronousDBusMethodCall, handler);
59}
60
Christopher Wileya4915c42014-03-27 14:45:37 -070061} // namespace dbus_utils
62
63} // namespace buffet