web3.js/lib/web3/httpprovider.js

147 lines
3.8 KiB
JavaScript
Raw Normal View History

2015-01-21 20:29:02 +01:00
/*
2015-10-08 15:34:07 +08:00
This file is part of web3.js.
2015-01-21 20:29:02 +01:00
2015-10-08 15:34:07 +08:00
web3.js is free software: you can redistribute it and/or modify
2015-01-21 20:29:02 +01:00
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
2015-10-08 15:34:07 +08:00
web3.js is distributed in the hope that it will be useful,
2015-01-21 20:29:02 +01:00
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
2015-10-08 15:34:07 +08:00
along with web3.js. If not, see <http://www.gnu.org/licenses/>.
2015-01-21 20:29:02 +01:00
*/
2015-02-28 15:55:41 +01:00
/** @file httpprovider.js
2015-01-21 20:29:02 +01:00
* @authors:
* Marek Kotewicz <marek@ethdev.com>
* Marian Oancea <marian@ethdev.com>
2015-03-12 16:33:19 +01:00
* Fabian Vogelsteller <fabian@ethdev.com>
2015-06-24 14:56:32 +02:00
* @date 2015
2015-01-21 20:29:02 +01:00
*/
"use strict";
2015-04-01 15:38:15 +02:00
var errors = require('./errors');
2015-08-06 17:49:02 +02:00
// workaround to use httpprovider in different envs
2015-08-06 17:58:57 +02:00
var XMLHttpRequest; // jshint ignore: line
2015-08-06 17:49:02 +02:00
// meteor server environment
2015-08-06 17:58:57 +02:00
if (typeof Meteor !== 'undefined' && Meteor.isServer) { // jshint ignore: line
XMLHttpRequest = Npm.require('xmlhttprequest').XMLHttpRequest; // jshint ignore: line
2015-08-06 17:49:02 +02:00
// browser
} else if (typeof window !== 'undefined' && window.XMLHttpRequest) {
2015-08-06 17:58:57 +02:00
XMLHttpRequest = window.XMLHttpRequest; // jshint ignore: line
2015-08-06 17:49:02 +02:00
// node
} else {
2015-08-06 17:58:57 +02:00
XMLHttpRequest = require('xmlhttprequest').XMLHttpRequest; // jshint ignore: line
2015-08-06 17:49:02 +02:00
}
/**
* HttpProvider should be used to send rpc calls over http
*/
2015-02-28 15:55:41 +01:00
var HttpProvider = function (host) {
this.host = host || 'http://localhost:8545';
2015-01-21 20:29:02 +01:00
};
2015-08-06 17:49:02 +02:00
/**
* Should be called to prepare new XMLHttpRequest
*
* @method prepareRequest
* @param {Boolean} true if request should be async
* @return {XMLHttpRequest} object
*/
HttpProvider.prototype.prepareRequest = function (async) {
2015-06-24 14:56:32 +02:00
var request = new XMLHttpRequest();
2015-08-06 17:49:02 +02:00
request.open('POST', this.host, async);
request.setRequestHeader('Content-Type','application/json');
2015-08-06 17:49:02 +02:00
return request;
2015-06-24 14:56:32 +02:00
};
2015-08-06 17:49:02 +02:00
/**
* Should be called to make sync request
*
* @method send
* @param {Object} payload
* @return {Object} result
*/
HttpProvider.prototype.send = function (payload) {
2015-08-06 17:49:02 +02:00
var request = this.prepareRequest(false);
2015-04-01 15:38:15 +02:00
try {
request.send(JSON.stringify(payload));
} catch(error) {
throw errors.InvalidConnection(this.host);
2015-04-01 15:38:15 +02:00
}
var result = request.responseText;
try {
result = JSON.parse(result);
} catch(e) {
throw errors.InvalidResponse(request.responseText);
}
return result;
};
2015-03-02 13:00:20 +01:00
2015-08-06 17:49:02 +02:00
/**
* Should be used to make async request
*
* @method sendAsync
* @param {Object} payload
* @param {Function} callback triggered on end with (err, result)
*/
HttpProvider.prototype.sendAsync = function (payload, callback) {
2015-08-06 17:49:02 +02:00
var request = this.prepareRequest(true);
request.onreadystatechange = function() {
if (request.readyState === 4) {
var result = request.responseText;
var error = null;
try {
result = JSON.parse(result);
} catch(e) {
error = errors.InvalidResponse(request.responseText);
}
callback(error, result);
}
};
2015-04-01 15:38:15 +02:00
try {
request.send(JSON.stringify(payload));
} catch(error) {
callback(errors.InvalidConnection(this.host));
2015-04-01 15:38:15 +02:00
}
2015-01-21 20:29:02 +01:00
};
2015-08-06 17:49:02 +02:00
/**
* Synchronously tries to make Http request
*
* @method isConnected
* @return {Boolean} returns true if request haven't failed. Otherwise false
*/
HttpProvider.prototype.isConnected = function() {
try {
this.send({
id: 9999999999,
jsonrpc: '2.0',
method: 'net_listening',
params: []
});
return true;
} catch(e) {
return false;
}
};
2015-02-28 15:55:41 +01:00
module.exports = HttpProvider;
2015-01-21 20:29:02 +01:00