aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarek Kotewicz <marek.kotewicz@gmail.com>2014-10-22 17:38:33 +0800
committerMarek Kotewicz <marek.kotewicz@gmail.com>2014-10-22 17:41:48 +0800
commit5cd93a061889b0f2b9047ed6798f91aeb132dcea (patch)
treecac772593418fb941c34c55c834ed2f545f46289
parenteef4cd1b64c38e3327dbe7f1b70a60b01ce9cbed (diff)
downloaddexon-5cd93a061889b0f2b9047ed6798f91aeb132dcea.tar.gz
dexon-5cd93a061889b0f2b9047ed6798f91aeb132dcea.tar.zst
dexon-5cd93a061889b0f2b9047ed6798f91aeb132dcea.zip
http provider
-rw-r--r--http.js52
-rw-r--r--main.js33
2 files changed, 70 insertions, 15 deletions
diff --git a/http.js b/http.js
new file mode 100644
index 000000000..88869c689
--- /dev/null
+++ b/http.js
@@ -0,0 +1,52 @@
+(function () {
+ var HttpProvider = function (host) {
+ this.handlers = [];
+ this.host = host;
+ };
+
+ //TODO unify the format of object passed to 'send method'
+ function formatJsonRpcObject(object) {
+ return {
+ jsonrpc: '2.0',
+ method: object.call,
+ params: object.args,
+ id: object._id
+ }
+ };
+
+ //TODO unify the format of output messages, maybe there should be objects instead
+ function formatJsonRpcMessage(message) {
+ var object = JSON.parse(message);
+
+ return JSON.stringify({
+ _id: object.id,
+ data: object.result
+ });
+ };
+
+ HttpProvider.prototype.send = function (payload) {
+ var data = formatJsonRpcObject(payload);
+
+ var request = new XMLHttpRequest();
+ request.open("POST", this.host, true);
+ request.send(JSON.stringify(data));
+ var self = this;
+ request.onreadystatechange = function () {
+ if (request.readyState === 4) {
+ self.handlers.forEach(function (handler) {
+ handler.call(self, formatJsonRpcMessage(request.responseText));
+ });
+ }
+ }
+ };
+
+ Object.defineProperty(HttpProvider.prototype, "onmessage", {
+ set: function (handler) {
+ this.handlers.push(handler);
+ }
+ });
+
+ if (typeof(web3) !== "undefined" && web3.providers !== undefined) {
+ web3.providers.HttpProvider = HttpProvider;
+ }
+})();
diff --git a/main.js b/main.js
index 79449c703..708e9b0e6 100644
--- a/main.js
+++ b/main.js
@@ -49,37 +49,40 @@
eth: {
prototype: Object(),
-
+ //TODO solve the issue with numberOrHash impl
block: function(numberOrHash) {
return new Promise(function(resolve, reject) {
- /*
- var func;
- if(typeof numberOrHash == "string") {
- func = "getBlockByHash";
- } else {
- func = "getBlockByNumber";
- }
- */
-
- web3.provider.send({call: /*func*/"block", args: [numberOrHash]}, function(block) {
+ var args = typeof numberOrHash === "string" ? [0, numberOrHash] : [numberOrHash, ""];
+ web3.provider.send({call: "block", args: args}, function(block) {
if(block)
resolve(block);
else
reject("not found");
-
});
});
},
transaction: function(numberOrHash, nth) {
return new Promise(function(resolve, reject) {
- reject("`transaction` not yet implemented")
+ var args = typeof numberOrHash === "string" ? [0, numberOrHash, nth] : [numberOrHash, "", nth];
+ web3.provider.send({call: "transaction", args: args}, function(block) {
+ if(block)
+ resolve(block);
+ else
+ reject("not found");
+ });
});
},
uncle: function(numberOrHash, nth) {
return new Promise(function(resolve, reject) {
- reject("`uncle` not yet implemented")
+ var args = typeof numberOrHash === "string" ? [0, numberOrHash, nth] : [numberOrHash, "", nth];
+ web3.provider.send({call: "uncle", args: args}, function(block) {
+ if(block)
+ resolve(block);
+ else
+ reject("not found");
+ });
});
},
@@ -128,7 +131,7 @@
return Promise.all(promises).then(function() {
return new Promise(function(resolve, reject) {
params.data = params.data.join("");
- web3.provider.send({call: "transact", args: ["0x"+params]}, function(data) {
+ web3.provider.send({call: "transact", args: [params]}, function(data) {
if(data[1])
reject(data[0]);
else