Support JSON response in get_simple_config.
This commit is contained in:
parent
b8ab910b81
commit
aa1f7592e8
@ -261,33 +261,45 @@ static ActorOwn<> get_simple_config_dns(Slice address, Slice host, Promise<Simpl
|
|||||||
name = is_test ? "tapv3.stel.com" : "apv3.stel.com";
|
name = is_test ? "tapv3.stel.com" : "apv3.stel.com";
|
||||||
}
|
}
|
||||||
auto get_config = [](HttpQuery &http_query) -> Result<string> {
|
auto get_config = [](HttpQuery &http_query) -> Result<string> {
|
||||||
VLOG(config_recoverer) << "Receive DNS response " << http_query.content_;
|
auto get_data = [](JsonValue &answer) -> Result<string> {
|
||||||
TRY_RESULT(json, json_decode(http_query.content_));
|
auto &answer_array = answer.get_array();
|
||||||
if (json.type() != JsonValue::Type::Object) {
|
vector<string> parts;
|
||||||
return Status::Error("Expected JSON object");
|
for (auto &answer_part : answer_array) {
|
||||||
}
|
if (answer_part.type() != JsonValue::Type::Object) {
|
||||||
auto &answer_object = json.get_object();
|
return Status::Error("Expected JSON object");
|
||||||
TRY_RESULT(answer, get_json_object_field(answer_object, "Answer", JsonValue::Type::Array, false));
|
}
|
||||||
auto &answer_array = answer.get_array();
|
auto &data_object = answer_part.get_object();
|
||||||
vector<string> parts;
|
TRY_RESULT(part, get_json_object_string_field(data_object, "data", false));
|
||||||
for (auto &answer_part : answer_array) {
|
parts.push_back(std::move(part));
|
||||||
if (answer_part.type() != JsonValue::Type::Object) {
|
}
|
||||||
|
if (parts.size() != 2) {
|
||||||
|
return Status::Error("Expected data in two parts");
|
||||||
|
}
|
||||||
|
string data;
|
||||||
|
if (parts[0].size() < parts[1].size()) {
|
||||||
|
data = parts[1] + parts[0];
|
||||||
|
} else {
|
||||||
|
data = parts[0] + parts[1];
|
||||||
|
}
|
||||||
|
return data;
|
||||||
|
};
|
||||||
|
if (!http_query.get_arg("Answer").empty()) {
|
||||||
|
VLOG(config_recoverer) << "Receive DNS response " << http_query.get_arg("Answer");
|
||||||
|
TRY_RESULT(answer, json_decode(http_query.get_arg("Answer")));
|
||||||
|
if (answer.type() != JsonValue::Type::Array) {
|
||||||
|
return Status::Error("Expected JSON array");
|
||||||
|
}
|
||||||
|
return get_data(answer);
|
||||||
|
} else {
|
||||||
|
VLOG(config_recoverer) << "Receive DNS response " << http_query.content_;
|
||||||
|
TRY_RESULT(json, json_decode(http_query.content_));
|
||||||
|
if (json.type() != JsonValue::Type::Object) {
|
||||||
return Status::Error("Expected JSON object");
|
return Status::Error("Expected JSON object");
|
||||||
}
|
}
|
||||||
auto &data_object = answer_part.get_object();
|
auto &answer_object = json.get_object();
|
||||||
TRY_RESULT(part, get_json_object_string_field(data_object, "data", false));
|
TRY_RESULT(answer, get_json_object_field(answer_object, "Answer", JsonValue::Type::Array, false));
|
||||||
parts.push_back(std::move(part));
|
return get_data(answer);
|
||||||
}
|
}
|
||||||
if (parts.size() != 2) {
|
|
||||||
return Status::Error("Expected data in two parts");
|
|
||||||
}
|
|
||||||
string data;
|
|
||||||
if (parts[0].size() < parts[1].size()) {
|
|
||||||
data = parts[1] + parts[0];
|
|
||||||
} else {
|
|
||||||
data = parts[0] + parts[1];
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
};
|
};
|
||||||
return get_simple_config_impl(std::move(promise), scheduler_id,
|
return get_simple_config_impl(std::move(promise), scheduler_id,
|
||||||
PSTRING() << "https://" << address << "?name=" << url_encode(name) << "&type=TXT",
|
PSTRING() << "https://" << address << "?name=" << url_encode(name) << "&type=TXT",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user