Change update checker version source
This commit is contained in:
parent
a0b0b19043
commit
6e9dc0ee27
2 changed files with 29 additions and 25 deletions
|
@ -881,7 +881,7 @@
|
||||||
All update modes will ignore builds with different major versions (e.g. Godot 4 -> Godot 5).
|
All update modes will ignore builds with different major versions (e.g. Godot 4 -> Godot 5).
|
||||||
</member>
|
</member>
|
||||||
<member name="network/connection/network_mode" type="int" setter="" getter="">
|
<member name="network/connection/network_mode" type="int" setter="" getter="">
|
||||||
Determines whether online features are enabled in the editor, such as the Asset Library or update checks. Disabling these online features helps alleviate privacy concerns by preventing the editor from making HTTP requests to the Godot website, GitHub, or third-party platforms hosting assets from the Asset Library.
|
Determines whether online features are enabled in the editor, such as the Asset Library or update checks. Disabling these online features helps alleviate privacy concerns by preventing the editor from making HTTP requests to the Godot website or third-party platforms hosting assets from the Asset Library.
|
||||||
</member>
|
</member>
|
||||||
<member name="network/debug/remote_host" type="String" setter="" getter="">
|
<member name="network/debug/remote_host" type="String" setter="" getter="">
|
||||||
The address to listen to when starting the remote debugger. This can be set to [code]0.0.0.0[/code] to allow external clients to connect to the remote debugger (instead of restricting the remote debugger to connections from [code]localhost[/code]).
|
The address to listen to when starting the remote debugger. This can be set to [code]0.0.0.0[/code] to allow external clients to connect to the remote debugger (instead of restricting the remote debugger to connections from [code]localhost[/code]).
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
|
|
||||||
#include "engine_update_label.h"
|
#include "engine_update_label.h"
|
||||||
|
|
||||||
|
#include "core/io/json.h"
|
||||||
#include "core/os/time.h"
|
#include "core/os/time.h"
|
||||||
#include "editor/editor_settings.h"
|
#include "editor/editor_settings.h"
|
||||||
#include "editor/editor_string_names.h"
|
#include "editor/editor_string_names.h"
|
||||||
|
@ -46,7 +47,7 @@ bool EngineUpdateLabel::_can_check_updates() const {
|
||||||
void EngineUpdateLabel::_check_update() {
|
void EngineUpdateLabel::_check_update() {
|
||||||
checked_update = true;
|
checked_update = true;
|
||||||
_set_status(UpdateStatus::BUSY);
|
_set_status(UpdateStatus::BUSY);
|
||||||
http->request("https://raw.githubusercontent.com/godotengine/godot-website/master/_data/versions.yml");
|
http->request("https://godotengine.org/versions.json");
|
||||||
}
|
}
|
||||||
|
|
||||||
void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_code, const PackedStringArray &p_headers, const PackedByteArray &p_body) {
|
void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_code, const PackedStringArray &p_headers, const PackedByteArray &p_body) {
|
||||||
|
@ -62,12 +63,24 @@ void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_cod
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PackedStringArray lines;
|
Array version_data;
|
||||||
{
|
{
|
||||||
String s;
|
String s;
|
||||||
const uint8_t *r = p_body.ptr();
|
const uint8_t *r = p_body.ptr();
|
||||||
s.parse_utf8((const char *)r, p_body.size());
|
s.parse_utf8((const char *)r, p_body.size());
|
||||||
lines = s.split("\n");
|
|
||||||
|
Variant result = JSON::parse_string(s);
|
||||||
|
if (result == Variant()) {
|
||||||
|
_set_status(UpdateStatus::ERROR);
|
||||||
|
_set_message(TTR("Failed to parse version JSON."), theme_cache.error_color);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (result.get_type() != Variant::ARRAY) {
|
||||||
|
_set_status(UpdateStatus::ERROR);
|
||||||
|
_set_message(TTR("Received JSON data is not a valid version array."), theme_cache.error_color);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
version_data = result;
|
||||||
}
|
}
|
||||||
|
|
||||||
UpdateMode update_mode = UpdateMode(int(EDITOR_GET("network/connection/engine_version_update_mode")));
|
UpdateMode update_mode = UpdateMode(int(EDITOR_GET("network/connection/engine_version_update_mode")));
|
||||||
|
@ -78,14 +91,11 @@ void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_cod
|
||||||
int current_minor = version_info["minor"];
|
int current_minor = version_info["minor"];
|
||||||
int current_patch = version_info["patch"];
|
int current_patch = version_info["patch"];
|
||||||
|
|
||||||
int current_version_line = -1;
|
Dictionary found_version_info;
|
||||||
for (int i = 0; i < lines.size(); i++) {
|
for (const Variant &data_bit : version_data) {
|
||||||
const String &line = lines[i];
|
const Dictionary info = data_bit;
|
||||||
if (!line.begins_with("- name")) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
const String version_string = _extract_sub_string(line);
|
const String version_string = info["name"];
|
||||||
const PackedStringArray version_bits = version_string.split(".");
|
const PackedStringArray version_bits = version_string.split(".");
|
||||||
|
|
||||||
if (version_bits.size() < 2) {
|
if (version_bits.size() < 2) {
|
||||||
|
@ -111,7 +121,7 @@ void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_cod
|
||||||
}
|
}
|
||||||
|
|
||||||
if (minor > current_minor || patch > current_patch) {
|
if (minor > current_minor || patch > current_patch) {
|
||||||
String version_type = _extract_sub_string(lines[i + 1]);
|
String version_type = info["flavor"];
|
||||||
if (stable_only && _get_version_type(version_type, nullptr) != VersionType::STABLE) {
|
if (stable_only && _get_version_type(version_type, nullptr) != VersionType::STABLE) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
@ -120,17 +130,17 @@ void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_cod
|
||||||
found_version += "-" + version_type;
|
found_version += "-" + version_type;
|
||||||
break;
|
break;
|
||||||
} else if (minor == current_minor && patch == current_patch) {
|
} else if (minor == current_minor && patch == current_patch) {
|
||||||
current_version_line = i;
|
found_version_info = info;
|
||||||
found_version = version_string;
|
found_version = version_string;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (current_version_line == -1 && !found_version.is_empty()) {
|
if (found_version_info.is_empty() && !found_version.is_empty()) {
|
||||||
_set_status(UpdateStatus::UPDATE_AVAILABLE);
|
_set_status(UpdateStatus::UPDATE_AVAILABLE);
|
||||||
_set_message(vformat(TTR("Update available: %s."), found_version), theme_cache.update_color);
|
_set_message(vformat(TTR("Update available: %s."), found_version), theme_cache.update_color);
|
||||||
return;
|
return;
|
||||||
} else if (current_version_line == -1 || stable_only) {
|
} else if (found_version_info.is_empty() || stable_only) {
|
||||||
_set_status(UpdateStatus::UP_TO_DATE);
|
_set_status(UpdateStatus::UP_TO_DATE);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -138,17 +148,11 @@ void EngineUpdateLabel::_http_request_completed(int p_result, int p_response_cod
|
||||||
int current_version_index;
|
int current_version_index;
|
||||||
VersionType current_version_type = _get_version_type(version_info["status"], ¤t_version_index);
|
VersionType current_version_type = _get_version_type(version_info["status"], ¤t_version_index);
|
||||||
|
|
||||||
for (int i = current_version_line + 1; i < lines.size(); i++) {
|
const Array releases = found_version_info["releases"];
|
||||||
const String &line = lines[i];
|
for (const Variant &data_bit : version_data) {
|
||||||
if (line.begins_with("- name")) {
|
const Dictionary info = data_bit;
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!line.begins_with(" - name") && !line.begins_with(" flavor")) {
|
const String version_string = info["name"];
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
const String version_string = _extract_sub_string(line);
|
|
||||||
int version_index;
|
int version_index;
|
||||||
VersionType version_type = _get_version_type(version_string, &version_index);
|
VersionType version_type = _get_version_type(version_string, &version_index);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue