[HTML5] Fix HTTPClient request_raw.
Now send data according to the spec, properly handle null data. Simplify JS code since we are at it.
This commit is contained in:
parent
ad293a82f1
commit
75c4e2c5fa
3 changed files with 18 additions and 29 deletions
|
@ -104,7 +104,11 @@ Error HTTPClient::request_raw(Method p_method, const String &p_url, const Vector
|
||||||
Error err = prepare_request(p_method, p_url, p_headers);
|
Error err = prepare_request(p_method, p_url, p_headers);
|
||||||
if (err != OK)
|
if (err != OK)
|
||||||
return err;
|
return err;
|
||||||
godot_xhr_send_data(xhr_id, p_body.ptr(), p_body.size());
|
if (p_body.is_empty()) {
|
||||||
|
godot_xhr_send(xhr_id, nullptr, 0);
|
||||||
|
} else {
|
||||||
|
godot_xhr_send(xhr_id, p_body.ptr(), p_body.size());
|
||||||
|
}
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -112,7 +116,12 @@ Error HTTPClient::request(Method p_method, const String &p_url, const Vector<Str
|
||||||
Error err = prepare_request(p_method, p_url, p_headers);
|
Error err = prepare_request(p_method, p_url, p_headers);
|
||||||
if (err != OK)
|
if (err != OK)
|
||||||
return err;
|
return err;
|
||||||
godot_xhr_send_string(xhr_id, p_body.utf8().get_data());
|
if (p_body.is_empty()) {
|
||||||
|
godot_xhr_send(xhr_id, nullptr, 0);
|
||||||
|
} else {
|
||||||
|
const CharString cs = p_body.utf8();
|
||||||
|
godot_xhr_send(xhr_id, cs.get_data(), cs.length());
|
||||||
|
}
|
||||||
return OK;
|
return OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -53,9 +53,7 @@ extern int godot_xhr_open(int p_xhr_id, const char *p_method, const char *p_url,
|
||||||
|
|
||||||
extern void godot_xhr_set_request_header(int p_xhr_id, const char *p_header, const char *p_value);
|
extern void godot_xhr_set_request_header(int p_xhr_id, const char *p_header, const char *p_value);
|
||||||
|
|
||||||
extern void godot_xhr_send_null(int p_xhr_id);
|
extern void godot_xhr_send(int p_xhr_id, const void *p_data, int p_len);
|
||||||
extern void godot_xhr_send_string(int p_xhr_id, const char *p_data);
|
|
||||||
extern void godot_xhr_send_data(int p_xhr_id, const void *p_data, int p_len);
|
|
||||||
extern void godot_xhr_abort(int p_xhr_id);
|
extern void godot_xhr_abort(int p_xhr_id);
|
||||||
|
|
||||||
/* this is an HTTPClient::ResponseCode, not ::Status */
|
/* this is an HTTPClient::ResponseCode, not ::Status */
|
||||||
|
|
|
@ -82,31 +82,13 @@ const GodotHTTPRequest = {
|
||||||
GodotHTTPRequest.requests[xhrId].setRequestHeader(GodotRuntime.parseString(header), GodotRuntime.parseString(value));
|
GodotHTTPRequest.requests[xhrId].setRequestHeader(GodotRuntime.parseString(header), GodotRuntime.parseString(value));
|
||||||
},
|
},
|
||||||
|
|
||||||
godot_xhr_send_null__sig: 'vi',
|
godot_xhr_send__sig: 'viii',
|
||||||
godot_xhr_send_null: function (xhrId) {
|
godot_xhr_send: function (xhrId, p_ptr, p_len) {
|
||||||
GodotHTTPRequest.requests[xhrId].send();
|
let data = null;
|
||||||
},
|
if (p_ptr && p_len) {
|
||||||
|
data = GodotRuntime.heapCopy(HEAP8, p_ptr, p_len);
|
||||||
godot_xhr_send_string__sig: 'vii',
|
|
||||||
godot_xhr_send_string: function (xhrId, strPtr) {
|
|
||||||
if (!strPtr) {
|
|
||||||
GodotRuntime.error('Failed to send string per XHR: null pointer');
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
GodotHTTPRequest.requests[xhrId].send(GodotRuntime.parseString(strPtr));
|
GodotHTTPRequest.requests[xhrId].send(data);
|
||||||
},
|
|
||||||
|
|
||||||
godot_xhr_send_data__sig: 'viii',
|
|
||||||
godot_xhr_send_data: function (xhrId, ptr, len) {
|
|
||||||
if (!ptr) {
|
|
||||||
GodotRuntime.error('Failed to send data per XHR: null pointer');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (len < 0) {
|
|
||||||
GodotRuntime.error('Failed to send data per XHR: buffer length less than 0');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
GodotHTTPRequest.requests[xhrId].send(HEAPU8.subarray(ptr, ptr + len));
|
|
||||||
},
|
},
|
||||||
|
|
||||||
godot_xhr_abort__sig: 'vi',
|
godot_xhr_abort__sig: 'vi',
|
||||||
|
|
Loading…
Reference in a new issue