buffet: Moved LoadJsonDict() function into buffet/utils.h

Moved LoadJsonDict from CommandManager class into a separate
header file as a stand-alone function so that it can be
used by itself.

This function will come in handy when implementing device
state management.

BUG=chromium:415364
TEST=FEATURES=test emerge-link buffet

Change-Id: Ie818a811989d82e4b092e399ca136e15276ab453
Reviewed-on: https://chromium-review.googlesource.com/219134
Tested-by: Alex Vakulenko <avakulenko@chromium.org>
Reviewed-by: Christopher Wiley <wiley@chromium.org>
Commit-Queue: Alex Vakulenko <avakulenko@chromium.org>
diff --git a/buffet/buffet.gyp b/buffet/buffet.gyp
index 002fd5c..ca2ddc7 100644
--- a/buffet/buffet.gyp
+++ b/buffet/buffet.gyp
@@ -40,6 +40,7 @@
         'device_registration_info.cc',
         'manager.cc',
         'storage_impls.cc',
+        'utils.cc',
       ],
     },
     {
diff --git a/buffet/commands/command_manager.cc b/buffet/commands/command_manager.cc
index f43fc66..7a1701a 100644
--- a/buffet/commands/command_manager.cc
+++ b/buffet/commands/command_manager.cc
@@ -5,24 +5,15 @@
 #include "buffet/commands/command_manager.h"
 
 #include <base/files/file_enumerator.h>
-#include <base/files/file_util.h>
-#include <base/json/json_reader.h>
 #include <base/values.h>
 #include <chromeos/dbus/exported_object_manager.h>
 #include <chromeos/errors/error.h>
-#include <chromeos/errors/error_codes.h>
 
 #include "buffet/commands/schema_constants.h"
+#include "buffet/utils.h"
 
 using chromeos::dbus_utils::ExportedObjectManager;
 
-namespace {
-
-const char kCommandManagerErrorDomain[] = "Buffet_CommandManager";
-const char kCommandManagerFileReadError[] = "file_read_error";
-
-}  // namespace
-
 namespace buffet {
 
 CommandManager::CommandManager() {
@@ -91,40 +82,6 @@
   }
 }
 
-std::unique_ptr<const base::DictionaryValue> CommandManager::LoadJsonDict(
-    const base::FilePath& json_file_path, chromeos::ErrorPtr* error) {
-  std::string json_string;
-  if (!base::ReadFileToString(json_file_path, &json_string)) {
-    chromeos::errors::system::AddSystemError(error, errno);
-    chromeos::Error::AddToPrintf(error, kCommandManagerErrorDomain,
-                                 kCommandManagerFileReadError,
-                                 "Failed to read file '%s'",
-                                 json_file_path.value().c_str());
-    return std::unique_ptr<const base::DictionaryValue>();
-  }
-  std::string error_message;
-  base::Value* value = base::JSONReader::ReadAndReturnError(
-      json_string, base::JSON_PARSE_RFC, nullptr, &error_message);
-  if (!value) {
-    chromeos::Error::AddToPrintf(error, chromeos::errors::json::kDomain,
-                                 chromeos::errors::json::kParseError,
-                                 "Error parsing content of JSON file '%s': %s",
-                                 json_file_path.value().c_str(),
-                                 error_message.c_str());
-    return std::unique_ptr<const base::DictionaryValue>();
-  }
-  const base::DictionaryValue* dict_value = nullptr;
-  if (!value->GetAsDictionary(&dict_value)) {
-    delete value;
-    chromeos::Error::AddToPrintf(error, chromeos::errors::json::kDomain,
-                                 chromeos::errors::json::kObjectExpected,
-                                 "Content of file '%s' is not a JSON object",
-                                 json_file_path.value().c_str());
-    return std::unique_ptr<const base::DictionaryValue>();
-  }
-  return std::unique_ptr<const base::DictionaryValue>(dict_value);
-}
-
 std::string CommandManager::AddCommand(
     std::unique_ptr<CommandInstance> command_instance) {
   return command_queue_.Add(std::move(command_instance));
diff --git a/buffet/commands/command_manager.h b/buffet/commands/command_manager.h
index 601ae9a..05326b3 100644
--- a/buffet/commands/command_manager.h
+++ b/buffet/commands/command_manager.h
@@ -79,12 +79,6 @@
   std::string AddCommand(std::unique_ptr<CommandInstance> command_instance);
 
  private:
-  // Helper function to load a JSON file that is expected to be
-  // an object/dictionary. In case of error, returns empty unique ptr and fills
-  // in error details in |error|.
-  std::unique_ptr<const base::DictionaryValue> LoadJsonDict(
-      const base::FilePath& json_file_path, chromeos::ErrorPtr* error);
-
   CommandDictionary base_dictionary_;  // Base/std command definitions/schemas.
   CommandDictionary dictionary_;  // Command definitions/schemas.
   CommandQueue command_queue_;
diff --git a/buffet/device_registration_info.cc b/buffet/device_registration_info.cc
index 0368c83..2f2ddac 100644
--- a/buffet/device_registration_info.cc
+++ b/buffet/device_registration_info.cc
@@ -20,11 +20,11 @@
 #include "buffet/commands/command_manager.h"
 #include "buffet/device_registration_storage_keys.h"
 #include "buffet/storage_impls.h"
+#include "buffet/utils.h"
 
 const char buffet::kErrorDomainOAuth2[] = "oauth2";
 const char buffet::kErrorDomainGCD[] = "gcd";
 const char buffet::kErrorDomainGCDServer[] = "gcd_server";
-const char buffet::kErrorDomainBuffet[] = "buffet";
 
 namespace buffet {
 namespace storage_keys {
diff --git a/buffet/device_registration_info.h b/buffet/device_registration_info.h
index ec2f00b..8cef223 100644
--- a/buffet/device_registration_info.h
+++ b/buffet/device_registration_info.h
@@ -29,7 +29,6 @@
 extern const char kErrorDomainOAuth2[];
 extern const char kErrorDomainGCD[];
 extern const char kErrorDomainGCDServer[];
-extern const char kErrorDomainBuffet[];
 
 // The DeviceRegistrationInfo class represents device registration information.
 class DeviceRegistrationInfo {
diff --git a/buffet/utils.cc b/buffet/utils.cc
new file mode 100644
index 0000000..71e9a56
--- /dev/null
+++ b/buffet/utils.cc
@@ -0,0 +1,55 @@
+// Copyright 2014 The Chromium OS Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "buffet/utils.h"
+
+#include <map>
+#include <string>
+
+#include <base/files/file_util.h>
+#include <base/json/json_reader.h>
+#include <chromeos/errors/error_codes.h>
+
+namespace buffet {
+
+const char kErrorDomainBuffet[] = "buffet";
+const char kFileReadError[] = "file_read_error";
+
+std::unique_ptr<const base::DictionaryValue> LoadJsonDict(
+    const base::FilePath& json_file_path, chromeos::ErrorPtr* error) {
+  std::unique_ptr<const base::DictionaryValue> result;
+  std::string json_string;
+  if (!base::ReadFileToString(json_file_path, &json_string)) {
+    chromeos::errors::system::AddSystemError(error, errno);
+    chromeos::Error::AddToPrintf(error, kErrorDomainBuffet,
+                                 kFileReadError,
+                                 "Failed to read file '%s'",
+                                 json_file_path.value().c_str());
+    return result;
+  }
+  std::string error_message;
+  base::Value* value = base::JSONReader::ReadAndReturnError(
+      json_string, base::JSON_PARSE_RFC, nullptr, &error_message);
+  if (!value) {
+    chromeos::Error::AddToPrintf(error, chromeos::errors::json::kDomain,
+                                 chromeos::errors::json::kParseError,
+                                 "Error parsing content of JSON file '%s': %s",
+                                 json_file_path.value().c_str(),
+                                 error_message.c_str());
+    return result;
+  }
+  const base::DictionaryValue* dict_value = nullptr;
+  if (!value->GetAsDictionary(&dict_value)) {
+    delete value;
+    chromeos::Error::AddToPrintf(error, chromeos::errors::json::kDomain,
+                                 chromeos::errors::json::kObjectExpected,
+                                 "Content of file '%s' is not a JSON object",
+                                 json_file_path.value().c_str());
+    return result;
+  }
+  result.reset(dict_value);
+  return result;
+}
+
+}  // namespace buffet
diff --git a/buffet/utils.h b/buffet/utils.h
new file mode 100644
index 0000000..e71560c
--- /dev/null
+++ b/buffet/utils.h
@@ -0,0 +1,27 @@
+// Copyright 2014 The Chromium OS 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 BUFFET_UTILS_H_
+#define BUFFET_UTILS_H_
+
+#include <memory>
+
+#include <base/values.h>
+#include <base/files/file_path.h>
+#include <chromeos/errors/error.h>
+
+namespace buffet {
+
+extern const char kErrorDomainBuffet[];
+extern const char kFileReadError[];
+
+// Helper function to load a JSON file that is expected to be
+// an object/dictionary. In case of error, returns empty unique ptr and fills
+// in error details in |error|.
+std::unique_ptr<const base::DictionaryValue> LoadJsonDict(
+    const base::FilePath& json_file_path, chromeos::ErrorPtr* error);
+
+}  // namespace buffet
+
+#endif  // BUFFET_UTILS_H_