blob: 24ce1ca17011f7686fb2c650c488f9709859bfcc [file] [log] [blame]
Vitaly Buka4615e0d2015-10-14 15:35:12 -07001// Copyright 2015 The Weave Authors. All rights reserved.
Alex Vakulenkob04936f2014-09-19 14:53:58 -07002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Stefan Sauer2d16dfa2015-09-25 17:08:35 +02005#include "src/utils.h"
Alex Vakulenkob04936f2014-09-19 14:53:58 -07006
Alex Vakulenkoae1ffbc2015-06-15 12:53:22 -07007#include <base/bind_helpers.h>
Alex Vakulenkob04936f2014-09-19 14:53:58 -07008#include <base/json/json_reader.h>
Vitaly Bukaea2f15f2015-08-13 15:26:20 -07009
Stefan Sauer2d16dfa2015-09-25 17:08:35 +020010#include "src/json_error_codes.h"
Alex Vakulenkob04936f2014-09-19 14:53:58 -070011
Vitaly Bukab6f015a2015-07-09 14:59:23 -070012namespace weave {
Alex Vakulenkob04936f2014-09-19 14:53:58 -070013
Alex Vakulenko36c85aa2015-04-09 09:06:39 -070014namespace {
15
16// Truncates a string if it is too long. Used for error reporting with really
17// long JSON strings.
18std::string LimitString(const std::string& text, size_t max_len) {
19 if (text.size() <= max_len)
20 return text;
21 return text.substr(0, max_len - 3) + "...";
22}
23
24const size_t kMaxStrLen = 1700; // Log messages are limited to 2000 chars.
25
Vitaly Buka70f77d92015-10-07 15:42:40 -070026const char kErrorCodeKey[] = "code";
27const char kErrorMessageKey[] = "message";
28
Alex Vakulenko36c85aa2015-04-09 09:06:39 -070029} // anonymous namespace
30
Vitaly Bukae2810e02015-08-16 23:31:55 -070031namespace errors {
Vitaly Buka0fa51e52015-07-10 00:12:25 -070032const char kErrorDomain[] = "weave";
Vitaly Bukae2810e02015-08-16 23:31:55 -070033const char kSchemaError[] = "schema_error";
Alex Vakulenko07216fe2014-09-19 15:31:09 -070034const char kInvalidCategoryError[] = "invalid_category";
35const char kInvalidPackageError[] = "invalid_package";
Vitaly Bukae2810e02015-08-16 23:31:55 -070036} // namespace errors
Alex Vakulenko9e2f8cd2015-04-07 16:28:09 -070037
Vitaly Buka207c1cb2015-05-14 17:06:18 -070038std::unique_ptr<base::DictionaryValue> LoadJsonDict(
39 const std::string& json_string,
Vitaly Buka0801a1f2015-08-14 10:03:46 -070040 ErrorPtr* error) {
Vitaly Buka207c1cb2015-05-14 17:06:18 -070041 std::unique_ptr<base::DictionaryValue> result;
Alex Vakulenkob04936f2014-09-19 14:53:58 -070042 std::string error_message;
Alex Vakulenkoae1ffbc2015-06-15 12:53:22 -070043 auto value = base::JSONReader::ReadAndReturnError(
Alex Vakulenkob04936f2014-09-19 14:53:58 -070044 json_string, base::JSON_PARSE_RFC, nullptr, &error_message);
45 if (!value) {
Vitaly Buka0801a1f2015-08-14 10:03:46 -070046 Error::AddToPrintf(error, FROM_HERE, errors::json::kDomain,
47 errors::json::kParseError,
48 "Error parsing JSON string '%s' (%zu): %s",
49 LimitString(json_string, kMaxStrLen).c_str(),
50 json_string.size(), error_message.c_str());
Alex Vakulenkob04936f2014-09-19 14:53:58 -070051 return result;
52 }
Vitaly Buka207c1cb2015-05-14 17:06:18 -070053 base::DictionaryValue* dict_value = nullptr;
Alex Vakulenkob04936f2014-09-19 14:53:58 -070054 if (!value->GetAsDictionary(&dict_value)) {
Vitaly Buka0801a1f2015-08-14 10:03:46 -070055 Error::AddToPrintf(error, FROM_HERE, errors::json::kDomain,
56 errors::json::kObjectExpected,
57 "JSON string '%s' is not a JSON object",
58 LimitString(json_string, kMaxStrLen).c_str());
Alex Vakulenkob04936f2014-09-19 14:53:58 -070059 return result;
Alex Vakulenkoae1ffbc2015-06-15 12:53:22 -070060 } else {
61 // |value| is now owned by |dict_value|.
62 base::IgnoreResult(value.release());
Alex Vakulenkob04936f2014-09-19 14:53:58 -070063 }
64 result.reset(dict_value);
65 return result;
66}
67
Vitaly Buka70f77d92015-10-07 15:42:40 -070068std::unique_ptr<base::DictionaryValue> ErrorInfoToJson(const Error& error) {
69 std::unique_ptr<base::DictionaryValue> output{new base::DictionaryValue};
70 output->SetString(kErrorMessageKey, error.GetMessage());
71 output->SetString(kErrorCodeKey, error.GetCode());
72 return output;
73}
74
Vitaly Bukab6f015a2015-07-09 14:59:23 -070075} // namespace weave