web3.js/lib/web3/contract.js

107 lines
3.4 KiB
JavaScript
Raw Normal View History

/*
This file is part of ethereum.js.
ethereum.js is free software: you can redistribute it and/or modify
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.
ethereum.js is distributed in the hope that it will be useful,
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
along with ethereum.js. If not, see <http://www.gnu.org/licenses/>.
*/
2015-04-20 19:59:35 +00:00
/**
* @file contract.js
* @author Marek Kotewicz <marek@ethdev.com>
* @date 2014
*/
2015-03-08 17:18:52 +00:00
var web3 = require('../web3');
var solAbi = require('../solidity/abi');
2015-03-08 17:18:52 +00:00
var utils = require('../utils/utils');
2015-04-20 20:06:49 +00:00
var SolidityEvent = require('./event');
2015-04-20 16:16:15 +00:00
var SolidityFunction = require('./function');
2015-04-20 19:59:35 +00:00
var addFunctionsToContract = function (contract, desc) {
2015-04-20 16:16:15 +00:00
desc.filter(function (json) {
return json.type === 'function';
}).map(function (json) {
return new SolidityFunction(json, contract.address);
2015-04-20 16:16:15 +00:00
}).forEach(function (f) {
f.attachToContract(contract);
});
2015-01-29 12:32:32 +00:00
};
2015-01-22 13:37:34 +00:00
var addEventsToContract = function (contract, desc) {
2015-04-20 19:59:35 +00:00
desc.filter(function (json) {
return json.type === 'event';
}).map(function (json) {
return new SolidityEvent(json, contract.address);
2015-04-20 19:59:35 +00:00
}).forEach(function (e) {
e.attachToContract(contract);
});
2015-01-29 12:32:32 +00:00
};
/**
* This method should be called when we want to call / transact some solidity method from javascript
* it returns an object which has same methods available as solidity contract description
* usage example:
*
* var abi = [{
* name: 'myMethod',
* inputs: [{ name: 'a', type: 'string' }],
* outputs: [{name: 'd', type: 'string' }]
* }]; // contract abi
*
2015-02-24 09:36:54 +00:00
* var MyContract = web3.eth.contract(abi); // creation of contract prototype
2015-01-29 12:32:32 +00:00
*
2015-02-24 09:36:54 +00:00
* var contractInstance = new MyContract('0x0123123121');
2015-01-29 12:32:32 +00:00
*
2015-02-24 09:36:54 +00:00
* contractInstance.myMethod('this is test string param for call'); // myMethod call (implicit, default)
* contractInstance.call().myMethod('this is test string param for call'); // myMethod call (explicit)
2015-02-24 12:00:24 +00:00
* contractInstance.sendTransaction().myMethod('this is test string param for transact'); // myMethod sendTransaction
2015-02-24 09:36:54 +00:00
*
* @param abi - abi json description of the contract, which is being created
2015-01-29 12:32:32 +00:00
* @returns contract object
*/
2015-02-24 09:36:54 +00:00
var contract = function (abi) {
// return prototype
2015-03-30 21:48:03 +00:00
return Contract.bind(null, abi);
2015-02-24 09:36:54 +00:00
};
2015-04-20 16:16:15 +00:00
var Contract = function (abi, options) {
2015-01-29 12:32:32 +00:00
2015-04-20 16:16:15 +00:00
this.address = '';
if (utils.isAddress(options)) {
2015-04-20 16:16:15 +00:00
this.address = options;
2015-04-20 12:38:08 +00:00
} else { // is an object!
// TODO, parse the rest of the args
2015-04-20 12:38:08 +00:00
options = options || {};
var args = Array.prototype.slice.call(arguments, 2);
var bytes = solAbi.formatConstructorParams(abi, args);
2015-04-20 12:38:08 +00:00
options.data += bytes;
2015-04-20 16:16:15 +00:00
this.address = web3.eth.sendTransaction(options);
}
2015-04-20 19:59:35 +00:00
addFunctionsToContract(this, abi);
addEventsToContract(this, abi);
2015-04-20 16:16:15 +00:00
};
Contract.prototype.call = function () {
console.error('contract.call is deprecated');
2015-04-20 19:59:35 +00:00
return this;
};
Contract.prototype.sendTransaction = function () {
console.error('contract.sendTransact is deprecated');
2015-04-20 19:59:35 +00:00
return this;
};
module.exports = contract;
2015-01-14 11:01:11 +00:00