mirror of
https://github.com/Qortal/qortal.git
synced 2025-05-10 11:47:51 +00:00
Fixed issue which caused UI to lock up when using qortalRequest()
This commit is contained in:
parent
d831972005
commit
4835e5732d
@ -1,10 +1,32 @@
|
|||||||
function httpGet(url) {
|
function httpGet(event, url) {
|
||||||
var request = new XMLHttpRequest();
|
var request = new XMLHttpRequest();
|
||||||
request.open("GET", url, false);
|
request.open("GET", url, false);
|
||||||
request.send(null);
|
request.send(null);
|
||||||
return request.responseText;
|
return request.responseText;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function httpGetAsyncWithEvent(event, url) {
|
||||||
|
fetch(url)
|
||||||
|
.then((response) => response.text())
|
||||||
|
.then((responseText) => {
|
||||||
|
|
||||||
|
if (responseText == null) {
|
||||||
|
// Pass to parent (UI), in case they can fulfil this request
|
||||||
|
event.data.requestedHandler = "UI";
|
||||||
|
parent.postMessage(event.data, '*', [event.ports[0]]);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
handleResponse(event, responseText);
|
||||||
|
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
let res = new Object();
|
||||||
|
res.error = error;
|
||||||
|
handleResponse(JSON.stringify(res), responseText);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
function handleResponse(event, response) {
|
function handleResponse(event, response) {
|
||||||
if (event == null) {
|
if (event == null) {
|
||||||
return;
|
return;
|
||||||
@ -143,15 +165,15 @@ window.addEventListener("message", (event) => {
|
|||||||
|
|
||||||
switch (data.action) {
|
switch (data.action) {
|
||||||
case "GET_ACCOUNT_DATA":
|
case "GET_ACCOUNT_DATA":
|
||||||
response = httpGet("/addresses/" + data.address);
|
response = httpGetAsyncWithEvent(event, "/addresses/" + data.address);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_ACCOUNT_NAMES":
|
case "GET_ACCOUNT_NAMES":
|
||||||
response = httpGet("/names/address/" + data.address);
|
response = httpGetAsyncWithEvent(event, "/names/address/" + data.address);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_NAME_DATA":
|
case "GET_NAME_DATA":
|
||||||
response = httpGet("/names/" + data.name);
|
response = httpGetAsyncWithEvent(event, "/names/" + data.name);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_QDN_RESOURCE_URL":
|
case "GET_QDN_RESOURCE_URL":
|
||||||
@ -174,7 +196,7 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "SEARCH_QDN_RESOURCES":
|
case "SEARCH_QDN_RESOURCES":
|
||||||
@ -190,7 +212,7 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "FETCH_QDN_RESOURCE":
|
case "FETCH_QDN_RESOURCE":
|
||||||
@ -200,19 +222,19 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.filepath != null) url = url.concat("&filepath=" + data.filepath);
|
if (data.filepath != null) url = url.concat("&filepath=" + data.filepath);
|
||||||
if (data.rebuild != null) url = url.concat("&rebuild=" + new Boolean(data.rebuild).toString())
|
if (data.rebuild != null) url = url.concat("&rebuild=" + new Boolean(data.rebuild).toString())
|
||||||
if (data.encoding != null) url = url.concat("&encoding=" + data.encoding);
|
if (data.encoding != null) url = url.concat("&encoding=" + data.encoding);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_QDN_RESOURCE_STATUS":
|
case "GET_QDN_RESOURCE_STATUS":
|
||||||
url = "/arbitrary/resource/status/" + data.service + "/" + data.name;
|
url = "/arbitrary/resource/status/" + data.service + "/" + data.name;
|
||||||
if (data.identifier != null) url = url.concat("/" + data.identifier);
|
if (data.identifier != null) url = url.concat("/" + data.identifier);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_QDN_RESOURCE_PROPERTIES":
|
case "GET_QDN_RESOURCE_PROPERTIES":
|
||||||
let identifier = (data.identifier != null) ? data.identifier : "default";
|
let identifier = (data.identifier != null) ? data.identifier : "default";
|
||||||
url = "/arbitrary/resource/properties/" + data.service + "/" + data.name + "/" + identifier;
|
url = "/arbitrary/resource/properties/" + data.service + "/" + data.name + "/" + identifier;
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "SEARCH_CHAT_MESSAGES":
|
case "SEARCH_CHAT_MESSAGES":
|
||||||
@ -227,7 +249,7 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "LIST_GROUPS":
|
case "LIST_GROUPS":
|
||||||
@ -235,23 +257,23 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_BALANCE":
|
case "GET_BALANCE":
|
||||||
url = "/addresses/balance/" + data.address;
|
url = "/addresses/balance/" + data.address;
|
||||||
if (data.assetId != null) url = url.concat("&assetId=" + data.assetId);
|
if (data.assetId != null) url = url.concat("&assetId=" + data.assetId);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_AT":
|
case "GET_AT":
|
||||||
url = "/at" + data.atAddress;
|
url = "/at" + data.atAddress;
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_AT_DATA":
|
case "GET_AT_DATA":
|
||||||
url = "/at/" + data.atAddress + "/data";
|
url = "/at/" + data.atAddress + "/data";
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "LIST_ATS":
|
case "LIST_ATS":
|
||||||
@ -260,19 +282,18 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "FETCH_BLOCK":
|
case "FETCH_BLOCK":
|
||||||
if (data.signature != null) {
|
if (data.signature != null) {
|
||||||
url = "/blocks/" + data.signature;
|
url = "/blocks/" + data.signature;
|
||||||
}
|
} else if (data.height != null) {
|
||||||
else if (data.height != null) {
|
|
||||||
url = "/blocks/byheight/" + data.height;
|
url = "/blocks/byheight/" + data.height;
|
||||||
}
|
}
|
||||||
url = url.concat("?");
|
url = url.concat("?");
|
||||||
if (data.includeOnlineSignatures != null) url = url.concat("&includeOnlineSignatures=" + data.includeOnlineSignatures);
|
if (data.includeOnlineSignatures != null) url = url.concat("&includeOnlineSignatures=" + data.includeOnlineSignatures);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "FETCH_BLOCK_RANGE":
|
case "FETCH_BLOCK_RANGE":
|
||||||
@ -280,7 +301,7 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.count != null) url = url.concat("&count=" + data.count);
|
if (data.count != null) url = url.concat("&count=" + data.count);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + data.reverse);
|
if (data.reverse != null) url = url.concat("&reverse=" + data.reverse);
|
||||||
if (data.includeOnlineSignatures != null) url = url.concat("&includeOnlineSignatures=" + data.includeOnlineSignatures);
|
if (data.includeOnlineSignatures != null) url = url.concat("&includeOnlineSignatures=" + data.includeOnlineSignatures);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "SEARCH_TRANSACTIONS":
|
case "SEARCH_TRANSACTIONS":
|
||||||
@ -294,14 +315,14 @@ window.addEventListener("message", (event) => {
|
|||||||
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
if (data.limit != null) url = url.concat("&limit=" + data.limit);
|
||||||
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
if (data.offset != null) url = url.concat("&offset=" + data.offset);
|
||||||
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
if (data.reverse != null) url = url.concat("&reverse=" + new Boolean(data.reverse).toString());
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "GET_PRICE":
|
case "GET_PRICE":
|
||||||
url = "/crosschain/price/" + data.blockchain + "?";
|
url = "/crosschain/price/" + data.blockchain + "?";
|
||||||
if (data.maxtrades != null) url = url.concat("&maxtrades=" + data.maxtrades);
|
if (data.maxtrades != null) url = url.concat("&maxtrades=" + data.maxtrades);
|
||||||
if (data.inverse != null) url = url.concat("&inverse=" + data.inverse);
|
if (data.inverse != null) url = url.concat("&inverse=" + data.inverse);
|
||||||
response = httpGet(url);
|
response = httpGetAsyncWithEvent(event, url);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -311,15 +332,6 @@ window.addEventListener("message", (event) => {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (response == null) {
|
|
||||||
// Pass to parent (UI), in case they can fulfil this request
|
|
||||||
event.data.requestedHandler = "UI";
|
|
||||||
parent.postMessage(event.data, '*', [event.ports[0]]);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
handleResponse(event, response);
|
|
||||||
|
|
||||||
}, false);
|
}, false);
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user