Skip to content

Commit

Permalink
fix: Add stricter checks to JSON parsing (osquery#8229)
Browse files Browse the repository at this point in the history
  • Loading branch information
Smjert authored Dec 27, 2023
1 parent 65db9e7 commit d9ac612
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 6 deletions.
4 changes: 4 additions & 0 deletions osquery/worker/ipc/include/table_ipc_base.h
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,10 @@ class TableIPCBase {
return status;
}

if (!json_message.doc().IsObject()) {
return Status::failure("JSON root is not an object");
}

if (!json_message.doc().HasMember("Type")) {
return Status::failure("No Type member");
}
Expand Down
12 changes: 9 additions & 3 deletions plugins/config/tls_config.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,14 @@
// clang-format on

#include <osquery/config/config.h>
#include <osquery/dispatcher/dispatcher.h>
#include <osquery/remote/enroll/enroll.h>
#include <osquery/core/flags.h>
#include <osquery/dispatcher/dispatcher.h>
#include <osquery/registry/registry.h>
#include <osquery/remote/enroll/enroll.h>
#include <osquery/remote/requests.h>
#include <osquery/remote/serializers/json.h>
#include <osquery/utils/json/json.h>
#include <osquery/utils/chars.h>
#include <osquery/utils/json/json.h>
#include <plugins/config/tls_config.h>

#include <sstream>
Expand Down Expand Up @@ -78,6 +78,12 @@ Status TLSConfigPlugin::genConfig(std::map<std::string, std::string>& config) {
Status parse_status = tree.fromString(json);
if (!parse_status.ok()) {
VLOG(1) << "Could not parse JSON from TLS config node API";
return Status::failure("Could not parse JSON from TLS config node API");
}

if (!tree.doc().IsObject()) {
return Status::failure(
"Root of the JSON from TLS config node API is not an object");
}

// Re-encode the config key into JSON.
Expand Down
6 changes: 3 additions & 3 deletions plugins/logger/kafka_producer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,10 @@

#include <osquery/config/config.h>
#include <osquery/core/core.h>
#include <osquery/dispatcher/dispatcher.h>
#include <osquery/core/flags.h>
#include <osquery/registry/registry_factory.h>
#include <osquery/core/system.h>
#include <osquery/dispatcher/dispatcher.h>
#include <osquery/registry/registry_factory.h>
#include <osquery/utils/json/json.h>

#include <plugins/config/parsers/kafka_topics.h>
Expand Down Expand Up @@ -121,7 +121,7 @@ inline std::string getMsgName(const std::string& payload) {
// If failed to parse as JSON, or JSON object doesn't have "name" top-level
// key, return base topic
if (!doc.fromString(payload, JSON::ParseMode::Iterative) ||
!doc.doc().HasMember(fieldName)) {
!doc.doc().IsObject() || !doc.doc().HasMember(fieldName)) {
return "";
}
auto& name = doc.doc()[fieldName];
Expand Down

0 comments on commit d9ac612

Please sign in to comment.