Skip to content
This repository has been archived by the owner on Apr 17, 2024. It is now read-only.

Commit

Permalink
Validate that parsed string is a JSON Object.
Browse files Browse the repository at this point in the history
Without this, parsing may crash if the input is a valid JSON value, but not a JSON Object.

PiperOrigin-RevId: 621489078
  • Loading branch information
juergw authored and copybara-github committed Apr 3, 2024
1 parent 6e5d0ea commit c7e4795
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 3 deletions.
7 changes: 4 additions & 3 deletions cc/core/json_keyset_reader.cc
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@
#include <istream>
#include <iterator>
#include <memory>
#include <sstream>
#include <string>
#include <utility>

Expand All @@ -34,8 +33,6 @@
#include "include/rapidjson/rapidjson.h"
#include "tink/keyset_reader.h"
#include "tink/util/enums.h"
#include "tink/util/errors.h"
#include "tink/util/protobuf_helper.h"
#include "tink/util/status.h"
#include "tink/util/statusor.h"
#include "proto/tink.pb.h"
Expand Down Expand Up @@ -252,6 +249,10 @@ util::StatusOr<std::unique_ptr<Keyset>> JsonKeysetReader::Read() {
"Invalid JSON Keyset: Error (offset ", json_doc.GetErrorOffset(),
"): ", rapidjson::GetParseError_En(json_doc.GetParseError())));
}
if (!json_doc.IsObject()) {
return util::Status(absl::StatusCode::kInvalidArgument,
"Invalid JSON Keyset: Expected object.");
}
return KeysetFromJson(json_doc);
}

Expand Down
9 changes: 9 additions & 0 deletions cc/core/json_keyset_reader_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -195,6 +195,15 @@ TEST_F(JsonKeysetReaderTest, testReadFromString) {
EXPECT_FALSE(read_result.ok());
EXPECT_EQ(absl::StatusCode::kInvalidArgument, read_result.status().code());
}

{ // A valid JSON value, but not a JSON object.
auto reader_result = JsonKeysetReader::New("124");
EXPECT_TRUE(reader_result.ok()) << reader_result.status();
auto reader = std::move(reader_result.value());
auto read_result = reader->Read();
EXPECT_FALSE(read_result.ok());
EXPECT_EQ(absl::StatusCode::kInvalidArgument, read_result.status().code());
}
}

TEST_F(JsonKeysetReaderTest, testReadFromStream) {
Expand Down

0 comments on commit c7e4795

Please sign in to comment.